blob: dc696c151e1c03cca0d54699abb542cb77026f68 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Daniel Borkmann09d621542018-10-19 15:51:02 +02002#include <linux/compiler.h>
Arnaldo Carvalho de Melo361c5642015-04-30 12:33:22 -03003#if defined(__i386__) || defined(__x86_64__)
4#include "../../arch/x86/include/asm/barrier.h"
Arnaldo Carvalho de Melo4f3db072015-05-07 18:14:25 -03005#elif defined(__arm__)
6#include "../../arch/arm/include/asm/barrier.h"
7#elif defined(__aarch64__)
8#include "../../arch/arm64/include/asm/barrier.h"
Arnaldo Carvalho de Meloe43a19c2015-05-06 18:35:20 -03009#elif defined(__powerpc__)
10#include "../../arch/powerpc/include/asm/barrier.h"
Arnaldo Carvalho de Melo07d207a2015-05-06 18:44:53 -030011#elif defined(__s390__)
12#include "../../arch/s390/include/asm/barrier.h"
Arnaldo Carvalho de Melo827634a2015-05-07 17:09:48 -030013#elif defined(__sh__)
14#include "../../arch/sh/include/asm/barrier.h"
Arnaldo Carvalho de Melo94cdda62015-05-07 17:27:23 -030015#elif defined(__sparc__)
16#include "../../arch/sparc/include/asm/barrier.h"
Arnaldo Carvalho de Melod3bd7082015-05-08 10:02:00 -030017#elif defined(__tile__)
18#include "../../arch/tile/include/asm/barrier.h"
Arnaldo Carvalho de Melo0da85d12015-05-07 17:52:19 -030019#elif defined(__alpha__)
20#include "../../arch/alpha/include/asm/barrier.h"
Arnaldo Carvalho de Meloe2164f02015-05-08 09:40:36 -030021#elif defined(__mips__)
22#include "../../arch/mips/include/asm/barrier.h"
Arnaldo Carvalho de Melo163e5892015-05-07 18:03:14 -030023#elif defined(__ia64__)
24#include "../../arch/ia64/include/asm/barrier.h"
Arnaldo Carvalho de Melo3d3337d2015-05-08 08:53:26 -030025#elif defined(__xtensa__)
26#include "../../arch/xtensa/include/asm/barrier.h"
Nickhuebd09752018-10-25 10:24:15 +080027#elif defined(__nds32__)
28#include "../../arch/nds32/include/asm/barrier.h"
Arnaldo Carvalho de Melo42b09d72015-05-07 17:17:17 -030029#else
30#include <asm-generic/barrier.h>
Arnaldo Carvalho de Melo361c5642015-04-30 12:33:22 -030031#endif
Daniel Borkmann09d621542018-10-19 15:51:02 +020032
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