Commit a5212682 authored by Rusty Russell's avatar Rusty Russell Committed by Linus Torvalds

[PATCH] Fix CPU Hotplug: neaten migrate_all_tasks.

A followup patch wants to do forced migration, so separate that part of the
code out of migrate_all_tasks().
Signed-off-by: default avatarRusty Russell <rusty@rustcorp.com.au>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent e50873c0
...@@ -3957,50 +3957,52 @@ static int migration_thread(void * data) ...@@ -3957,50 +3957,52 @@ static int migration_thread(void * data)
} }
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
/* migrate_all_tasks - function to migrate all tasks from the dead cpu. */ /* Figure out where task on dead CPU should go, use force if neccessary. */
static void migrate_all_tasks(int src_cpu) static void move_task_off_dead_cpu(int dead_cpu, struct task_struct *tsk)
{ {
struct task_struct *tsk, *t;
int dest_cpu; int dest_cpu;
unsigned int node;
write_lock_irq(&tasklist_lock);
/* watch out for per node tasks, let's stay on this node */
node = cpu_to_node(src_cpu);
do_each_thread(t, tsk) {
cpumask_t mask; cpumask_t mask;
if (tsk == current)
continue;
if (task_cpu(tsk) != src_cpu) /* On same node? */
continue; mask = node_to_cpumask(cpu_to_node(dead_cpu));
/* Figure out where this task should go (attempting to
* keep it on-node), and check if it can be migrated
* as-is. NOTE that kernel threads bound to more than
* one online cpu will be migrated. */
mask = node_to_cpumask(node);
cpus_and(mask, mask, tsk->cpus_allowed); cpus_and(mask, mask, tsk->cpus_allowed);
dest_cpu = any_online_cpu(mask); dest_cpu = any_online_cpu(mask);
/* On any allowed CPU? */
if (dest_cpu == NR_CPUS) if (dest_cpu == NR_CPUS)
dest_cpu = any_online_cpu(tsk->cpus_allowed); dest_cpu = any_online_cpu(tsk->cpus_allowed);
/* No more Mr. Nice Guy. */
if (dest_cpu == NR_CPUS) { if (dest_cpu == NR_CPUS) {
cpus_setall(tsk->cpus_allowed); cpus_setall(tsk->cpus_allowed);
dest_cpu = any_online_cpu(tsk->cpus_allowed); dest_cpu = any_online_cpu(tsk->cpus_allowed);
/* /*
* Don't tell them about moving exiting tasks * Don't tell them about moving exiting tasks or
* or kernel threads (both mm NULL), since * kernel threads (both mm NULL), since they never
* they never leave kernel. * leave kernel.
*/ */
if (tsk->mm && printk_ratelimit()) if (tsk->mm && printk_ratelimit())
printk(KERN_INFO "process %d (%s) no " printk(KERN_INFO "process %d (%s) no "
"longer affine to cpu%d\n", "longer affine to cpu%d\n",
tsk->pid, tsk->comm, src_cpu); tsk->pid, tsk->comm, dead_cpu);
} }
__migrate_task(tsk, src_cpu, dest_cpu); __migrate_task(tsk, dead_cpu, dest_cpu);
}
/* migrate_all_tasks - function to migrate all tasks from the dead cpu. */
static void migrate_all_tasks(int src_cpu)
{
struct task_struct *tsk, *t;
write_lock_irq(&tasklist_lock);
do_each_thread(t, tsk) {
if (tsk == current)
continue;
if (task_cpu(tsk) == src_cpu)
move_task_off_dead_cpu(src_cpu, tsk);
} while_each_thread(t, tsk); } while_each_thread(t, tsk);
write_unlock_irq(&tasklist_lock); write_unlock_irq(&tasklist_lock);
......
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