Fix ARMv7 JIT from XER optimization.

This was a subtle bug I introduced since I removed a LDR in one of the ComputeCarry functions.
Basically since I wasn't loading the XER value prior to operations when I did a BIC tmp, tmp, 1 it would clear the first bit in our temp register but
retain the rest of the "random" data from that temp register. This would then save in to xer_ca, which the Interpreter will use later without any
masking to generate the XER value. Our XER generation helper functions don't do any masking since they were only expecting a single bit worth of data
in xer_ca with the rest being zero.
So now we only have one bit of data being stored in xer_ca from the ARMv7 JIT recompiler, and also a slight optimization in the ComputeCarry function
that is used on the immediate path. There wasn't any reason to load xer_ca since it only contains one bit of data now.
This commit is contained in:
Ryan Houdek 2014-10-07 21:43:15 -05:00
parent 38b64fd077
commit 5f0011d065
1 changed files with 4 additions and 5 deletions

View File

@ -47,9 +47,9 @@ void JitArm::ComputeCarry()
{ {
ARMReg tmp = gpr.GetReg(); ARMReg tmp = gpr.GetReg();
SetCC(CC_CS); SetCC(CC_CS);
ORR(tmp, tmp, 1); MOV(tmp, 1);
SetCC(CC_CC); SetCC(CC_CC);
BIC(tmp, tmp, 1); EOR(tmp, tmp, tmp);
SetCC(); SetCC();
STRB(tmp, R9, PPCSTATE_OFF(xer_ca)); STRB(tmp, R9, PPCSTATE_OFF(xer_ca));
gpr.Unlock(tmp); gpr.Unlock(tmp);
@ -58,11 +58,10 @@ void JitArm::ComputeCarry()
void JitArm::ComputeCarry(bool Carry) void JitArm::ComputeCarry(bool Carry)
{ {
ARMReg tmp = gpr.GetReg(); ARMReg tmp = gpr.GetReg();
LDRB(tmp, R9, PPCSTATE_OFF(xer_ca));
if (Carry) if (Carry)
ORR(tmp, tmp, 1); MOV(tmp, 1);
else else
BIC(tmp, tmp, 1); EOR(tmp, tmp, tmp);
STRB(tmp, R9, PPCSTATE_OFF(xer_ca)); STRB(tmp, R9, PPCSTATE_OFF(xer_ca));
gpr.Unlock(tmp); gpr.Unlock(tmp);
} }