]> git.baikalelectronics.ru Git - kernel.git/commit
metag: Fix atomic_*_return inline asm constraints
authorJames Hogan <james.hogan@imgtec.com>
Tue, 3 May 2016 08:11:21 +0000 (09:11 +0100)
committerJames Hogan <james.hogan@imgtec.com>
Tue, 3 May 2016 08:25:46 +0000 (09:25 +0100)
commitd41306c8937755df42a7ef743a6af31e697aa13e
treee6051225686d798abd3e841f6575c6a920ce1a14
parent121361321ce75f335fd4d6bb10a7bdde76852b82
metag: Fix atomic_*_return inline asm constraints

The argument i of atomic_*_return() operations is given to inline asm
with the "bd" constraint, which means "An Op2 register where Op1 is a
data unit register and the instruction supports O2R", however Op1 is
constrained by "da" which allows an address unit register to be used.

Fix the constraint to use "br", meaning "An Op2 register and the
instruction supports O2R", i.e. not requiring Op1 to be a data unit
register.

Fixes: 31f392ca252a ("locking,arch,metag: Fold atomic_ops")
Signed-off-by: James Hogan <james.hogan@imgtec.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: linux-metag@vger.kernel.org
arch/metag/include/asm/atomic_lnkget.h