diff options
| author | Lennart Poettering <lennart@poettering.net> | 2014-11-27 12:51:22 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2014-11-27 22:02:13 +0100 | 
| commit | 38ce47e262fbb76b6f6514e8e80cacfc584bee5a (patch) | |
| tree | 7a55696b5277a3ecf25cddb35429dfda8d4c4974 | |
| parent | 771b2724c0f9591e8f4dd7463c15bf0c957737dc (diff) | |
sd-bus: when we get the list of well-known names back from kdbus we shouldn't confuse the empty list with unknown information
| -rw-r--r-- | src/libsystemd/sd-bus/bus-control.c | 7 | ||||
| -rw-r--r-- | src/libsystemd/sd-bus/bus-kernel.c | 8 | 
2 files changed, 15 insertions, 0 deletions
| diff --git a/src/libsystemd/sd-bus/bus-control.c b/src/libsystemd/sd-bus/bus-control.c index 758715d74e..e6e905c0e0 100644 --- a/src/libsystemd/sd-bus/bus-control.c +++ b/src/libsystemd/sd-bus/bus-control.c @@ -692,6 +692,13 @@ static int bus_get_name_creds_kdbus(                  c->mask |= SD_BUS_CREDS_UNIQUE_NAME;          } +        /* If KDBUS_ITEM_OWNED_NAME is requested then we'll get 0 of +           them in case the service has no names. This does not mean +           however that the list of owned names could not be +           acquired. Hence, let's explicitly clarify that the data is +           complete. */ +        c->mask |= mask & SD_BUS_CREDS_WELL_KNOWN_NAMES; +          r = bus_populate_creds_from_items(bus, conn_info, mask, c);          if (r < 0)                  goto fail; diff --git a/src/libsystemd/sd-bus/bus-kernel.c b/src/libsystemd/sd-bus/bus-kernel.c index 3a3ed200a0..3bf7b074ef 100644 --- a/src/libsystemd/sd-bus/bus-kernel.c +++ b/src/libsystemd/sd-bus/bus-kernel.c @@ -717,6 +717,14 @@ static int bus_kernel_make_message(sd_bus *bus, struct kdbus_msg *k) {                  }          } +        /* If we requested the list of well-known names to be appended +         * and the sender had none no item for it will be +         * attached. However, this does *not* mean that we the kernel +         * didn't want to provide this information to us. Hence, let's +         * explicitly mark this information as available if it was +         * requested. */ +        m->creds.mask |= bus->creds_mask & SD_BUS_CREDS_WELL_KNOWN_NAMES; +          r = bus_message_parse_fields(m);          if (r < 0)                  goto fail; | 
