CPU/PGXP: Rewrite SLTI/SLTIU handlers

Don't read uninitialized memory...
This commit is contained in:
Stenzek 2024-07-09 20:14:07 +10:00
parent d922a43127
commit f0e2d1a9fa
No known key found for this signature in database
1 changed files with 20 additions and 19 deletions

View File

@ -888,18 +888,18 @@ void CPU::PGXP::CPU_SLTI(u32 instr, u32 rsVal)
LOG_VALUES_C1(rs(instr), rsVal); LOG_VALUES_C1(rs(instr), rsVal);
// Rt = Rs < Imm (signed) // Rt = Rs < Imm (signed)
Validate(&g_state.pgxp_gpr[rs(instr)], rsVal); PGXP_value& prsVal = g_state.pgxp_gpr[rs(instr)];
PGXP_value ret = g_state.pgxp_gpr[rs(instr)]; Validate(&prsVal, rsVal);
psx_value tempImm; const float fimmx = static_cast<float>(static_cast<s16>(imm(instr)));
tempImm.w.h = imm(instr); const float fimmy = fimmx < 0.0f ? -1.0f : 0.0f;
ret.y = 0.f;
ret.x = (g_state.pgxp_gpr[rs(instr)].x < tempImm.sw.h) ? 1.f : 0.f;
ret.SetValid(COMP_Y);
ret.flags |= VALID_TAINTED_Z;
ret.value = BoolToUInt32(static_cast<s32>(rsVal) < imm_sext(instr));
g_state.pgxp_gpr[rt(instr)] = ret; PGXP_value& prtVal = g_state.pgxp_gpr[rt(instr)];
prtVal.x = (prsVal.GetValidY(rsVal) < fimmy || prsVal.GetValidX(rsVal) < fimmx) ? 1.f : 0.f;
prtVal.y = 0.0f;
prtVal.z = prsVal.z;
prtVal.flags = prsVal.flags | VALID_X | VALID_Y | VALID_TAINTED_Z;
prtVal.value = BoolToUInt32(static_cast<s32>(rsVal) < imm_sext(instr));
} }
void CPU::PGXP::CPU_SLTIU(u32 instr, u32 rsVal) void CPU::PGXP::CPU_SLTIU(u32 instr, u32 rsVal)
@ -907,18 +907,19 @@ void CPU::PGXP::CPU_SLTIU(u32 instr, u32 rsVal)
LOG_VALUES_C1(rs(instr), rsVal); LOG_VALUES_C1(rs(instr), rsVal);
// Rt = Rs < Imm (Unsigned) // Rt = Rs < Imm (Unsigned)
PGXP_value& prsVal = g_state.pgxp_gpr[rs(instr)];
Validate(&g_state.pgxp_gpr[rs(instr)], rsVal); Validate(&g_state.pgxp_gpr[rs(instr)], rsVal);
PGXP_value ret = g_state.pgxp_gpr[rs(instr)];
psx_value tempImm; const float fimmx = static_cast<float>(static_cast<s16>(imm(instr)));
tempImm.w.h = imm(instr); const float fimmy = fimmx < 0.0f ? -1.0f : 0.0f;
ret.y = 0.f;
ret.x = (f16Unsign(g_state.pgxp_gpr[rs(instr)].x) < tempImm.w.h) ? 1.f : 0.f;
ret.SetValid(COMP_Y);
ret.flags |= VALID_TAINTED_Z;
ret.value = BoolToUInt32(rsVal < imm(instr));
g_state.pgxp_gpr[rt(instr)] = ret; PGXP_value& prtVal = g_state.pgxp_gpr[rt(instr)];
prtVal.x =
(f16Unsign(prsVal.GetValidY(rsVal)) < f16Unsign(fimmy) || f16Unsign(prsVal.GetValidX(rsVal)) < fimmx) ? 1.0f : 0.0f;
prtVal.y = 0.f;
prtVal.z = prsVal.z;
prtVal.flags = prsVal.flags | VALID_X | VALID_Y | VALID_TAINTED_Z;
prtVal.value = BoolToUInt32(rsVal < imm(instr));
} }
//////////////////////////////////// ////////////////////////////////////