aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJack Steiner <steiner@sgi.com>2008-03-28 15:12:08 -0400
committerIngo Molnar <mingo@elte.hu>2008-04-17 11:41:33 -0400
commita65d1d644c2b65bfb99e766e7160d764b8b2bfa4 (patch)
treefe19c7b1d5fbb7089537d78383c2b89863c0377b
parentae261868658773538ddda829c50224e5851c2342 (diff)
x86: increase size of APICID
Increase the number of bits in an apicid from 8 to 32. By default, MP_processor_info() gets the APICID from the mpc_config_processor structure. However, this structure limits the size of APICID to 8 bits. This patch allows the caller of MP_processor_info() to optionally pass a larger APICID that will be used instead of the one in the mpc_config_processor struct. Signed-off-by: Jack Steiner <steiner@sgi.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r--arch/x86/kernel/mpparse_32.c4
-rw-r--r--arch/x86/kernel/mpparse_64.c4
-rw-r--r--arch/x86/mm/srat_64.c6
-rw-r--r--include/asm-x86/apicdef.h9
-rw-r--r--include/asm-x86/mpspec.h4
5 files changed, 17 insertions, 10 deletions
diff --git a/arch/x86/kernel/mpparse_32.c b/arch/x86/kernel/mpparse_32.c
index 4b46a37e0634..7b7e008496e0 100644
--- a/arch/x86/kernel/mpparse_32.c
+++ b/arch/x86/kernel/mpparse_32.c
@@ -807,7 +807,7 @@ void __init mp_register_lapic_address(u64 address)
807 Dprintk("Boot CPU = %d\n", boot_cpu_physical_apicid); 807 Dprintk("Boot CPU = %d\n", boot_cpu_physical_apicid);
808} 808}
809 809
810void __cpuinit mp_register_lapic (u8 id, u8 enabled) 810void __cpuinit mp_register_lapic (int id, u8 enabled)
811{ 811{
812 if (MAX_APICS - id <= 0) { 812 if (MAX_APICS - id <= 0) {
813 printk(KERN_WARNING "Processor #%d invalid (max %d)\n", 813 printk(KERN_WARNING "Processor #%d invalid (max %d)\n",
@@ -862,7 +862,7 @@ static u8 uniq_ioapic_id(u8 id)
862 return id; 862 return id;
863} 863}
864 864
865void __init mp_register_ioapic(u8 id, u32 address, u32 gsi_base) 865void __init mp_register_ioapic(int id, u32 address, u32 gsi_base)
866{ 866{
867 int idx = 0; 867 int idx = 0;
868 868
diff --git a/arch/x86/kernel/mpparse_64.c b/arch/x86/kernel/mpparse_64.c
index 29d2c40e54a2..4840a846904e 100644
--- a/arch/x86/kernel/mpparse_64.c
+++ b/arch/x86/kernel/mpparse_64.c
@@ -633,7 +633,7 @@ void __init mp_register_lapic_address(u64 address)
633 if (boot_cpu_physical_apicid == -1U) 633 if (boot_cpu_physical_apicid == -1U)
634 boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id()); 634 boot_cpu_physical_apicid = GET_APIC_ID(read_apic_id());
635} 635}
636void __cpuinit mp_register_lapic(u8 id, u8 enabled) 636void __cpuinit mp_register_lapic(int id, u8 enabled)
637{ 637{
638 if (!enabled) { 638 if (!enabled) {
639 ++disabled_cpus; 639 ++disabled_cpus;
@@ -683,7 +683,7 @@ static u8 uniq_ioapic_id(u8 id)
683 return find_first_zero_bit(used, 256); 683 return find_first_zero_bit(used, 256);
684} 684}
685 685
686void __init mp_register_ioapic(u8 id, u32 address, u32 gsi_base) 686void __init mp_register_ioapic(int id, u32 address, u32 gsi_base)
687{ 687{
688 int idx = 0; 688 int idx = 0;
689 689
diff --git a/arch/x86/mm/srat_64.c b/arch/x86/mm/srat_64.c
index 04e06c8226e3..1bae9c855ceb 100644
--- a/arch/x86/mm/srat_64.c
+++ b/arch/x86/mm/srat_64.c
@@ -20,6 +20,7 @@
20#include <asm/proto.h> 20#include <asm/proto.h>
21#include <asm/numa.h> 21#include <asm/numa.h>
22#include <asm/e820.h> 22#include <asm/e820.h>
23#include <asm/genapic.h>
23 24
24int acpi_numa __initdata; 25int acpi_numa __initdata;
25 26
@@ -148,7 +149,10 @@ acpi_numa_processor_affinity_init(struct acpi_srat_cpu_affinity *pa)
148 return; 149 return;
149 } 150 }
150 151
151 apic_id = pa->apic_id; 152 if (is_uv_system())
153 apic_id = (pa->apic_id << 8) | pa->local_sapic_eid;
154 else
155 apic_id = pa->apic_id;
152 apicid_to_node[apic_id] = node; 156 apicid_to_node[apic_id] = node;
153 acpi_numa = 1; 157 acpi_numa = 1;
154 printk(KERN_INFO "SRAT: PXM %u -> APIC %u -> Node %u\n", 158 printk(KERN_INFO "SRAT: PXM %u -> APIC %u -> Node %u\n",
diff --git a/include/asm-x86/apicdef.h b/include/asm-x86/apicdef.h
index 8b244683431b..6b9008c78731 100644
--- a/include/asm-x86/apicdef.h
+++ b/include/asm-x86/apicdef.h
@@ -133,7 +133,7 @@
133# define MAX_IO_APICS 64 133# define MAX_IO_APICS 64
134#else 134#else
135# define MAX_IO_APICS 128 135# define MAX_IO_APICS 128
136# define MAX_LOCAL_APIC 256 136# define MAX_LOCAL_APIC 32768
137#endif 137#endif
138 138
139/* 139/*
@@ -406,6 +406,9 @@ struct local_apic {
406 406
407#undef u32 407#undef u32
408 408
409#define BAD_APICID 0xFFu 409#ifdef CONFIG_X86_32
410 410 #define BAD_APICID 0xFFu
411#else
412 #define BAD_APICID 0xFFFFu
413#endif
411#endif 414#endif
diff --git a/include/asm-x86/mpspec.h b/include/asm-x86/mpspec.h
index 31bac12a97d1..1f6445b147f8 100644
--- a/include/asm-x86/mpspec.h
+++ b/include/asm-x86/mpspec.h
@@ -47,9 +47,9 @@ extern void get_smp_config(void);
47 47
48void __cpuinit generic_processor_info(int apicid, int version); 48void __cpuinit generic_processor_info(int apicid, int version);
49#ifdef CONFIG_ACPI 49#ifdef CONFIG_ACPI
50extern void mp_register_lapic(u8 id, u8 enabled); 50extern void mp_register_lapic(int id, u8 enabled);
51extern void mp_register_lapic_address(u64 address); 51extern void mp_register_lapic_address(u64 address);
52extern void mp_register_ioapic(u8 id, u32 address, u32 gsi_base); 52extern void mp_register_ioapic(int id, u32 address, u32 gsi_base);
53extern void mp_override_legacy_irq(u8 bus_irq, u8 polarity, u8 trigger, 53extern void mp_override_legacy_irq(u8 bus_irq, u8 polarity, u8 trigger,
54 u32 gsi); 54 u32 gsi);
55extern void mp_config_acpi_legacy_irqs(void); 55extern void mp_config_acpi_legacy_irqs(void);