summaryrefslogtreecommitdiffstats
path: root/tools/virtio/asm/barrier.h
blob: 26b7926bda8849a8b931fff6750a3ed8217dae89 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#if defined(__i386__) || defined(__x86_64__)
#define barrier() asm volatile("" ::: "memory")
#define mb() __sync_synchronize()

#define smp_mb()	mb()
# define dma_rmb()	barrier()
# define dma_wmb()	barrier()
# define smp_rmb()	barrier()
# define smp_wmb()	barrier()
/* Weak barriers should be used. If not - it's a bug */
# define rmb()	abort()
# define wmb()	abort()
#else
#error Please fill in barrier macros
#endif