diff options
| author | Arun Sharma <asharma@fb.com> | 2011-07-26 19:09:07 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-07-26 19:49:47 -0400 |
| commit | f24219b4e90cf70ec4a211b17fbabc725a0ddf3c (patch) | |
| tree | c1c753bd425d61a5094995d9835b23b46383d9b2 /arch/mips/include/asm | |
| parent | 60063497a95e716c9a689af3be2687d261f115b4 (diff) | |
atomic: move atomic_add_unless to generic code
This is in preparation for more generic atomic primitives based on
__atomic_add_unless.
Signed-off-by: Arun Sharma <asharma@fb.com>
Signed-off-by: Hans-Christian Egtvedt <hans-christian.egtvedt@atmel.com>
Reviewed-by: Eric Dumazet <eric.dumazet@gmail.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: David Miller <davem@davemloft.net>
Acked-by: Mike Frysinger <vapier@gentoo.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/mips/include/asm')
| -rw-r--r-- | arch/mips/include/asm/atomic.h | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/arch/mips/include/asm/atomic.h b/arch/mips/include/asm/atomic.h index 833a4023648a..31cb23debb7e 100644 --- a/arch/mips/include/asm/atomic.h +++ b/arch/mips/include/asm/atomic.h | |||
| @@ -303,15 +303,15 @@ static __inline__ int atomic_sub_if_positive(int i, atomic_t * v) | |||
| 303 | #define atomic_xchg(v, new) (xchg(&((v)->counter), (new))) | 303 | #define atomic_xchg(v, new) (xchg(&((v)->counter), (new))) |
| 304 | 304 | ||
| 305 | /** | 305 | /** |
| 306 | * atomic_add_unless - add unless the number is a given value | 306 | * __atomic_add_unless - add unless the number is a given value |
| 307 | * @v: pointer of type atomic_t | 307 | * @v: pointer of type atomic_t |
| 308 | * @a: the amount to add to v... | 308 | * @a: the amount to add to v... |
| 309 | * @u: ...unless v is equal to u. | 309 | * @u: ...unless v is equal to u. |
| 310 | * | 310 | * |
| 311 | * Atomically adds @a to @v, so long as it was not @u. | 311 | * Atomically adds @a to @v, so long as it was not @u. |
| 312 | * Returns non-zero if @v was not @u, and zero otherwise. | 312 | * Returns the old value of @v. |
| 313 | */ | 313 | */ |
| 314 | static __inline__ int atomic_add_unless(atomic_t *v, int a, int u) | 314 | static __inline__ int __atomic_add_unless(atomic_t *v, int a, int u) |
| 315 | { | 315 | { |
| 316 | int c, old; | 316 | int c, old; |
| 317 | c = atomic_read(v); | 317 | c = atomic_read(v); |
| @@ -323,7 +323,7 @@ static __inline__ int atomic_add_unless(atomic_t *v, int a, int u) | |||
| 323 | break; | 323 | break; |
| 324 | c = old; | 324 | c = old; |
| 325 | } | 325 | } |
| 326 | return c != (u); | 326 | return c; |
| 327 | } | 327 | } |
| 328 | 328 | ||
| 329 | #define atomic_dec_return(v) atomic_sub_return(1, (v)) | 329 | #define atomic_dec_return(v) atomic_sub_return(1, (v)) |
| @@ -679,7 +679,7 @@ static __inline__ long atomic64_sub_if_positive(long i, atomic64_t * v) | |||
| 679 | * @u: ...unless v is equal to u. | 679 | * @u: ...unless v is equal to u. |
| 680 | * | 680 | * |
| 681 | * Atomically adds @a to @v, so long as it was not @u. | 681 | * Atomically adds @a to @v, so long as it was not @u. |
| 682 | * Returns non-zero if @v was not @u, and zero otherwise. | 682 | * Returns the old value of @v. |
| 683 | */ | 683 | */ |
| 684 | static __inline__ int atomic64_add_unless(atomic64_t *v, long a, long u) | 684 | static __inline__ int atomic64_add_unless(atomic64_t *v, long a, long u) |
| 685 | { | 685 | { |
