diff options
author | Frederic Weisbecker <fweisbec@gmail.com> | 2011-12-22 22:25:23 -0500 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2011-12-27 12:05:20 -0500 |
commit | 7e3aa30ac8c904a706518b725c451bb486daaae9 (patch) | |
tree | 1a6ad0678271d1cba5eba2fcafcbfa71b4e4c66d /kernel/cgroup.c | |
parent | c6ca57500c23d57a4ccec9874b6a3c99c297e1b5 (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/cgroup.c')
-rw-r--r-- | kernel/cgroup.c | 15 |
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 | } |