tile: support atomic64_dec_if_positive()
authorChris Metcalf <cmetcalf@tilera.com>
Fri, 1 Feb 2013 17:37:48 +0000 (12:37 -0500)
committerChris Metcalf <cmetcalf@tilera.com>
Fri, 22 Mar 2013 19:47:00 +0000 (15:47 -0400)
Use the normal cmpxchg() idiom to implement this functionality.

Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
arch/tile/Kconfig
arch/tile/include/asm/atomic.h

index 0e500d90c2a0c546bc370d36068457979138da19..9a9d08637ab9b56f6af9d52908a999753a6ed6ff 100644 (file)
@@ -24,6 +24,7 @@ config TILE
        select MODULES_USE_ELF_RELA
        select HAVE_ARCH_TRACEHOOK
        select HAVE_SYSCALL_TRACEPOINTS
+       select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
 
 # FIXME: investigate whether we need/want these options.
 #      select HAVE_IOREMAP_PROT
index f2461429a4a4004b474e5024447b4a11200d4fa3..e71387ab20cacce942a3b5742fc1ad1c0ab88cdf 100644 (file)
@@ -131,4 +131,25 @@ static inline int atomic_read(const atomic_t *v)
 #include <asm/atomic_64.h>
 #endif
 
+#ifndef __ASSEMBLY__
+
+static inline long long atomic64_dec_if_positive(atomic64_t *v)
+{
+       long long c, old, dec;
+
+       c = atomic64_read(v);
+       for (;;) {
+               dec = c - 1;
+               if (unlikely(dec < 0))
+                       break;
+               old = atomic64_cmpxchg((v), c, dec);
+               if (likely(old == c))
+                       break;
+               c = old;
+       }
+       return dec;
+}
+
+#endif /* __ASSEMBLY__ */
+
 #endif /* _ASM_TILE_ATOMIC_H */