X-Git-Url: https://git.lttng.org/?a=blobdiff_plain;f=arch_atomic_ppc.h;h=5d36cfb76bda0099924554798d66ad392596d988;hb=834a45ba9dc8fcb5c6c51e81674bd2db3bdc2df0;hp=16ddc012302dd397038c71da6b2f96cc817e21ff;hpb=5f8052b4e0acf2de0d3a143b82549d78413b29ab;p=urcu.git diff --git a/arch_atomic_ppc.h b/arch_atomic_ppc.h index 16ddc01..5d36cfb 100644 --- a/arch_atomic_ppc.h +++ b/arch_atomic_ppc.h @@ -52,8 +52,8 @@ do { \ /* xchg */ -static __attribute__((always_inline)) -unsigned long _atomic_exchange(volatile void *addr, unsigned long val, int len) +static inline __attribute__((always_inline)) +unsigned long _atomic_exchange(void *addr, unsigned long val, int len) { switch (len) { case 4: @@ -97,13 +97,13 @@ unsigned long _atomic_exchange(volatile void *addr, unsigned long val, int len) return 0; } -#define xchg(addr, v) (__typeof__(*(addr))) _atomic_exchange((addr), (v), \ - sizeof(*(addr))) - +#define xchg(addr, v) \ + ((__typeof__(*(addr))) _atomic_exchange((addr), (unsigned long)(v), \ + sizeof(*(addr)))) /* cmpxchg */ -static __attribute__((always_inline)) -unsigned long _atomic_cmpxchg(volatile void *addr, unsigned long old, +static inline __attribute__((always_inline)) +unsigned long _atomic_cmpxchg(void *addr, unsigned long old, unsigned long _new, int len) { switch (len) { @@ -120,7 +120,7 @@ unsigned long _atomic_cmpxchg(volatile void *addr, unsigned long old, "bne- 1b\n" /* retry if lost reservation */ "isync\n" "2:\n" - : "=&r"(old_val), + : "=&r"(old_val) : "r"(addr), "r"((unsigned int)_new), "r"((unsigned int)old) : "memory", "cc"); @@ -156,14 +156,16 @@ unsigned long _atomic_cmpxchg(volatile void *addr, unsigned long old, return 0; } -#define cmpxchg(addr, old, _new) \ - (__typeof__(*(addr))) _atomic_cmpxchg((addr), (old), (_new), \ - sizeof(*(addr))) + +#define cmpxchg(addr, old, _new) \ + ((__typeof__(*(addr))) _atomic_cmpxchg((addr), (unsigned long)(old),\ + (unsigned long)(_new), \ + sizeof(*(addr)))) /* atomic_add_return */ -static __attribute__((always_inline)) -unsigned long _atomic_add_return(volatile void *addr, unsigned long val, +static inline __attribute__((always_inline)) +unsigned long _atomic_add_return(void *addr, unsigned long val, int len) { switch (len) { @@ -210,8 +212,11 @@ unsigned long _atomic_add_return(volatile void *addr, unsigned long val, return 0; } -#define atomic_add_return(addr, v) \ - (__typeof__(*(addr))) _atomic_add((addr), (v), sizeof(*(addr))) + +#define atomic_add_return(addr, v) \ + ((__typeof__(*(addr))) _atomic_add_return((addr), \ + (unsigned long)(v), \ + sizeof(*(addr)))) /* atomic_sub_return, atomic_add, atomic_sub, atomic_inc, atomic_dec */