aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86
diff options
context:
space:
mode:
authorYinghai Lu <Yinghai.Lu@Sun.COM>2008-02-19 06:21:06 -0500
committerIngo Molnar <mingo@elte.hu>2008-04-17 11:40:58 -0400
commit8643f9d02a7bb9db74634b4c062d8e70ce7c59b9 (patch)
treef7d31205f8a9ea6e1c9551cbc0d160072c33f112 /include/asm-x86
parent6079d2d5d11122eb52721f0f3c828952a490e6c1 (diff)
x86: get boot_cpu_id as early for k8_scan_nodes
When acpi=off or there is no SRAT defined, apicid_to_node is got from K8 Northbridge PCI configuration space in k8_scan_nodes() in arch/x86_64/mm/k8toplogy.c. The problem is that it assumes bsp apic id is 0 at that point. For four socket system with Quad core cpus installed, all cpus apic id is offset by 4, and bsp apic id is 4. For eight socket system with dual core cpus installed, all cpus apic id is offset by 2, and bsp apic id is 2. We need get boot_cpu_id --- bsp apic id, before k8_scan_nodes by called. So create early_acpi_boot_init and early_get_smp_config for get boot_cpu_id. Signed-off-by: Yinghai Lu <yhlu.kernel@gmail.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'include/asm-x86')
-rw-r--r--include/asm-x86/apic.h1
-rw-r--r--include/asm-x86/mpspec.h3
2 files changed, 4 insertions, 0 deletions
diff --git a/include/asm-x86/apic.h b/include/asm-x86/apic.h
index f0321a427e16..db5f7501aed6 100644
--- a/include/asm-x86/apic.h
+++ b/include/asm-x86/apic.h
@@ -129,6 +129,7 @@ extern void enable_NMI_through_LVT0(void);
129 */ 129 */
130#ifdef CONFIG_X86_64 130#ifdef CONFIG_X86_64
131extern void setup_apic_routing(void); 131extern void setup_apic_routing(void);
132extern void early_init_lapic_mapping(void);
132#endif 133#endif
133 134
134extern u8 setup_APIC_eilvt_mce(u8 vector, u8 msg_type, u8 mask); 135extern u8 setup_APIC_eilvt_mce(u8 vector, u8 msg_type, u8 mask);
diff --git a/include/asm-x86/mpspec.h b/include/asm-x86/mpspec.h
index dbd63f8d4750..982550bef2cd 100644
--- a/include/asm-x86/mpspec.h
+++ b/include/asm-x86/mpspec.h
@@ -25,6 +25,9 @@ extern int pic_mode;
25 25
26extern DECLARE_BITMAP(mp_bus_not_pci, MAX_MP_BUSSES); 26extern DECLARE_BITMAP(mp_bus_not_pci, MAX_MP_BUSSES);
27 27
28extern void early_find_smp_config(void);
29extern void early_get_smp_config(void);
30
28#endif 31#endif
29 32
30extern int mp_bus_id_to_pci_bus[MAX_MP_BUSSES]; 33extern int mp_bus_id_to_pci_bus[MAX_MP_BUSSES];