Linux Audio

Check our new training course

Loading...
v5.4
 1/* SPDX-License-Identifier: GPL-2.0 */
 2#include <linux/compiler.h>
 3#if defined(__i386__) || defined(__x86_64__)
 4#include "../../arch/x86/include/asm/barrier.h"
 5#elif defined(__arm__)
 6#include "../../arch/arm/include/asm/barrier.h"
 7#elif defined(__aarch64__)
 8#include "../../arch/arm64/include/asm/barrier.h"
 9#elif defined(__powerpc__)
10#include "../../arch/powerpc/include/asm/barrier.h"
11#elif defined(__s390__)
12#include "../../arch/s390/include/asm/barrier.h"
13#elif defined(__sh__)
14#include "../../arch/sh/include/asm/barrier.h"
15#elif defined(__sparc__)
16#include "../../arch/sparc/include/asm/barrier.h"
17#elif defined(__tile__)
18#include "../../arch/tile/include/asm/barrier.h"
19#elif defined(__alpha__)
20#include "../../arch/alpha/include/asm/barrier.h"
21#elif defined(__mips__)
22#include "../../arch/mips/include/asm/barrier.h"
23#elif defined(__ia64__)
24#include "../../arch/ia64/include/asm/barrier.h"
25#elif defined(__xtensa__)
26#include "../../arch/xtensa/include/asm/barrier.h"
27#elif defined(__nds32__)
28#include "../../arch/nds32/include/asm/barrier.h"
29#else
30#include <asm-generic/barrier.h>
31#endif
32
33/*
34 * Generic fallback smp_*() definitions for archs that haven't
35 * been updated yet.
36 */
37
38#ifndef smp_rmb
39# define smp_rmb()	rmb()
40#endif
41
42#ifndef smp_wmb
43# define smp_wmb()	wmb()
44#endif
45
46#ifndef smp_mb
47# define smp_mb()	mb()
48#endif
49
50#ifndef smp_store_release
51# define smp_store_release(p, v)		\
52do {						\
53	smp_mb();				\
54	WRITE_ONCE(*p, v);			\
55} while (0)
56#endif
57
58#ifndef smp_load_acquire
59# define smp_load_acquire(p)			\
60({						\
61	typeof(*p) ___p1 = READ_ONCE(*p);	\
62	smp_mb();				\
63	___p1;					\
64})
65#endif
v6.8
 1/* SPDX-License-Identifier: GPL-2.0 */
 2#include <linux/compiler.h>
 3#if defined(__i386__) || defined(__x86_64__)
 4#include "../../arch/x86/include/asm/barrier.h"
 5#elif defined(__arm__)
 6#include "../../arch/arm/include/asm/barrier.h"
 7#elif defined(__aarch64__)
 8#include "../../arch/arm64/include/asm/barrier.h"
 9#elif defined(__powerpc__)
10#include "../../arch/powerpc/include/asm/barrier.h"
11#elif defined(__s390__)
12#include "../../arch/s390/include/asm/barrier.h"
13#elif defined(__sh__)
14#include "../../arch/sh/include/asm/barrier.h"
15#elif defined(__sparc__)
16#include "../../arch/sparc/include/asm/barrier.h"
17#elif defined(__tile__)
18#include "../../arch/tile/include/asm/barrier.h"
19#elif defined(__alpha__)
20#include "../../arch/alpha/include/asm/barrier.h"
21#elif defined(__mips__)
22#include "../../arch/mips/include/asm/barrier.h"
23#elif defined(__ia64__)
24#include "../../arch/ia64/include/asm/barrier.h"
25#elif defined(__xtensa__)
26#include "../../arch/xtensa/include/asm/barrier.h"
 
 
27#else
28#include <asm-generic/barrier.h>
29#endif
30
31/*
32 * Generic fallback smp_*() definitions for archs that haven't
33 * been updated yet.
34 */
35
36#ifndef smp_rmb
37# define smp_rmb()	rmb()
38#endif
39
40#ifndef smp_wmb
41# define smp_wmb()	wmb()
42#endif
43
44#ifndef smp_mb
45# define smp_mb()	mb()
46#endif
47
48#ifndef smp_store_release
49# define smp_store_release(p, v)		\
50do {						\
51	smp_mb();				\
52	WRITE_ONCE(*p, v);			\
53} while (0)
54#endif
55
56#ifndef smp_load_acquire
57# define smp_load_acquire(p)			\
58({						\
59	typeof(*p) ___p1 = READ_ONCE(*p);	\
60	smp_mb();				\
61	___p1;					\
62})
63#endif