X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fmachine%2Fmachine.c;h=9a5cc9a63c4eb1f017d0c8a2196c14ec6ce9c833;hb=2292547af9638e2b3f7e0e96a56dd6c909e516dc;hp=4596a80838f6bd8f751110715f45c9e66696910c;hpb=39883f622f392d8579f4428fc5a789a102efbb10;p=elogind.git diff --git a/src/machine/machine.c b/src/machine/machine.c index 4596a8083..9a5cc9a63 100644 --- a/src/machine/machine.c +++ b/src/machine/machine.c @@ -410,7 +410,15 @@ int machine_kill(Machine *m, KillWho who, int signo) { if (!m->unit) return -ESRCH; - return manager_kill_unit(m->manager, m->unit, who, signo, NULL); + if (who == KILL_LEADER) { + /* If we shall simply kill the leader, do so directly */ + + if (kill(m->leader, signo) < 0) + return -errno; + } + + /* Otherwise make PID 1 do it for us, for the entire cgroup */ + return manager_kill_unit(m->manager, m->unit, signo, NULL); } static const char* const machine_class_table[_MACHINE_CLASS_MAX] = {