diff options
author | Li Zefan <lizf@cn.fujitsu.com> | 2011-03-23 16:42:48 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-03-23 19:46:35 -0700 |
commit | 523fb486bfd94e3a3b16a42bcb21b1959cf14df8 (patch) | |
tree | 34c1b15a9bc55ef7a3bafb87cce3d3d184d78906 | |
parent | ee24d3797780eee6ffe581a7b78d27896f9b494a (diff) | |
download | linux-523fb486bfd94e3a3b16a42bcb21b1959cf14df8.tar.gz linux-523fb486bfd94e3a3b16a42bcb21b1959cf14df8.tar.bz2 linux-523fb486bfd94e3a3b16a42bcb21b1959cf14df8.zip |
cpuset: hold callback_mutex in cpuset_post_clone()
Chaning cpuset->mems/cpuset->cpus should be protected under
callback_mutex.
cpuset_clone() doesn't follow this rule. It's ok because it's
called when creating and initializing a cgroup, but we'd better
hold the lock to avoid subtil break in the future.
Signed-off-by: Li Zefan <lizf@cn.fujitsu.com>
Acked-by: Paul Menage <menage@google.com>
Acked-by: David Rientjes <rientjes@google.com>
Cc: Miao Xie <miaox@cn.fujitsu.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | kernel/cpuset.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/kernel/cpuset.c b/kernel/cpuset.c index e472fe139192..33eee16addb8 100644 --- a/kernel/cpuset.c +++ b/kernel/cpuset.c @@ -1840,8 +1840,10 @@ static void cpuset_post_clone(struct cgroup_subsys *ss, cs = cgroup_cs(cgroup); parent_cs = cgroup_cs(parent); + mutex_lock(&callback_mutex); cs->mems_allowed = parent_cs->mems_allowed; cpumask_copy(cs->cpus_allowed, parent_cs->cpus_allowed); + mutex_unlock(&callback_mutex); return; } |