kexec: migrate to reboot cpu
Vivek Goyal [Thu, 19 Dec 2013 01:08:31 +0000 (17:08 -0800)]
Commit 1b3a5d02ee07 ("reboot: move arch/x86 reboot= handling to generic
kernel") moved reboot= handling to generic code.  In the process it also
removed the code in native_machine_shutdown() which are moving reboot
process to reboot_cpu/cpu0.

I guess that thought must have been that all reboot paths are calling
migrate_to_reboot_cpu(), so we don't need this special handling.  But
kexec reboot path (kernel_kexec()) is not calling
migrate_to_reboot_cpu() so above change broke kexec.  Now reboot can
happen on non-boot cpu and when INIT is sent in second kerneo to bring
up BP, it brings down the machine.

So start calling migrate_to_reboot_cpu() in kexec reboot path to avoid
this problem.

Bisected by WANG Chao.

Change-Id: Ic91cfd26731d488bbd5e387a823ff1c56124dbef
Reported-by: Matthew Whitehead <>
Reported-by: Dave Young <>
Signed-off-by: Vivek Goyal <>
Tested-by: Baoquan He <>
Tested-by: WANG Chao <>
Acked-by: H. Peter Anvin <>
Cc: <>
Signed-off-by: Andrew Morton <>
Signed-off-by: Linus Torvalds <>
Signed-off-by: Varun Wadekar <>
Reviewed-on: http://git-master/r/603284
Reviewed-by: Bharat Nihalani <>


index 626e697..51495b1 100644 (file)
@@ -42,6 +42,7 @@ extern int unregister_reboot_notifier(struct notifier_block *);
  * Architecture-specific implementations of sys_reboot commands.
+extern void migrate_to_reboot_cpu(void);
 extern void machine_restart(char *cmd);
 extern void machine_halt(void);
 extern void machine_power_off(void);
index 1f8d938..57cc094 100644 (file)
@@ -1683,6 +1683,7 @@ int kernel_kexec(void)
                kexec_in_progress = true;
+               migrate_to_reboot_cpu();
                printk(KERN_EMERG "Starting new kernel\n");
index f813b34..662c83f 100644 (file)
@@ -104,7 +104,7 @@ int unregister_reboot_notifier(struct notifier_block *nb)
-static void migrate_to_reboot_cpu(void)
+void migrate_to_reboot_cpu(void)
        /* The boot cpu is always logical cpu 0 */
        int cpu = reboot_cpu;