xref: /linux/arch/mips/include/asm/vdso/processor.h (revision eb01fe7abbe2d0b38824d2a93fdb4cc3eaf2ccc1)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (C) 2020 ARM Ltd.
4  */
5 #ifndef __ASM_VDSO_PROCESSOR_H
6 #define __ASM_VDSO_PROCESSOR_H
7 
8 #ifndef __ASSEMBLY__
9 
10 #ifdef CONFIG_CPU_LOONGSON64
11 /*
12  * Loongson-3's SFB (Store-Fill-Buffer) may buffer writes indefinitely when a
13  * tight read loop is executed, because reads take priority over writes & the
14  * hardware (incorrectly) doesn't ensure that writes will eventually occur.
15  *
16  * Since spin loops of any kind should have a cpu_relax() in them, force an SFB
17  * flush from cpu_relax() such that any pending writes will become visible as
18  * expected.
19  */
20 #define cpu_relax()	smp_mb()
21 #else
22 #define cpu_relax()	barrier()
23 #endif
24 
25 #endif /* __ASSEMBLY__ */
26 
27 #endif /* __ASM_VDSO_PROCESSOR_H */
28