[PATCH] Fix the race between smp_call_function and CPU booting
From: Liu, Chuansheng
Date: Mon Mar 12 2012 - 05:27:09 EST
From: liu chuansheng <chuansheng.liu@xxxxxxxxx>
Subject: [PATCH] Fix the race between smp_call_function and CPU booting
When system is waking up from suspend state, sometimes the smp_call_function is called which will cause deadlock specially on the platform which just has two CPUs.
CPU0: CPU1:
pm_suspend -->
suspend_devices_and_enter -->
enable_nonboot_cpus -->
_cpu_up -->
__cpu_up -->
native_cpu_up
start_secondary
-- set cpu online
-- waiting for the active state new thread call:
smp_call_function -->
smp_call_function_many -->
smp_call_function_single -->
-- csd_lock
-- generic_exec_single -->
-- arch_send_call_function_single_ipi
-- csd_lock_wait
At this time, both CPUs are blocked. Normally the CPU0 will set the CPU1 with active state after finished the _cpu_up calling, but CPU1 can not handle the IPI due to the corresponding irq is still disabled, which will be enabled after waiting for the active state.
The solution is just to send smp call to active cpus instead of online cpus.
Signed-off-by: liu chuansheng <chuansheng.liu@xxxxxxxxx>
---
kernel/smp.c | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/kernel/smp.c b/kernel/smp.c index fb67dfa..e67674b 100644
--- a/kernel/smp.c
+++ b/kernel/smp.c
@@ -573,7 +573,7 @@ EXPORT_SYMBOL(smp_call_function_many);
int smp_call_function(smp_call_func_t func, void *info, int wait) {
preempt_disable();
- smp_call_function_many(cpu_online_mask, func, info, wait);
+ smp_call_function_many(cpu_active_mask, func, info, wait);
preempt_enable();
return 0;
--
1.7.0.4
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/