X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=include%2Fasm-m68k%2Fatomic.h;h=4915294fea63a726cb901ec1799ed9e7bc4586f9;hb=681e14730c73cc2c71af282c001de6bc71c22f00;hp=862e497c26453070674af81cd0786f5d1c5ad30d;hpb=fd4a0b92db6a57cba8d03efbe1cebf91f9124ce0;p=powerpc.git diff --git a/include/asm-m68k/atomic.h b/include/asm-m68k/atomic.h index 862e497c26..4915294fea 100644 --- a/include/asm-m68k/atomic.h +++ b/include/asm-m68k/atomic.h @@ -1,9 +1,8 @@ #ifndef __ARCH_M68K_ATOMIC__ #define __ARCH_M68K_ATOMIC__ -#include -#include /* local_irq_XXX() */ +#include /* * Atomic operations that C can't guarantee us. Useful for @@ -171,14 +170,21 @@ static inline void atomic_set_mask(unsigned long mask, unsigned long *v) __asm__ __volatile__("orl %1,%0" : "+m" (*v) : "id" (mask)); } -#define atomic_add_unless(v, a, u) \ -({ \ - int c, old; \ - c = atomic_read(v); \ - while (c != (u) && (old = atomic_cmpxchg((v), c, c + (a))) != c) \ - c = old; \ - c != (u); \ -}) +static __inline__ int atomic_add_unless(atomic_t *v, int a, int u) +{ + int c, old; + c = atomic_read(v); + for (;;) { + if (unlikely(c == (u))) + break; + old = atomic_cmpxchg((v), c, c + (a)); + if (likely(old == c)) + break; + c = old; + } + return c != (u); +} + #define atomic_inc_not_zero(v) atomic_add_unless((v), 1, 0) /* Atomic operations are already serializing */