Systemd/src/cgroups-agent/cgroups-agent.c

68 lines
2.3 KiB
C
Raw Normal View History

/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2010-03-31 16:29:55 +02:00
/***
This file is part of systemd.
Copyright 2010 Lennart Poettering
systemd is free software; you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
2010-03-31 16:29:55 +02:00
(at your option) any later version.
systemd is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
2010-03-31 16:29:55 +02:00
You should have received a copy of the GNU Lesser General Public License
2010-03-31 16:29:55 +02:00
along with systemd; If not, see <http://www.gnu.org/licenses/>.
***/
#include <stdlib.h>
2013-08-12 00:57:16 +02:00
#include "sd-bus.h"
2013-08-12 00:57:16 +02:00
#include "bus-util.h"
#include "log.h"
2010-03-31 16:29:55 +02:00
int main(int argc, char *argv[]) {
_cleanup_(sd_bus_flush_close_unrefp) sd_bus *bus = NULL;
2013-08-12 00:57:16 +02:00
int r;
2010-03-31 16:29:55 +02:00
if (argc != 2) {
log_error("Incorrect number of arguments.");
2013-08-12 00:57:16 +02:00
return EXIT_FAILURE;
2010-03-31 16:29:55 +02:00
}
log_set_target(LOG_TARGET_AUTO);
log_parse_environment();
log_open();
/* We send this event to the private D-Bus socket and then the
* system instance will forward this to the system bus. We do
* this to avoid an activation loop when we start dbus when we
* are called when the dbus service is shut down. */
r = bus_connect_system_systemd(&bus);
2013-08-12 00:57:16 +02:00
if (r < 0) {
2013-11-25 15:20:59 +01:00
/* If we couldn't connect we assume this was triggered
* while systemd got restarted/transitioned from
* initrd to the system, so let's ignore this */
log_debug_errno(r, "Failed to get D-Bus connection: %m");
2013-08-12 00:57:16 +02:00
return EXIT_FAILURE;
2010-03-31 16:29:55 +02:00
}
2013-08-12 00:57:16 +02:00
r = sd_bus_emit_signal(bus,
"/org/freedesktop/systemd1/agent",
"org.freedesktop.systemd1.Agent",
"Released",
"s", argv[1]);
if (r < 0) {
log_debug_errno(r, "Failed to send signal message on private connection: %m");
2013-08-12 00:57:16 +02:00
return EXIT_FAILURE;
}
2010-03-31 16:29:55 +02:00
2013-08-12 00:57:16 +02:00
return EXIT_SUCCESS;
2010-03-31 16:29:55 +02:00
}