x86: isolate logic to disable smp
Put it in a disable_smp() function, as x86_64 does Signed-off-by: Glauber Costa <gcosta@redhat.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
4780b261e2
commit
b675f11127
1 changed files with 16 additions and 16 deletions
|
@ -742,6 +742,15 @@ void *xquad_portio;
|
||||||
EXPORT_SYMBOL(xquad_portio);
|
EXPORT_SYMBOL(xquad_portio);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static void __init disable_smp(void)
|
||||||
|
{
|
||||||
|
smpboot_clear_io_apic_irqs();
|
||||||
|
phys_cpu_present_map = physid_mask_of_physid(0);
|
||||||
|
map_cpu_to_logical_apicid();
|
||||||
|
cpu_set(0, per_cpu(cpu_sibling_map, 0));
|
||||||
|
cpu_set(0, per_cpu(cpu_core_map, 0));
|
||||||
|
}
|
||||||
|
|
||||||
static int __init smp_sanity_check(unsigned max_cpus)
|
static int __init smp_sanity_check(unsigned max_cpus)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -750,14 +759,10 @@ static int __init smp_sanity_check(unsigned max_cpus)
|
||||||
*/
|
*/
|
||||||
if (!smp_found_config && !acpi_lapic) {
|
if (!smp_found_config && !acpi_lapic) {
|
||||||
printk(KERN_NOTICE "SMP motherboard not detected.\n");
|
printk(KERN_NOTICE "SMP motherboard not detected.\n");
|
||||||
smpboot_clear_io_apic_irqs();
|
disable_smp();
|
||||||
phys_cpu_present_map = physid_mask_of_physid(0);
|
|
||||||
if (APIC_init_uniprocessor())
|
if (APIC_init_uniprocessor())
|
||||||
printk(KERN_NOTICE "Local APIC not detected."
|
printk(KERN_NOTICE "Local APIC not detected."
|
||||||
" Using dummy APIC emulation.\n");
|
" Using dummy APIC emulation.\n");
|
||||||
map_cpu_to_logical_apicid();
|
|
||||||
cpu_set(0, per_cpu(cpu_sibling_map, 0));
|
|
||||||
cpu_set(0, per_cpu(cpu_core_map, 0));
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -779,11 +784,6 @@ static int __init smp_sanity_check(unsigned max_cpus)
|
||||||
printk(KERN_ERR "BIOS bug, local APIC #%d not detected!...\n",
|
printk(KERN_ERR "BIOS bug, local APIC #%d not detected!...\n",
|
||||||
boot_cpu_physical_apicid);
|
boot_cpu_physical_apicid);
|
||||||
printk(KERN_ERR "... forcing use of dummy APIC emulation. (tell your hw vendor)\n");
|
printk(KERN_ERR "... forcing use of dummy APIC emulation. (tell your hw vendor)\n");
|
||||||
smpboot_clear_io_apic_irqs();
|
|
||||||
phys_cpu_present_map = physid_mask_of_physid(0);
|
|
||||||
map_cpu_to_logical_apicid();
|
|
||||||
cpu_set(0, per_cpu(cpu_sibling_map, 0));
|
|
||||||
cpu_set(0, per_cpu(cpu_core_map, 0));
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -801,11 +801,6 @@ static int __init smp_sanity_check(unsigned max_cpus)
|
||||||
connect_bsp_APIC();
|
connect_bsp_APIC();
|
||||||
setup_local_APIC();
|
setup_local_APIC();
|
||||||
}
|
}
|
||||||
smpboot_clear_io_apic_irqs();
|
|
||||||
phys_cpu_present_map = physid_mask_of_physid(0);
|
|
||||||
map_cpu_to_logical_apicid();
|
|
||||||
cpu_set(0, per_cpu(cpu_sibling_map, 0));
|
|
||||||
cpu_set(0, per_cpu(cpu_core_map, 0));
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -835,7 +830,12 @@ static void __init smp_boot_cpus(unsigned int max_cpus)
|
||||||
|
|
||||||
set_cpu_sibling_map(0);
|
set_cpu_sibling_map(0);
|
||||||
|
|
||||||
smp_sanity_check(max_cpus);
|
if (smp_sanity_check(max_cpus) < 0) {
|
||||||
|
printk(KERN_INFO "SMP disabled\n");
|
||||||
|
disable_smp();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
connect_bsp_APIC();
|
connect_bsp_APIC();
|
||||||
setup_local_APIC();
|
setup_local_APIC();
|
||||||
map_cpu_to_logical_apicid();
|
map_cpu_to_logical_apicid();
|
||||||
|
|
Loading…
Add table
Reference in a new issue