From 0c7bb346c22dded964be4688a343b848f9ba283c Mon Sep 17 00:00:00 2001 From: Tejun Heo Date: Fri, 9 Nov 2012 09:12:29 -0800 Subject: [PATCH] --- yaml --- r: 339323 b: refs/heads/master c: eb6fd5040ee799009173daa49c3e7aa0362167c9 h: refs/heads/master i: 339321: 3aaf6f758a24993c3545f61f0229cbdfe1816b54 339319: 99776a187b4dd6e40742c3fc75470c3db608f0cf v: v3 --- [refs] | 2 +- trunk/include/linux/cgroup.h | 1 + trunk/kernel/cgroup.c | 8 +++----- 3 files changed, 5 insertions(+), 6 deletions(-) diff --git a/[refs] b/[refs] index 47a220fe8dae..53151468d29a 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: a8638030f668884720b8f4456448d0ce33952b05 +refs/heads/master: eb6fd5040ee799009173daa49c3e7aa0362167c9 diff --git a/trunk/include/linux/cgroup.h b/trunk/include/linux/cgroup.h index b4421221111d..90c33ebdd6bc 100644 --- a/trunk/include/linux/cgroup.h +++ b/trunk/include/linux/cgroup.h @@ -12,6 +12,7 @@ #include #include #include +#include #include #include #include diff --git a/trunk/kernel/cgroup.c b/trunk/kernel/cgroup.c index 26f2edbaf4f5..2ed5968a04e7 100644 --- a/trunk/kernel/cgroup.c +++ b/trunk/kernel/cgroup.c @@ -1650,7 +1650,6 @@ static struct dentry *cgroup_mount(struct file_system_type *fs_type, free_cg_links(&tmp_cg_links); - BUG_ON(!list_empty(&root_cgrp->sibling)); BUG_ON(!list_empty(&root_cgrp->children)); BUG_ON(root->number_of_cgroups != 1); @@ -1699,7 +1698,6 @@ static void cgroup_kill_sb(struct super_block *sb) { BUG_ON(root->number_of_cgroups != 1); BUG_ON(!list_empty(&cgrp->children)); - BUG_ON(!list_empty(&cgrp->sibling)); mutex_lock(&cgroup_mutex); mutex_lock(&cgroup_root_mutex); @@ -4052,7 +4050,7 @@ static long cgroup_create(struct cgroup *parent, struct dentry *dentry, } } - list_add(&cgrp->sibling, &cgrp->parent->children); + list_add_tail_rcu(&cgrp->sibling, &cgrp->parent->children); root->number_of_cgroups++; err = cgroup_create_dir(cgrp, dentry, mode); @@ -4083,7 +4081,7 @@ static long cgroup_create(struct cgroup *parent, struct dentry *dentry, err_remove: - list_del(&cgrp->sibling); + list_del_rcu(&cgrp->sibling); root->number_of_cgroups--; err_destroy: @@ -4209,7 +4207,7 @@ static int cgroup_rmdir(struct inode *unused_dir, struct dentry *dentry) raw_spin_unlock(&release_list_lock); /* delete this cgroup from parent->children */ - list_del_init(&cgrp->sibling); + list_del_rcu(&cgrp->sibling); list_del_init(&cgrp->allcg_node);