aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86
diff options
context:
space:
mode:
authortravis@sgi.com <travis@sgi.com>2008-01-30 07:33:21 -0500
committerIngo Molnar <mingo@elte.hu>2008-01-30 07:33:21 -0500
commit834beda15ecc43c110c0a6ac39ec1aa79f891716 (patch)
tree56f00ac3e1b06083c5be928dc740369a022b76fa /include/asm-x86
parentac72e7888a612dccfbc15b34698aad441bdfda10 (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')
-rw-r--r--include/asm-x86/topology.h23
1 files changed, 23 insertions, 0 deletions
diff --git a/include/asm-x86/topology.h b/include/asm-x86/topology.h
index 2da1464ecbe..040374f030c 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
34extern u8 cpu_to_node_map[];
35
36#else
33DECLARE_PER_CPU(u16, x86_cpu_to_node_map); 37DECLARE_PER_CPU(u16, x86_cpu_to_node_map);
34extern u16 x86_cpu_to_node_map_init[]; 38extern u16 x86_cpu_to_node_map_init[];
35extern void *x86_cpu_to_node_map_early_ptr; 39extern void *x86_cpu_to_node_map_early_ptr;
40#endif
41
36extern cpumask_t node_to_cpumask_map[]; 42extern 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)
41static inline int cpu_to_node(int cpu) 49static inline int cpu_to_node(int cpu)
42{ 50{
51 return cpu_to_node_map[cpu];
52}
53
54#else /* CONFIG_X86_64 */
55static 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
67static 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!