From: Lennart Poettering Date: Tue, 2 Jul 2013 14:24:13 +0000 (+0200) Subject: core: don't consider a unit's cgroup empty if only a subcgroup runs empty X-Git-Tag: v205~26 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=06025d9148036ee4de9866f3f067ffa75e14a751;ds=sidebyside core: don't consider a unit's cgroup empty if only a subcgroup runs empty --- diff --git a/src/core/cgroup.c b/src/core/cgroup.c index cdccf3ff1..c7f1e77c6 100644 --- a/src/core/cgroup.c +++ b/src/core/cgroup.c @@ -728,16 +728,15 @@ int manager_notify_cgroup_empty(Manager *m, const char *cgroup) { assert(m); assert(cgroup); - r = cg_is_empty_recursive(SYSTEMD_CGROUP_CONTROLLER, cgroup, true); - if (r == 0) - return 0; - u = manager_get_unit_by_cgroup(m, cgroup); if (u) { - if (UNIT_VTABLE(u)->notify_cgroup_empty) - UNIT_VTABLE(u)->notify_cgroup_empty(u); + r = cg_is_empty_recursive(SYSTEMD_CGROUP_CONTROLLER, u->cgroup_path, true); + if (r > 0) { + if (UNIT_VTABLE(u)->notify_cgroup_empty) + UNIT_VTABLE(u)->notify_cgroup_empty(u); - unit_add_to_gc_queue(u); + unit_add_to_gc_queue(u); + } } return 0;