diff options
author | travis@sgi.com <travis@sgi.com> | 2008-01-30 07:33:21 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:33:21 -0500 |
commit | 834beda15ecc43c110c0a6ac39ec1aa79f891716 (patch) | |
tree | 56f00ac3e1b06083c5be928dc740369a022b76fa /include/asm-x86/topology.h | |
parent | ac72e7888a612dccfbc15b34698aad441bdfda10 (diff) |
x86: change NR_CPUS arrays in numa_64 fixup
Change the following static arrays sized by NR_CPUS to
per_cpu data variables:
char cpu_to_node_map[NR_CPUS];
fixup:
- Split cpu_to_node function into "early" and "late" versions
so that x86_cpu_to_node_map_early_ptr is not EXPORT'ed and
the cpu_to_node inline function is more streamlined.
- This also involves setting up the percpu maps as early as possible.
- Fix X86_32 NUMA build errors that previous version of this
patch caused.
V2->V3:
- add early_cpu_to_node function to keep cpu_to_node efficient
- move and rename smp_set_apicids() to setup_percpu_maps()
- call setup_percpu_maps() as early as possible
V1->V2:
- Removed extraneous casts
- Fix !NUMA builds with '#ifdef CONFIG_NUMA"
Signed-off-by: Mike Travis <travis@sgi.com>
Reviewed-by: Christoph Lameter <clameter@sgi.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/asm-x86/topology.h')
-rw-r--r-- | include/asm-x86/topology.h | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/include/asm-x86/topology.h b/include/asm-x86/topology.h index 2da1464ecbef..040374f030cf 100644 --- a/include/asm-x86/topology.h +++ b/include/asm-x86/topology.h | |||
@@ -30,16 +30,30 @@ | |||
30 | #include <asm/mpspec.h> | 30 | #include <asm/mpspec.h> |
31 | 31 | ||
32 | /* Mappings between logical cpu number and node number */ | 32 | /* Mappings between logical cpu number and node number */ |
33 | #ifdef CONFIG_X86_32 | ||
34 | extern u8 cpu_to_node_map[]; | ||
35 | |||
36 | #else | ||
33 | DECLARE_PER_CPU(u16, x86_cpu_to_node_map); | 37 | DECLARE_PER_CPU(u16, x86_cpu_to_node_map); |
34 | extern u16 x86_cpu_to_node_map_init[]; | 38 | extern u16 x86_cpu_to_node_map_init[]; |
35 | extern void *x86_cpu_to_node_map_early_ptr; | 39 | extern void *x86_cpu_to_node_map_early_ptr; |
40 | #endif | ||
41 | |||
36 | extern cpumask_t node_to_cpumask_map[]; | 42 | extern cpumask_t node_to_cpumask_map[]; |
37 | 43 | ||
38 | #define NUMA_NO_NODE ((u16)(~0)) | 44 | #define NUMA_NO_NODE ((u16)(~0)) |
39 | 45 | ||
40 | /* Returns the number of the node containing CPU 'cpu' */ | 46 | /* Returns the number of the node containing CPU 'cpu' */ |
47 | #ifdef CONFIG_X86_32 | ||
48 | #define early_cpu_to_node(cpu) cpu_to_node(cpu) | ||
41 | static inline int cpu_to_node(int cpu) | 49 | static inline int cpu_to_node(int cpu) |
42 | { | 50 | { |
51 | return cpu_to_node_map[cpu]; | ||
52 | } | ||
53 | |||
54 | #else /* CONFIG_X86_64 */ | ||
55 | static inline int early_cpu_to_node(int cpu) | ||
56 | { | ||
43 | u16 *cpu_to_node_map = x86_cpu_to_node_map_early_ptr; | 57 | u16 *cpu_to_node_map = x86_cpu_to_node_map_early_ptr; |
44 | 58 | ||
45 | if (cpu_to_node_map) | 59 | if (cpu_to_node_map) |
@@ -50,6 +64,15 @@ static inline int cpu_to_node(int cpu) | |||
50 | return NUMA_NO_NODE; | 64 | return NUMA_NO_NODE; |
51 | } | 65 | } |
52 | 66 | ||
67 | static inline int cpu_to_node(int cpu) | ||
68 | { | ||
69 | if(per_cpu_offset(cpu)) | ||
70 | return per_cpu(x86_cpu_to_node_map, cpu); | ||
71 | else | ||
72 | return NUMA_NO_NODE; | ||
73 | } | ||
74 | #endif /* CONFIG_X86_64 */ | ||
75 | |||
53 | /* | 76 | /* |
54 | * Returns the number of the node containing Node 'node'. This | 77 | * Returns the number of the node containing Node 'node'. This |
55 | * architecture is flat, so it is a pretty simple function! | 78 | * architecture is flat, so it is a pretty simple function! |