X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=include%2Fasm-arm%2Fatomic.h;h=4b0ce3e7de9a4267088ab585e46232214b139879;hb=977e6b9f3a9b17f1c608a9d1e5a7b5c46a5f7d4a;hp=75b802719723ad459d719b6f598254fe0dfe02e4;hpb=8426e1f6af0fd7f44d040af7263750c5a52f3cc3;p=linux-2.6 diff --git a/include/asm-arm/atomic.h b/include/asm-arm/atomic.h index 75b8027197..4b0ce3e7de 100644 --- a/include/asm-arm/atomic.h +++ b/include/asm-arm/atomic.h @@ -11,7 +11,7 @@ #ifndef __ASM_ARM_ATOMIC_H #define __ASM_ARM_ATOMIC_H -#include +#include typedef struct { volatile int counter; } atomic_t; @@ -82,11 +82,12 @@ static inline int atomic_sub_return(int i, atomic_t *v) static inline int atomic_cmpxchg(atomic_t *ptr, int old, int new) { - u32 oldval, res; + unsigned long oldval, res; do { __asm__ __volatile__("@ atomic_cmpxchg\n" "ldrex %1, [%2]\n" + "mov %0, #0\n" "teq %1, %3\n" "strexeq %0, %4, [%2]\n" : "=&r" (res), "=&r" (oldval) @@ -173,6 +174,8 @@ static inline void atomic_clear_mask(unsigned long mask, unsigned long *addr) #endif /* __LINUX_ARM_ARCH__ */ +#define atomic_xchg(v, new) (xchg(&((v)->counter), new)) + static inline int atomic_add_unless(atomic_t *v, int a, int u) { int c, old; @@ -203,5 +206,6 @@ static inline int atomic_add_unless(atomic_t *v, int a, int u) #define smp_mb__before_atomic_inc() barrier() #define smp_mb__after_atomic_inc() barrier() +#include #endif #endif