drm/rockchip: vop2: Support 32x8 superblock afbc
[drm/drm-misc.git] / arch / mips / include / asm / vdso / processor.h
blob511c95d735e654d7aac3ce1ae89ce87ee4c1adcc
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
8 #ifndef __ASSEMBLY__
10 #ifdef CONFIG_CPU_LOONGSON64
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.
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.
20 #define cpu_relax() smp_mb()
21 #else
22 #define cpu_relax() barrier()
23 #endif
25 #endif /* __ASSEMBLY__ */
27 #endif /* __ASM_VDSO_PROCESSOR_H */