Files
player/Project/Src/NES/mapper/023.cpp
2025-06-27 00:32:57 +08:00

287 lines
5.8 KiB
C++
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#include "nes_mapper.h"
/////////////////////////////////////////////////////////////////////
// Mapper 23
void MAP23_Reset()
{
// patch = 0xFFFF;
// if(parent_NES->crc32() == 0x93794634) // Akumajou Special - Boku Dracula Kun
// {
// patch = 0xF00C;
// }
// // set CPU bank pointers
// set_CPU_banks(0,1,num_8k_ROM_banks-2,num_8k_ROM_banks-1);
// set PPU bank pointers
set_PPU_banks(0,1,2,3,4,5,6,7);
MAPx->regs[0] = 0;
MAPx->regs[1] = 1;
MAPx->regs[2] = 2;
MAPx->regs[3] = 3;
MAPx->regs[4] = 4;
MAPx->regs[5] = 5;
MAPx->regs[6] = 6;
MAPx->regs[7] = 7;
MAPx->regs[8] = 0;
MAPx->irq_enabled = 0;
MAPx->irq_counter = 0;
MAPx->irq_latch = 0;
}
void MAP23_MemoryWrite(uint16 addr, uint8 data)
{
// MAPx->regs[0] ... 1K VROM bank at PPU $0000
// MAPx->regs[1] ... 1K VROM bank at PPU $0400
// MAPx->regs[2] ... 1K VROM bank at PPU $0800
// MAPx->regs[3] ... 1K VROM bank at PPU $0C00
// MAPx->regs[4] ... 1K VROM bank at PPU $1000
// MAPx->regs[5] ... 1K VROM bank at PPU $1400
// MAPx->regs[6] ... 1K VROM bank at PPU $1800
// MAPx->regs[7] ... 1K VROM bank at PPU $1C00
// MAPx->regs[8] ... $9008 swap
// switch(addr & patch)
switch(addr)
{
case 0x8000:
case 0x8004:
case 0x8008:
case 0x800C:
{
if(MAPx->regs[8])
{
set_CPU_bank6(data);
}
else
{
set_CPU_bank4(data);
}
}
break;
case 0x9000:
{
if(data != 0xFF)
{
data &= 0x03;
if(data == 0)
{
set_mirroring(0,1,0,1);//´¹Ö±¾µÏñInfoNES_Mirroring( 1 ); //0101
//set_mirroring(NES_PPU::MIRROR_VERT);
}
else if(data == 1)
{
set_mirroring(0,0,1,1);//ˮƽ¾µÏñInfoNES_Mirroring( 0 ); //0011
//set_mirroring(NES_PPU::MIRROR_HORIZ);
}
else if(data == 2)
{
set_mirroring(0,0,0,0);
}
else
{
set_mirroring(1,1,1,1);
}
}
}
break;
case 0x9008:
{
MAPx->regs[8] = data & 0x02;
}
break;
case 0xA000:
case 0xA004:
case 0xA008:
case 0xA00C:
{
set_CPU_bank5(data);
}
break;
case 0xB000:
{
MAPx->regs[0] = (MAPx->regs[0] & 0xF0) | (data & 0x0F);
set_PPU_bank0(MAPx->regs[0]);
}
break;
case 0xB001:
case 0xB004:
{
MAPx->regs[0] = (MAPx->regs[0] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank0(MAPx->regs[0]);
}
break;
case 0xB002:
case 0xB008:
{
MAPx->regs[1] = (MAPx->regs[1] & 0xF0) | (data & 0x0F);
set_PPU_bank1(MAPx->regs[1]);
}
break;
case 0xB003:
case 0xB00C:
{
MAPx->regs[1] = (MAPx->regs[1] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank1(MAPx->regs[1]);
}
break;
case 0xC000:
{
MAPx->regs[2] = (MAPx->regs[2] & 0xF0) | (data & 0x0F);
set_PPU_bank2(MAPx->regs[2]);
}
break;
case 0xC001:
case 0xC004:
{
MAPx->regs[2] = (MAPx->regs[2] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank2(MAPx->regs[2]);
}
break;
case 0xC002:
case 0xC008:
{
MAPx->regs[3] = (MAPx->regs[3] & 0xF0) | (data & 0x0F);
set_PPU_bank3(MAPx->regs[3]);
}
break;
case 0xC003:
case 0xC00C:
{
MAPx->regs[3] = (MAPx->regs[3] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank3(MAPx->regs[3]);
}
break;
case 0xD000:
{
MAPx->regs[4] = (MAPx->regs[4] & 0xF0) | (data & 0x0F);
set_PPU_bank4(MAPx->regs[4]);
}
break;
case 0xD001:
case 0xD004:
{
MAPx->regs[4] = (MAPx->regs[4] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank4(MAPx->regs[4]);
}
break;
case 0xD002:
case 0xD008:
{
MAPx->regs[5] = (MAPx->regs[5] & 0xF0) | (data & 0x0F);
set_PPU_bank5(MAPx->regs[5]);
}
break;
case 0xD003:
case 0xD00C:
{
MAPx->regs[5] = (MAPx->regs[5] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank5(MAPx->regs[5]);
}
break;
case 0xE000:
{
MAPx->regs[6] = (MAPx->regs[6] & 0xF0) | (data & 0x0F);
set_PPU_bank6(MAPx->regs[6]);
}
break;
case 0xE001:
case 0xE004:
{
MAPx->regs[6] = (MAPx->regs[6] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank6(MAPx->regs[6]);
}
break;
case 0xE002:
case 0xE008:
{
MAPx->regs[7] = (MAPx->regs[7] & 0xF0) | (data & 0x0F);
set_PPU_bank7(MAPx->regs[7]);
}
break;
case 0xE003:
case 0xE00C:
{
MAPx->regs[7] = (MAPx->regs[7] & 0x0F) | ((data & 0x0F) << 4);
set_PPU_bank7(MAPx->regs[7]);
}
break;
case 0xF000:
{
MAPx->irq_latch = (MAPx->irq_latch & 0xF0) | (data & 0x0F);
}
break;
case 0xF004:
{
MAPx->irq_latch = (MAPx->irq_latch & 0x0F) | ((data & 0x0F) << 4);
}
break;
case 0xF008:
{
MAPx->irq_enabled = data & 0x03;
if(MAPx->irq_enabled & 0x02)
{
MAPx->irq_counter = MAPx->irq_latch;
}
}
break;
case 0xF00C:
{
MAPx->irq_enabled = (MAPx->irq_enabled & 0x01) * 3;
}
break;
}
}
void MAP23_HSync(int scanline)
{
if(MAPx->irq_enabled & 0x02)
{
if(MAPx->irq_counter == 0xFF)
{
CPU_IRQ;
MAPx->irq_counter = MAPx->irq_latch;
MAPx->irq_enabled = (MAPx->irq_enabled & 0x01) * 3;
}
else
{
MAPx->irq_counter++;
}
}
}
void MAP23_Init()
{
NES_Mapper->Reset = MAP23_Reset;
NES_Mapper->Write = MAP23_MemoryWrite;
NES_Mapper->HSync = MAP23_HSync;
}