diff options
author | Cyrill Gorcunov <gorcunov@gmail.com> | 2009-05-11 09:41:40 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-05-11 09:50:58 -0400 |
commit | cec6be6d1069d697beb490bbb40a290d5ff554a2 (patch) | |
tree | 43ef99d950545909d8dbc87cddb14e29789aa060 /arch | |
parent | 97a52714658cd959a3cfa35c5b6f489859f0204b (diff) |
x86: apic: Fixmap apic address even if apic disabled
In case if apic were disabled by boot option
we still need read_apic operation. So fixmap
a fake apic area if needed.
[ Impact: fix boot crash ]
Signed-off-by: Cyrill Gorcunov <gorcunov@openvz.org>
Cc: yinghai@kernel.org
Cc: eswierk@aristanetworks.com
LKML-Reference: <20090511134140.GH4624@lenovo>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/x86/kernel/apic/apic.c | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/arch/x86/kernel/apic/apic.c b/arch/x86/kernel/apic/apic.c index 0e6543fafb50..07cffc1214cb 100644 --- a/arch/x86/kernel/apic/apic.c +++ b/arch/x86/kernel/apic/apic.c | |||
@@ -1587,13 +1587,6 @@ void __init init_apic_mappings(void) | |||
1587 | } else | 1587 | } else |
1588 | apic_phys = mp_lapic_addr; | 1588 | apic_phys = mp_lapic_addr; |
1589 | 1589 | ||
1590 | /* lets check if we may NOP'ify apic operations */ | ||
1591 | if (!cpu_has_apic) { | ||
1592 | pr_info("APIC: disable apic facility\n"); | ||
1593 | apic_disable(); | ||
1594 | return; | ||
1595 | } | ||
1596 | |||
1597 | /* | 1590 | /* |
1598 | * acpi lapic path already maps that address in | 1591 | * acpi lapic path already maps that address in |
1599 | * acpi_register_lapic_address() | 1592 | * acpi_register_lapic_address() |
@@ -1602,7 +1595,15 @@ void __init init_apic_mappings(void) | |||
1602 | set_fixmap_nocache(FIX_APIC_BASE, apic_phys); | 1595 | set_fixmap_nocache(FIX_APIC_BASE, apic_phys); |
1603 | 1596 | ||
1604 | apic_printk(APIC_VERBOSE, "mapped APIC to %08lx (%08lx)\n", | 1597 | apic_printk(APIC_VERBOSE, "mapped APIC to %08lx (%08lx)\n", |
1605 | APIC_BASE, apic_phys); | 1598 | APIC_BASE, apic_phys); |
1599 | |||
1600 | /* lets check if we may NOP'ify apic operations */ | ||
1601 | if (!cpu_has_apic) { | ||
1602 | pr_info("APIC: disable apic facility\n"); | ||
1603 | apic_disable(); | ||
1604 | return; | ||
1605 | } | ||
1606 | |||
1606 | /* | 1607 | /* |
1607 | * Fetch the APIC ID of the BSP in case we have a | 1608 | * Fetch the APIC ID of the BSP in case we have a |
1608 | * default configuration (or the MP table is broken). | 1609 | * default configuration (or the MP table is broken). |