diff options
author | 2013-01-24 14:31:27 +0800 | |
---|---|---|
committer | 2013-01-24 12:05:18 -0800 | |
commit | 86a3db5643c7d29bb36ca85c7a4bb67ad4d88d77 (patch) | |
tree | 62fb73cc15fbcb751ee434a7bd9d1546851a4556 /tools/perf/scripts/python/export-to-postgresql.py | |
parent | sched: remove redundant NULL cgroup check in task_group_path() (diff) | |
download | linux-dev-86a3db5643c7d29bb36ca85c7a4bb67ad4d88d77.tar.xz linux-dev-86a3db5643c7d29bb36ca85c7a4bb67ad4d88d77.zip |
cgroup: remove duplicate RCU free on struct cgroup
When destroying a cgroup, though in cgroup_diput() we've called
synchronize_rcu(), we then still have to free it via call_rcu().
The story is, long ago to fix a race between reading /proc/sched_debug
and freeing cgroup, the code was changed to utilize call_rcu(). See
commit a47295e6bc42ad35f9c15ac66f598aa24debd4e2 ("cgroups: make
cgroup_path() RCU-safe")
As we've fixed cpu cgroup that cpu_cgroup_offline_css() is used
to unregister a task_group so there won't be concurrent access
to this task_group after synchronize_rcu() in diput(). Now we can
just kfree(cgrp).
Signed-off-by: Li Zefan <lizefan@huawei.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'tools/perf/scripts/python/export-to-postgresql.py')
0 files changed, 0 insertions, 0 deletions