Mesen/Core/Mapper222.h

83 lines
1.9 KiB
C
Raw Normal View History

2016-08-13 00:48:16 +00:00
#pragma once
#include "stdafx.h"
#include "BaseMapper.h"
#include "PPU.h"
#include "CPU.h"
class Mapper222 : public BaseMapper
{
private:
uint16_t _irqCounter;
uint32_t _cyclesDown;
uint32_t _lastCycle;
protected:
virtual uint16_t GetPRGPageSize() { return 0x2000; }
virtual uint16_t GetCHRPageSize() { return 0x400; }
void InitMapper()
{
_irqCounter = 0;
_cyclesDown = 0;
_lastCycle = 0;
SelectPrgPage2x(1, -2);
}
void StreamState(bool saving)
{
BaseMapper::StreamState(saving);
Stream(_irqCounter, _cyclesDown, _lastCycle);
}
virtual void NotifyVRAMAddressChange(uint16_t addr)
{
uint32_t cycle = PPU::GetFrameCycle();
if((addr & 0x1000) == 0) {
if(_cyclesDown == 0) {
_cyclesDown = 1;
} else {
if(_lastCycle > cycle) {
//We changed frames
_cyclesDown += (89342 - _lastCycle) + cycle;
} else {
_cyclesDown += (cycle - _lastCycle);
}
}
} else if(addr & 0x1000) {
if(_cyclesDown > 8) {
if(_irqCounter) {
_irqCounter++;
if(_irqCounter >= 240) {
CPU::SetIRQSource(IRQSource::External);
_irqCounter = 0;
}
}
}
_cyclesDown = 0;
}
_lastCycle = cycle;
}
void WriteRegister(uint16_t addr, uint8_t value)
{
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;
}
}
};