Loading...
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 __attribute__((__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 */
1#ifndef _ASM_X86_CACHE_H
2#define _ASM_X86_CACHE_H
3
4#include <linux/linkage.h>
5
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#define INTERNODE_CACHE_SHIFT CONFIG_X86_INTERNODE_CACHE_SHIFT
13#define INTERNODE_CACHE_BYTES (1 << INTERNODE_CACHE_SHIFT)
14
15#ifdef CONFIG_X86_VSMP
16#ifdef CONFIG_SMP
17#define __cacheline_aligned_in_smp \
18 __attribute__((__aligned__(INTERNODE_CACHE_BYTES))) \
19 __page_aligned_data
20#endif
21#endif
22
23#endif /* _ASM_X86_CACHE_H */