diff options
author | Tejun Heo <tj@kernel.org> | 2014-02-25 10:04:01 -0500 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2014-02-25 10:04:01 -0500 |
commit | c75611282cf1bf717c1866e7a7eb4d0743815187 (patch) | |
tree | 4579606847463892cc65977a55bee386b2b5cf2a /include/linux/cgroup.h | |
parent | f153ad11bca27996a5e8e1782557e36e80b03a8c (diff) |
cgroup: add css_set->mg_tasks
Currently, while migrating tasks from one cgroup to another,
cgroup_attach_task() builds a flex array of all target tasks;
unfortunately, this has a couple issues.
* Flex array has size limit. On 64bit, struct task_and_cgroup is
24bytes making the flex element limit around 87k. It is a high
number but not impossible to hit. This means that the current
cgroup implementation can't migrate a process with more than 87k
threads.
* Process migration involves memory allocation whose size is dependent
on the number of threads the process has. This means that cgroup
core can't guarantee success or failure of multi-process migrations
as memory allocation failure can happen in the middle. This is in
part because cgroup can't grab threadgroup locks of multiple
processes at the same time, so when there are multiple processes to
migrate, it is imposible to tell how many tasks are to be migrated
beforehand.
Note that this already affects cgroup_transfer_tasks(). cgroup
currently cannot guarantee atomic success or failure of the
operation. It may fail in the middle and after such failure cgroup
doesn't have enough information to roll back properly. It just
aborts with some tasks migrated and others not.
To resolve the situation, we're going to use task->cg_list during
migration too. Instead of building a separate array, target tasks
will be linked into a dedicated migration list_head on the owning
css_set. Tasks on the migration list are treated the same as tasks on
the usual tasks list; however, being on a separate list allows cgroup
migration code path to keep track of the target tasks by simply
keeping the list of css_sets with tasks being migrated, making
unpredictable dynamic allocation unnecessary.
In prepartion of such migration path update, this patch introduces
css_set->mg_tasks list and updates css_set task iterations so that
they walk both css_set->tasks and ->mg_tasks. Note that ->mg_tasks
isn't used yet.
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.h | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h index 8c283a910b91..528e2aed36c3 100644 --- a/include/linux/cgroup.h +++ b/include/linux/cgroup.h | |||
@@ -324,10 +324,14 @@ struct css_set { | |||
324 | struct hlist_node hlist; | 324 | struct hlist_node hlist; |
325 | 325 | ||
326 | /* | 326 | /* |
327 | * List running through all tasks using this cgroup | 327 | * Lists running through all tasks using this cgroup group. |
328 | * group. Protected by css_set_lock | 328 | * mg_tasks lists tasks which belong to this cset but are in the |
329 | * process of being migrated out or in. Protected by | ||
330 | * css_set_rwsem, but, during migration, once tasks are moved to | ||
331 | * mg_tasks, it can be read safely while holding cgroup_mutex. | ||
329 | */ | 332 | */ |
330 | struct list_head tasks; | 333 | struct list_head tasks; |
334 | struct list_head mg_tasks; | ||
331 | 335 | ||
332 | /* | 336 | /* |
333 | * List of cgrp_cset_links pointing at cgroups referenced from this | 337 | * List of cgrp_cset_links pointing at cgroups referenced from this |