aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/cgroup.h
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2012-11-19 11:13:36 -0500
committerTejun Heo <tj@kernel.org>2012-11-19 11:13:36 -0500
commitfebfcef60d4f9457785b45aab548bc7ee5ea158f (patch)
tree70fab0e8ec07aec4142f1dc228f307e6b1d79de0 /include/linux/cgroup.h
parent4e139afc22cb98d0d032ffce0285bfcc73ca5217 (diff)
cgroup: cgroup->dentry isn't a RCU pointer
cgroup->dentry is marked and used as a RCU pointer; however, it isn't one - the final dentry put doesn't go through call_rcu(). cgroup and dentry share the same RCU freeing rule via synchronize_rcu() in cgroup_diput() (kfree_rcu() used on cgrp is unnecessary). If cgrp is accessible under RCU read lock, so is its dentry and dereferencing cgrp->dentry doesn't need any further RCU protection or annotation. While not being accurate, before the previous patch, the RCU accessors served a purpose as memory barriers - cgroup->dentry used to be assigned after the cgroup was made visible to cgroup_path(), so the assignment and dereferencing in cgroup_path() needed the memory barrier pair. Now that list_add_tail_rcu() happens after cgroup->dentry is assigned, this no longer is necessary. Remove the now unnecessary and misleading RCU annotations from cgroup->dentry. To make up for the removal of rcu_dereference_check() in cgroup_path(), add an explicit rcu_lockdep_assert(), which asserts the dereference rule of @cgrp, not cgrp->dentry. Signed-off-by: Tejun Heo <tj@kernel.org> Acked-by: Li Zefan <lizefan@huawei.com>
Diffstat (limited to 'include/linux/cgroup.h')
-rw-r--r--include/linux/cgroup.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h
index 8f64b459fbd4..d605857c4bf3 100644
--- a/include/linux/cgroup.h
+++ b/include/linux/cgroup.h
@@ -165,7 +165,7 @@ struct cgroup {
165 struct list_head files; /* my files */ 165 struct list_head files; /* my files */
166 166
167 struct cgroup *parent; /* my parent */ 167 struct cgroup *parent; /* my parent */
168 struct dentry __rcu *dentry; /* cgroup fs entry, RCU protected */ 168 struct dentry *dentry; /* cgroup fs entry, RCU protected */
169 169
170 /* Private pointers for each registered subsystem */ 170 /* Private pointers for each registered subsystem */
171 struct cgroup_subsys_state *subsys[CGROUP_SUBSYS_COUNT]; 171 struct cgroup_subsys_state *subsys[CGROUP_SUBSYS_COUNT];