Commit 985ed670 authored by Tejun Heo's avatar Tejun Heo

cgroup: use cgroup_setup_root() to initialize cgroup_dummy_root

cgroup_dummy_root is used to host controllers which aren't attached to
any other hierarchy.  The root is minimally set up during kernfs
bootstrap and didn't go through full hierarchy initialization.  We're
planning to use cgroup_dummy_root for the default unified hierarchy
and thus want it to be fully functional.

Replace the special initialization, which was collected into
cgroup_init() by the previous patch, with an invocation of
cgroup_setup_root().  This simplifies the init path and makes
cgroup_dummy_root a full hierarchy with its own kernfs_root and all.

As this puts the dummy hierarchy on the cgroup_roots list, rename
for_each_active_root() to for_each_root() and update its users to skip
the dummy root for now.

This patch doesn't cause any userland visible behavior changes at this
point.
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
Acked-by: default avatarLi Zefan <lizefan@huawei.com>
parent 172a2c06
...@@ -289,8 +289,8 @@ static int notify_on_release(const struct cgroup *cgrp) ...@@ -289,8 +289,8 @@ static int notify_on_release(const struct cgroup *cgrp)
for ((ssid) = 0; (ssid) < CGROUP_SUBSYS_COUNT && \ for ((ssid) = 0; (ssid) < CGROUP_SUBSYS_COUNT && \
(((ss) = cgroup_subsys[ssid]) || true); (ssid)++) (((ss) = cgroup_subsys[ssid]) || true); (ssid)++)
/* iterate across the active hierarchies */ /* iterate across the hierarchies */
#define for_each_active_root(root) \ #define for_each_root(root) \
list_for_each_entry((root), &cgroup_roots, root_list) list_for_each_entry((root), &cgroup_roots, root_list)
/** /**
...@@ -354,7 +354,6 @@ static struct css_set init_css_set = { ...@@ -354,7 +354,6 @@ static struct css_set init_css_set = {
.mg_node = LIST_HEAD_INIT(init_css_set.mg_node), .mg_node = LIST_HEAD_INIT(init_css_set.mg_node),
}; };
static struct cgrp_cset_link init_cgrp_cset_link;
static int css_set_count = 1; /* 1 for init_css_set */ static int css_set_count = 1; /* 1 for init_css_set */
/* /*
...@@ -693,14 +692,13 @@ static struct cgroupfs_root *cgroup_root_from_kf(struct kernfs_root *kf_root) ...@@ -693,14 +692,13 @@ static struct cgroupfs_root *cgroup_root_from_kf(struct kernfs_root *kf_root)
return top_cgrp->root; return top_cgrp->root;
} }
static int cgroup_init_root_id(struct cgroupfs_root *root, int start, int end) static int cgroup_init_root_id(struct cgroupfs_root *root)
{ {
int id; int id;
lockdep_assert_held(&cgroup_mutex); lockdep_assert_held(&cgroup_mutex);
id = idr_alloc_cyclic(&cgroup_hierarchy_idr, root, start, end, id = idr_alloc_cyclic(&cgroup_hierarchy_idr, root, 0, 0, GFP_KERNEL);
GFP_KERNEL);
if (id < 0) if (id < 0)
return id; return id;
...@@ -1405,8 +1403,7 @@ static int cgroup_setup_root(struct cgroupfs_root *root, unsigned long ss_mask) ...@@ -1405,8 +1403,7 @@ static int cgroup_setup_root(struct cgroupfs_root *root, unsigned long ss_mask)
if (ret) if (ret)
goto out; goto out;
/* ID 0 is reserved for dummy root, 1 for unified hierarchy */ ret = cgroup_init_root_id(root);
ret = cgroup_init_root_id(root, 2, 0);
if (ret) if (ret)
goto out; goto out;
...@@ -1486,9 +1483,12 @@ static struct dentry *cgroup_mount(struct file_system_type *fs_type, ...@@ -1486,9 +1483,12 @@ static struct dentry *cgroup_mount(struct file_system_type *fs_type,
goto out_unlock; goto out_unlock;
/* look for a matching existing root */ /* look for a matching existing root */
for_each_active_root(root) { for_each_root(root) {
bool name_match = false; bool name_match = false;
if (root == &cgroup_dummy_root)
continue;
/* /*
* If we asked for a name then it must match. Also, if * If we asked for a name then it must match. Also, if
* name matches but sybsys_mask doesn't, we should fail. * name matches but sybsys_mask doesn't, we should fail.
...@@ -2106,9 +2106,12 @@ int cgroup_attach_task_all(struct task_struct *from, struct task_struct *tsk) ...@@ -2106,9 +2106,12 @@ int cgroup_attach_task_all(struct task_struct *from, struct task_struct *tsk)
int retval = 0; int retval = 0;
mutex_lock(&cgroup_mutex); mutex_lock(&cgroup_mutex);
for_each_active_root(root) { for_each_root(root) {
struct cgroup *from_cgrp; struct cgroup *from_cgrp;
if (root == &cgroup_dummy_root)
continue;
down_read(&css_set_rwsem); down_read(&css_set_rwsem);
from_cgrp = task_cgroup_from_root(from, root); from_cgrp = task_cgroup_from_root(from, root);
up_read(&css_set_rwsem); up_read(&css_set_rwsem);
...@@ -4073,26 +4076,17 @@ int __init cgroup_init(void) ...@@ -4073,26 +4076,17 @@ int __init cgroup_init(void)
BUG_ON(cgroup_init_cftypes(NULL, cgroup_base_files)); BUG_ON(cgroup_init_cftypes(NULL, cgroup_base_files));
/* allocate id for the dummy hierarchy */ mutex_lock(&cgroup_tree_mutex);
mutex_lock(&cgroup_mutex); mutex_lock(&cgroup_mutex);
/* Add init_css_set to the hash table */ /* Add init_css_set to the hash table */
key = css_set_hash(init_css_set.subsys); key = css_set_hash(init_css_set.subsys);
hash_add(css_set_table, &init_css_set.hlist, key); hash_add(css_set_table, &init_css_set.hlist, key);
BUG_ON(cgroup_init_root_id(&cgroup_dummy_root, 0, 1)); BUG_ON(cgroup_setup_root(&cgroup_dummy_root, 0));
err = idr_alloc(&cgroup_dummy_root.cgroup_idr, cgroup_dummy_top,
0, 1, GFP_KERNEL);
BUG_ON(err < 0);
cgroup_root_count = 1;
init_cgrp_cset_link.cset = &init_css_set;
init_cgrp_cset_link.cgrp = cgroup_dummy_top;
list_add(&init_cgrp_cset_link.cset_link, &cgroup_dummy_top->cset_links);
list_add(&init_cgrp_cset_link.cgrp_link, &init_css_set.cgrp_links);
mutex_unlock(&cgroup_mutex); mutex_unlock(&cgroup_mutex);
mutex_unlock(&cgroup_tree_mutex);
for_each_subsys(ss, ssid) { for_each_subsys(ss, ssid) {
if (!ss->early_init) if (!ss->early_init)
...@@ -4176,11 +4170,14 @@ int proc_cgroup_show(struct seq_file *m, void *v) ...@@ -4176,11 +4170,14 @@ int proc_cgroup_show(struct seq_file *m, void *v)
mutex_lock(&cgroup_mutex); mutex_lock(&cgroup_mutex);
down_read(&css_set_rwsem); down_read(&css_set_rwsem);
for_each_active_root(root) { for_each_root(root) {
struct cgroup_subsys *ss; struct cgroup_subsys *ss;
struct cgroup *cgrp; struct cgroup *cgrp;
int ssid, count = 0; int ssid, count = 0;
if (root == &cgroup_dummy_root)
continue;
seq_printf(m, "%d:", root->hierarchy_id); seq_printf(m, "%d:", root->hierarchy_id);
for_each_subsys(ss, ssid) for_each_subsys(ss, ssid)
if (root->subsys_mask & (1 << ssid)) if (root->subsys_mask & (1 << ssid))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment