aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorFrederic Weisbecker <fweisbec@gmail.com>2011-12-22 22:25:23 -0500
committerTejun Heo <tj@kernel.org>2011-12-27 12:05:20 -0500
commit7e3aa30ac8c904a706518b725c451bb486daaae9 (patch)
tree1a6ad0678271d1cba5eba2fcafcbfa71b4e4c66d /kernel
parentc6ca57500c23d57a4ccec9874b6a3c99c297e1b5 (diff)
cgroup: Remove task_lock() from cgroup_post_fork()
cgroup_post_fork() is protected between threadgroup_change_begin() and threadgroup_change_end() against concurrent changes of the child's css_set in cgroup_task_migrate(). Also the child can't exit and call cgroup_exit() at this stage, this means it's css_set can't be changed with init_css_set concurrently. For these reasons, we don't need to hold task_lock() on the child because it's css_set can only remain stable in this place. Let's remove the lock there. v2: Update comment to explain that we are safe against cgroup_exit() Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com> Acked-by: Li Zefan <lizf@cn.fujitsu.com> Signed-off-by: Tejun Heo <tj@kernel.org> Cc: Containers <containers@lists.linux-foundation.org> Cc: Cgroups <cgroups@vger.kernel.org> Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Cc: Oleg Nesterov <oleg@redhat.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Paul Menage <paul@paulmenage.org> Cc: Mandeep Singh Baines <msb@chromium.org>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/cgroup.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index c6bd67b3fcf6..548d8d4e86d0 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -4595,10 +4595,19 @@ void cgroup_post_fork(struct task_struct *child)
4595{ 4595{
4596 if (use_task_css_set_links) { 4596 if (use_task_css_set_links) {
4597 write_lock(&css_set_lock); 4597 write_lock(&css_set_lock);
4598 task_lock(child); 4598 if (list_empty(&child->cg_list)) {
4599 if (list_empty(&child->cg_list)) 4599 /*
4600 * It's safe to use child->cgroups without task_lock()
4601 * here because we are protected through
4602 * threadgroup_change_begin() against concurrent
4603 * css_set change in cgroup_task_migrate(). Also
4604 * the task can't exit at that point until
4605 * wake_up_new_task() is called, so we are protected
4606 * against cgroup_exit() setting child->cgroup to
4607 * init_css_set.
4608 */
4600 list_add(&child->cg_list, &child->cgroups->tasks); 4609 list_add(&child->cg_list, &child->cgroups->tasks);
4601 task_unlock(child); 4610 }
4602 write_unlock(&css_set_lock); 4611 write_unlock(&css_set_lock);
4603 } 4612 }
4604} 4613}