summaryrefslogtreecommitdiffstats
path: root/kernel/rcutree.c
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2013-06-13 06:04:54 +0200
committerTejun Heo <tj@kernel.org>2013-06-13 19:55:18 +0200
commitddd69148bdc45e5e3e55bfde3571daecd5a96d75 (patch)
tree0d248de63b78acf91668a96a1f6cc77f49f2946c /kernel/rcutree.c
parentcgroup: rename CGRP_REMOVED to CGRP_DEAD (diff)
downloadlinux-ddd69148bdc45e5e3e55bfde3571daecd5a96d75.tar.xz
linux-ddd69148bdc45e5e3e55bfde3571daecd5a96d75.zip
cgroup: drop unnecessary RCU dancing from __put_css_set()
__put_css_set() does RCU read access on @cgrp across dropping @cgrp->count so that it can continue accessing @cgrp even if the count reached zero and destruction of the cgroup commenced. Given that both sides - __css_put() and cgroup_destroy_locked() - are cold paths, this is unnecessary. Just making cgroup_destroy_locked() grab css_set_lock while checking @cgrp->count is enough. Remove the RCU read locking from __put_css_set() and make cgroup_destroy_locked() read-lock css_set_lock when checking @cgrp->count. This will also allow removing @cgrp->count. Signed-off-by: Tejun Heo <tj@kernel.org> Acked-by: Li Zefan <lizefan@huawei.com>
Diffstat (limited to 'kernel/rcutree.c')
0 files changed, 0 insertions, 0 deletions