#pragma once #include #include #include #include class CRSPSystem; class RSPRegisterHandlerPlugin; class CRSPRecompiler { friend class CRSPRecompilerOps; typedef struct { uint32_t StartPC, CurrPC; // Block start struct { uint32_t TargetPC; // Target for this unknown branch uint32_t * X86JumpLoc; // Our x86 uint32_t to fill } BranchesToResolve[200]; // Branches inside or outside block uint32_t ResolveCount; // Branches with NULL jump table } RSP_BLOCK; public: CRSPRecompiler(CRSPSystem & System); void RunCPU(void); void Branch_AddRef(uint32_t Target, uint32_t * X86Loc); void SetJumpTable(uint32_t End); private: CRSPRecompiler(); CRSPRecompiler(const CRSPRecompiler &); CRSPRecompiler & operator=(const CRSPRecompiler &); void CompilerRSPBlock(void); void LinkBranches(RSP_BLOCK * Block); void ReOrderSubBlock(RSP_BLOCK * Block); void ReOrderInstructions(uint32_t StartPC, uint32_t EndPC); void ResetJumpTables(void); CRSPSystem & m_System; RSPRegisterHandlerPlugin *& m_RSPRegisterHandler; RSPOpcode & m_OpCode; RSP_BLOCK m_CurrentBlock; uint8_t *& m_IMEM; }; extern uint32_t CompilePC, NextInstruction, JumpTableSize; extern bool ChangedPC; #define CompilerWarning \ if (ShowErrors) g_Notify->DisplayError #define High16BitAccum 1 #define Middle16BitAccum 2 #define Low16BitAccum 4 #define EntireAccum (Low16BitAccum | Middle16BitAccum | High16BitAccum) bool WriteToAccum(int Location, int PC); bool WriteToVectorDest(uint32_t DestReg, int PC); bool UseRspFlags(int PC); bool DelaySlotAffectBranch(uint32_t PC); bool CompareInstructions(uint32_t PC, RSPOpcode * Top, RSPOpcode * Bottom); bool IsOpcodeBranch(uint32_t PC, RSPOpcode RspOp); bool IsOpcodeNop(uint32_t PC); bool IsNextInstructionMmx(uint32_t PC); bool IsRegisterConstant(uint32_t Reg, uint32_t * Constant); #define MainBuffer 0 #define SecondaryBuffer 1 void BuildRecompilerCPU(void); void CompilerToggleBuffer(void); typedef struct { bool bIsRegConst[32]; // bool toggle for constant uint32_t MipsRegConst[32]; // Value of register 32-bit uint32_t BranchLabels[250]; uint32_t LabelCount; uint32_t BranchLocations[250]; uint32_t BranchCount; } RSP_CODE; extern RSP_CODE RspCode; #define IsRegConst(i) (RspCode.bIsRegConst[i]) #define MipsRegConst(i) (RspCode.MipsRegConst[i]) typedef struct { bool mmx, mmx2, sse; // CPU specs and compiling bool bFlags; // RSP flag analysis bool bReOrdering; // Instruction reordering bool bSections; // Microcode sections bool bDest; // Vector destination toggle bool bAccum; // Accumulator toggle bool bGPRConstants; // Analyze GPR constants bool bAlignVector; // Align known vector loads bool bAudioUcode; // Audio microcode analysis } RSP_COMPILER; extern RSP_COMPILER Compiler; #define IsMmxEnabled (Compiler.mmx) #define IsMmx2Enabled (Compiler.mmx2) #define IsSseEnabled (Compiler.sse)