CPU/PGXP: Don't force valid input on slt/sltu

This commit is contained in:
Stenzek 2024-07-09 19:28:32 +10:00
parent 3b7844be5a
commit d922a43127
No known key found for this signature in database
1 changed files with 10 additions and 24 deletions

View File

@ -1157,20 +1157,13 @@ void CPU::PGXP::CPU_SLT(u32 instr, u32 rsVal, u32 rtVal)
Validate(&prsVal, rsVal); Validate(&prsVal, rsVal);
Validate(&prtVal, rtVal); Validate(&prtVal, rtVal);
// iCB: Only require one valid input
if (((prtVal.flags & VALID_XY) != VALID_XY) != ((prsVal.flags & VALID_XY) != VALID_XY))
{
MakeValid(&prsVal, rsVal);
MakeValid(&prtVal, rtVal);
}
PGXP_value ret = prsVal; PGXP_value ret = prsVal;
ret.x = (prsVal.GetValidY(rsVal) < prtVal.GetValidY(rtVal) ||
f16Unsign(prsVal.GetValidX(rsVal)) < f16Unsign(prtVal.GetValidX(rtVal))) ?
1.f :
0.f;
ret.y = 0.f; ret.y = 0.f;
ret.SetValid(COMP_Y); ret.flags |= VALID_TAINTED_Z | VALID_X | VALID_Y;
ret.flags |= VALID_TAINTED_Z;
ret.x = (prsVal.y < prtVal.y) ? 1.f : (f16Unsign(prsVal.x) < f16Unsign(prtVal.x)) ? 1.f : 0.f;
ret.value = BoolToUInt32(static_cast<s32>(rsVal) < static_cast<s32>(rtVal)); ret.value = BoolToUInt32(static_cast<s32>(rsVal) < static_cast<s32>(rtVal));
g_state.pgxp_gpr[rd(instr)] = ret; g_state.pgxp_gpr[rd(instr)] = ret;
} }
@ -1185,20 +1178,13 @@ void CPU::PGXP::CPU_SLTU(u32 instr, u32 rsVal, u32 rtVal)
Validate(&prsVal, rsVal); Validate(&prsVal, rsVal);
Validate(&prtVal, rtVal); Validate(&prtVal, rtVal);
// iCB: Only require one valid input
if (((prtVal.flags & VALID_XY) != VALID_XY) != ((prsVal.flags & VALID_XY) != VALID_XY))
{
MakeValid(&prsVal, rsVal);
MakeValid(&prtVal, rtVal);
}
PGXP_value ret = prsVal; PGXP_value ret = prsVal;
ret.x = (f16Unsign(prsVal.GetValidY(rsVal)) < f16Unsign(prtVal.GetValidY(rtVal)) ||
f16Unsign(prsVal.GetValidX(rsVal)) < f16Unsign(prtVal.GetValidX(rtVal))) ?
1.f :
0.f;
ret.y = 0.f; ret.y = 0.f;
ret.SetValid(COMP_Y); ret.flags |= VALID_TAINTED_Z | VALID_X | VALID_Y;
ret.flags |= VALID_TAINTED_Z;
ret.x = (f16Unsign(prsVal.y) < f16Unsign(prtVal.y)) ? 1.f : (f16Unsign(prsVal.x) < f16Unsign(prtVal.x)) ? 1.f : 0.f;
ret.value = BoolToUInt32(rsVal < rtVal); ret.value = BoolToUInt32(rsVal < rtVal);
g_state.pgxp_gpr[rd(instr)] = ret; g_state.pgxp_gpr[rd(instr)] = ret;
} }