2024-08-01 23:30:38 +00:00
|
|
|
#pragma once
|
2024-08-14 22:06:53 +00:00
|
|
|
#include <Project64-rsp-core/RSPInfo.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-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-01 23:30:38 +00:00
|
|
|
class CRSPSystem
|
|
|
|
{
|
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;
|
|
|
|
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-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-08-01 23:30:38 +00:00
|
|
|
uint32_t RunInterpreterCPU(uint32_t Cycles);
|
|
|
|
|
|
|
|
private:
|
2024-08-22 07:00:20 +00:00
|
|
|
CRSPSystem(const CRSPSystem &);
|
|
|
|
CRSPSystem & operator=(const CRSPSystem &);
|
|
|
|
|
|
|
|
CRSPRecompiler * m_Recompiler;
|
|
|
|
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-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);
|
|
|
|
void (*ProcessRdpList)(void);
|
2024-08-01 23:30:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern CRSPSystem RSPSystem;
|