x86_64: Provide per_cpu_var definition There needs to be a way to determine the offset for the CPU ops of per cpu variables. The offset is simply the address of the variable. But we do not want to code ugly things like CPU_READ(per_cpu__statistics) in the core. So define a new helper per_cpu_var(var) that simply adds the per_cpu__ prefix. Signed-off-by: Christoph Lameter --- include/asm-x86/percpu_64.h | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 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:57.121465756 -0800 +++ linux-2.6/include/asm-x86/percpu_64.h 2007-11-20 21:06:04.300715904 -0800 @@ -16,29 +16,35 @@ /* Legacy: lockdep in the core kernel uses this */ #define per_cpu_offset(cpu) CPU_OFFSET(cpu) +/* + * Needed in order to be able to pass per cpu variables to CPU_xx + * macros. Another solution may be to simply drop the prefix? + */ +#define per_cpu_var(var) per_cpu__##var + /* Separate out the type, so (int[3], foo) works. */ #define DEFINE_PER_CPU(type, name) \ - __attribute__((__section__(".data.percpu"))) __typeof__(type) per_cpu__##name + __attribute__((__section__(".data.percpu"))) __typeof__(type) per_cpu_var(name) #define DEFINE_PER_CPU_SHARED_ALIGNED(type, name) \ __attribute__((__section__(".data.percpu.shared_aligned"))) \ - __typeof__(type) per_cpu__##name \ + __typeof__(type) per_cpu_var(name) \ ____cacheline_internodealigned_in_smp #define DEFINE_PER_CPU_FIRST(type, name) \ __attribute__((__section__(".data.percpu.first"))) \ - __typeof__(type) per_cpu__##name + __typeof__(type) per_cpu_var(name) /* var is in discarded region: offset to particular copy we want */ #define per_cpu(var, cpu) (*({ \ extern int simple_identifier_##var(void); \ - CPU_PTR(&per_cpu__##var, (cpu)); })) + CPU_PTR(&per_cpu_var(var), (cpu)); })) #define __get_cpu_var(var) (*({ \ extern int simple_identifier_##var(void); \ - THIS_CPU(&per_cpu__##var); })) + THIS_CPU(&per_cpu_var(var)); })) #define __raw_get_cpu_var(var) (*({ \ extern int simple_identifier_##var(void); \ - __THIS_CPU(&per_cpu__##var); })) + __THIS_CPU(&per_cpu_var(var)); })) /* A macro to avoid #include hell... */ #define percpu_modcopy(pcpudst, src, size) \