2022-01-04 21:44:03 +00:00
|
|
|
#pragma once
|
|
|
|
#include "MemoryHandler.h"
|
2022-10-10 00:22:17 +00:00
|
|
|
#include <Project64-core/Logging.h>
|
|
|
|
#include <Project64-core/N64System/MemoryHandler/MIPSInterfaceHandler.h>
|
|
|
|
#include <Project64-core/Settings/DebugSettings.h>
|
|
|
|
#include <Project64-core/Settings/GameSettings.h>
|
2022-01-04 21:44:03 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
class PeripheralInterfaceReg
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
PeripheralInterfaceReg(uint32_t * PeripheralInterface);
|
|
|
|
|
|
|
|
public:
|
|
|
|
uint32_t & PI_DRAM_ADDR_REG;
|
|
|
|
uint32_t & PI_CART_ADDR_REG;
|
|
|
|
uint32_t & PI_RD_LEN_REG;
|
|
|
|
uint32_t & PI_WR_LEN_REG;
|
|
|
|
uint32_t & PI_STATUS_REG;
|
|
|
|
uint32_t & PI_BSD_DOM1_LAT_REG;
|
|
|
|
uint32_t & PI_DOMAIN1_REG;
|
|
|
|
uint32_t & PI_BSD_DOM1_PWD_REG;
|
|
|
|
uint32_t & PI_BSD_DOM1_PGS_REG;
|
|
|
|
uint32_t & PI_BSD_DOM1_RLS_REG;
|
|
|
|
uint32_t & PI_BSD_DOM2_LAT_REG;
|
|
|
|
uint32_t & PI_DOMAIN2_REG;
|
|
|
|
uint32_t & PI_BSD_DOM2_PWD_REG;
|
|
|
|
uint32_t & PI_BSD_DOM2_PGS_REG;
|
|
|
|
uint32_t & PI_BSD_DOM2_RLS_REG;
|
|
|
|
|
|
|
|
private:
|
|
|
|
PeripheralInterfaceReg();
|
2022-10-10 00:22:17 +00:00
|
|
|
PeripheralInterfaceReg(const PeripheralInterfaceReg &);
|
|
|
|
PeripheralInterfaceReg & operator=(const PeripheralInterfaceReg &);
|
2022-01-04 21:44:03 +00:00
|
|
|
};
|
|
|
|
|
2022-10-10 00:22:17 +00:00
|
|
|
class CN64System;
|
2022-01-04 21:44:03 +00:00
|
|
|
class CRegisters;
|
|
|
|
class CMipsMemoryVM;
|
2022-06-19 23:40:01 +00:00
|
|
|
class CartridgeDomain2Address2Handler;
|
2022-01-04 21:44:03 +00:00
|
|
|
|
2022-07-04 07:44:27 +00:00
|
|
|
// Peripheral interface flags
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
PI_STATUS_DMA_BUSY = 0x01,
|
|
|
|
PI_STATUS_IO_BUSY = 0x02,
|
|
|
|
PI_STATUS_ERROR = 0x04,
|
|
|
|
PI_STATUS_INTERRUPT = 0x08,
|
|
|
|
|
|
|
|
PI_SET_RESET = 0x01,
|
|
|
|
PI_CLR_INTR = 0x02,
|
|
|
|
};
|
|
|
|
|
2022-01-04 21:44:03 +00:00
|
|
|
class PeripheralInterfaceHandler :
|
|
|
|
public MemoryHandler,
|
|
|
|
private CGameSettings,
|
|
|
|
private CDebugSettings,
|
|
|
|
private CLogging,
|
2022-07-04 07:44:27 +00:00
|
|
|
private PeripheralInterfaceReg,
|
|
|
|
private MIPSInterfaceReg
|
2022-01-04 21:44:03 +00:00
|
|
|
{
|
|
|
|
public:
|
2022-07-04 07:44:27 +00:00
|
|
|
PeripheralInterfaceHandler(CN64System & System, CMipsMemoryVM & MMU, CRegisters & Reg, CartridgeDomain2Address2Handler & Domain2Address2Handler);
|
2022-02-21 11:26:25 +00:00
|
|
|
|
2022-01-04 21:44:03 +00:00
|
|
|
bool Read32(uint32_t Address, uint32_t & Value);
|
|
|
|
bool Write32(uint32_t Address, uint32_t Value, uint32_t Mask);
|
|
|
|
|
|
|
|
private:
|
|
|
|
PeripheralInterfaceHandler();
|
|
|
|
PeripheralInterfaceHandler(const PeripheralInterfaceHandler &);
|
|
|
|
PeripheralInterfaceHandler & operator=(const PeripheralInterfaceHandler &);
|
|
|
|
|
2022-10-10 00:22:17 +00:00
|
|
|
static void stSystemReset(PeripheralInterfaceHandler * _this)
|
|
|
|
{
|
|
|
|
_this->SystemReset();
|
|
|
|
}
|
|
|
|
static void stLoadedGameState(PeripheralInterfaceHandler * _this)
|
|
|
|
{
|
|
|
|
_this->LoadedGameState();
|
|
|
|
}
|
2022-07-04 07:44:27 +00:00
|
|
|
|
2022-06-19 23:40:01 +00:00
|
|
|
void PI_DMA_READ();
|
|
|
|
void PI_DMA_WRITE();
|
2022-08-22 03:41:20 +00:00
|
|
|
void LoadedGameState(void);
|
2022-07-04 07:44:27 +00:00
|
|
|
void SystemReset(void);
|
2022-06-19 23:40:01 +00:00
|
|
|
void OnFirstDMA();
|
2022-07-04 07:44:27 +00:00
|
|
|
void ReadBlock(uint32_t Address, uint8_t * Block, uint32_t BlockLen);
|
2022-06-19 23:40:01 +00:00
|
|
|
|
|
|
|
CartridgeDomain2Address2Handler & m_Domain2Address2Handler;
|
2022-01-04 21:44:03 +00:00
|
|
|
CMipsMemoryVM & m_MMU;
|
|
|
|
CRegisters & m_Reg;
|
2024-06-06 04:39:12 +00:00
|
|
|
uint64_t & m_PC;
|
2022-08-22 03:41:20 +00:00
|
|
|
|
|
|
|
bool m_DMAUsed;
|
2022-01-04 21:44:03 +00:00
|
|
|
};
|