X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fcgroups-agent%2Fcgroups-agent.c;h=47a526b87f6be7cd0c8ed011524629d4c6f40cbc;hp=1b215b99ab327066300f588037bc65ae6a90bbae;hb=9eb822a5a6b67eb82909f0d68213afbfcee6e93e;hpb=0a1beeb64207eaa88ab9236787b1cbc2f704ae14 diff --git a/src/cgroups-agent/cgroups-agent.c b/src/cgroups-agent/cgroups-agent.c index 1b215b99a..47a526b87 100644 --- a/src/cgroups-agent/cgroups-agent.c +++ b/src/cgroups-agent/cgroups-agent.c @@ -26,7 +26,7 @@ #include "bus-util.h" int main(int argc, char *argv[]) { - _cleanup_bus_close_unref_ sd_bus *bus = NULL; + _cleanup_bus_flush_close_unref_ sd_bus *bus = NULL; int r; if (argc != 2) { @@ -38,17 +38,32 @@ int main(int argc, char *argv[]) { log_parse_environment(); log_open(); +#if 0 /* 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_open_system_systemd(&bus); +#else + /* Unlike in systemd where this has to use a private socket, + since elogind doesn't associate control groups with services + and doesn't manage the dbus service, we can just use the + system bus. */ + r = sd_bus_open_system(&bus); +#endif // 0 + if (r < 0) { +#if 0 /* 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"); + log_debug_errno(r, "Failed to get D-Bus connection: %m"); +#else + /* If dbus isn't running or responding, there is nothing + * we can do about it. */ + log_debug_errno(r, "Failed to open system bus: %m"); +#endif return EXIT_FAILURE; } @@ -58,7 +73,11 @@ int main(int argc, char *argv[]) { "Released", "s", argv[1]); if (r < 0) { - log_debug_errno(-r, "Failed to send signal message on private connection: %m"); +#if 0 + log_debug_errno(r, "Failed to send signal message on private connection: %m"); +#else + log_debug_errno(r, "Failed to send signal message: %m"); +#endif return EXIT_FAILURE; }