Commit c47d6a04 authored by Mark Rutland's avatar Mark Rutland Committed by Catalin Marinas

arm64: klib: bitops: fix unpredictable stxr usage

We're currently relying on unpredictable behaviour in our testops
(test_and_*_bit), as stxr is unpredictable when the status register and
the source register are the same

This patch changes reallocates the status register so as to bring us back into
the realm of predictable behaviour. Boot tested on an AEMv8 model.
Signed-off-by: default avatarMark Rutland <mark.rutland@arm.com>
Signed-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
parent 1ae90e79
...@@ -50,8 +50,8 @@ ENTRY( \name ) ...@@ -50,8 +50,8 @@ ENTRY( \name )
1: ldxr x2, [x1] 1: ldxr x2, [x1]
lsr x0, x2, x3 // Save old value of bit lsr x0, x2, x3 // Save old value of bit
\instr x2, x2, x4 // toggle bit \instr x2, x2, x4 // toggle bit
stxr w2, x2, [x1] stxr w5, x2, [x1]
cbnz w2, 1b cbnz w5, 1b
smp_dmb ish smp_dmb ish
and x0, x0, #1 and x0, x0, #1
3: ret 3: ret
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment