Commit-ID:  da4c54457e6d8262423aded4bcbccc4103049506
Gitweb:     http://git.kernel.org/tip/da4c54457e6d8262423aded4bcbccc4103049506
Author:     Peter Zijlstra <pet...@infradead.org>
AuthorDate: Tue, 2 Sep 2014 22:21:26 +0200
Committer:  Ingo Molnar <mi...@kernel.org>
CommitDate: Wed, 10 Sep 2014 11:45:06 +0200

locking, mips: Fix atomics

The patch folding the atomic ops had two silly fails in the _return
primitives.

Fixes: ef31563e950c ("locking,arch,mips: Fold atomic_ops")
Reported-by: Guenter Roeck <li...@roeck-us.net>
Tested-by: Guenter Roeck <li...@roeck-us.net>
Signed-off-by: Peter Zijlstra (Intel) <pet...@infradead.org>
Cc: Bart Van Assche <bvanass...@acm.org>
Cc: Hannes Reinecke <h...@suse.de>
Cc: Linus Torvalds <torva...@linux-foundation.org>
Cc: Maciej W. Rozycki <ma...@codesourcery.com>
Cc: Markos Chandras <markos.chand...@imgtec.com>
Cc: Paul Burton <paul.bur...@imgtec.com>
Cc: Paul E. McKenney <paul...@linux.vnet.ibm.com>
Cc: Ralf Baechle <r...@linux-mips.org>
Cc: Stephen Rothwell <s...@canb.auug.org.au>
Link: http://lkml.kernel.org/r/20140902202126.ga3...@worktop.ger.corp.intel.com
Signed-off-by: Ingo Molnar <mi...@kernel.org>
---
 arch/mips/include/asm/atomic.h | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)

diff --git a/arch/mips/include/asm/atomic.h b/arch/mips/include/asm/atomic.h
index 476fe3b..f3ee721 100644
--- a/arch/mips/include/asm/atomic.h
+++ b/arch/mips/include/asm/atomic.h
@@ -93,7 +93,7 @@ static __inline__ int atomic_##op##_return(int i, atomic_t * 
v)                       \
                "       " #asm_op " %0, %1, %3                          \n"     
\
                "       sc      %0, %2                                  \n"     
\
                "       beqzl   %0, 1b                                  \n"     
\
-               "       addu    %0, %1, %3                              \n"     
\
+               "       " #asm_op " %0, %1, %3                          \n"     
\
                "       .set    mips0                                   \n"     
\
                : "=&r" (result), "=&r" (temp), "+m" (v->counter)               
\
                : "Ir" (i));                                                    
\
@@ -111,7 +111,7 @@ static __inline__ int atomic_##op##_return(int i, atomic_t 
* v)                     \
                        : "Ir" (i));                                            
\
                } while (unlikely(!result));                                    
\
                                                                                
\
-               result = temp + i;                                              
\
+               result = temp; result c_op i;                                   
\
        } else {                                                                
\
                unsigned long flags;                                            
\
                                                                                
\
@@ -387,7 +387,7 @@ static __inline__ long atomic64_##op##_return(long i, 
atomic64_t * v)               \
                        : "memory");                                            
\
                } while (unlikely(!result));                                    
\
                                                                                
\
-               result = temp + i;                                              
\
+               result = temp; result c_op i;                                   
\
        } else {                                                                
\
                unsigned long flags;                                            
\
                                                                                
\
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to