mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-27 04:54:41 +08:00
52393ccc0a
set_wmb should not be used in the kernel because it just confuses the code more and has no benefit. Since it is not currently used in the kernel this patch removes it so that new code does not include it. All archs define set_wmb(var, value) to do { var = value; wmb(); } while(0) except ia64 and sparc which use a mb() instead. But this is still moot since it is not used anyway. Hasn't been tested on any archs but x86 and x86_64 (and only compiled tested) Signed-off-by: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
34 lines
693 B
C
34 lines
693 B
C
#ifndef __BARRIER_H
|
|
#define __BARRIER_H
|
|
|
|
#include <asm/compiler.h>
|
|
|
|
#define mb() \
|
|
__asm__ __volatile__("mb": : :"memory")
|
|
|
|
#define rmb() \
|
|
__asm__ __volatile__("mb": : :"memory")
|
|
|
|
#define wmb() \
|
|
__asm__ __volatile__("wmb": : :"memory")
|
|
|
|
#define read_barrier_depends() \
|
|
__asm__ __volatile__("mb": : :"memory")
|
|
|
|
#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() barrier()
|
|
#endif
|
|
|
|
#define set_mb(var, value) \
|
|
do { var = value; mb(); } while (0)
|
|
|
|
#endif /* __BARRIER_H */
|