2024-08-01 23:30:38 +00:00
|
|
|
#pragma once
|
2024-08-29 06:07:52 +00:00
|
|
|
#include <Project64-rsp-core/Hle/HleTask.h>
|
2024-08-14 22:06:53 +00:00
|
|
|
#include <Project64-rsp-core/RSPInfo.h>
|
2024-08-28 22:19:40 +00:00
|
|
|
#include <Project64-rsp-core/Recompiler/RspRecompilerCPU.h>
|
2024-08-01 23:30:38 +00:00
|
|
|
#include <Project64-rsp-core/cpu/RSPInterpreterOps.h>
|
2024-08-08 03:25:54 +00:00
|
|
|
#include <Project64-rsp-core/cpu/RSPRegisters.h>
|
2024-08-22 10:14:07 +00:00
|
|
|
#include <Project64-rsp-core/cpu/RspPipelineStage.h>
|
2024-08-01 23:30:38 +00:00
|
|
|
#include <Project64-rsp-core/cpu/RspTypes.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2024-08-22 07:00:20 +00:00
|
|
|
class RSPRegisterHandlerPlugin;
|
|
|
|
|
2024-08-29 06:07:52 +00:00
|
|
|
class CRSPSystem :
|
|
|
|
public CHleTask
|
2024-08-01 23:30:38 +00:00
|
|
|
{
|
2024-08-07 21:56:15 +00:00
|
|
|
friend class RSPOp;
|
|
|
|
friend class CRSPRecompilerOps;
|
2024-08-08 03:25:54 +00:00
|
|
|
friend class CRSPRecompiler;
|
2024-08-29 06:07:52 +00:00
|
|
|
friend class CHleTask;
|
2024-08-08 03:25:54 +00:00
|
|
|
friend class RSPDebuggerUI;
|
2024-08-15 04:13:56 +00:00
|
|
|
friend class CRDPLog;
|
2024-08-22 07:00:20 +00:00
|
|
|
friend class RSPRegisterHandler;
|
|
|
|
friend class RSPRegisterHandlerPlugin;
|
2024-08-29 06:07:52 +00:00
|
|
|
friend class CHle;
|
2024-08-22 07:00:20 +00:00
|
|
|
|
2024-08-07 21:56:15 +00:00
|
|
|
friend void UpdateRSPRegistersScreen(void);
|
|
|
|
|
2024-08-01 23:30:38 +00:00
|
|
|
public:
|
|
|
|
CRSPSystem();
|
2024-08-22 07:00:20 +00:00
|
|
|
~CRSPSystem();
|
2024-08-01 23:30:38 +00:00
|
|
|
|
2024-08-14 22:06:53 +00:00
|
|
|
void Reset(RSP_INFO & Info);
|
2024-08-22 07:00:20 +00:00
|
|
|
void RomClosed(void);
|
2024-08-07 21:56:15 +00:00
|
|
|
|
2024-08-22 07:00:20 +00:00
|
|
|
void RunRecompiler(void);
|
2024-09-12 05:43:45 +00:00
|
|
|
void ExecuteOps(uint32_t Cycles, uint32_t TargetPC);
|
2024-08-01 23:30:38 +00:00
|
|
|
|
|
|
|
private:
|
2024-08-22 07:00:20 +00:00
|
|
|
CRSPSystem(const CRSPSystem &);
|
|
|
|
CRSPSystem & operator=(const CRSPSystem &);
|
|
|
|
|
2024-08-28 22:19:40 +00:00
|
|
|
CRSPRecompiler m_Recompiler;
|
2024-08-22 07:00:20 +00:00
|
|
|
RSPRegisterHandlerPlugin * m_RSPRegisterHandler;
|
2024-08-07 21:56:15 +00:00
|
|
|
CRSPRegisters m_Reg;
|
2024-08-08 03:25:54 +00:00
|
|
|
RSPOp m_Op;
|
|
|
|
RSPOpcode m_OpCode;
|
2024-08-22 10:14:07 +00:00
|
|
|
RSPPIPELINE_STAGE m_NextInstruction;
|
|
|
|
uint32_t m_JumpTo;
|
2024-08-14 22:06:53 +00:00
|
|
|
uint8_t * m_HEADER;
|
|
|
|
uint8_t * m_RDRAM;
|
|
|
|
uint8_t * m_DMEM;
|
|
|
|
uint8_t * m_IMEM;
|
|
|
|
uint32_t * m_MI_INTR_REG;
|
|
|
|
uint32_t * m_SP_MEM_ADDR_REG;
|
|
|
|
uint32_t * m_SP_DRAM_ADDR_REG;
|
|
|
|
uint32_t * m_SP_RD_LEN_REG;
|
|
|
|
uint32_t * m_SP_WR_LEN_REG;
|
|
|
|
uint32_t * m_SP_STATUS_REG;
|
|
|
|
uint32_t * m_SP_DMA_FULL_REG;
|
|
|
|
uint32_t * m_SP_DMA_BUSY_REG;
|
|
|
|
uint32_t * m_SP_PC_REG;
|
|
|
|
uint32_t * m_SP_SEMAPHORE_REG;
|
|
|
|
uint32_t * m_DPC_START_REG;
|
|
|
|
uint32_t * m_DPC_END_REG;
|
|
|
|
uint32_t * m_DPC_CURRENT_REG;
|
|
|
|
uint32_t * m_DPC_STATUS_REG;
|
|
|
|
uint32_t * m_DPC_CLOCK_REG;
|
|
|
|
uint32_t * m_DPC_BUFBUSY_REG;
|
|
|
|
uint32_t * m_DPC_PIPEBUSY_REG;
|
|
|
|
uint32_t * m_DPC_TMEM_REG;
|
2024-08-22 07:00:20 +00:00
|
|
|
uint32_t m_RdramSize;
|
2024-08-14 22:06:53 +00:00
|
|
|
void (*CheckInterrupts)(void);
|
2024-08-29 06:07:52 +00:00
|
|
|
void (*ProcessDList)(void);
|
2024-08-14 22:06:53 +00:00
|
|
|
void (*ProcessRdpList)(void);
|
2024-08-01 23:30:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern CRSPSystem RSPSystem;
|