2012-12-19 09:30:18 +00:00
|
|
|
#pragma once
|
|
|
|
|
2022-07-18 08:31:00 +00:00
|
|
|
#include <Project64-core/N64System/Mips/R4300iOpcode.h>
|
2022-10-10 00:22:17 +00:00
|
|
|
#include <Project64-core/N64System/Mips/Register.h>
|
|
|
|
#include <Project64-core/Settings/DebugSettings.h>
|
2015-11-15 00:29:15 +00:00
|
|
|
|
2023-04-05 00:46:21 +00:00
|
|
|
class CX86RecompilerOps;
|
|
|
|
|
2010-06-04 06:25:07 +00:00
|
|
|
class R4300iOp :
|
2015-11-13 13:23:43 +00:00
|
|
|
public CLogging,
|
2023-10-18 23:58:25 +00:00
|
|
|
private CDebugSettings,
|
|
|
|
private CSystemRegisters
|
2010-05-25 09:15:19 +00:00
|
|
|
{
|
2023-04-05 00:46:21 +00:00
|
|
|
friend CX86RecompilerOps;
|
|
|
|
|
2010-05-25 09:15:19 +00:00
|
|
|
public:
|
2023-10-18 23:58:25 +00:00
|
|
|
R4300iOp();
|
|
|
|
~R4300iOp(void);
|
|
|
|
|
|
|
|
void ExecuteCPU();
|
|
|
|
void ExecuteOps(int32_t Cycles);
|
2023-10-18 23:02:42 +00:00
|
|
|
static void InPermLoop();
|
|
|
|
|
2022-10-10 00:22:17 +00:00
|
|
|
typedef void (*Func)();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// Opcode functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void J();
|
|
|
|
static void JAL();
|
|
|
|
static void BNE();
|
|
|
|
static void BEQ();
|
|
|
|
static void BLEZ();
|
|
|
|
static void BGTZ();
|
|
|
|
static void ADDI();
|
|
|
|
static void ADDIU();
|
|
|
|
static void SLTI();
|
|
|
|
static void SLTIU();
|
|
|
|
static void ANDI();
|
|
|
|
static void ORI();
|
|
|
|
static void XORI();
|
|
|
|
static void LUI();
|
|
|
|
static void BEQL();
|
|
|
|
static void BNEL();
|
|
|
|
static void BLEZL();
|
|
|
|
static void BGTZL();
|
2022-08-15 00:35:16 +00:00
|
|
|
static void DADDI();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void DADDIU();
|
|
|
|
static void LDL();
|
|
|
|
static void LDR();
|
|
|
|
static void LB();
|
|
|
|
static void LH();
|
|
|
|
static void LWL();
|
|
|
|
static void LW();
|
|
|
|
static void LBU();
|
|
|
|
static void LHU();
|
|
|
|
static void LWR();
|
|
|
|
static void LWU();
|
|
|
|
static void SB();
|
|
|
|
static void SH();
|
|
|
|
static void SWL();
|
|
|
|
static void SW();
|
|
|
|
static void SDL();
|
|
|
|
static void SDR();
|
|
|
|
static void SWR();
|
|
|
|
static void CACHE();
|
|
|
|
static void LL();
|
|
|
|
static void LWC1();
|
2023-09-14 07:01:37 +00:00
|
|
|
static void LLD();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void LDC1();
|
|
|
|
static void LD();
|
|
|
|
static void SC();
|
|
|
|
static void SWC1();
|
|
|
|
static void SDC1();
|
|
|
|
static void SD();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// R4300i opcodes: Special
|
2022-08-01 02:13:17 +00:00
|
|
|
static void SPECIAL_SLL();
|
|
|
|
static void SPECIAL_SRL();
|
|
|
|
static void SPECIAL_SRA();
|
|
|
|
static void SPECIAL_SLLV();
|
|
|
|
static void SPECIAL_SRLV();
|
|
|
|
static void SPECIAL_SRAV();
|
|
|
|
static void SPECIAL_JR();
|
|
|
|
static void SPECIAL_JALR();
|
|
|
|
static void SPECIAL_SYSCALL();
|
|
|
|
static void SPECIAL_BREAK();
|
|
|
|
static void SPECIAL_SYNC();
|
|
|
|
static void SPECIAL_MFHI();
|
|
|
|
static void SPECIAL_MTHI();
|
|
|
|
static void SPECIAL_MFLO();
|
|
|
|
static void SPECIAL_MTLO();
|
|
|
|
static void SPECIAL_DSLLV();
|
|
|
|
static void SPECIAL_DSRLV();
|
|
|
|
static void SPECIAL_DSRAV();
|
|
|
|
static void SPECIAL_MULT();
|
|
|
|
static void SPECIAL_MULTU();
|
|
|
|
static void SPECIAL_DIV();
|
|
|
|
static void SPECIAL_DIVU();
|
|
|
|
static void SPECIAL_DMULT();
|
|
|
|
static void SPECIAL_DMULTU();
|
|
|
|
static void SPECIAL_DDIV();
|
|
|
|
static void SPECIAL_DDIVU();
|
|
|
|
static void SPECIAL_ADD();
|
|
|
|
static void SPECIAL_ADDU();
|
|
|
|
static void SPECIAL_SUB();
|
|
|
|
static void SPECIAL_SUBU();
|
|
|
|
static void SPECIAL_AND();
|
|
|
|
static void SPECIAL_OR();
|
|
|
|
static void SPECIAL_XOR();
|
|
|
|
static void SPECIAL_NOR();
|
|
|
|
static void SPECIAL_SLT();
|
|
|
|
static void SPECIAL_SLTU();
|
|
|
|
static void SPECIAL_DADD();
|
|
|
|
static void SPECIAL_DADDU();
|
|
|
|
static void SPECIAL_DSUB();
|
|
|
|
static void SPECIAL_DSUBU();
|
2022-10-10 00:22:17 +00:00
|
|
|
static void SPECIAL_TGE();
|
|
|
|
static void SPECIAL_TGEU();
|
|
|
|
static void SPECIAL_TLT();
|
|
|
|
static void SPECIAL_TLTU();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void SPECIAL_TEQ();
|
2022-10-10 00:22:17 +00:00
|
|
|
static void SPECIAL_TNE();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void SPECIAL_DSLL();
|
|
|
|
static void SPECIAL_DSRL();
|
|
|
|
static void SPECIAL_DSRA();
|
|
|
|
static void SPECIAL_DSLL32();
|
|
|
|
static void SPECIAL_DSRL32();
|
|
|
|
static void SPECIAL_DSRA32();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// R4300i opcodes: RegImm
|
2022-08-01 02:13:17 +00:00
|
|
|
static void REGIMM_BLTZ();
|
|
|
|
static void REGIMM_BGEZ();
|
|
|
|
static void REGIMM_BLTZL();
|
|
|
|
static void REGIMM_BGEZL();
|
|
|
|
static void REGIMM_BLTZAL();
|
|
|
|
static void REGIMM_BGEZAL();
|
2022-08-15 00:48:51 +00:00
|
|
|
static void REGIMM_BGEZALL();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void REGIMM_TEQI();
|
|
|
|
static void REGIMM_TGEI();
|
|
|
|
static void REGIMM_TGEIU();
|
|
|
|
static void REGIMM_TLTI();
|
|
|
|
static void REGIMM_TLTIU();
|
|
|
|
static void REGIMM_TNEI();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP0 functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP0_MF();
|
2022-09-19 07:06:44 +00:00
|
|
|
static void COP0_DMF();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP0_MT();
|
2022-09-19 07:06:44 +00:00
|
|
|
static void COP0_DMT();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP0 CO functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP0_CO_TLBR();
|
|
|
|
static void COP0_CO_TLBWI();
|
|
|
|
static void COP0_CO_TLBWR();
|
|
|
|
static void COP0_CO_TLBP();
|
|
|
|
static void COP0_CO_ERET();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1 functions
|
2023-05-09 01:58:59 +00:00
|
|
|
static void CPO1_UNIMPLEMENTED_OP(void);
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_MF();
|
|
|
|
static void COP1_DMF();
|
|
|
|
static void COP1_CF();
|
|
|
|
static void COP1_MT();
|
|
|
|
static void COP1_DMT();
|
|
|
|
static void COP1_CT();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: BC1 functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_BCF();
|
|
|
|
static void COP1_BCT();
|
|
|
|
static void COP1_BCFL();
|
|
|
|
static void COP1_BCTL();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: S functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_S_ADD();
|
|
|
|
static void COP1_S_SUB();
|
|
|
|
static void COP1_S_MUL();
|
|
|
|
static void COP1_S_DIV();
|
|
|
|
static void COP1_S_SQRT();
|
|
|
|
static void COP1_S_ABS();
|
|
|
|
static void COP1_S_MOV();
|
|
|
|
static void COP1_S_NEG();
|
|
|
|
static void COP1_S_ROUND_L();
|
|
|
|
static void COP1_S_TRUNC_L();
|
2022-10-10 00:22:17 +00:00
|
|
|
static void COP1_S_CEIL_L();
|
|
|
|
static void COP1_S_FLOOR_L();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_S_ROUND_W();
|
|
|
|
static void COP1_S_TRUNC_W();
|
2022-10-10 00:22:17 +00:00
|
|
|
static void COP1_S_CEIL_W();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_S_FLOOR_W();
|
|
|
|
static void COP1_S_CVT_D();
|
|
|
|
static void COP1_S_CVT_W();
|
|
|
|
static void COP1_S_CVT_L();
|
|
|
|
static void COP1_S_CMP();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: D functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_D_ADD();
|
|
|
|
static void COP1_D_SUB();
|
|
|
|
static void COP1_D_MUL();
|
|
|
|
static void COP1_D_DIV();
|
|
|
|
static void COP1_D_SQRT();
|
|
|
|
static void COP1_D_ABS();
|
|
|
|
static void COP1_D_MOV();
|
|
|
|
static void COP1_D_NEG();
|
|
|
|
static void COP1_D_ROUND_L();
|
2022-10-10 00:22:17 +00:00
|
|
|
static void COP1_D_TRUNC_L();
|
|
|
|
static void COP1_D_CEIL_L();
|
|
|
|
static void COP1_D_FLOOR_L();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_D_ROUND_W();
|
|
|
|
static void COP1_D_TRUNC_W();
|
2022-10-10 00:22:17 +00:00
|
|
|
static void COP1_D_CEIL_W();
|
|
|
|
static void COP1_D_FLOOR_W();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_D_CVT_S();
|
|
|
|
static void COP1_D_CVT_W();
|
|
|
|
static void COP1_D_CVT_L();
|
|
|
|
static void COP1_D_CMP();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: W functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_W_CVT_S();
|
|
|
|
static void COP1_W_CVT_D();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: L functions
|
2022-08-01 02:13:17 +00:00
|
|
|
static void COP1_L_CVT_S();
|
|
|
|
static void COP1_L_CVT_D();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2023-05-18 08:34:41 +00:00
|
|
|
// COP2 functions
|
|
|
|
static void CPO2_INVALID_OP(void);
|
|
|
|
static void COP2_MF();
|
|
|
|
static void COP2_DMF();
|
|
|
|
static void COP2_CF();
|
|
|
|
static void COP2_MT();
|
|
|
|
static void COP2_DMT();
|
|
|
|
static void COP2_CT();
|
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// Other functions
|
2022-09-19 02:42:08 +00:00
|
|
|
static void ReservedInstruction();
|
2022-08-01 02:13:17 +00:00
|
|
|
static void UnknownOpcode();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2022-01-18 07:47:21 +00:00
|
|
|
static bool m_TestTimer;
|
2022-07-18 08:31:00 +00:00
|
|
|
static R4300iOpcode m_Opcode;
|
2010-05-25 09:15:19 +00:00
|
|
|
|
2023-10-18 23:58:25 +00:00
|
|
|
private:
|
|
|
|
R4300iOp(const R4300iOp &);
|
|
|
|
R4300iOp & operator=(const R4300iOp &);
|
|
|
|
|
|
|
|
void BuildInterpreter(void);
|
2018-02-13 07:16:53 +00:00
|
|
|
|
2022-01-18 07:47:21 +00:00
|
|
|
static void SPECIAL();
|
|
|
|
static void REGIMM();
|
|
|
|
static void COP0();
|
|
|
|
static void COP0_CO();
|
|
|
|
static void COP1();
|
2022-12-12 10:59:16 +00:00
|
|
|
static void COP2();
|
|
|
|
static void COP3();
|
2022-01-18 07:47:21 +00:00
|
|
|
static void COP1_BC();
|
|
|
|
static void COP1_S();
|
|
|
|
static void COP1_D();
|
|
|
|
static void COP1_W();
|
|
|
|
static void COP1_L();
|
2015-11-08 20:55:32 +00:00
|
|
|
|
|
|
|
static Func Jump_Opcode[64];
|
|
|
|
static Func Jump_Special[64];
|
|
|
|
static Func Jump_Regimm[32];
|
|
|
|
static Func Jump_CoP0[32];
|
|
|
|
static Func Jump_CoP0_Function[64];
|
|
|
|
static Func Jump_CoP1[32];
|
|
|
|
static Func Jump_CoP1_BC[32];
|
|
|
|
static Func Jump_CoP1_S[64];
|
|
|
|
static Func Jump_CoP1_D[64];
|
|
|
|
static Func Jump_CoP1_W[64];
|
|
|
|
static Func Jump_CoP1_L[64];
|
2023-05-18 08:34:41 +00:00
|
|
|
static Func Jump_CoP2[32];
|
2015-11-08 20:55:32 +00:00
|
|
|
|
2023-01-30 01:10:03 +00:00
|
|
|
static bool TestCop1UsableException(void);
|
2023-02-21 04:24:22 +00:00
|
|
|
static bool CheckFPUInput32(const float & Value);
|
2023-04-24 09:32:00 +00:00
|
|
|
static bool CheckFPUInput32Conv(const float & Value);
|
2023-03-06 07:58:32 +00:00
|
|
|
static bool CheckFPUInput64(const double & Value);
|
2023-05-09 03:27:08 +00:00
|
|
|
static bool CheckFPUInput64Conv(const double & Value);
|
2023-01-30 10:06:58 +00:00
|
|
|
static bool CheckFPUResult32(float & Result);
|
2023-03-06 07:58:32 +00:00
|
|
|
static bool CheckFPUResult64(double & Result);
|
2023-04-24 09:32:00 +00:00
|
|
|
static bool CheckFPUInvalidException(void);
|
2023-08-17 05:54:57 +00:00
|
|
|
static bool InitFpuOperation(FPRoundingMode RoundingModel);
|
2023-05-08 22:36:15 +00:00
|
|
|
static bool SetFPUException(void);
|
2022-05-09 00:36:10 +00:00
|
|
|
|
2015-11-08 20:55:32 +00:00
|
|
|
static const uint32_t SWL_MASK[4], SWR_MASK[4], LWL_MASK[4], LWR_MASK[4];
|
2022-05-09 00:36:10 +00:00
|
|
|
static const int32_t SWL_SHIFT[4], SWR_SHIFT[4], LWL_SHIFT[4], LWR_SHIFT[4];
|
2010-05-25 09:15:19 +00:00
|
|
|
};
|