tcg/ppc: Use TCG_REG_TMP2 for scratch tcg_out_qemu_st
In the fallback when STDBRX is not available, avoid clobbering
TCG_REG_TMP1, which might be h.base, which is still in use.
Use TCG_REG_TMP2 instead.
Cc: qemu-stable@nongnu.org
Fixes: 01a112e2e9
("tcg/ppc: Reorg tcg_out_tlb_read")
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Tested-By: Michael Tokarev <mjt@tls.msk.ru>
This commit is contained in:
parent
124e769083
commit
4cabcb89b1
@ -2704,9 +2704,9 @@ static void tcg_out_qemu_st(TCGContext *s, TCGReg datalo, TCGReg datahi,
|
|||||||
uint32_t insn = qemu_stx_opc[opc & (MO_BSWAP | MO_SIZE)];
|
uint32_t insn = qemu_stx_opc[opc & (MO_BSWAP | MO_SIZE)];
|
||||||
if (!have_isa_2_06 && insn == STDBRX) {
|
if (!have_isa_2_06 && insn == STDBRX) {
|
||||||
tcg_out32(s, STWBRX | SAB(datalo, h.base, h.index));
|
tcg_out32(s, STWBRX | SAB(datalo, h.base, h.index));
|
||||||
tcg_out32(s, ADDI | TAI(TCG_REG_TMP1, h.index, 4));
|
tcg_out32(s, ADDI | TAI(TCG_REG_TMP2, h.index, 4));
|
||||||
tcg_out_shri64(s, TCG_REG_R0, datalo, 32);
|
tcg_out_shri64(s, TCG_REG_R0, datalo, 32);
|
||||||
tcg_out32(s, STWBRX | SAB(TCG_REG_R0, h.base, TCG_REG_TMP1));
|
tcg_out32(s, STWBRX | SAB(TCG_REG_R0, h.base, TCG_REG_TMP2));
|
||||||
} else {
|
} else {
|
||||||
tcg_out32(s, insn | SAB(datalo, h.base, h.index));
|
tcg_out32(s, insn | SAB(datalo, h.base, h.index));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user