]> pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - include/asm-arm26/atomic.h
Merge branch 'master'
[linux-2.6-omap-h63xx.git] / include / asm-arm26 / atomic.h
index 54b24ead7132520692d54ea45eec9329780b3e12..a47cadc59686237260877f1874b2c18ff0ed9421 100644 (file)
@@ -76,6 +76,21 @@ static inline int atomic_cmpxchg(atomic_t *v, int old, int new)
        return ret;
 }
 
+static inline int atomic_add_unless(atomic_t *v, int a, int u)
+{
+       int ret;
+       unsigned long flags;
+
+       local_irq_save(flags);
+       ret = v->counter;
+       if (ret != u)
+               v->counter += a;
+       local_irq_restore(flags);
+
+       return ret != u;
+}
+#define atomic_inc_not_zero(v) atomic_add_unless((v), 1, 0)
+
 static inline void atomic_clear_mask(unsigned long mask, unsigned long *addr)
 {
         unsigned long flags;