Commit 05981277 authored by Paul E. McKenney's avatar Paul E. McKenney Committed by Catalin Marinas

arm64: Use common outgoing-CPU-notification code

This commit removes the open-coded CPU-offline notification with new
common code.  In particular, this change avoids calling scheduler code
using RCU from an offline CPU that RCU is ignoring.  This is a minimal
change.  A more intrusive change might invoke the cpu_check_up_prepare()
and cpu_set_state_online() functions at CPU-online time, which would
allow onlining throw an error if the CPU did not go offline properly.
Signed-off-by: default avatarPaul E. McKenney <>
Acked-by: default avatarWill Deacon <>
Signed-off-by: default avatarCatalin Marinas <>
parent 5b09a094
......@@ -254,15 +254,13 @@ static int op_cpu_kill(unsigned int cpu)
return cpu_ops[cpu]->cpu_kill(cpu);
static DECLARE_COMPLETION(cpu_died);
* called on the thread which is asking for a CPU to be shutdown -
* waits until shutdown has completed, or it is timed out.
void __cpu_die(unsigned int cpu)
if (!wait_for_completion_timeout(&cpu_died, msecs_to_jiffies(5000))) {
if (!cpu_wait_death(cpu, 5)) {
pr_crit("CPU%u: cpu didn't die\n", cpu);
......@@ -295,7 +293,7 @@ void cpu_die(void)
/* Tell __cpu_die() that this CPU is now safe to dispose of */
* Actually shutdown the CPU. This must never fail. The specific hotplug
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