2016-08-13 00:48:16 +00:00
|
|
|
#pragma once
|
|
|
|
#include "stdafx.h"
|
|
|
|
#include "BaseMapper.h"
|
|
|
|
#include "CPU.h"
|
2016-08-26 03:29:23 +00:00
|
|
|
#include "A12Watcher.h"
|
2016-08-13 00:48:16 +00:00
|
|
|
|
|
|
|
class Mapper222 : public BaseMapper
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
uint16_t _irqCounter;
|
2016-08-26 03:29:23 +00:00
|
|
|
A12Watcher _a12Watcher;
|
2016-08-13 00:48:16 +00:00
|
|
|
|
|
|
|
protected:
|
2016-12-18 04:14:47 +00:00
|
|
|
virtual uint16_t GetPRGPageSize() override { return 0x2000; }
|
|
|
|
virtual uint16_t GetCHRPageSize() override { return 0x400; }
|
2016-08-13 00:48:16 +00:00
|
|
|
|
2016-12-18 04:14:47 +00:00
|
|
|
void InitMapper() override
|
2016-08-13 00:48:16 +00:00
|
|
|
{
|
|
|
|
_irqCounter = 0;
|
|
|
|
|
|
|
|
SelectPrgPage2x(1, -2);
|
|
|
|
}
|
|
|
|
|
2016-12-18 04:14:47 +00:00
|
|
|
void StreamState(bool saving) override
|
2016-08-13 00:48:16 +00:00
|
|
|
{
|
|
|
|
BaseMapper::StreamState(saving);
|
2016-08-26 03:29:23 +00:00
|
|
|
SnapshotInfo a12Watcher{ &_a12Watcher };
|
|
|
|
Stream(_irqCounter, a12Watcher);
|
2016-08-13 00:48:16 +00:00
|
|
|
}
|
|
|
|
|
2016-12-18 04:14:47 +00:00
|
|
|
virtual void NotifyVRAMAddressChange(uint16_t addr) override
|
2016-08-13 00:48:16 +00:00
|
|
|
{
|
2016-08-26 03:29:23 +00:00
|
|
|
if(_a12Watcher.UpdateVramAddress(addr) == A12StateChange::Rise) {
|
|
|
|
if(_irqCounter) {
|
|
|
|
_irqCounter++;
|
|
|
|
if(_irqCounter >= 240) {
|
|
|
|
CPU::SetIRQSource(IRQSource::External);
|
|
|
|
_irqCounter = 0;
|
2016-08-13 00:48:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-18 04:14:47 +00:00
|
|
|
void WriteRegister(uint16_t addr, uint8_t value) override
|
2016-08-13 00:48:16 +00:00
|
|
|
{
|
|
|
|
switch(addr & 0xF003) {
|
|
|
|
case 0x8000: SelectPRGPage(0, value); break;
|
|
|
|
case 0x9000: SetMirroringType(value & 0x01 ? MirroringType::Horizontal : MirroringType::Vertical); break;
|
|
|
|
case 0xA000: SelectPRGPage(1, value); break;
|
|
|
|
case 0xB000: SelectCHRPage(0, value); break;
|
|
|
|
case 0xB002: SelectCHRPage(1, value); break;
|
|
|
|
case 0xC000: SelectCHRPage(2, value); break;
|
|
|
|
case 0xC002: SelectCHRPage(3, value); break;
|
|
|
|
case 0xD000: SelectCHRPage(4, value); break;
|
|
|
|
case 0xD002: SelectCHRPage(5, value); break;
|
|
|
|
case 0xE000: SelectCHRPage(6, value); break;
|
|
|
|
case 0xE002: SelectCHRPage(7, value); break;
|
|
|
|
case 0xF000:
|
|
|
|
_irqCounter = value;
|
|
|
|
CPU::ClearIRQSource(IRQSource::External);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|