xref: /linux/arch/x86/include/asm/cache.h (revision 24bce201d79807b668bf9d9e0aca801c5c0d5f78)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _ASM_X86_CACHE_H
3 #define _ASM_X86_CACHE_H
4 
5 #include <linux/linkage.h>
6 
7 /* L1 cache line size */
8 #define L1_CACHE_SHIFT	(CONFIG_X86_L1_CACHE_SHIFT)
9 #define L1_CACHE_BYTES	(1 << L1_CACHE_SHIFT)
10 
11 #define __read_mostly __section(".data..read_mostly")
12 
13 #define INTERNODE_CACHE_SHIFT CONFIG_X86_INTERNODE_CACHE_SHIFT
14 #define INTERNODE_CACHE_BYTES (1 << INTERNODE_CACHE_SHIFT)
15 
16 #ifdef CONFIG_X86_VSMP
17 #ifdef CONFIG_SMP
18 #define __cacheline_aligned_in_smp					\
19 	__attribute__((__aligned__(INTERNODE_CACHE_BYTES)))		\
20 	__page_aligned_data
21 #endif
22 #endif
23 
24 #endif /* _ASM_X86_CACHE_H */
25