2016-01-27 09:11:59 +00:00
|
|
|
#pragma once
|
2016-07-06 20:14:12 +00:00
|
|
|
#if defined(__i386__) || defined(_M_IX86)
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2022-10-10 00:22:17 +00:00
|
|
|
#include <Project64-core/N64System/Interpreter/InterpreterOps.h>
|
|
|
|
#include <Project64-core/N64System/Mips/Register.h>
|
2016-06-28 11:22:30 +00:00
|
|
|
#include <Project64-core/N64System/Recompiler/ExitInfo.h>
|
2022-10-10 00:22:17 +00:00
|
|
|
#include <Project64-core/N64System/Recompiler/JumpInfo.h>
|
2016-07-04 07:51:11 +00:00
|
|
|
#include <Project64-core/N64System/Recompiler/RecompilerOps.h>
|
2022-10-10 00:22:17 +00:00
|
|
|
#include <Project64-core/N64System/Recompiler/RegInfo.h>
|
2022-12-19 05:05:17 +00:00
|
|
|
#include <Project64-core/N64System/Recompiler/asmjit.h>
|
2016-06-27 10:54:53 +00:00
|
|
|
#include <Project64-core/N64System/Recompiler/x86/x86ops.h>
|
2022-10-10 00:22:17 +00:00
|
|
|
#include <Project64-core/Settings/GameSettings.h>
|
2016-01-27 09:11:59 +00:00
|
|
|
#include <Project64-core/Settings/N64SystemSettings.h>
|
|
|
|
#include <Project64-core/Settings/RecompilerSettings.h>
|
|
|
|
|
2016-07-03 05:22:14 +00:00
|
|
|
class CCodeBlock;
|
2016-01-27 09:11:59 +00:00
|
|
|
class CCodeSection;
|
|
|
|
|
2016-07-04 07:51:11 +00:00
|
|
|
class CX86RecompilerOps :
|
2023-04-04 08:14:42 +00:00
|
|
|
public CRecompilerOpsBase,
|
2016-01-27 09:11:59 +00:00
|
|
|
protected CN64SystemSettings,
|
2022-01-03 23:37:52 +00:00
|
|
|
protected CRecompilerSettings,
|
2023-04-04 08:14:42 +00:00
|
|
|
protected CLogSettings,
|
2022-01-03 23:37:52 +00:00
|
|
|
private CGameSettings
|
2016-01-27 09:11:59 +00:00
|
|
|
{
|
2023-08-17 05:54:57 +00:00
|
|
|
friend CX86RegInfo;
|
|
|
|
|
2016-06-28 11:22:30 +00:00
|
|
|
public:
|
2023-10-26 09:29:11 +00:00
|
|
|
CX86RecompilerOps(CN64System & m_System, CCodeBlock & CodeBlock);
|
2022-05-01 22:06:50 +00:00
|
|
|
~CX86RecompilerOps();
|
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// Trap functions
|
2022-08-15 03:09:34 +00:00
|
|
|
void Compile_TrapCompare(RecompilerTrapCompare CompareType);
|
2019-12-17 15:08:15 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// Branch functions
|
2022-08-15 03:09:34 +00:00
|
|
|
void Compile_BranchCompare(RecompilerBranchCompare CompareType);
|
|
|
|
void Compile_Branch(RecompilerBranchCompare CompareType, bool Link);
|
|
|
|
void Compile_BranchLikely(RecompilerBranchCompare CompareType, bool Link);
|
2016-06-30 09:11:46 +00:00
|
|
|
void BNE_Compare();
|
|
|
|
void BEQ_Compare();
|
|
|
|
void BGTZ_Compare();
|
|
|
|
void BLEZ_Compare();
|
|
|
|
void BLTZ_Compare();
|
|
|
|
void BGEZ_Compare();
|
|
|
|
void COP1_BCF_Compare();
|
|
|
|
void COP1_BCT_Compare();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// Opcode functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void J();
|
|
|
|
void JAL();
|
|
|
|
void ADDI();
|
|
|
|
void ADDIU();
|
|
|
|
void SLTI();
|
|
|
|
void SLTIU();
|
|
|
|
void ANDI();
|
|
|
|
void ORI();
|
|
|
|
void XORI();
|
|
|
|
void LUI();
|
2022-08-15 00:35:16 +00:00
|
|
|
void DADDI();
|
2016-07-04 07:51:11 +00:00
|
|
|
void DADDIU();
|
|
|
|
void LDL();
|
|
|
|
void LDR();
|
2022-10-24 06:20:12 +00:00
|
|
|
void RESERVED31();
|
2016-07-04 07:51:11 +00:00
|
|
|
void LB();
|
|
|
|
void LH();
|
|
|
|
void LWL();
|
|
|
|
void LW();
|
|
|
|
void LBU();
|
|
|
|
void LHU();
|
|
|
|
void LWR();
|
|
|
|
void LWU();
|
|
|
|
void SB();
|
|
|
|
void SH();
|
|
|
|
void SWL();
|
|
|
|
void SW();
|
|
|
|
void SWR();
|
|
|
|
void SDL();
|
|
|
|
void SDR();
|
|
|
|
void CACHE();
|
|
|
|
void LL();
|
|
|
|
void LWC1();
|
|
|
|
void LDC1();
|
|
|
|
void LD();
|
|
|
|
void SC();
|
|
|
|
void SWC1();
|
|
|
|
void SDC1();
|
|
|
|
void SD();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// R4300i opcodes: Special
|
2016-07-04 07:51:11 +00:00
|
|
|
void SPECIAL_SLL();
|
|
|
|
void SPECIAL_SRL();
|
|
|
|
void SPECIAL_SRA();
|
|
|
|
void SPECIAL_SLLV();
|
|
|
|
void SPECIAL_SRLV();
|
|
|
|
void SPECIAL_SRAV();
|
|
|
|
void SPECIAL_JR();
|
|
|
|
void SPECIAL_JALR();
|
2016-06-28 11:22:30 +00:00
|
|
|
void SPECIAL_SYSCALL();
|
2022-10-10 01:37:04 +00:00
|
|
|
void SPECIAL_BREAK();
|
2023-12-14 03:22:15 +00:00
|
|
|
void SPECIAL_SYNC();
|
2016-07-04 07:51:11 +00:00
|
|
|
void SPECIAL_MFLO();
|
|
|
|
void SPECIAL_MTLO();
|
|
|
|
void SPECIAL_MFHI();
|
|
|
|
void SPECIAL_MTHI();
|
|
|
|
void SPECIAL_DSLLV();
|
|
|
|
void SPECIAL_DSRLV();
|
|
|
|
void SPECIAL_DSRAV();
|
|
|
|
void SPECIAL_MULT();
|
|
|
|
void SPECIAL_MULTU();
|
|
|
|
void SPECIAL_DIV();
|
|
|
|
void SPECIAL_DIVU();
|
|
|
|
void SPECIAL_DMULT();
|
|
|
|
void SPECIAL_DMULTU();
|
|
|
|
void SPECIAL_DDIV();
|
|
|
|
void SPECIAL_DDIVU();
|
|
|
|
void SPECIAL_ADD();
|
|
|
|
void SPECIAL_ADDU();
|
|
|
|
void SPECIAL_SUB();
|
|
|
|
void SPECIAL_SUBU();
|
|
|
|
void SPECIAL_AND();
|
|
|
|
void SPECIAL_OR();
|
|
|
|
void SPECIAL_XOR();
|
|
|
|
void SPECIAL_NOR();
|
|
|
|
void SPECIAL_SLT();
|
|
|
|
void SPECIAL_SLTU();
|
|
|
|
void SPECIAL_DADD();
|
|
|
|
void SPECIAL_DADDU();
|
|
|
|
void SPECIAL_DSUB();
|
|
|
|
void SPECIAL_DSUBU();
|
|
|
|
void SPECIAL_DSLL();
|
|
|
|
void SPECIAL_DSRL();
|
|
|
|
void SPECIAL_DSRA();
|
|
|
|
void SPECIAL_DSLL32();
|
|
|
|
void SPECIAL_DSRL32();
|
|
|
|
void SPECIAL_DSRA32();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP0 functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP0_MF();
|
2022-10-10 01:08:55 +00:00
|
|
|
void COP0_DMF();
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP0_MT();
|
2022-10-10 01:08:55 +00:00
|
|
|
void COP0_DMT();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP0 CO functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP0_CO_TLBR();
|
|
|
|
void COP0_CO_TLBWI();
|
|
|
|
void COP0_CO_TLBWR();
|
|
|
|
void COP0_CO_TLBP();
|
|
|
|
void COP0_CO_ERET();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1 functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP1_MF();
|
|
|
|
void COP1_DMF();
|
|
|
|
void COP1_CF();
|
|
|
|
void COP1_MT();
|
|
|
|
void COP1_DMT();
|
|
|
|
void COP1_CT();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: S functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP1_S_ADD();
|
|
|
|
void COP1_S_SUB();
|
|
|
|
void COP1_S_MUL();
|
|
|
|
void COP1_S_DIV();
|
|
|
|
void COP1_S_ABS();
|
|
|
|
void COP1_S_NEG();
|
|
|
|
void COP1_S_SQRT();
|
|
|
|
void COP1_S_MOV();
|
|
|
|
void COP1_S_ROUND_L();
|
|
|
|
void COP1_S_TRUNC_L();
|
|
|
|
void COP1_S_CEIL_L();
|
|
|
|
void COP1_S_FLOOR_L();
|
|
|
|
void COP1_S_ROUND_W();
|
|
|
|
void COP1_S_TRUNC_W();
|
|
|
|
void COP1_S_CEIL_W();
|
|
|
|
void COP1_S_FLOOR_W();
|
|
|
|
void COP1_S_CVT_D();
|
|
|
|
void COP1_S_CVT_W();
|
|
|
|
void COP1_S_CVT_L();
|
|
|
|
void COP1_S_CMP();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: D functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP1_D_ADD();
|
|
|
|
void COP1_D_SUB();
|
|
|
|
void COP1_D_MUL();
|
|
|
|
void COP1_D_DIV();
|
|
|
|
void COP1_D_ABS();
|
|
|
|
void COP1_D_NEG();
|
|
|
|
void COP1_D_SQRT();
|
|
|
|
void COP1_D_MOV();
|
|
|
|
void COP1_D_ROUND_L();
|
|
|
|
void COP1_D_TRUNC_L();
|
|
|
|
void COP1_D_CEIL_L();
|
|
|
|
void COP1_D_FLOOR_L();
|
|
|
|
void COP1_D_ROUND_W();
|
|
|
|
void COP1_D_TRUNC_W();
|
|
|
|
void COP1_D_CEIL_W();
|
|
|
|
void COP1_D_FLOOR_W();
|
|
|
|
void COP1_D_CVT_S();
|
|
|
|
void COP1_D_CVT_W();
|
|
|
|
void COP1_D_CVT_L();
|
|
|
|
void COP1_D_CMP();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: W functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP1_W_CVT_S();
|
|
|
|
void COP1_W_CVT_D();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// COP1: L functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void COP1_L_CVT_S();
|
|
|
|
void COP1_L_CVT_D();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2021-05-18 11:51:36 +00:00
|
|
|
// Other functions
|
2016-07-04 07:51:11 +00:00
|
|
|
void UnknownOpcode();
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2023-12-14 03:22:15 +00:00
|
|
|
void RecordLLAddress(const asmjit::x86::Gp & AddressReg);
|
2023-12-14 02:40:20 +00:00
|
|
|
void RecordLLAddress(uint64_t Address);
|
2018-02-15 07:28:08 +00:00
|
|
|
void ClearCachedInstructionInfo();
|
2018-03-02 06:48:15 +00:00
|
|
|
void FoundMemoryBreakpoint();
|
2018-02-15 07:28:08 +00:00
|
|
|
void PreReadInstruction();
|
2018-02-13 07:16:53 +00:00
|
|
|
void PreWriteInstruction();
|
2022-11-07 10:33:32 +00:00
|
|
|
void TestWriteBreakpoint(const asmjit::x86::Gp & AddressReg, uint32_t FunctAddress, const char * FunctName);
|
|
|
|
void TestReadBreakpoint(const asmjit::x86::Gp & AddressReg, uint32_t FunctAddress, const char * FunctName);
|
|
|
|
void TestBreakpoint(const asmjit::x86::Gp & AddressReg, uint32_t FunctAddress, const char * FunctName);
|
2016-07-04 07:51:11 +00:00
|
|
|
void EnterCodeBlock();
|
|
|
|
void ExitCodeBlock();
|
2016-06-28 11:22:30 +00:00
|
|
|
void CompileExitCode();
|
2024-02-15 10:30:12 +00:00
|
|
|
void CompileCheckFPUInput(asmjit::x86::Gp RegPointer, FpuOpSize OpSize, bool Conv = false);
|
2023-08-31 00:38:49 +00:00
|
|
|
void CompileCheckFPUResult32(int32_t DestReg);
|
2024-01-18 06:39:27 +00:00
|
|
|
void CompileCheckFPUResult64(asmjit::x86::Gp RegPointer);
|
2016-07-03 05:22:14 +00:00
|
|
|
void CompileCop1Test();
|
2023-08-31 00:38:49 +00:00
|
|
|
void CompileInitFpuOperation(CRegBase::FPU_ROUND RoundMethod);
|
2016-07-03 05:22:14 +00:00
|
|
|
void CompileInPermLoop(CRegInfo & RegSet, uint32_t ProgramCounter);
|
|
|
|
void SyncRegState(const CRegInfo & SyncTo);
|
2022-08-08 10:52:51 +00:00
|
|
|
bool SetupRegisterForLoop(CCodeBlock & BlockInfo, const CRegInfo & RegSet);
|
2016-07-03 05:22:14 +00:00
|
|
|
CRegInfo & GetRegWorkingSet(void);
|
|
|
|
void SetRegWorkingSet(const CRegInfo & RegInfo);
|
|
|
|
bool InheritParentInfo();
|
2022-12-26 02:24:04 +00:00
|
|
|
void LinkJump(CJumpInfo & JumpInfo);
|
2016-07-03 05:22:14 +00:00
|
|
|
void JumpToSection(CCodeSection * Section);
|
|
|
|
void JumpToUnknown(CJumpInfo * JumpInfo);
|
|
|
|
void SetCurrentPC(uint32_t ProgramCounter);
|
|
|
|
uint32_t GetCurrentPC(void);
|
|
|
|
void SetCurrentSection(CCodeSection * section);
|
2022-01-18 07:47:21 +00:00
|
|
|
void SetNextStepType(PIPELINE_STAGE StepType);
|
|
|
|
PIPELINE_STAGE GetNextStepType(void);
|
2022-07-18 08:31:00 +00:00
|
|
|
const R4300iOpcode & GetOpcode(void) const;
|
2023-12-21 00:04:03 +00:00
|
|
|
const R4300iInstruction & GetInstruction(void) const;
|
2016-07-03 05:22:14 +00:00
|
|
|
void PreCompileOpcode(void);
|
2016-07-04 07:51:11 +00:00
|
|
|
void PostCompileOpcode(void);
|
2024-06-06 04:39:12 +00:00
|
|
|
void CompileExit(uint64_t JumpPC, uint64_t TargetPC, CRegInfo & ExitRegSet, ExitReason Reason);
|
2016-07-03 05:22:14 +00:00
|
|
|
|
2022-11-07 10:33:32 +00:00
|
|
|
void CompileReadTLBMiss(uint32_t VirtualAddress, const asmjit::x86::Gp & LookUpReg);
|
|
|
|
void CompileReadTLBMiss(const asmjit::x86::Gp & AddressReg, const asmjit::x86::Gp & LookUpReg);
|
|
|
|
void CompileWriteTLBMiss(const asmjit::x86::Gp & AddressReg, const asmjit::x86::Gp & LookUpReg);
|
2022-08-08 10:52:51 +00:00
|
|
|
void UpdateSyncCPU(CRegInfo & RegSet, uint32_t Cycles);
|
2022-04-18 11:27:59 +00:00
|
|
|
void UpdateCounters(CRegInfo & RegSet, bool CheckTimer, bool ClearValues = false, bool UpdateTimer = true);
|
2016-07-04 07:51:11 +00:00
|
|
|
void CompileSystemCheck(uint32_t TargetPC, const CRegInfo & RegSet);
|
2018-01-20 23:18:52 +00:00
|
|
|
void CompileExecuteBP(void);
|
2018-07-29 20:07:45 +00:00
|
|
|
void CompileExecuteDelaySlotBP(void);
|
2016-01-27 09:11:59 +00:00
|
|
|
static void ChangeDefaultRoundingModel();
|
2016-07-04 07:51:11 +00:00
|
|
|
void OverflowDelaySlot(bool TestTimer);
|
2016-01-27 09:11:59 +00:00
|
|
|
|
2022-10-10 00:22:17 +00:00
|
|
|
CX86Ops & Assembler()
|
|
|
|
{
|
|
|
|
return m_Assembler;
|
|
|
|
}
|
2022-08-15 03:09:34 +00:00
|
|
|
|
2016-06-29 13:40:36 +00:00
|
|
|
private:
|
2022-10-10 00:22:17 +00:00
|
|
|
CX86RecompilerOps(const CX86RecompilerOps &);
|
|
|
|
CX86RecompilerOps & operator=(const CX86RecompilerOps &);
|
2022-05-01 22:06:50 +00:00
|
|
|
|
2022-11-07 10:33:32 +00:00
|
|
|
asmjit::x86::Gp BaseOffsetAddress(bool UseBaseRegister);
|
2024-10-24 03:02:02 +00:00
|
|
|
void CompileLoadMemoryValue(asmjit::x86::Gp & AddressReg, const asmjit::x86::Gp & ValueReg, const asmjit::x86::Gp & ValueRegHi, uint8_t ValueSize, bool SignExtend);
|
|
|
|
void CompileStoreMemoryValue(asmjit::x86::Gp AddressReg, const asmjit::x86::Gp & ValueReg, const asmjit::x86::Gp & ValueRegHi, uint64_t Value, uint8_t ValueSize);
|
2024-03-21 06:43:16 +00:00
|
|
|
void COP1_D_Opcode(void (CX86Ops::*Instruction)(void));
|
2024-03-14 07:42:58 +00:00
|
|
|
void COP1_D_Opcode(void (CX86Ops::*Instruction)(const asmjit::x86::Mem &));
|
2024-04-11 08:39:30 +00:00
|
|
|
void COP1_S_Opcode(void (CX86Ops::*Instruction)(void));
|
|
|
|
void COP1_S_Opcode(void (CX86Ops::*Instruction)(const asmjit::x86::Mem &));
|
2022-05-22 20:54:56 +00:00
|
|
|
|
2022-08-08 10:52:51 +00:00
|
|
|
void SB_Const(uint32_t Value, uint32_t Addr);
|
2022-11-07 10:33:32 +00:00
|
|
|
void SB_Register(const asmjit::x86::Gp & Reg, uint32_t Addr);
|
2022-08-08 10:52:51 +00:00
|
|
|
void SH_Const(uint32_t Value, uint32_t Addr);
|
2022-11-07 10:33:32 +00:00
|
|
|
void SH_Register(const asmjit::x86::Gp & Reg, uint32_t Addr);
|
2016-06-29 13:40:36 +00:00
|
|
|
void SW_Const(uint32_t Value, uint32_t Addr);
|
2022-11-07 10:33:32 +00:00
|
|
|
void SW_Register(const asmjit::x86::Gp & Reg, uint32_t Addr);
|
|
|
|
void LB_KnownAddress(const asmjit::x86::Gp & Reg, uint32_t VAddr, bool SignExtend);
|
|
|
|
void LH_KnownAddress(const asmjit::x86::Gp & Reg, uint32_t VAddr, bool SignExtend);
|
|
|
|
void LW_KnownAddress(const asmjit::x86::Gp & Reg, uint32_t VAddr);
|
2016-06-29 13:40:36 +00:00
|
|
|
void LW(bool ResultSigned, bool bRecordLLBit);
|
|
|
|
void SW(bool bCheckLLbit);
|
2024-06-06 04:39:12 +00:00
|
|
|
void CompileExit(uint64_t JumpPC, uint64_t TargetPC, CRegInfo & ExitRegSet, ExitReason Reason, bool CompileNow, void (CX86Ops::*x86Jmp)(const char * LabelName, asmjit::Label & JumpLabel));
|
2016-07-03 10:17:45 +00:00
|
|
|
void ResetMemoryStack();
|
2024-01-18 06:39:27 +00:00
|
|
|
void COP1_S_CVT(CRegBase::FPU_ROUND RoundMethod, CRegInfo::FPU_STATE OldFormat, CRegInfo::FPU_STATE NewFormat);
|
2016-06-29 13:40:36 +00:00
|
|
|
|
2023-09-14 01:39:28 +00:00
|
|
|
static void x86CompilerBreakPoint();
|
|
|
|
static void x86BreakPointDelaySlot();
|
|
|
|
static void x86MemoryBreakPoint();
|
|
|
|
static void x86TestReadBreakPoint8();
|
|
|
|
static void x86TestReadBreakPoint16();
|
|
|
|
static void x86TestReadBreakPoint32();
|
|
|
|
static void x86TestReadBreakPoint64();
|
|
|
|
static void x86TestWriteBreakPoint8();
|
|
|
|
static void x86TestWriteBreakPoint16();
|
|
|
|
static void x86TestWriteBreakPoint32();
|
|
|
|
static void x86TestWriteBreakPoint64();
|
|
|
|
|
2016-06-28 11:22:30 +00:00
|
|
|
EXIT_LIST m_ExitInfo;
|
2022-08-15 03:09:34 +00:00
|
|
|
CX86Ops m_Assembler;
|
2022-08-08 10:52:51 +00:00
|
|
|
PIPELINE_STAGE m_PipelineStage;
|
2024-06-06 04:39:12 +00:00
|
|
|
const uint64_t & m_CompilePC;
|
2022-08-08 10:52:51 +00:00
|
|
|
CX86RegInfo m_RegWorkingSet;
|
|
|
|
CRegInfo m_RegBeforeDelay;
|
|
|
|
bool m_EffectDelaySlot;
|
2023-08-17 05:54:57 +00:00
|
|
|
static uint32_t m_RoundingModeValue;
|
2023-12-14 02:40:20 +00:00
|
|
|
static bool m_TempMemoryUsed;
|
2022-05-16 06:21:37 +00:00
|
|
|
static uint32_t m_TempValue32;
|
2022-10-10 09:55:16 +00:00
|
|
|
static uint64_t m_TempValue64;
|
2022-08-08 10:52:51 +00:00
|
|
|
static uint32_t m_BranchCompare;
|
2016-01-27 09:11:59 +00:00
|
|
|
};
|
2016-07-06 20:14:12 +00:00
|
|
|
|
2022-10-24 00:45:46 +00:00
|
|
|
typedef CX86RecompilerOps CRecompilerOps;
|
|
|
|
|
2016-07-06 20:14:12 +00:00
|
|
|
#endif
|