📄 infones_mapper.cpp
字号:
{
Map4_Chr5 = dwBankNum;
Map4_Set_PPU_Banks();
}
break;
case 0x04:
if ( NesHeader.byVRomSize > 0 )
{
Map4_Chr6 = dwBankNum;
Map4_Set_PPU_Banks();
}
break;
case 0x05:
if ( NesHeader.byVRomSize > 0 )
{
Map4_Chr7 = dwBankNum;
Map4_Set_PPU_Banks();
}
break;
/* Set ROM Banks */
case 0x06:
Map4_Prg0 = dwBankNum;
Map4_Set_CPU_Banks();
break;
case 0x07:
Map4_Prg1 = dwBankNum;
Map4_Set_CPU_Banks();
break;
}
break;
case 0xa000:
Map4_Regs[ 2 ] = byData;
if ( !ROM_FourScr )
{
if ( byData & 0x01 )
{
InfoNES_Mirroring( 0 );
} else {
InfoNES_Mirroring( 1 );
}
}
break;
case 0xa001:
Map4_Regs[ 3 ] = byData;
break;
case 0xc000:
Map4_Regs[ 4 ] = byData;
Map4_IRQ_Cnt = Map4_Regs[ 4 ];
break;
case 0xc001:
Map4_Regs[ 5 ] = byData;
Map4_IRQ_Latch = Map4_Regs[ 5 ];
break;
case 0xe000:
Map4_Regs[ 6 ] = byData;
Map4_IRQ_Enable = 0;
break;
case 0xe001:
Map4_Regs[ 7 ] = byData;
Map4_IRQ_Enable = 1;
break;
}
}
/*-------------------------------------------------------------------*/
/* Mapper 4 H-Sync Function */
/*-------------------------------------------------------------------*/
void Map4_HSync()
{
/*
* Callback at HSync
*
*/
if ( Map4_IRQ_Enable )
{
if ( 0 <= PPU_Scanline && PPU_Scanline <= 239 )
{
if ( ( PPU_R1 & R1_SHOW_SCR ) || ( PPU_R1 & R1_SHOW_SP ) )
{
if ( !( Map4_IRQ_Cnt-- ) )
{
Map4_IRQ_Cnt = Map4_IRQ_Latch;
IRQ_REQ;
}
}
}
}
}
/*-------------------------------------------------------------------*/
/* Mapper 4 Set CPU Banks Function */
/*-------------------------------------------------------------------*/
void Map4_Set_CPU_Banks()
{
if ( Map4_Prg_Swap() )
{
ROMBANK0 = ROMLASTPAGE( 1 );
ROMBANK1 = ROMPAGE( Map4_Prg1 % ( NesHeader.byRomSize << 1 ) );
ROMBANK2 = ROMPAGE( Map4_Prg0 % ( NesHeader.byRomSize << 1 ) );
ROMBANK3 = ROMLASTPAGE( 0 );
} else {
ROMBANK0 = ROMPAGE( Map4_Prg0 % ( NesHeader.byRomSize << 1 ) );
ROMBANK1 = ROMPAGE( Map4_Prg1 % ( NesHeader.byRomSize << 1 ) );
ROMBANK2 = ROMLASTPAGE( 1 );
ROMBANK3 = ROMLASTPAGE( 0 );
}
}
/*-------------------------------------------------------------------*/
/* Mapper 4 Set PPU Banks Function */
/*-------------------------------------------------------------------*/
void Map4_Set_PPU_Banks()
{
if ( NesHeader.byVRomSize > 0 )
{
if ( Map4_Chr_Swap() )
{
PPUBANK[ 0 ] = VROMPAGE( Map4_Chr4 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( Map4_Chr5 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( Map4_Chr6 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( Map4_Chr7 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( ( Map4_Chr01 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( ( Map4_Chr01 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( ( Map4_Chr23 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( ( Map4_Chr23 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VROMPAGE( ( Map4_Chr01 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( ( Map4_Chr01 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( ( Map4_Chr23 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( ( Map4_Chr23 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( Map4_Chr4 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( Map4_Chr5 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( Map4_Chr6 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( Map4_Chr7 % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
}
}
else
{
if ( Map4_Chr_Swap() )
{
PPUBANK[ 0 ] = VRAMPAGE0( 0 );
PPUBANK[ 1 ] = VRAMPAGE0( 1 );
PPUBANK[ 2 ] = VRAMPAGE0( 2 );
PPUBANK[ 3 ] = VRAMPAGE0( 3 );
PPUBANK[ 4 ] = VRAMPAGE1( 0 );
PPUBANK[ 5 ] = VRAMPAGE1( 1 );
PPUBANK[ 6 ] = VRAMPAGE1( 2 );
PPUBANK[ 7 ] = VRAMPAGE1( 3 );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VRAMPAGE1( 0 );
PPUBANK[ 1 ] = VRAMPAGE1( 1 );
PPUBANK[ 2 ] = VRAMPAGE1( 2 );
PPUBANK[ 3 ] = VRAMPAGE1( 3 );
PPUBANK[ 4 ] = VRAMPAGE0( 0 );
PPUBANK[ 5 ] = VRAMPAGE0( 1 );
PPUBANK[ 6 ] = VRAMPAGE0( 2 );
PPUBANK[ 7 ] = VRAMPAGE0( 3 );
InfoNES_SetupChr();
}
}
}
/*===================================================================*/
/* */
/* Mapper 5 (MMC5) */
/* */
/*===================================================================*/
BYTE Map5_Wram[ 0x2000 * 8 ];
BYTE Map5_Ex_Ram[ 0x400 ];
BYTE Map5_Ex_Vram[ 0x400 ];
BYTE Map5_Ex_Nam[ 0x400 ];
BYTE Map5_Prg_Reg[ 8 ];
BYTE Map5_Wram_Reg[ 8 ];
BYTE Map5_Chr_Reg[ 8 ][ 2 ];
BYTE Map5_IRQ_Enable;
BYTE Map5_IRQ_Status;
BYTE Map5_IRQ_Line;
DWORD Map5_Value0;
DWORD Map5_Value1;
BYTE Map5_Wram_Protect0;
BYTE Map5_Wram_Protect1;
BYTE Map5_Prg_Size;
BYTE Map5_Chr_Size;
BYTE Map5_Gfx_Mode;
/*-------------------------------------------------------------------*/
/* Initialize Mapper 5 */
/*-------------------------------------------------------------------*/
void Map5_Init()
{
int nPage;
/* Initialize Mapper */
MapperInit = Map5_Init;
/* Write to Mapper */
MapperWrite = Map5_Write;
/* Write to SRAM */
MapperSram = Map0_Sram;
/* Write to APU */
MapperApu = Map5_Apu;
/* Read from APU */
MapperReadApu = Map5_ReadApu;
/* Callback at VSync */
MapperVSync = Map0_VSync;
/* Callback at HSync */
MapperHSync = Map5_HSync;
/* Callback at PPU */
MapperPPU = Map0_PPU;
/* Callback at Rendering Screen ( 1:BG, 0:Sprite ) */
MapperRenderScreen = Map5_RenderScreen;
/* Set SRAM Banks */
SRAMBANK = SRAM;
/* Set ROM Banks */
ROMBANK0 = ROMLASTPAGE( 0 );
ROMBANK1 = ROMLASTPAGE( 0 );
ROMBANK2 = ROMLASTPAGE( 0 );
ROMBANK3 = ROMLASTPAGE( 0 );
/* Set PPU Banks */
for ( nPage = 0; nPage < 8; ++nPage )
PPUBANK[ nPage ] = VROMPAGE( nPage );
InfoNES_SetupChr();
/* Initialize State Registers */
for ( nPage = 4; nPage < 8; ++nPage )
{
Map5_Prg_Reg[ nPage ] = ( NesHeader.byRomSize << 1 ) - 1;
Map5_Wram_Reg[ nPage ] = 0xff;
}
Map5_Wram_Reg[ 3 ] = 0xff;
for ( BYTE byPage = 4; byPage < 8; ++byPage )
{
Map5_Chr_Reg[ byPage ][ 0 ] = byPage;
Map5_Chr_Reg[ byPage ][ 1 ] = ( byPage & 0x03 ) + 4;
}
InfoNES_MemorySet( Map5_Wram, 0x00, sizeof( Map5_Wram ) );
InfoNES_MemorySet( Map5_Ex_Ram, 0x00, sizeof( Map5_Ex_Ram ) );
InfoNES_MemorySet( Map5_Ex_Vram, 0x00, sizeof( Map5_Ex_Vram ) );
InfoNES_MemorySet( Map5_Ex_Nam, 0x00, sizeof( Map5_Ex_Nam ) );
Map5_Prg_Size = 3;
Map5_Wram_Protect0 = 0;
Map5_Wram_Protect1 = 0;
Map5_Chr_Size = 3;
Map5_Gfx_Mode = 0;
Map5_IRQ_Enable = 0;
Map5_IRQ_Status = 0;
Map5_IRQ_Line = 0;
/* Set up wiring of the interrupt pin */
K6502_Set_Int_Wiring( 1, 1 );
}
/*-------------------------------------------------------------------*/
/* Mapper 5 Read from APU Function */
/*-------------------------------------------------------------------*/
BYTE Map5_ReadApu( WORD wAddr )
{
BYTE byRet = (BYTE)( wAddr >> 8 );
switch ( wAddr )
{
case 0x5204:
byRet = Map5_IRQ_Status;
Map5_IRQ_Status = 0;
break;
case 0x5205:
byRet = (BYTE)( ( Map5_Value0 * Map5_Value1 ) & 0x00ff );
break;
case 0x5206:
byRet = (BYTE)( ( ( Map5_Value0 * Map5_Value1 ) & 0xff00 ) >> 8 );
break;
default:
if ( 0x5c00 <= wAddr && wAddr <= 0x5fff )
{
byRet = Map5_Ex_Ram[ wAddr - 0x5c00 ];
}
break;
}
return byRet;
}
/*-------------------------------------------------------------------*/
/* Mapper 5 Write to APU Function */
/*-------------------------------------------------------------------*/
void Map5_Apu( WORD wAddr, BYTE byData )
{
int nPage;
switch ( wAddr )
{
case 0x5100:
Map5_Prg_Size = byData & 0x03;
break;
case 0x5101:
Map5_Chr_Size = byData & 0x03;
break;
case 0x5102:
Map5_Wram_Protect0 = byData & 0x03;
break;
case 0x5103:
Map5_Wram_Protect1 = byData & 0x03;
break;
case 0x5104:
Map5_Gfx_Mode = byData & 0x03;
break;
case 0x5105:
for ( nPage = 0; nPage < 4; nPage++ )
{
BYTE byNamReg;
byNamReg = byData & 0x03;
byData = byData >> 2;
switch ( byNamReg )
{
case 0:
PPUBANK[ nPage + 8 ] = VRAMPAGE( 0 );
break;
case 1:
PPUBANK[ nPage + 8 ] = VRAMPAGE( 1 );
break;
case 2:
PPUBANK[ nPage + 8 ] = Map5_Ex_Vram;
break;
case 3:
PPUBANK[ nPage + 8 ] = Map5_Ex_Nam;
break;
}
}
break;
case 0x5106:
InfoNES_MemorySet( Map5_Ex_Nam, byData, 0x3c0 );
break;
case 0x5107:
byData &= 0x03;
byData = byData | ( byData << 2 ) | ( byData << 4 ) | ( byData << 6 );
InfoNES_MemorySet( &( Map5_Ex_Nam[ 0x3c0 ] ), byData, 0x400 - 0x3c0 );
break;
case 0x5113:
Map5_Wram_Reg[ 3 ] = byData & 0x07;
SRAMBANK = Map5_ROMPAGE( byData & 0x07 );
break;
case 0x5114:
case 0x5115:
case 0x5116:
case 0x5117:
Map5_Prg_Reg[ wAddr & 0x07 ] = byData;
Map5_Sync_Prg_Banks();
break;
case 0x5120:
case 0x5121:
case 0x5122:
case 0x5123:
case 0x5124:
case 0x5125:
case 0x5126:
case 0x5127:
Map5_Chr_Reg[ wAddr & 0x07 ][ 0 ] = byData;
Map5_Sync_Prg_Banks();
break;
case 0x5128:
case 0x5129:
case 0x512a:
case 0x512b:
Map5_Chr_Reg[ ( wAddr & 0x03 ) + 0 ][ 1 ] = byData;
Map5_Chr_Reg[ ( wAddr & 0x03 ) + 4 ][ 1 ] = byData;
break;
case 0x5200:
case 0x5201:
case 0x5202:
/* Nothing to do */
break;
case 0x5203:
if ( Map5_IRQ_Line >= 0x40 )
{
Map5_IRQ_Line = byData;
} else {
Map5_IRQ_Line += byData;
}
break;
case 0x5204:
Map5_IRQ_Enable = byData;
break;
case 0x5205:
Map5_Value0 = byData;
break;
case 0x5206:
Map5_Value1 = byData;
break;
default:
if ( 0x5000 <= wAddr && wAddr <= 0x5015 )
{
/* Extra Sound */
} else
if ( 0x5c00 <= wAddr && wAddr <= 0x5fff )
{
switch ( Map5_Gfx_Mode )
{
case 0:
Map5_Ex_Vram[ wAddr - 0x5c00 ] = byData;
break;
case 2:
Map5_Ex_Ram[ wAddr - 0x5c00 ] = byData;
break;
}
}
break;
}
}
/*-------------------------------------------------------------------*/
/* Mapper 5 Write to SRAM Function */
/*-------------------------------------------------------------------*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -