Mesen/Core/Mapper227.h
2023-05-12 20:39:46 -05:00

78 lines
1.8 KiB
C++

#pragma once
#include "BaseMapper.h"
class Mapper227 : public BaseMapper
{
protected:
uint32_t GetDipSwitchCount() override { return 4; }
uint16_t GetPRGPageSize() override { return 0x4000; }
uint16_t GetCHRPageSize() override { return 0x2000; }
bool AllowRegisterRead() override { return true; }
bool _mFlag;
void InitMapper() override
{
WriteRegister(0x8000, 0);
}
void Reset(bool softreset) override
{
WriteRegister(0x8000, 0);
}
void StreamState(bool saving) override
{
BaseMapper::StreamState(saving);
Stream(_mFlag);
}
uint8_t ReadRegister(uint16_t addr) override
{
if(_mFlag) {
addr |= GetDipSwitches();
}
return InternalReadRam(addr);
}
void WriteRegister(uint16_t addr, uint8_t value) override
{
uint16_t prgBank = ((addr >> 2) & 0x1F) | ((addr & 0x100) >> 3);
bool sFlag = (addr & 0x01) == 0x01;
bool lFlag = ((addr >> 9) & 0x01) == 0x01;
bool prgMode = ((addr >> 7) & 0x01) == 0x01;
_mFlag = ((addr >> 10) & 0x01) == 0x01;
if(prgMode) {
if(sFlag) {
SelectPrgPage2x(0, prgBank & 0xFE);
} else {
SelectPRGPage(0, prgBank);
SelectPRGPage(1, prgBank);
}
} else {
if(sFlag){
if(lFlag) {
SelectPRGPage(0, prgBank & 0x3E);
SelectPRGPage(1, prgBank | 0x07);
} else {
SelectPRGPage(0, prgBank & 0x3E);
SelectPRGPage(1, prgBank & 0x38);
}
} else {
if(lFlag) {
SelectPRGPage(0, prgBank);
SelectPRGPage(1, prgBank | 0x07);
} else {
SelectPRGPage(0, prgBank);
SelectPRGPage(1, prgBank & 0x38);
}
}
}
// protect CHR-RAM on nrom modes
SetPpuMemoryMapping(0, 0x1FFF, 0, ChrMemoryType::Default, (!HasBattery() && prgMode) ? MemoryAccessType::Read : MemoryAccessType::ReadWrite);
SetMirroringType((addr & 0x02) == 0x02 ? MirroringType::Horizontal : MirroringType::Vertical);
}
};