X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fbusname.c;h=00e56686e5d88dbbe42b9e37c5bac04c4e7fd8b1;hb=09667885bad3a8cb7f1a002766f9e59140775526;hp=d4aa463397ea58de428fc4623d1646e2df8e9bc2;hpb=94e15fdc4d9d96fa6607bfb4eaaea164a3aec417;p=elogind.git diff --git a/src/core/busname.c b/src/core/busname.c index d4aa46339..00e56686e 100644 --- a/src/core/busname.c +++ b/src/core/busname.c @@ -26,9 +26,10 @@ #include "bus-internal.h" #include "bus-util.h" #include "service.h" +#include "kdbus.h" +#include "bus-policy.h" #include "dbus-busname.h" #include "busname.h" -#include "kdbus.h" static const UnitActiveState state_translation_table[_BUSNAME_STATE_MAX] = { [BUSNAME_DEAD] = UNIT_INACTIVE, @@ -730,7 +731,9 @@ static int busname_peek_message(BusName *n) { .size = sizeof(cmd_recv), .flags = KDBUS_RECV_PEEK, }; - struct kdbus_cmd_free cmd_free = {}; + struct kdbus_cmd_free cmd_free = { + .size = sizeof(cmd_free), + }; const char *comm = NULL; struct kdbus_item *d; struct kdbus_msg *k; @@ -767,9 +770,9 @@ static int busname_peek_message(BusName *n) { * longer than necessary. */ ps = page_size(); - start = (cmd_recv.reply.offset / ps) * ps; - delta = cmd_recv.reply.offset - start; - sz = PAGE_ALIGN(delta + cmd_recv.reply.msg_size); + start = (cmd_recv.msg.offset / ps) * ps; + delta = cmd_recv.msg.offset - start; + sz = PAGE_ALIGN(delta + cmd_recv.msg.msg_size); p = mmap(NULL, sz, PROT_READ, MAP_SHARED, n->starter_fd, start); if (p == MAP_FAILED) { @@ -801,7 +804,7 @@ finish: if (p) (void) munmap(p, sz); - cmd_free.offset = cmd_recv.reply.offset; + cmd_free.offset = cmd_recv.msg.offset; if (ioctl(n->starter_fd, KDBUS_CMD_FREE, &cmd_free) < 0) log_unit_warning(UNIT(n)->id, "Failed to free peeked message, ignoring: %m"); @@ -971,6 +974,16 @@ static int busname_get_timeout(Unit *u, uint64_t *timeout) { return 1; } +static bool busname_supported(Manager *m) { + int supported = -1; + assert(m); + + if (supported < 0) + supported = access("/sys/fs/kdbus", F_OK) >= 0; + + return supported; +} + static const char* const busname_state_table[_BUSNAME_STATE_MAX] = { [BUSNAME_DEAD] = "dead", [BUSNAME_MAKING] = "making", @@ -1032,6 +1045,8 @@ const UnitVTable busname_vtable = { .reset_failed = busname_reset_failed, + .supported = busname_supported, + .bus_interface = "org.freedesktop.systemd1.BusName", .bus_vtable = bus_busname_vtable,