All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 1/2] cgroup: remove synchronize_rcu() from cgroup_attach_{task|proc}()
@ 2013-01-14  9:23 ` Li Zefan
  0 siblings, 0 replies; 10+ messages in thread
From: Li Zefan @ 2013-01-14  9:23 UTC (permalink / raw)
  To: Tejun Heo; +Cc: Colin Cross, Mike Galbraith, LKML, Cgroups

These 2 syncronize_rcu()s make attaching a task to a cgroup
quite slow, and it can't be ignored in some situations.

A real case from Colin Cross: Android uses cgroups heavily to
manage thread priorities, putting threads in a background group
with reduced cpu.shares when they are not visible to the user,
and in a foreground group when they are. Some RPCs from foreground
threads to background threads will temporarily move the background
thread into the foreground group for the duration of the RPC.
This results in many calls to cgroup_attach_task.

In cgroup_attach_task() it's task->cgroups that is protected by RCU,
and put_css_set() calls kfree_rcu() to free it.

If we remove this synchronize_rcu(), there can be threads in RCU-read
sections accessing their old cgroup via current->cgroups with
concurrent rmdir operation, but this is safe.

 # time for ((i=0; i<50; i++)) { echo $$ > /mnt/sub/tasks; echo $$ > /mnt/tasks; }

real    0m2.524s
user    0m0.008s
sys     0m0.004s

With this patch:

real    0m0.004s
user    0m0.004s
sys     0m0.000s

Signed-off-by: Li Zefan <lizefan@huawei.com>
---
 kernel/cgroup.c | 2 --
 1 file changed, 2 deletions(-)

diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index a5262d9..67b0fa0 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -1974,7 +1974,6 @@ int cgroup_attach_task(struct cgroup *cgrp, struct task_struct *tsk)
 			ss->attach(cgrp, &tset);
 	}
 
-	synchronize_rcu();
 out:
 	if (retval) {
 		for_each_subsys(root, ss) {
@@ -2143,7 +2142,6 @@ static int cgroup_attach_proc(struct cgroup *cgrp, struct task_struct *leader)
 	/*
 	 * step 5: success! and cleanup
 	 */
-	synchronize_rcu();
 	retval = 0;
 out_put_css_set_refs:
 	if (retval) {
-- 
1.8.0.2

^ permalink raw reply related	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2013-01-14 18:55 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2013-01-14  9:23 [PATCH 1/2] cgroup: remove synchronize_rcu() from cgroup_attach_{task|proc}() Li Zefan
2013-01-14  9:23 ` Li Zefan
2013-01-14  9:24 ` [PATCH 2/2] cgroup: remove synchronize_rcu() from rebind_subsystems() Li Zefan
2013-01-14  9:24   ` Li Zefan
2013-01-14 18:55   ` Tejun Heo
2013-01-14 18:55     ` Tejun Heo
2013-01-14 18:55     ` Tejun Heo
2013-01-14 18:55       ` Tejun Heo
2013-01-14 18:42 ` [PATCH 1/2] cgroup: remove synchronize_rcu() from cgroup_attach_{task|proc}() Tejun Heo
2013-01-14 18:42   ` Tejun Heo

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.