aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2013-08-08 20:11:27 -0400
committerTejun Heo <tj@kernel.org>2013-08-08 20:11:27 -0400
commitd99c8727e7bbc01b70e2c57e6127bfab26b868fd (patch)
tree9479ba1329ac1184cf82755ade7dfe94e9d7a4be /kernel
parent81eeaf0411204f52af8ef78ff107cfca2fcfec1d (diff)
cgroup: make cgroup_taskset deal with cgroup_subsys_state instead of cgroup
cgroup is in the process of converting to css (cgroup_subsys_state) from cgroup as the principal subsystem interface handle. This is mostly to prepare for the unified hierarchy support where css's will be created and destroyed dynamically but also helps cleaning up subsystem implementations as css is usually what they are interested in anyway. cgroup_taskset which is used by the subsystem attach methods is the last cgroup subsystem API which isn't using css as the handle. Update cgroup_taskset_cur_cgroup() to cgroup_taskset_cur_css() and cgroup_taskset_for_each() to take @skip_css instead of @skip_cgrp. The conversions are pretty mechanical. One exception is cpuset::cgroup_cs(), which lost its last user and got removed. This patch shouldn't introduce any functional changes. Signed-off-by: Tejun Heo <tj@kernel.org> Acked-by: Li Zefan <lizefan@huawei.com> Acked-by: Daniel Wagner <daniel.wagner@bmw-carit.de> Cc: Ingo Molnar <mingo@redhat.com> Cc: Matt Helsley <matthltc@us.ibm.com> Cc: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/cgroup.c16
-rw-r--r--kernel/cgroup_freezer.c2
-rw-r--r--kernel/cpuset.c15
-rw-r--r--kernel/events/core.c2
-rw-r--r--kernel/sched/core.c4
5 files changed, 18 insertions, 21 deletions
diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index a71f2e0f9711..e5bfb2a81dcb 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -1907,18 +1907,20 @@ struct task_struct *cgroup_taskset_next(struct cgroup_taskset *tset)
1907EXPORT_SYMBOL_GPL(cgroup_taskset_next); 1907EXPORT_SYMBOL_GPL(cgroup_taskset_next);
1908 1908
1909/** 1909/**
1910 * cgroup_taskset_cur_cgroup - return the matching cgroup for the current task 1910 * cgroup_taskset_cur_css - return the matching css for the current task
1911 * @tset: taskset of interest 1911 * @tset: taskset of interest
1912 * @subsys_id: the ID of the target subsystem
1912 * 1913 *
1913 * Return the cgroup for the current (last returned) task of @tset. This 1914 * Return the css for the current (last returned) task of @tset for
1914 * function must be preceded by either cgroup_taskset_first() or 1915 * subsystem specified by @subsys_id. This function must be preceded by
1915 * cgroup_taskset_next(). 1916 * either cgroup_taskset_first() or cgroup_taskset_next().
1916 */ 1917 */
1917struct cgroup *cgroup_taskset_cur_cgroup(struct cgroup_taskset *tset) 1918struct cgroup_subsys_state *cgroup_taskset_cur_css(struct cgroup_taskset *tset,
1919 int subsys_id)
1918{ 1920{
1919 return tset->cur_cgrp; 1921 return cgroup_css(tset->cur_cgrp, subsys_id);
1920} 1922}
1921EXPORT_SYMBOL_GPL(cgroup_taskset_cur_cgroup); 1923EXPORT_SYMBOL_GPL(cgroup_taskset_cur_css);
1922 1924
1923/** 1925/**
1924 * cgroup_taskset_size - return the number of tasks in taskset 1926 * cgroup_taskset_size - return the number of tasks in taskset
diff --git a/kernel/cgroup_freezer.c b/kernel/cgroup_freezer.c
index 5cd2b6d55243..224da9aa27f5 100644
--- a/kernel/cgroup_freezer.c
+++ b/kernel/cgroup_freezer.c
@@ -189,7 +189,7 @@ static void freezer_attach(struct cgroup_subsys_state *new_css,
189 * current state before executing the following - !frozen tasks may 189 * current state before executing the following - !frozen tasks may
190 * be visible in a FROZEN cgroup and frozen tasks in a THAWED one. 190 * be visible in a FROZEN cgroup and frozen tasks in a THAWED one.
191 */ 191 */
192 cgroup_taskset_for_each(task, new_css->cgroup, tset) { 192 cgroup_taskset_for_each(task, new_css, tset) {
193 if (!(freezer->state & CGROUP_FREEZING)) { 193 if (!(freezer->state & CGROUP_FREEZING)) {
194 __thaw_task(task); 194 __thaw_task(task);
195 } else { 195 } else {
diff --git a/kernel/cpuset.c b/kernel/cpuset.c
index 39e52175f4af..bf69717325b4 100644
--- a/kernel/cpuset.c
+++ b/kernel/cpuset.c
@@ -119,12 +119,6 @@ static inline struct cpuset *css_cs(struct cgroup_subsys_state *css)
119 return css ? container_of(css, struct cpuset, css) : NULL; 119 return css ? container_of(css, struct cpuset, css) : NULL;
120} 120}
121 121
122/* Retrieve the cpuset for a cgroup */
123static inline struct cpuset *cgroup_cs(struct cgroup *cgrp)
124{
125 return css_cs(cgroup_css(cgrp, cpuset_subsys_id));
126}
127
128/* Retrieve the cpuset for a task */ 122/* Retrieve the cpuset for a task */
129static inline struct cpuset *task_cs(struct task_struct *task) 123static inline struct cpuset *task_cs(struct task_struct *task)
130{ 124{
@@ -1459,7 +1453,7 @@ static int cpuset_can_attach(struct cgroup_subsys_state *css,
1459 (cpumask_empty(cs->cpus_allowed) || nodes_empty(cs->mems_allowed))) 1453 (cpumask_empty(cs->cpus_allowed) || nodes_empty(cs->mems_allowed)))
1460 goto out_unlock; 1454 goto out_unlock;
1461 1455
1462 cgroup_taskset_for_each(task, css->cgroup, tset) { 1456 cgroup_taskset_for_each(task, css, tset) {
1463 /* 1457 /*
1464 * Kthreads which disallow setaffinity shouldn't be moved 1458 * Kthreads which disallow setaffinity shouldn't be moved
1465 * to a new cpuset; we don't want to change their cpu 1459 * to a new cpuset; we don't want to change their cpu
@@ -1511,9 +1505,10 @@ static void cpuset_attach(struct cgroup_subsys_state *css,
1511 struct mm_struct *mm; 1505 struct mm_struct *mm;
1512 struct task_struct *task; 1506 struct task_struct *task;
1513 struct task_struct *leader = cgroup_taskset_first(tset); 1507 struct task_struct *leader = cgroup_taskset_first(tset);
1514 struct cgroup *oldcgrp = cgroup_taskset_cur_cgroup(tset); 1508 struct cgroup_subsys_state *oldcss = cgroup_taskset_cur_css(tset,
1509 cpuset_subsys_id);
1515 struct cpuset *cs = css_cs(css); 1510 struct cpuset *cs = css_cs(css);
1516 struct cpuset *oldcs = cgroup_cs(oldcgrp); 1511 struct cpuset *oldcs = css_cs(oldcss);
1517 struct cpuset *cpus_cs = effective_cpumask_cpuset(cs); 1512 struct cpuset *cpus_cs = effective_cpumask_cpuset(cs);
1518 struct cpuset *mems_cs = effective_nodemask_cpuset(cs); 1513 struct cpuset *mems_cs = effective_nodemask_cpuset(cs);
1519 1514
@@ -1527,7 +1522,7 @@ static void cpuset_attach(struct cgroup_subsys_state *css,
1527 1522
1528 guarantee_online_mems(mems_cs, &cpuset_attach_nodemask_to); 1523 guarantee_online_mems(mems_cs, &cpuset_attach_nodemask_to);
1529 1524
1530 cgroup_taskset_for_each(task, css->cgroup, tset) { 1525 cgroup_taskset_for_each(task, css, tset) {
1531 /* 1526 /*
1532 * can_attach beforehand should guarantee that this doesn't 1527 * can_attach beforehand should guarantee that this doesn't
1533 * fail. TODO: have a better way to handle failure here 1528 * fail. TODO: have a better way to handle failure here
diff --git a/kernel/events/core.c b/kernel/events/core.c
index 9705a0ed1dce..c199c4f24910 100644
--- a/kernel/events/core.c
+++ b/kernel/events/core.c
@@ -7816,7 +7816,7 @@ static void perf_cgroup_attach(struct cgroup_subsys_state *css,
7816{ 7816{
7817 struct task_struct *task; 7817 struct task_struct *task;
7818 7818
7819 cgroup_taskset_for_each(task, css->cgroup, tset) 7819 cgroup_taskset_for_each(task, css, tset)
7820 task_function_call(task, __perf_cgroup_move, task); 7820 task_function_call(task, __perf_cgroup_move, task);
7821} 7821}
7822 7822
diff --git a/kernel/sched/core.c b/kernel/sched/core.c
index cc9a49266382..a7122d5b8310 100644
--- a/kernel/sched/core.c
+++ b/kernel/sched/core.c
@@ -7135,7 +7135,7 @@ static int cpu_cgroup_can_attach(struct cgroup_subsys_state *css,
7135{ 7135{
7136 struct task_struct *task; 7136 struct task_struct *task;
7137 7137
7138 cgroup_taskset_for_each(task, css->cgroup, tset) { 7138 cgroup_taskset_for_each(task, css, tset) {
7139#ifdef CONFIG_RT_GROUP_SCHED 7139#ifdef CONFIG_RT_GROUP_SCHED
7140 if (!sched_rt_can_attach(css_tg(css), task)) 7140 if (!sched_rt_can_attach(css_tg(css), task))
7141 return -EINVAL; 7141 return -EINVAL;
@@ -7153,7 +7153,7 @@ static void cpu_cgroup_attach(struct cgroup_subsys_state *css,
7153{ 7153{
7154 struct task_struct *task; 7154 struct task_struct *task;
7155 7155
7156 cgroup_taskset_for_each(task, css->cgroup, tset) 7156 cgroup_taskset_for_each(task, css, tset)
7157 sched_move_task(task); 7157 sched_move_task(task);
7158} 7158}
7159 7159