cpuset: fix to migrate mm correctly in a corner case
authorLi Zefan <lizefan@huawei.com>
Thu, 13 Jun 2013 07:11:44 +0000 (15:11 +0800)
committerTejun Heo <tj@kernel.org>
Thu, 13 Jun 2013 17:51:22 +0000 (10:51 -0700)
Before moving tasks out of empty cpusets, update_tasks_nodemask()
is called, which calls do_migrate_pages(xx, from, to). Then those
tasks are moved to an ancestor, and do_migrate_pages() is called
again.

The first time: from = node_to_be_offlined, to = empty.
The second time: from = empty, to = ancestor's nodemask.

so looks like no pages will be migrated.

Fix this by:

- Don't call update_tasks_nodemask() on empty cpusets.
- Pass cs->old_mems_allowed to do_migrate_pages().

v4: added comment in cpuset_hotplug_update_tasks() and rephased comment
    in cpuset_attach().

Signed-off-by: Li Zefan <lizefan@huawei.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
kernel/cpuset.c

diff --cc kernel/cpuset.c
Simple merge