H. Peter Anvin | 1965aae | 2008-10-22 22:26:29 -0700 | [diff] [blame] | 1 | #ifndef _ASM_X86_CACHE_H |
| 2 | #define _ASM_X86_CACHE_H |
Thomas Gleixner | 9bfa23d | 2007-10-15 23:28:20 +0200 | [diff] [blame] | 3 | |
Tim Abbott | abe1ee3 | 2009-09-20 18:14:15 -0400 | [diff] [blame] | 4 | #include <linux/linkage.h> |
| 5 | |
Thomas Gleixner | 9bfa23d | 2007-10-15 23:28:20 +0200 | [diff] [blame] | 6 | /* L1 cache line size */ |
| 7 | #define L1_CACHE_SHIFT (CONFIG_X86_L1_CACHE_SHIFT) |
| 8 | #define L1_CACHE_BYTES (1 << L1_CACHE_SHIFT) |
| 9 | |
| 10 | #define __read_mostly __attribute__((__section__(".data.read_mostly"))) |
| 11 | |
| 12 | #ifdef CONFIG_X86_VSMP |
| 13 | /* vSMP Internode cacheline shift */ |
| 14 | #define INTERNODE_CACHE_SHIFT (12) |
| 15 | #ifdef CONFIG_SMP |
| 16 | #define __cacheline_aligned_in_smp \ |
| 17 | __attribute__((__aligned__(1 << (INTERNODE_CACHE_SHIFT)))) \ |
Tim Abbott | abe1ee3 | 2009-09-20 18:14:15 -0400 | [diff] [blame] | 18 | __page_aligned_data |
Thomas Gleixner | 9bfa23d | 2007-10-15 23:28:20 +0200 | [diff] [blame] | 19 | #endif |
| 20 | #endif |
| 21 | |
H. Peter Anvin | 1965aae | 2008-10-22 22:26:29 -0700 | [diff] [blame] | 22 | #endif /* _ASM_X86_CACHE_H */ |