forked from Minki/linux
arch,arm: Convert smp_mb__*()
ARM uses ll/sc primitives that do not imply barriers for all regular atomic ops, therefore smp_mb__{before,after} need be a full barrier. Since ARM doesn't use asm-generic/barrier.h include the required definitions in its asm/barrier.h Signed-off-by: Peter Zijlstra <peterz@infradead.org> Acked-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Link: http://lkml.kernel.org/n/tip-yijo7sglsl7uusbp13upcuvo@git.kernel.org Cc: Albin Tonnerre <albin.tonnerre@arm.com> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Chen Gang <gang.chen@asianux.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Nicolas Pitre <nico@linaro.org> Cc: Russell King <linux@arm.linux.org.uk> Cc: Victor Kamensky <victor.kamensky@linaro.org> Cc: Will Deacon <will.deacon@arm.com> Cc: linux-arm-kernel@lists.infradead.org Cc: linux-kernel@vger.kernel.org Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
d594ffa94b
commit
030d0178bd
@ -241,11 +241,6 @@ static inline int __atomic_add_unless(atomic_t *v, int a, int u)
|
|||||||
|
|
||||||
#define atomic_add_negative(i,v) (atomic_add_return(i, v) < 0)
|
#define atomic_add_negative(i,v) (atomic_add_return(i, v) < 0)
|
||||||
|
|
||||||
#define smp_mb__before_atomic_dec() smp_mb()
|
|
||||||
#define smp_mb__after_atomic_dec() smp_mb()
|
|
||||||
#define smp_mb__before_atomic_inc() smp_mb()
|
|
||||||
#define smp_mb__after_atomic_inc() smp_mb()
|
|
||||||
|
|
||||||
#ifndef CONFIG_GENERIC_ATOMIC64
|
#ifndef CONFIG_GENERIC_ATOMIC64
|
||||||
typedef struct {
|
typedef struct {
|
||||||
long long counter;
|
long long counter;
|
||||||
|
@ -79,5 +79,8 @@ do { \
|
|||||||
|
|
||||||
#define set_mb(var, value) do { var = value; smp_mb(); } while (0)
|
#define set_mb(var, value) do { var = value; smp_mb(); } while (0)
|
||||||
|
|
||||||
|
#define smp_mb__before_atomic() smp_mb()
|
||||||
|
#define smp_mb__after_atomic() smp_mb()
|
||||||
|
|
||||||
#endif /* !__ASSEMBLY__ */
|
#endif /* !__ASSEMBLY__ */
|
||||||
#endif /* __ASM_BARRIER_H */
|
#endif /* __ASM_BARRIER_H */
|
||||||
|
@ -25,9 +25,7 @@
|
|||||||
|
|
||||||
#include <linux/compiler.h>
|
#include <linux/compiler.h>
|
||||||
#include <linux/irqflags.h>
|
#include <linux/irqflags.h>
|
||||||
|
#include <asm/barrier.h>
|
||||||
#define smp_mb__before_clear_bit() smp_mb()
|
|
||||||
#define smp_mb__after_clear_bit() smp_mb()
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* These functions are the basis of our bit ops.
|
* These functions are the basis of our bit ops.
|
||||||
|
Loading…
Reference in New Issue
Block a user