diff options
author | Tejun Heo <tj@kernel.org> | 2011-01-23 08:37:40 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2011-01-28 08:54:09 -0500 |
commit | 645a79195f66eb68ef3ab2b21d9829ac3aa085a9 (patch) | |
tree | 5808c94ad0371f70a391e1e77baf12465969e19c /arch/x86/kernel/cpu/amd.c | |
parent | bbc9e2f452d9c4b166d1f9a78d941d80173312fe (diff) |
x86: Unify CPU -> NUMA node mapping between 32 and 64bit
Unlike 64bit, 32bit has been using its own cpu_to_node_map[] for
CPU -> NUMA node mapping. Replace it with early_percpu variable
x86_cpu_to_node_map and share the mapping code with 64bit.
* USE_PERCPU_NUMA_NODE_ID is now enabled for 32bit too.
* x86_cpu_to_node_map and numa_set/clear_node() are moved from
numa_64 to numa. For now, on 32bit, x86_cpu_to_node_map is initialized
with 0 instead of NUMA_NO_NODE. This is to avoid introducing unexpected
behavior change and will be updated once init path is unified.
* srat_detect_node() is now enabled for x86_32 too. It calls
numa_set_node() and initializes the mapping making explicit
cpu_to_node_map[] updates from map/unmap_cpu_to_node() unnecessary.
Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: eric.dumazet@gmail.com
Cc: yinghai@kernel.org
Cc: brgerst@gmail.com
Cc: gorcunov@gmail.com
Cc: penberg@kernel.org
Cc: shaohui.zheng@intel.com
Cc: rientjes@google.com
LKML-Reference: <1295789862-25482-15-git-send-email-tj@kernel.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Cc: David Rientjes <rientjes@google.com>
Diffstat (limited to 'arch/x86/kernel/cpu/amd.c')
-rw-r--r-- | arch/x86/kernel/cpu/amd.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/x86/kernel/cpu/amd.c b/arch/x86/kernel/cpu/amd.c index 3cce8f2bb2e1..77858fd64620 100644 --- a/arch/x86/kernel/cpu/amd.c +++ b/arch/x86/kernel/cpu/amd.c | |||
@@ -233,7 +233,7 @@ static void __cpuinit init_amd_k7(struct cpuinfo_x86 *c) | |||
233 | } | 233 | } |
234 | #endif | 234 | #endif |
235 | 235 | ||
236 | #if defined(CONFIG_NUMA) && defined(CONFIG_X86_64) | 236 | #ifdef CONFIG_NUMA |
237 | /* | 237 | /* |
238 | * To workaround broken NUMA config. Read the comment in | 238 | * To workaround broken NUMA config. Read the comment in |
239 | * srat_detect_node(). | 239 | * srat_detect_node(). |
@@ -338,7 +338,7 @@ EXPORT_SYMBOL_GPL(amd_get_nb_id); | |||
338 | 338 | ||
339 | static void __cpuinit srat_detect_node(struct cpuinfo_x86 *c) | 339 | static void __cpuinit srat_detect_node(struct cpuinfo_x86 *c) |
340 | { | 340 | { |
341 | #if defined(CONFIG_NUMA) && defined(CONFIG_X86_64) | 341 | #ifdef CONFIG_NUMA |
342 | int cpu = smp_processor_id(); | 342 | int cpu = smp_processor_id(); |
343 | int node; | 343 | int node; |
344 | unsigned apicid = c->apicid; | 344 | unsigned apicid = c->apicid; |