Commit 5e23efd0 authored by Paul E. McKenney's avatar Paul E. McKenney Committed by Greg Kroah-Hartman

printk: Fix scheduling-while-atomic problem in console_cpu_notify()

commit 85eae82a upstream.

The console_cpu_notify() function runs with interrupts disabled in the
CPU_DYING case.  It therefore cannot block, for example, as will happen
when it calls console_lock().  Therefore, remove the CPU_DYING leg of
the switch statement to avoid this problem.
Signed-off-by: default avatarPaul E. McKenney <paulmck@linux.vnet.ibm.com>
Reviewed-by: default avatarSrivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Cc: Guillaume Morin <guillaume@morinfr.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 36f0c45d
...@@ -1172,7 +1172,6 @@ static int __cpuinit console_cpu_notify(struct notifier_block *self, ...@@ -1172,7 +1172,6 @@ static int __cpuinit console_cpu_notify(struct notifier_block *self,
switch (action) { switch (action) {
case CPU_ONLINE: case CPU_ONLINE:
case CPU_DEAD: case CPU_DEAD:
case CPU_DYING:
case CPU_DOWN_FAILED: case CPU_DOWN_FAILED:
case CPU_UP_CANCELED: case CPU_UP_CANCELED:
console_lock(); console_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