提交 97577896 编写于 作者: L Luca Barbieri 提交者: H. Peter Anvin

lib: Fix atomic64_add_unless return value convention

atomic64_add_unless must return 1 if it perfomed the add and 0 otherwise.
The generic implementation did the opposite thing.
Reported-by: NH. Peter Anvin <hpa@zytor.com>
Confirmed-by: NPaul Mackerras <paulus@samba.org>
Signed-off-by: NLuca Barbieri <luca@luca-barbieri.com>
LKML-Reference: <1267469749-11878-4-git-send-email-luca@luca-barbieri.com>
Signed-off-by: NH. Peter Anvin <hpa@zytor.com>
上级 6e6104fe
...@@ -162,12 +162,12 @@ int atomic64_add_unless(atomic64_t *v, long long a, long long u) ...@@ -162,12 +162,12 @@ int atomic64_add_unless(atomic64_t *v, long long a, long long u)
{ {
unsigned long flags; unsigned long flags;
spinlock_t *lock = lock_addr(v); spinlock_t *lock = lock_addr(v);
int ret = 1; int ret = 0;
spin_lock_irqsave(lock, flags); spin_lock_irqsave(lock, flags);
if (v->counter != u) { if (v->counter != u) {
v->counter += a; v->counter += a;
ret = 0; ret = 1;
} }
spin_unlock_irqrestore(lock, flags); spin_unlock_irqrestore(lock, flags);
return ret; return ret;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册