arm64: compat: fix stxr failure case in SWP emulation
If the STXR instruction fails in the SWP emulation code, we leave *data
overwritten with the loaded value, therefore corrupting the data written
by a subsequent, successful attempt.
This patch re-jigs the code so that we only write back to *data once we
know that the update has happened.
Cc: <stable@vger.kernel.org>
Fixes: bd35a4adc4
("arm64: Port SWP/SWPB emulation support from arm")
Reported-by: Shengjiu Wang <shengjiu.wang@freescale.com>
Reported-by: Vladimir Murzin <vladimir.murzin@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
This commit is contained in:
parent
32b88194f7
commit
589cb22bbe
1 changed files with 9 additions and 7 deletions
|
@ -284,21 +284,23 @@ static void register_insn_emulation_sysctl(struct ctl_table *table)
|
||||||
__asm__ __volatile__( \
|
__asm__ __volatile__( \
|
||||||
ALTERNATIVE("nop", SET_PSTATE_PAN(0), ARM64_HAS_PAN, \
|
ALTERNATIVE("nop", SET_PSTATE_PAN(0), ARM64_HAS_PAN, \
|
||||||
CONFIG_ARM64_PAN) \
|
CONFIG_ARM64_PAN) \
|
||||||
" mov %w2, %w1\n" \
|
"0: ldxr"B" %w2, [%3]\n" \
|
||||||
"0: ldxr"B" %w1, [%3]\n" \
|
"1: stxr"B" %w0, %w1, [%3]\n" \
|
||||||
"1: stxr"B" %w0, %w2, [%3]\n" \
|
|
||||||
" cbz %w0, 2f\n" \
|
" cbz %w0, 2f\n" \
|
||||||
" mov %w0, %w4\n" \
|
" mov %w0, %w4\n" \
|
||||||
|
" b 3f\n" \
|
||||||
"2:\n" \
|
"2:\n" \
|
||||||
|
" mov %w1, %w2\n" \
|
||||||
|
"3:\n" \
|
||||||
" .pushsection .fixup,\"ax\"\n" \
|
" .pushsection .fixup,\"ax\"\n" \
|
||||||
" .align 2\n" \
|
" .align 2\n" \
|
||||||
"3: mov %w0, %w5\n" \
|
"4: mov %w0, %w5\n" \
|
||||||
" b 2b\n" \
|
" b 3b\n" \
|
||||||
" .popsection" \
|
" .popsection" \
|
||||||
" .pushsection __ex_table,\"a\"\n" \
|
" .pushsection __ex_table,\"a\"\n" \
|
||||||
" .align 3\n" \
|
" .align 3\n" \
|
||||||
" .quad 0b, 3b\n" \
|
" .quad 0b, 4b\n" \
|
||||||
" .quad 1b, 3b\n" \
|
" .quad 1b, 4b\n" \
|
||||||
" .popsection\n" \
|
" .popsection\n" \
|
||||||
ALTERNATIVE("nop", SET_PSTATE_PAN(1), ARM64_HAS_PAN, \
|
ALTERNATIVE("nop", SET_PSTATE_PAN(1), ARM64_HAS_PAN, \
|
||||||
CONFIG_ARM64_PAN) \
|
CONFIG_ARM64_PAN) \
|
||||||
|
|
Loading…
Reference in a new issue