summaryrefslogtreecommitdiff
path: root/kernel
diff options
context:
space:
mode:
authorTiejun Chen <tiejun.chen@windriver.com>2013-11-07 02:06:07 (GMT)
committerScott Wood <scottwood@freescale.com>2015-02-13 22:21:04 (GMT)
commit9b7074763f5aca78149f1ba7b13cc68a7da3966d (patch)
treebf15b7281a343e471fda519ad76306dd81ce4451 /kernel
parent0464cead458c293d97265fa212a0b064bd3fa19c (diff)
downloadlinux-fsl-qoriq-9b7074763f5aca78149f1ba7b13cc68a7da3966d.tar.xz
cpu_down: move migrate_enable() back
Commit 08c1ab68, "hotplug-use-migrate-disable.patch", intends to use migrate_enable()/migrate_disable() to replace that combination of preempt_enable() and preempt_disable(), but actually in !CONFIG_PREEMPT_RT_FULL case, migrate_enable()/migrate_disable() are still equal to preempt_enable()/preempt_disable(). So that followed cpu_hotplug_begin()/cpu_unplug_begin(cpu) would go schedule() to trigger schedule_debug() like this: _cpu_down() | + migrate_disable() = preempt_disable() | + cpu_hotplug_begin() or cpu_unplug_begin() | + schedule() | + __schedule() | + preempt_disable(); | + __schedule_bug() is true! So we should move migrate_enable() as the original scheme. Cc: stable-rt@vger.kernel.org Signed-off-by: Tiejun Chen <tiejun.chen@windriver.com>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/cpu.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/kernel/cpu.c b/kernel/cpu.c
index 423ba34..6d2cab1 100644
--- a/kernel/cpu.c
+++ b/kernel/cpu.c
@@ -601,6 +601,7 @@ static int __ref _cpu_down(unsigned int cpu, int tasks_frozen)
err = -EBUSY;
goto restore_cpus;
}
+ migrate_enable();
cpu_hotplug_begin();
err = cpu_unplug_begin(cpu);
@@ -654,7 +655,6 @@ static int __ref _cpu_down(unsigned int cpu, int tasks_frozen)
out_release:
cpu_unplug_done(cpu);
out_cancel:
- migrate_enable();
cpu_hotplug_done();
if (!err)
cpu_notify_nofail(CPU_POST_DEAD | mod, hcpu);