2022-02-21 11:26:25 +00:00
|
|
|
#pragma once
|
|
|
|
#include "MemoryHandler.h"
|
2022-10-10 00:22:17 +00:00
|
|
|
#include "SPRegistersHandler.h"
|
|
|
|
#include <Project64-core\Logging.h>
|
|
|
|
#include <Project64-core\Settings\DebugSettings.h>
|
2022-02-21 11:26:25 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
enum
|
|
|
|
{
|
2022-10-10 00:22:17 +00:00
|
|
|
DPC_CLR_XBUS_DMEM_DMA = 0x0001, // Bit 0: Clear xbus_dmem_dma
|
|
|
|
DPC_SET_XBUS_DMEM_DMA = 0x0002, // Bit 1: Set xbus_dmem_dma
|
|
|
|
DPC_CLR_FREEZE = 0x0004, // Bit 2: Clear freeze
|
|
|
|
DPC_SET_FREEZE = 0x0008, // Bit 3: Set freeze
|
|
|
|
DPC_CLR_FLUSH = 0x0010, // Bit 4: Clear flush
|
|
|
|
DPC_SET_FLUSH = 0x0020, // Bit 5: Set flush
|
|
|
|
DPC_CLR_TMEM_CTR = 0x0040, // Bit 6: Clear TMEM CTR
|
|
|
|
DPC_CLR_PIPE_CTR = 0x0080, // Bit 7: Clear pipe CTR
|
|
|
|
DPC_CLR_CMD_CTR = 0x0100, // Bit 8: Clear CMD CTR
|
|
|
|
DPC_CLR_CLOCK_CTR = 0x0200, // Bit 9: Clear clock CTR
|
2022-02-21 11:26:25 +00:00
|
|
|
|
2022-10-10 00:22:17 +00:00
|
|
|
DPC_STATUS_XBUS_DMEM_DMA = 0x001, // Bit 0: xbus_dmem_dma
|
|
|
|
DPC_STATUS_FREEZE = 0x002, // Bit 1: Freeze
|
|
|
|
DPC_STATUS_FLUSH = 0x004, // Bit 2: Flush
|
|
|
|
DPC_STATUS_START_GCLK = 0x008, // Bit 3: Start GCLK
|
|
|
|
DPC_STATUS_TMEM_BUSY = 0x010, // Bit 4: TMEM busy
|
|
|
|
DPC_STATUS_PIPE_BUSY = 0x020, // Bit 5: Pipe busy
|
|
|
|
DPC_STATUS_CMD_BUSY = 0x040, // Bit 6: CMD busy
|
|
|
|
DPC_STATUS_CBUF_READY = 0x080, // Bit 7: CBUF ready
|
|
|
|
DPC_STATUS_DMA_BUSY = 0x100, // Bit 8: DMA busy
|
|
|
|
DPC_STATUS_END_VALID = 0x200, // Bit 9: End valid
|
|
|
|
DPC_STATUS_START_VALID = 0x400, // Bit 10: Start valid
|
2022-02-21 11:26:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class DisplayControlReg
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
DisplayControlReg(uint32_t * _DisplayProcessor);
|
|
|
|
|
|
|
|
public:
|
|
|
|
uint32_t & DPC_START_REG;
|
|
|
|
uint32_t & DPC_END_REG;
|
|
|
|
uint32_t & DPC_CURRENT_REG;
|
|
|
|
uint32_t & DPC_STATUS_REG;
|
|
|
|
uint32_t & DPC_CLOCK_REG;
|
|
|
|
uint32_t & DPC_BUFBUSY_REG;
|
|
|
|
uint32_t & DPC_PIPEBUSY_REG;
|
|
|
|
uint32_t & DPC_TMEM_REG;
|
|
|
|
|
|
|
|
private:
|
|
|
|
DisplayControlReg();
|
2022-10-10 00:22:17 +00:00
|
|
|
DisplayControlReg(const DisplayControlReg &);
|
|
|
|
DisplayControlReg & operator=(const DisplayControlReg &);
|
2022-02-21 11:26:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class CN64System;
|
|
|
|
class CPlugins;
|
|
|
|
class CRegisters;
|
|
|
|
|
|
|
|
class DisplayControlRegHandler :
|
|
|
|
public MemoryHandler,
|
|
|
|
private CDebugSettings,
|
|
|
|
private CLogging,
|
|
|
|
private DisplayControlReg,
|
|
|
|
private SPRegistersReg
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DisplayControlRegHandler(CN64System & N64System, CPlugins * Plugins, CRegisters & Reg);
|
|
|
|
|
|
|
|
bool Read32(uint32_t Address, uint32_t & Value);
|
|
|
|
bool Write32(uint32_t Address, uint32_t Value, uint32_t Mask);
|
|
|
|
|
|
|
|
private:
|
|
|
|
DisplayControlRegHandler();
|
|
|
|
DisplayControlRegHandler(const DisplayControlRegHandler &);
|
|
|
|
DisplayControlRegHandler & operator=(const DisplayControlRegHandler &);
|
|
|
|
|
2023-10-19 08:58:38 +00:00
|
|
|
void ProcessRDPList(void);
|
|
|
|
|
2022-02-21 11:26:25 +00:00
|
|
|
CN64System & m_System;
|
|
|
|
CPlugins * m_Plugins;
|
2024-06-06 04:39:12 +00:00
|
|
|
uint64_t & m_PC;
|
2022-02-21 11:26:25 +00:00
|
|
|
};
|