On Fri, Apr 30, 2021 at 08:50:36AM +0200, Christian Brauner wrote: > On Thu, Apr 29, 2021 at 08:22:03PM -0700, Roman Gushchin wrote: > > On Thu, Apr 29, 2021 at 02:01:10PM +0200, Christian Brauner wrote: > > > From: Christian Brauner <christian.brauner@xxxxxxxxxx> > > > > > > Give a brief overview of the cgroup.kill functionality. > > > > > > Cc: Roman Gushchin <guro@xxxxxx> > > > Cc: Tejun Heo <tj@xxxxxxxxxx> > > > Cc: cgroups@xxxxxxxxxxxxxxx > > > Signed-off-by: Christian Brauner <christian.brauner@xxxxxxxxxx> > > > --- > > > Documentation/admin-guide/cgroup-v2.rst | 17 +++++++++++++++++ > > > 1 file changed, 17 insertions(+) > > > > > > diff --git a/Documentation/admin-guide/cgroup-v2.rst b/Documentation/admin-guide/cgroup-v2.rst > > > index 64c62b979f2f..c9f656a84590 100644 > > > --- a/Documentation/admin-guide/cgroup-v2.rst > > > +++ b/Documentation/admin-guide/cgroup-v2.rst > > > @@ -949,6 +949,23 @@ All cgroup core files are prefixed with "cgroup." > > > it's possible to delete a frozen (and empty) cgroup, as well as > > > create new sub-cgroups. > > > > > > + cgroup.kill > > > + A write-only single value file which exists in non-root cgroups. > > > + The only allowed value is "1". > > > + > > > + Writing "1" to the file causes the cgroup and all descendant cgroups to > > > + be killed. This means that all processes located in the affected cgroup > > > + tree will be killed via SIGKILL. > > > + > > > + Killing a cgroup tree will deal with concurrent forks appropriately and > > > + is protected against migrations. If callers require strict guarantees > > > + they can issue the cgroup.kill request after a freezing the cgroup via > > > + cgroup.freeze. > > > > Hm, is it necessarily? What additional guarantees adds using the freezer? > > Every new process that get's added is frozen. So even if the a process > ends up escaping the cgroup.kill request somehow it will be frozen in > the cgroup and can't itself fork again right away. So you could do: Right, but how it can escape? I think one of the main reasons of introducing a dedicated cgroup.kill interface is to avoid a necessity to use freezer as a synchronization mechanism. I'd just drop the sentence about the freezer here. Thanks!