From: Li Zefan <lizf@cn.fujitsu.com>
To: "akpm >> Andrew Morton" <akpm@linux-foundation.org>
Cc: Paul Menage <menage@google.com>,
Stephane Eranian <eranian@google.com>,
LKML <linux-kernel@vger.kernel.org>,
containers@lists.linux-foundation.org, matthltc@us.ibm.com
Subject: [PATCH 5/7] cgroups: Make freezer subsystem bindable
Date: Fri, 22 Oct 2010 16:11:41 +0800 [thread overview]
Message-ID: <4CC1473D.9070201@cn.fujitsu.com> (raw)
In-Reply-To: <4CC146A4.9090505@cn.fujitsu.com>
To make it bindable, we need to thaw all processes when unbinding
the freezer subsystem from a cgroup hierarchy.
Signed-off-by: Li Zefan <lizf@cn.fujitsu.com>
---
include/linux/cgroup.h | 3 ++-
kernel/cgroup.c | 22 ++++++++++++++++++++--
kernel/cgroup_freezer.c | 19 +++++++++++++++++--
3 files changed, 39 insertions(+), 5 deletions(-)
diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h
index 49369ff..1e4e1df 100644
--- a/include/linux/cgroup.h
+++ b/include/linux/cgroup.h
@@ -478,7 +478,8 @@ struct cgroup_subsys {
int (*populate)(struct cgroup_subsys *ss,
struct cgroup *cgrp);
void (*post_clone)(struct cgroup_subsys *ss, struct cgroup *cgrp);
- void (*bind)(struct cgroup_subsys *ss, struct cgroup *root);
+ void (*bind)(struct cgroup_subsys *ss, struct cgroup *cgrp,
+ bool unbind);
int subsys_id;
diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index 6364bb5..12c1f7c 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -1105,6 +1105,22 @@ static int hierarchy_populate_dir(struct cgroup *cgrp, void *data)
return 0;
}
+static int hierarchy_subsys_bind(struct cgroup *cgrp, void *data)
+{
+ struct cgroup_subsys *ss = data;
+
+ ss->bind(ss, cgrp, false);
+ return 0;
+}
+
+static int hierarchy_subsys_unbind(struct cgroup *cgrp, void *data)
+{
+ struct cgroup_subsys *ss = data;;
+
+ ss->bind(ss, cgrp, true);
+ return 0;
+}
+
/*
* Call with cgroup_mutex held. Drops reference counts on modules, including
* any duplicate ones that parse_cgroupfs_options took. If this function
@@ -1172,7 +1188,8 @@ static int rebind_subsystems(struct cgroupfs_root *root,
list_move(&ss->sibling, &root->subsys_list);
ss->root = root;
if (ss->bind)
- ss->bind(ss, cgrp);
+ cgroup_walk_hierarchy(hierarchy_subsys_bind,
+ ss, cgrp);
mutex_unlock(&ss->hierarchy_mutex);
/* refcount was already taken, and we're keeping it */
} else if (bit & removed_bits) {
@@ -1180,7 +1197,8 @@ static int rebind_subsystems(struct cgroupfs_root *root,
BUG_ON(ss == NULL);
mutex_lock(&ss->hierarchy_mutex);
if (ss->bind)
- ss->bind(ss, dummytop);
+ cgroup_walk_hierarchy(hierarchy_subsys_unbind,
+ ss, cgrp);
subsys[i]->root = &rootnode;
list_move(&ss->sibling, &rootnode.subsys_list);
mutex_unlock(&ss->hierarchy_mutex);
diff --git a/kernel/cgroup_freezer.c b/kernel/cgroup_freezer.c
index e7bebb7..de13ce4 100644
--- a/kernel/cgroup_freezer.c
+++ b/kernel/cgroup_freezer.c
@@ -383,6 +383,21 @@ static int freezer_populate(struct cgroup_subsys *ss, struct cgroup *cgroup)
return cgroup_add_files(cgroup, ss, files, ARRAY_SIZE(files));
}
+/*
+ * Thaw all processes before unbinding the freezer subsysem from
+ * cgroup hierarchy.
+ * */
+static void freezer_bind(struct cgroup_subsys *ss, struct cgroup *cgrp,
+ bool unbind)
+{
+ struct freezer *freezer = cgroup_freezer(cgrp);
+
+ if (!unbind)
+ return;
+
+ unfreeze_cgroup(cgrp, freezer);
+}
+
struct cgroup_subsys freezer_subsys = {
.name = "freezer",
.create = freezer_create,
@@ -390,7 +405,7 @@ struct cgroup_subsys freezer_subsys = {
.populate = freezer_populate,
.subsys_id = freezer_subsys_id,
.can_attach = freezer_can_attach,
- .attach = NULL,
.fork = freezer_fork,
- .exit = NULL,
+ .bind = freezer_bind,
+ .can_bind = 1,
};
--
1.7.0.1
next prev parent reply other threads:[~2010-10-22 8:10 UTC|newest]
Thread overview: 75+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-10-22 8:09 [PATCH 0/7] cgroups: Allow to bind/unbind subsystems to/from non-trival hierarchy Li Zefan
2010-10-22 8:09 ` [PATCH 1/7] cgroups: Shrink struct cgroup_subsys Li Zefan
[not found] ` <4CC146BA.7080009-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-28 23:34 ` Paul Menage
2010-10-28 23:34 ` Paul Menage
[not found] ` <AANLkTikf-1kLStxqi5UjP=vn3pqVBHy0OA7ibeWTkJ5z-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-11-08 5:23 ` Li Zefan
2010-11-08 5:23 ` Li Zefan
2010-11-09 21:05 ` Paul Menage
[not found] ` <AANLkTim6d1fQLZbkmZST3PTN0RMSs3m=oossF81pYBn9-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-11-10 0:52 ` Li Zefan
2010-11-10 0:52 ` Li Zefan
2010-11-10 1:53 ` Paul Menage
2010-11-10 2:06 ` Li Zefan
[not found] ` <4CD9FE2D.2070108-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-11-10 2:15 ` Paul Menage
2010-11-10 2:15 ` Paul Menage
[not found] ` <AANLkTinMr7VE4Os7rXWjiHWOVysv=oE0vHKduLWCN0bC-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-11-10 2:06 ` Li Zefan
[not found] ` <4CD9ECD2.3030805-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-11-10 1:53 ` Paul Menage
[not found] ` <4CD78946.5060405-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-11-09 21:05 ` Paul Menage
2010-10-22 8:10 ` [PATCH 3/7] cgroups: Allow to unbind subsystem from a cgroup hierarachy Li Zefan
2010-10-29 0:02 ` Paul Menage
[not found] ` <4CC146F5.9060006-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-29 0:02 ` Paul Menage
2010-10-22 8:11 ` [PATCH 4/7] cgroups: Mark some subsystems bindable Li Zefan
2010-10-22 8:11 ` Li Zefan [this message]
[not found] ` <4CC1473D.9070201-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-22 20:57 ` [PATCH 5/7] cgroups: Make freezer subsystem bindable Matt Helsley
2010-10-22 20:57 ` Matt Helsley
[not found] ` <20101022205755.GJ10119-52DBMbEzqgQ/wnmkkaCWp/UQ3DHhIser@public.gmane.org>
2010-10-22 21:46 ` Matt Helsley
2010-10-22 21:57 ` Matt Helsley
2010-10-25 1:15 ` Li Zefan
2010-10-22 21:46 ` Matt Helsley
[not found] ` <20101022214650.GL10119-52DBMbEzqgQ/wnmkkaCWp/UQ3DHhIser@public.gmane.org>
2010-10-29 0:06 ` Paul Menage
2010-10-29 0:06 ` Paul Menage
2010-10-22 21:57 ` Matt Helsley
2010-10-25 1:15 ` Li Zefan
[not found] ` <4CC146A4.9090505-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-22 8:09 ` [PATCH 1/7] cgroups: Shrink struct cgroup_subsys Li Zefan
2010-10-22 8:09 ` [PATCH 2/7] cgroups: Allow to bind a subsystem to a cgroup hierarchy Li Zefan
2010-10-22 8:09 ` Li Zefan
[not found] ` <4CC146D4.7030009-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-22 12:47 ` Peter Zijlstra
2010-10-22 21:38 ` Matt Helsley
2010-10-28 23:55 ` Paul Menage
2010-10-28 23:55 ` Paul Menage
2010-11-08 5:26 ` Li Zefan
[not found] ` <AANLkTimCD90s+y_6y=LyOL1QqEOOAaT+b2b4guDrzo_g-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-11-08 5:26 ` Li Zefan
2010-10-22 12:47 ` Peter Zijlstra
2010-10-25 0:59 ` Li Zefan
2010-10-25 0:59 ` Li Zefan
2010-10-22 21:38 ` Matt Helsley
[not found] ` <20101022213819.GK10119-52DBMbEzqgQ/wnmkkaCWp/UQ3DHhIser@public.gmane.org>
2010-10-25 1:23 ` Li Zefan
2010-10-25 1:23 ` Li Zefan
2010-10-28 23:57 ` Paul Menage
2010-10-28 23:57 ` Paul Menage
2010-10-22 8:10 ` [PATCH 3/7] cgroups: Allow to unbind subsystem from a cgroup hierarachy Li Zefan
2010-10-22 8:11 ` [PATCH 4/7] cgroups: Mark some subsystems bindable Li Zefan
2010-10-22 8:11 ` [PATCH 5/7] cgroups: Make freezer subsystem bindable Li Zefan
2010-10-22 8:12 ` [PATCH 6/7] cgroups: Warn if a bindable subsystem calls css_get() Li Zefan
2010-10-22 8:12 ` [PATCH 7/7] cgroups: Update documentation for bindable subsystems Li Zefan
2010-10-22 12:50 ` [PATCH 0/7] cgroups: Allow to bind/unbind subsystems to/from non-trival hierarchy Peter Zijlstra
2010-10-22 8:12 ` [PATCH 6/7] cgroups: Warn if a bindable subsystem calls css_get() Li Zefan
2010-10-29 0:05 ` Paul Menage
[not found] ` <4CC14756.5010504-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-29 0:05 ` Paul Menage
2010-10-22 8:12 ` [PATCH 7/7] cgroups: Update documentation for bindable subsystems Li Zefan
2010-10-25 0:36 ` KAMEZAWA Hiroyuki
2010-10-25 0:52 ` Li Zefan
2010-10-25 0:56 ` Li Zefan
[not found] ` <4CC4D4B9.3020807-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-25 0:56 ` Li Zefan
[not found] ` <20101025093617.7de750c0.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-10-25 0:52 ` Li Zefan
[not found] ` <4CC14769.2000406-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-25 0:36 ` KAMEZAWA Hiroyuki
2010-10-29 0:13 ` Paul Menage
2010-10-29 0:13 ` Paul Menage
2010-10-29 0:15 ` Paul Menage
2010-11-08 5:27 ` Li Zefan
[not found] ` <AANLkTinbtLkF=haFeDkzecEWv_FE9jG4TefiptSnZcPi-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-10-29 0:15 ` Paul Menage
2010-11-08 5:27 ` Li Zefan
2010-10-22 12:50 ` [PATCH 0/7] cgroups: Allow to bind/unbind subsystems to/from non-trival hierarchy Peter Zijlstra
2010-10-25 1:07 ` Li Zefan
2010-10-25 1:07 ` Li Zefan
2010-10-28 23:33 ` Paul Menage
[not found] ` <4CC4D84C.5000705-BthXqXjhjHXQFUHtdCDX3A@public.gmane.org>
2010-10-28 23:33 ` Paul Menage
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4CC1473D.9070201@cn.fujitsu.com \
--to=lizf@cn.fujitsu.com \
--cc=akpm@linux-foundation.org \
--cc=containers@lists.linux-foundation.org \
--cc=eranian@google.com \
--cc=linux-kernel@vger.kernel.org \
--cc=matthltc@us.ibm.com \
--cc=menage@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.