mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2025-01-18 22:35:39 +00:00
PGXP: Fix MFC0/MTC0
Doubt it'll change anything.
This commit is contained in:
parent
a722fd6b53
commit
0bfa1bf873
|
@ -1303,7 +1303,7 @@ restart_instruction:
|
|||
const std::optional<u32> value = ReadCop0Reg(static_cast<Cop0Reg>(inst.r.rd.GetValue()));
|
||||
|
||||
if constexpr (pgxp_mode == PGXPMode::CPU)
|
||||
PGXP::CPU_MFC0(inst.bits, value.value_or(0), ReadReg(inst.i.rs));
|
||||
PGXP::CPU_MFC0(inst.bits, value.value_or(0));
|
||||
|
||||
if (value)
|
||||
WriteRegDelayed(inst.r.rt, value.value());
|
||||
|
@ -1319,7 +1319,7 @@ restart_instruction:
|
|||
if constexpr (pgxp_mode == PGXPMode::CPU)
|
||||
{
|
||||
PGXP::CPU_MTC0(inst.bits, ReadCop0Reg(static_cast<Cop0Reg>(inst.r.rd.GetValue())).value_or(0),
|
||||
ReadReg(inst.i.rs));
|
||||
ReadReg(inst.i.rt));
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
|
|
@ -1876,12 +1876,12 @@ void CPU_MTLO(u32 instr, u32 rdVal)
|
|||
CPU_Lo = CPU_reg[rd(instr)];
|
||||
}
|
||||
|
||||
void CPU_MFC0(u32 instr, u32 rtVal, u32 rdVal)
|
||||
void CPU_MFC0(u32 instr, u32 rdVal)
|
||||
{
|
||||
// CPU[Rt] = CP0[Rd]
|
||||
Validate(&CP0_reg[rd(instr)], rdVal);
|
||||
CPU_reg[rt(instr)] = CP0_reg[rd(instr)];
|
||||
CPU_reg[rt(instr)].value = rtVal;
|
||||
CPU_reg[rt(instr)].value = rdVal;
|
||||
}
|
||||
|
||||
void CPU_MTC0(u32 instr, u32 rdVal, u32 rtVal)
|
||||
|
@ -1892,20 +1892,4 @@ void CPU_MTC0(u32 instr, u32 rdVal, u32 rtVal)
|
|||
CP0_reg[rd(instr)].value = rdVal;
|
||||
}
|
||||
|
||||
void CPU_CFC0(u32 instr, u32 rtVal, u32 rdVal)
|
||||
{
|
||||
// CPU[Rt] = CP0[Rd]
|
||||
Validate(&CP0_reg[rd(instr)], rdVal);
|
||||
CPU_reg[rt(instr)] = CP0_reg[rd(instr)];
|
||||
CPU_reg[rt(instr)].value = rtVal;
|
||||
}
|
||||
|
||||
void CPU_CTC0(u32 instr, u32 rdVal, u32 rtVal)
|
||||
{
|
||||
// CP0[Rd] = CPU[Rt]
|
||||
Validate(&CPU_reg[rt(instr)], rtVal);
|
||||
CP0_reg[rd(instr)] = CPU_reg[rt(instr)];
|
||||
CP0_reg[rd(instr)].value = rdVal;
|
||||
}
|
||||
|
||||
} // namespace PGXP
|
||||
|
|
|
@ -98,9 +98,7 @@ void CPU_MFLO(u32 instr, u32 loVal);
|
|||
void CPU_MTLO(u32 instr, u32 rdVal);
|
||||
|
||||
// CP0 Data transfer tracking
|
||||
void CPU_MFC0(u32 instr, u32 rtVal, u32 rdVal);
|
||||
void CPU_MFC0(u32 instr, u32 rdVal);
|
||||
void CPU_MTC0(u32 instr, u32 rdVal, u32 rtVal);
|
||||
void CPU_CFC0(u32 instr, u32 rtVal, u32 rdVal);
|
||||
void CPU_CTC0(u32 instr, u32 rdVal, u32 rtVal);
|
||||
|
||||
} // namespace PGXP
|
Loading…
Reference in a new issue