JitArm64: Add additional condition for lmw/stmw a discard

If a is one of the registers that will be loaded/stored, we must not
discard it early. Sorry for this fixup of a fixup...
This commit is contained in:
JosJuice 2023-12-10 19:13:35 +01:00
parent db1620db42
commit 0ec12f9e7e
1 changed files with 2 additions and 2 deletions

View File

@ -549,7 +549,7 @@ void JitArm64::lmw(UGeckoInstruction inst)
{ {
if (a_is_addr_base_reg) if (a_is_addr_base_reg)
gprs_to_discard[a] = false; gprs_to_discard[a] = false;
else else if (a < d)
gpr.DiscardRegisters(BitSet32{int(a)}); gpr.DiscardRegisters(BitSet32{int(a)});
} }
} }
@ -666,7 +666,7 @@ void JitArm64::stmw(UGeckoInstruction inst)
{ {
if (a_is_addr_base_reg) if (a_is_addr_base_reg)
gprs_to_discard[a] = false; gprs_to_discard[a] = false;
else else if (a < s)
gpr.DiscardRegisters(BitSet32{int(a)}); gpr.DiscardRegisters(BitSet32{int(a)});
} }
} }