aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86
diff options
context:
space:
mode:
authorJames Bottomley <James.Bottomley@HansenPartnership.com>2008-10-30 17:08:38 -0400
committerIngo Molnar <mingo@elte.hu>2008-10-30 17:53:08 -0400
commit08c33308575b370c89b4ed1198ece5f93145a2aa (patch)
tree60fc194d18efe7645cb6f90cfa6a8c58c787ea5c /arch/x86
parentc08b6acc9b996ba6231105cb12a4125c957e0c97 (diff)
x86/voyager: fix boot breakage caused by x86: boot secondary cpus through initial_code
Impact: boot up secondary CPUs as well on x86/Voyager systems This commit: | commit 3e9704739daf46a8ba6593d749c67b5f7cd633d2 | Author: Glauber Costa <gcosta@redhat.com> | Date: Wed May 28 13:01:54 2008 -0300 | | x86: boot secondary cpus through initial_code removed the use of initialize_secondary. However, it didn't update voyager, so the secondary cpus no longer boot. Fix this by adding the initial_code switch to voyager as well. Signed-off-by: James Bottomley <James.Bottomley@HansenPartnership.com> Cc: Glauber Costa <gcosta@redhat.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86')
-rw-r--r--arch/x86/mach-voyager/voyager_smp.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/arch/x86/mach-voyager/voyager_smp.c b/arch/x86/mach-voyager/voyager_smp.c
index 0f6e8a6523ae..9cd327a278ad 100644
--- a/arch/x86/mach-voyager/voyager_smp.c
+++ b/arch/x86/mach-voyager/voyager_smp.c
@@ -90,6 +90,7 @@ static void ack_vic_irq(unsigned int irq);
90static void vic_enable_cpi(void); 90static void vic_enable_cpi(void);
91static void do_boot_cpu(__u8 cpuid); 91static void do_boot_cpu(__u8 cpuid);
92static void do_quad_bootstrap(void); 92static void do_quad_bootstrap(void);
93static void initialize_secondary(void);
93 94
94int hard_smp_processor_id(void); 95int hard_smp_processor_id(void);
95int safe_smp_processor_id(void); 96int safe_smp_processor_id(void);
@@ -650,6 +651,8 @@ void __init smp_boot_cpus(void)
650 smp_tune_scheduling(); 651 smp_tune_scheduling();
651 */ 652 */
652 smp_store_cpu_info(boot_cpu_id); 653 smp_store_cpu_info(boot_cpu_id);
654 /* setup the jump vector */
655 initial_code = (unsigned long)initialize_secondary;
653 printk("CPU%d: ", boot_cpu_id); 656 printk("CPU%d: ", boot_cpu_id);
654 print_cpu_info(&cpu_data(boot_cpu_id)); 657 print_cpu_info(&cpu_data(boot_cpu_id));
655 658
@@ -702,7 +705,7 @@ void __init smp_boot_cpus(void)
702 705
703/* Reload the secondary CPUs task structure (this function does not 706/* Reload the secondary CPUs task structure (this function does not
704 * return ) */ 707 * return ) */
705void __init initialize_secondary(void) 708static void __init initialize_secondary(void)
706{ 709{
707#if 0 710#if 0
708 // AC kernels only 711 // AC kernels only