diff options
author | Mark Rutland <mark.rutland@arm.com> | 2013-04-30 06:11:15 -0400 |
---|---|---|
committer | Catalin Marinas <catalin.marinas@arm.com> | 2013-04-30 10:53:01 -0400 |
commit | c47d6a04e6ed22ccc5d89aaf2a136bf4971de310 (patch) | |
tree | 93e33762f824a13ff3a9abdee0fb499db0d1dfc9 /arch/arm64/lib | |
parent | 1ae90e79051318c34d5a75c2ef5b9a55bd22f2ed (diff) |
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: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
Diffstat (limited to 'arch/arm64/lib')
-rw-r--r-- | arch/arm64/lib/bitops.S | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/arm64/lib/bitops.S b/arch/arm64/lib/bitops.S index fd1e801b53e7..eaed8bbd78fc 100644 --- a/arch/arm64/lib/bitops.S +++ b/arch/arm64/lib/bitops.S | |||
@@ -50,8 +50,8 @@ ENTRY( \name ) | |||
50 | 1: ldxr x2, [x1] | 50 | 1: ldxr x2, [x1] |
51 | lsr x0, x2, x3 // Save old value of bit | 51 | lsr x0, x2, x3 // Save old value of bit |
52 | \instr x2, x2, x4 // toggle bit | 52 | \instr x2, x2, x4 // toggle bit |
53 | stxr w2, x2, [x1] | 53 | stxr w5, x2, [x1] |
54 | cbnz w2, 1b | 54 | cbnz w5, 1b |
55 | smp_dmb ish | 55 | smp_dmb ish |
56 | and x0, x0, #1 | 56 | and x0, x0, #1 |
57 | 3: ret | 57 | 3: ret |