2019-02-11 22:41:34 -05:00
|
|
|
#pragma once
|
|
|
|
#include "stdafx.h"
|
2019-02-26 22:27:09 -05:00
|
|
|
#include "DebugTypes.h"
|
2019-07-25 22:22:09 -04:00
|
|
|
#include "MemoryMappings.h"
|
2019-03-12 09:15:57 -04:00
|
|
|
#include "../Utilities/ISerializable.h"
|
2019-02-11 22:41:34 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
class IMemoryHandler;
|
|
|
|
class RegisterHandlerA;
|
|
|
|
class RegisterHandlerB;
|
|
|
|
class InternalRegisters;
|
|
|
|
class RamHandler;
|
2019-07-25 22:22:09 -04:00
|
|
|
class BaseCartridge;
|
2019-02-26 22:27:09 -05:00
|
|
|
class Console;
|
|
|
|
class Ppu;
|
2019-07-06 09:29:35 -04:00
|
|
|
class Cpu;
|
2019-10-12 22:40:25 -04:00
|
|
|
class CheatManager;
|
2019-02-26 22:27:09 -05:00
|
|
|
enum class MemoryOperationType;
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2020-06-24 18:43:49 -04:00
|
|
|
enum class SnesEventType : uint8_t
|
|
|
|
{
|
|
|
|
HdmaInit,
|
|
|
|
DramRefresh,
|
|
|
|
HdmaStart,
|
|
|
|
EndOfScanline
|
|
|
|
};
|
|
|
|
|
2019-03-12 09:15:57 -04:00
|
|
|
class MemoryManager : public ISerializable
|
2019-02-11 22:41:34 -05:00
|
|
|
{
|
2019-02-15 21:33:13 -05:00
|
|
|
public:
|
|
|
|
constexpr static uint32_t WorkRamSize = 0x20000;
|
|
|
|
|
2019-02-11 22:41:34 -05:00
|
|
|
private:
|
2019-07-12 23:34:19 -04:00
|
|
|
Console* _console;
|
2019-02-12 22:13:09 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
shared_ptr<RegisterHandlerA> _registerHandlerA;
|
|
|
|
shared_ptr<RegisterHandlerB> _registerHandlerB;
|
|
|
|
|
2020-12-19 23:30:09 +03:00
|
|
|
InternalRegisters* _regs;
|
2019-07-12 23:34:19 -04:00
|
|
|
Ppu* _ppu;
|
|
|
|
Cpu* _cpu;
|
2019-07-25 22:22:09 -04:00
|
|
|
BaseCartridge* _cart;
|
2019-10-12 22:40:25 -04:00
|
|
|
CheatManager* _cheatManager;
|
2020-12-19 23:30:09 +03:00
|
|
|
uint8_t* _workRam;
|
2020-06-24 18:43:49 -04:00
|
|
|
|
2019-07-13 13:43:56 -04:00
|
|
|
uint64_t _masterClock = 0;
|
2019-04-20 09:30:51 -04:00
|
|
|
uint16_t _hClock = 0;
|
2020-06-24 18:43:49 -04:00
|
|
|
uint16_t _nextEventClock = 0;
|
2019-04-20 09:30:51 -04:00
|
|
|
uint16_t _dramRefreshPosition = 0;
|
2020-06-24 18:43:49 -04:00
|
|
|
SnesEventType _nextEvent = SnesEventType::DramRefresh;
|
2019-07-25 22:22:09 -04:00
|
|
|
SnesMemoryType _memTypeBusA = SnesMemoryType::PrgRom;
|
2019-04-20 11:46:51 -04:00
|
|
|
|
2020-06-24 18:43:49 -04:00
|
|
|
uint8_t _cpuSpeed = 8;
|
|
|
|
uint8_t _openBus = 0;
|
|
|
|
|
|
|
|
MemoryMappings _mappings;
|
|
|
|
vector<unique_ptr<IMemoryHandler>> _workRamHandlers;
|
|
|
|
uint8_t _masterClockTable[0x800];
|
2019-02-11 22:41:34 -05:00
|
|
|
|
2019-04-20 11:46:51 -04:00
|
|
|
void Exec();
|
2019-03-08 10:26:54 -05:00
|
|
|
|
2020-06-24 18:43:49 -04:00
|
|
|
void ProcessEvent();
|
|
|
|
|
2019-02-11 22:41:34 -05:00
|
|
|
public:
|
2019-07-12 23:34:19 -04:00
|
|
|
void Initialize(Console* console);
|
2019-03-31 14:50:12 -04:00
|
|
|
virtual ~MemoryManager();
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2019-03-16 12:20:18 -04:00
|
|
|
void Reset();
|
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
void GenerateMasterClockTable();
|
2019-07-12 23:55:18 -04:00
|
|
|
|
|
|
|
void IncMasterClock4();
|
|
|
|
void IncMasterClock6();
|
|
|
|
void IncMasterClock8();
|
|
|
|
void IncMasterClock40();
|
|
|
|
void IncMasterClockStartup();
|
2019-02-26 22:27:09 -05:00
|
|
|
void IncrementMasterClockValue(uint16_t value);
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
uint8_t Read(uint32_t addr, MemoryOperationType type);
|
2019-03-16 16:36:58 -04:00
|
|
|
uint8_t ReadDma(uint32_t addr, bool forBusA);
|
2019-03-26 22:34:48 -04:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
uint8_t Peek(uint32_t addr);
|
2019-02-28 16:53:04 -05:00
|
|
|
uint16_t PeekWord(uint32_t addr);
|
2020-12-19 23:30:09 +03:00
|
|
|
void PeekBlock(uint32_t addr, uint8_t* dest);
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
void Write(uint32_t addr, uint8_t value, MemoryOperationType type);
|
2019-03-16 16:36:58 -04:00
|
|
|
void WriteDma(uint32_t addr, uint8_t value, bool forBusA);
|
2019-02-17 14:42:35 -05:00
|
|
|
|
2019-03-09 00:31:54 -05:00
|
|
|
uint8_t GetOpenBus();
|
2019-02-26 22:27:09 -05:00
|
|
|
uint64_t GetMasterClock();
|
2019-04-20 11:46:51 -04:00
|
|
|
uint16_t GetHClock();
|
2019-02-26 22:27:09 -05:00
|
|
|
uint8_t* DebugGetWorkRam();
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2019-07-25 22:22:09 -04:00
|
|
|
MemoryMappings* GetMemoryMappings();
|
|
|
|
|
2019-04-20 09:30:51 -04:00
|
|
|
uint8_t GetCpuSpeed(uint32_t addr);
|
|
|
|
uint8_t GetCpuSpeed();
|
|
|
|
void SetCpuSpeed(uint8_t speed);
|
2019-07-25 22:22:09 -04:00
|
|
|
SnesMemoryType GetMemoryTypeBusA();
|
2019-04-20 09:30:51 -04:00
|
|
|
|
2019-03-07 20:12:32 -05:00
|
|
|
bool IsRegister(uint32_t cpuAddress);
|
2019-03-09 14:27:32 -05:00
|
|
|
bool IsWorkRam(uint32_t cpuAddress);
|
2019-03-12 09:15:57 -04:00
|
|
|
|
2020-12-19 23:30:09 +03:00
|
|
|
void Serialize(Serializer& s) override;
|
2019-02-26 22:27:09 -05:00
|
|
|
};
|