blob: 26404b77f007b6029e4fba1fc276c36ec604cbc0 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _ASM_IA64_PERCPU_H
2#define _ASM_IA64_PERCPU_H
3
4/*
5 * Copyright (C) 2002-2003 Hewlett-Packard Co
6 * David Mosberger-Tang <davidm@hpl.hp.com>
7 */
8
9#define PERCPU_ENOUGH_ROOM PERCPU_PAGE_SIZE
10
11#ifdef __ASSEMBLY__
12# define THIS_CPU(var) (per_cpu__##var) /* use this to mark accesses to per-CPU variables... */
13#else /* !__ASSEMBLY__ */
14
Linus Torvalds1da177e2005-04-16 15:20:36 -070015
16#include <linux/threads.h>
17
18#ifdef HAVE_MODEL_SMALL_ATTRIBUTE
travis@sgi.com5280e002008-01-30 13:32:52 +010019# define PER_CPU_ATTRIBUTES __attribute__((__model__ (__small__)))
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#endif
21
Linus Torvalds1da177e2005-04-16 15:20:36 -070022#ifdef CONFIG_SMP
23
travis@sgi.com05991be2008-01-30 23:27:58 +010024#define __my_cpu_offset __ia64_per_cpu_var(local_per_cpu_offset)
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
Linus Torvalds1da177e2005-04-16 15:20:36 -070026extern void *per_cpu_init(void);
27
28#else /* ! SMP */
29
Linus Torvalds1da177e2005-04-16 15:20:36 -070030#define per_cpu_init() (__phys_per_cpu_start)
31
32#endif /* SMP */
33
Linus Torvalds1da177e2005-04-16 15:20:36 -070034/*
35 * Be extremely careful when taking the address of this variable! Due to virtual
36 * remapping, it is different from the canonical address returned by __get_cpu_var(var)!
37 * On the positive side, using __ia64_per_cpu_var() instead of __get_cpu_var() is slightly
38 * more efficient.
39 */
travis@sgi.com05991be2008-01-30 23:27:58 +010040#define __ia64_per_cpu_var(var) per_cpu__##var
41
42#include <asm-generic/percpu.h>
43
44/* Equal to __per_cpu_offset[smp_processor_id()], but faster to access: */
45DECLARE_PER_CPU(unsigned long, local_per_cpu_offset);
Linus Torvalds1da177e2005-04-16 15:20:36 -070046
47#endif /* !__ASSEMBLY__ */
48
49#endif /* _ASM_IA64_PERCPU_H */