From: Lennart Poettering Date: Mon, 20 Apr 2015 22:53:43 +0000 (+0200) Subject: sd-bus: augmenting cgroups-based creds when we have the cgroup path already is free X-Git-Tag: v220~392 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=822d9b6e4c2f0dc1ebc606006dc52257f06850c5;p=thirdparty%2Fsystemd.git sd-bus: augmenting cgroups-based creds when we have the cgroup path already is free --- diff --git a/src/libsystemd/sd-bus/bus-creds.c b/src/libsystemd/sd-bus/bus-creds.c index ea805f7fcd1..1183bbe6a1c 100644 --- a/src/libsystemd/sd-bus/bus-creds.c +++ b/src/libsystemd/sd-bus/bus-creds.c @@ -937,17 +937,22 @@ int bus_creds_add_more(sd_bus_creds *c, uint64_t mask, pid_t pid, pid_t tid) { if (missing & (SD_BUS_CREDS_CGROUP|SD_BUS_CREDS_UNIT|SD_BUS_CREDS_USER_UNIT|SD_BUS_CREDS_SLICE|SD_BUS_CREDS_SESSION|SD_BUS_CREDS_OWNER_UID)) { - r = cg_pid_get_path(NULL, pid, &c->cgroup); - if (r < 0) { - if (r != -EPERM && r != -EACCES) - return r; - } else { + if (!c->cgroup) { + r = cg_pid_get_path(NULL, pid, &c->cgroup); + if (r < 0) { + if (r != -EPERM && r != -EACCES) + return r; + } + } + + if (!c->cgroup_root) { r = cg_get_root_path(&c->cgroup_root); if (r < 0) return r; + } + if (c->cgroup) c->mask |= missing & (SD_BUS_CREDS_CGROUP|SD_BUS_CREDS_UNIT|SD_BUS_CREDS_USER_UNIT|SD_BUS_CREDS_SLICE|SD_BUS_CREDS_SESSION|SD_BUS_CREDS_OWNER_UID); - } } if (missing & SD_BUS_CREDS_AUDIT_SESSION_ID) {