x86_64: Remove obsolete per_cpu offset calculations Replace all uses of __per_cpu_offset with CPU_PTR. This will avoid a lot of lookups for per cpu offset calculations. Keep per_cpu_offset() itself because lockdep uses it. Signed-off-by: Christoph Lameter --- arch/x86/kernel/smpboot_64.c | 8 +++----- include/asm-x86/percpu_64.h | 14 ++++++-------- 2 files changed, 9 insertions(+), 13 deletions(-) Index: linux-2.6/include/asm-x86/percpu_64.h =================================================================== --- linux-2.6.orig/include/asm-x86/percpu_64.h 2007-11-20 21:05:53.717715854 -0800 +++ linux-2.6/include/asm-x86/percpu_64.h 2007-11-20 21:05:57.121465756 -0800 @@ -13,10 +13,8 @@ #include -#define __per_cpu_offset(cpu) (cpu_pda(cpu)->data_offset) -#define __my_cpu_offset() read_pda(data_offset) - -#define per_cpu_offset(x) (__per_cpu_offset(x)) +/* Legacy: lockdep in the core kernel uses this */ +#define per_cpu_offset(cpu) CPU_OFFSET(cpu) /* Separate out the type, so (int[3], foo) works. */ #define DEFINE_PER_CPU(type, name) \ @@ -34,20 +32,20 @@ /* var is in discarded region: offset to particular copy we want */ #define per_cpu(var, cpu) (*({ \ extern int simple_identifier_##var(void); \ - RELOC_HIDE(&per_cpu__##var, __per_cpu_offset(cpu)); })) + CPU_PTR(&per_cpu__##var, (cpu)); })) #define __get_cpu_var(var) (*({ \ extern int simple_identifier_##var(void); \ - RELOC_HIDE(&per_cpu__##var, __my_cpu_offset()); })) + THIS_CPU(&per_cpu__##var); })) #define __raw_get_cpu_var(var) (*({ \ extern int simple_identifier_##var(void); \ - RELOC_HIDE(&per_cpu__##var, __my_cpu_offset()); })) + __THIS_CPU(&per_cpu__##var); })) /* A macro to avoid #include hell... */ #define percpu_modcopy(pcpudst, src, size) \ do { \ unsigned int __i; \ for_each_possible_cpu(__i) \ - memcpy((pcpudst)+__per_cpu_offset(__i), \ + memcpy(CPU_PTR(pcpudst, __i), \ (src), (size)); \ } while (0) Index: linux-2.6/arch/x86/kernel/smpboot_64.c =================================================================== --- linux-2.6.orig/arch/x86/kernel/smpboot_64.c 2007-11-20 21:04:35.508465744 -0800 +++ linux-2.6/arch/x86/kernel/smpboot_64.c 2007-11-20 21:05:57.121465756 -0800 @@ -835,11 +835,9 @@ void __init smp_set_apicids(void) { int cpu; - for_each_cpu_mask(cpu, cpu_possible_map) { - if (per_cpu_offset(cpu)) - per_cpu(x86_cpu_to_apicid, cpu) = - x86_cpu_to_apicid_init[cpu]; - } + for_each_cpu_mask(cpu, cpu_possible_map) + per_cpu(x86_cpu_to_apicid, cpu) = + x86_cpu_to_apicid_init[cpu]; /* indicate the static array will be going away soon */ x86_cpu_to_apicid_ptr = NULL;