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-02-13 13:32:21 -05:00
|
|
|
#include "Ppu.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;
|
|
|
|
class Console;
|
|
|
|
class Ppu;
|
|
|
|
enum class MemoryOperationType;
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2019-02-11 22:41:34 -05:00
|
|
|
class MemoryManager
|
|
|
|
{
|
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-02-12 22:13:09 -05:00
|
|
|
shared_ptr<Console> _console;
|
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
shared_ptr<RegisterHandlerA> _registerHandlerA;
|
|
|
|
shared_ptr<RegisterHandlerB> _registerHandlerB;
|
|
|
|
|
2019-02-21 18:12:44 -05:00
|
|
|
InternalRegisters* _regs;
|
2019-02-13 13:32:21 -05:00
|
|
|
shared_ptr<Ppu> _ppu;
|
2019-02-15 00:08:50 -05:00
|
|
|
|
2019-02-17 14:42:35 -05:00
|
|
|
IMemoryHandler* _handlers[0x100 * 0x10];
|
|
|
|
vector<unique_ptr<RamHandler>> _workRamHandlers;
|
|
|
|
|
|
|
|
uint8_t * _workRam;
|
2019-02-13 13:32:21 -05:00
|
|
|
|
|
|
|
uint64_t _masterClock;
|
2019-02-21 22:10:41 -05:00
|
|
|
uint8_t _previousSpeed;
|
2019-02-13 13:32:21 -05:00
|
|
|
uint64_t _lastMasterClock;
|
2019-02-21 18:12:44 -05:00
|
|
|
uint8_t _masterClockTable[2][0x10000];
|
2019-02-11 22:41:34 -05:00
|
|
|
|
|
|
|
public:
|
2019-02-26 22:27:09 -05:00
|
|
|
void Initialize(shared_ptr<Console> console);
|
|
|
|
~MemoryManager();
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
void RegisterHandler(uint32_t startAddr, uint32_t endAddr, IMemoryHandler* handler);
|
2019-02-17 14:42:35 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
void GenerateMasterClockTable();
|
|
|
|
void IncrementMasterClock(uint32_t addr);
|
2019-02-21 23:35:51 -05:00
|
|
|
template<uint16_t value>
|
2019-02-26 22:27:09 -05:00
|
|
|
void IncrementMasterClockValue();
|
|
|
|
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);
|
|
|
|
uint8_t ReadDma(uint32_t addr);
|
|
|
|
uint8_t Peek(uint32_t addr);
|
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);
|
|
|
|
void WriteDma(uint32_t addr, uint8_t value);
|
2019-02-17 14:42:35 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
uint64_t GetMasterClock();
|
|
|
|
uint8_t* DebugGetWorkRam();
|
2019-02-13 13:32:21 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
AddressInfo GetAbsoluteAddress(uint32_t addr);
|
|
|
|
int GetRelativeAddress(AddressInfo &address, int32_t cpuAddress = -1);
|
|
|
|
};
|
2019-02-21 23:35:51 -05:00
|
|
|
|
2019-02-26 22:27:09 -05:00
|
|
|
template<uint16_t value>
|
|
|
|
void MemoryManager::IncrementMasterClockValue()
|
|
|
|
{
|
|
|
|
_masterClock += value;
|
|
|
|
while(_lastMasterClock < _masterClock - 3) {
|
|
|
|
_ppu->Exec();
|
|
|
|
_lastMasterClock += 4;
|
2019-02-21 23:35:51 -05:00
|
|
|
}
|
2019-02-26 22:27:09 -05:00
|
|
|
}
|