summaryrefslogtreecommitdiff
path: root/arch/cris/include/asm/barrier.h
blob: 198ad7fa6b25aee9434f09e4ba92e97c32e1a817 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#ifndef __ASM_CRIS_BARRIER_H
#define __ASM_CRIS_BARRIER_H

#define nop() __asm__ __volatile__ ("nop");

#define barrier() __asm__ __volatile__("": : :"memory")
#define mb() barrier()
#define rmb() mb()
#define wmb() mb()
#define read_barrier_depends() do { } while(0)
#define set_mb(var, value)  do { var = value; mb(); } while (0)

#ifdef CONFIG_SMP
#define smp_mb()        mb()
#define smp_rmb()       rmb()
#define smp_wmb()       wmb()
#define smp_read_barrier_depends()     read_barrier_depends()
#else
#define smp_mb()        barrier()
#define smp_rmb()       barrier()
#define smp_wmb()       barrier()
#define smp_read_barrier_depends()     do { } while(0)
#endif

#endif /* __ASM_CRIS_BARRIER_H */