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

53 lines
No EOL
1.3 KiB
C++

#pragma once
#include "pch.h"
#include "NES/BaseMapper.h"
class Caltron41 : public BaseMapper
{
private:
uint8_t _prgBank = 0;
uint8_t _chrBank = 0;
protected:
uint16_t GetPrgPageSize() override { return 0x8000; }
uint16_t GetChrPageSize() override { return 0x2000; }
uint16_t RegisterStartAddress() override { return 0x8000; }
uint16_t RegisterEndAddress() override { return 0xFFFF; }
void InitMapper() override
{
AddRegisterRange(0x6000, 0x67FF, MemoryOperation::Write);
}
void Reset(bool softReset) override
{
_chrBank = 0;
_prgBank = 0;
WriteRegister(0x6000, 0);
WriteRegister(0x8000, 0);
}
void Serialize(Serializer& s) override
{
BaseMapper::Serialize(s);
SV(_prgBank);
SV(_chrBank);
}
void WriteRegister(uint16_t addr, uint8_t value) override
{
if(addr <= 0x67FF) {
_prgBank = addr & 0x07;
_chrBank = (_chrBank & 0x03) | ((addr >> 1) & 0x0C);
SelectPrgPage(0, _prgBank);
SelectChrPage(0, _chrBank);
SetMirroringType(addr & 0x20 ? MirroringType::Horizontal : MirroringType::Vertical);
} else {
//"Note that the Inner CHR Bank Select only can be written while the PRG ROM bank is 4, 5, 6, or 7"
if(_prgBank >= 4) {
_chrBank = (_chrBank & 0x0C) | (value & 0x03);
SelectChrPage(0, _chrBank);
}
}
}
};