#pragma once #include class CRSPSystem; class CRSPRegisters; class CRSPRecompiler; class CRSPRecompilerOps { enum { HIT_BRANCH = 0x2, }; enum EndHleTaskOp { J_0x1118 = 0x09000446 }; public: CRSPRecompilerOps(CRSPSystem & System, CRSPRecompiler & Recompiler); void SPECIAL(void); void REGIMM(void); void J(void); void JAL(void); void BEQ(void); void BNE(void); void BLEZ(void); void BGTZ(void); void ADDI(void); void ADDIU(void); void SLTI(void); void SLTIU(void); void ANDI(void); void ORI(void); void XORI(void); void LUI(void); void COP0(void); void COP2(void); void LB(void); void LH(void); void LW(void); void LBU(void); void LHU(void); void LWU(void); void SB(void); void SH(void); void SW(void); void LC2(void); void SC2(void); // R4300i Opcodes: Special void Special_SLL(void); void Special_SRL(void); void Special_SRA(void); void Special_SLLV(void); void Special_SRLV(void); void Special_SRAV(void); void Special_JR(void); void Special_JALR(void); void Special_BREAK(void); void Special_ADD(void); void Special_ADDU(void); void Special_SUB(void); void Special_SUBU(void); void Special_AND(void); void Special_OR(void); void Special_XOR(void); void Special_NOR(void); void Special_SLT(void); void Special_SLTU(void); // R4300i Opcodes: RegImm void RegImm_BLTZ(void); void RegImm_BGEZ(void); void RegImm_BLTZAL(void); void RegImm_BGEZAL(void); // COP0 functions void Cop0_MF(void); void Cop0_MT(void); // COP2 functions void Cop2_MF(void); void Cop2_CF(void); void Cop2_MT(void); void Cop2_CT(void); void COP2_VECTOR(void); // Vector functions void Vector_VMULF(void); void Vector_VMULU(void); void Vector_VRNDN(void); void Vector_VRNDP(void); void Vector_VMULQ(void); void Vector_VMUDL(void); void Vector_VMUDM(void); void Vector_VMUDN(void); void Vector_VMUDH(void); void Vector_VMACF(void); void Vector_VMACU(void); void Vector_VMACQ(void); void Vector_VMADL(void); void Vector_VMADM(void); void Vector_VMADN(void); void Vector_VMADH(void); void Vector_VADD(void); void Vector_VSUB(void); void Vector_VABS(void); void Vector_VADDC(void); void Vector_VSUBC(void); void Vector_VSAW(void); void Vector_VLT(void); void Vector_VEQ(void); void Vector_VNE(void); void Vector_VGE(void); void Vector_VCL(void); void Vector_VCH(void); void Vector_VCR(void); void Vector_VMRG(void); void Vector_VAND(void); void Vector_VNAND(void); void Vector_VOR(void); void Vector_VNOR(void); void Vector_VXOR(void); void Vector_VNXOR(void); void Vector_VRCP(void); void Vector_VRCPL(void); void Vector_VRCPH(void); void Vector_VMOV(void); void Vector_VRSQ(void); void Vector_VRSQL(void); void Vector_VRSQH(void); void Vector_VNOOP(void); void Vector_Reserved(void); // LC2 functions void Opcode_LBV(void); void Opcode_LSV(void); void Opcode_LLV(void); void Opcode_LDV(void); void Opcode_LQV(void); void Opcode_LRV(void); void Opcode_LPV(void); void Opcode_LUV(void); void Opcode_LHV(void); void Opcode_LFV(void); void Opcode_LWV(void); void Opcode_LTV(void); // SC2 functions void Opcode_SBV(void); void Opcode_SSV(void); void Opcode_SLV(void); void Opcode_SDV(void); void Opcode_SQV(void); void Opcode_SRV(void); void Opcode_SPV(void); void Opcode_SUV(void); void Opcode_SHV(void); void Opcode_SFV(void); void Opcode_SWV(void); void Opcode_STV(void); // Other functions void UnknownOpcode(void); bool RSP_DoSections(void); private: void Cheat_r4300iOpcode(RSPOp::Func FunctAddress, const char * FunctName); void Cheat_r4300iOpcodeNoMessage(RSPOp::Func FunctAddress, const char * FunctName); bool IsNextInstructionMmx(uint32_t PC); bool UseRspFlags(int PC); bool WriteToAccum(int Location, int PC); uint32_t WriteToAccum2(int Location, int PC, bool RecursiveCall); bool WriteToVectorDest(uint32_t DestReg, int PC); bool WriteToVectorDest2(uint32_t DestReg, int PC, bool RecursiveCall); void RSP_Element2Mmx(int MmxReg); void RSP_MultiElement2Mmx(int MmxReg1, int MmxReg2); void CompileBranchExit(uint32_t TargetPC, uint32_t ContinuePC); bool Compile_Vector_VMULF_MMX(void); bool Compile_Vector_VMUDL_MMX(void); bool Compile_Vector_VMUDM_MMX(void); bool Compile_Vector_VMUDN_MMX(void); bool Compile_Vector_VMUDH_MMX(void); bool Compile_Vector_VADD_MMX(void); bool Compile_Vector_VSUB_MMX(void); bool Compile_Vector_VABS_MMX(void); bool Compile_Vector_VGE_MMX(void); bool Compile_Vector_VAND_MMX(void); bool Compile_Vector_VNAND_MMX(void); bool Compile_Vector_VOR_MMX(void); bool Compile_Vector_VNOR_MMX(void); bool Compile_Vector_VXOR_MMX(void); bool Compile_Vector_VNXOR_MMX(void); void RSP_Sections_VMUDH(RSPOpcode RspOp, uint32_t AccumStyle); void RSP_Sections_VMADH(RSPOpcode RspOp, uint32_t AccumStyle); void RSP_Sections_VMUDL(RSPOpcode RspOp, uint32_t AccumStyle); void RSP_Sections_VMUDN(RSPOpcode RspOp, uint32_t AccumStyle); void RSP_Sections_VMADN(RSPOpcode RspOp, uint32_t AccumStyle); void RSP_Sections_VMULF(RSPOpcode RspOp, uint32_t AccumStyle); void RSP_Sections_VMACF(RSPOpcode RspOp, uint32_t AccumStyle); bool Check_Section_000(void); bool Check_Section_001(void); bool Check_Section_002(void); bool Check_Section_003(void); void Compile_Section_000(void); void Compile_Section_001(void); void Compile_Section_002(void); void Compile_Section_003(void); void resampler_hle(); CRSPSystem & m_System; RSPRegisterHandlerPlugin *& m_RSPRegisterHandler; CRSPRegisters & m_Reg; CRSPRecompiler & m_Recompiler; RSPPIPELINE_STAGE & m_NextInstruction; RSPOpcode & m_OpCode; uint32_t & m_CompilePC; UWORD32 * m_GPR; UDWORD * m_ACCUM; UWORD32 * m_Flags; RSPVector * m_Vect; }; typedef void (CRSPRecompilerOps::*p_Recompfunc)(void);