X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fbusname.c;h=1d77292f9b9d98ec40ee36ed353a9e47bc4439c9;hb=5ad096b3f1331b175340129a8c9a5a9d711e5415;hp=acd665282da4e3676bfaeeb9675b631e784b9124;hpb=e24e415e5f3af2fe86d2be9a1f1a2e8d5f8c96bf;p=elogind.git diff --git a/src/core/busname.c b/src/core/busname.c index acd665282..1d77292f9 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, @@ -204,7 +205,7 @@ static int busname_verify(BusName *n) { return -EINVAL; } - e = strappenda(n->name, ".busname"); + e = strjoina(n->name, ".busname"); if (!unit_has_name(UNIT(n), e)) { log_unit_error(UNIT(n)->id, "%s's Name= setting doesn't match unit name. Refusing.", UNIT(n)->id); return -EINVAL; @@ -614,7 +615,7 @@ static int busname_start(Unit *u) { n->result = BUSNAME_SUCCESS; busname_enter_making(n); - return 0; + return 1; } static int busname_stop(Unit *u) { @@ -637,7 +638,7 @@ static int busname_stop(Unit *u) { assert(IN_SET(n->state, BUSNAME_REGISTERED, BUSNAME_LISTENING, BUSNAME_RUNNING)); busname_enter_dead(n, BUSNAME_SUCCESS); - return 0; + return 1; } static int busname_serialize(Unit *u, FILE *f, FDSet *fds) { @@ -769,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) { @@ -803,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"); @@ -974,7 +975,7 @@ static int busname_get_timeout(Unit *u, uint64_t *timeout) { } static bool busname_supported(Manager *m) { - int supported = -1; + static int supported = -1; assert(m); if (supported < 0)