Mesen2/Core/NES/Mappers/Txc/Txc22211A.h
2022-09-08 21:29:52 -04:00

54 lines
No EOL
1.2 KiB
C++

#pragma once
#include "pch.h"
#include "NES/BaseMapper.h"
#include "NES/Mappers/Txc/TxcChip.h"
class Txc22211A : public BaseMapper
{
protected:
TxcChip _txc = TxcChip(false);
uint16_t GetPrgPageSize() override { return 0x8000; }
uint16_t GetChrPageSize() override { return 0x2000; }
uint16_t RegisterStartAddress() override { return 0x8000; }
uint16_t RegisterEndAddress() override { return 0xFFFF; }
bool AllowRegisterRead() override { return true; }
void InitMapper() override
{
AddRegisterRange(0x4020, 0x5FFF, MemoryOperation::Any);
RemoveRegisterRange(0x8000, 0xFFFF, MemoryOperation::Read);
SelectPrgPage(0, 0);
SelectChrPage(0, 0);
}
void Serialize(Serializer& s) override
{
BaseMapper::Serialize(s);
SV(_txc);
}
virtual void UpdateState()
{
SelectPrgPage(0, (_txc.GetOutput() >> 2) & 0x01);
SelectChrPage(0, _txc.GetOutput() & 0x03);
}
uint8_t ReadRegister(uint16_t addr) override
{
uint8_t openBus = _console->GetMemoryManager()->GetOpenBus();
uint8_t value = openBus;
if((addr & 0x103) == 0x100) {
value = (openBus & 0xF0) | (_txc.Read() & 0x0F);
}
UpdateState();
return value;
}
void WriteRegister(uint16_t addr, uint8_t value) override
{
_txc.Write(addr, value & 0x0F);
UpdateState();
}
};