本文整理汇总了C++中InfoNES_SetupChr函数的典型用法代码示例。如果您正苦于以下问题:C++ InfoNES_SetupChr函数的具体用法?C++ InfoNES_SetupChr怎么用?C++ InfoNES_SetupChr使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了InfoNES_SetupChr函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Map99_Apu
/*-------------------------------------------------------------------*/
void Map99_Apu( WORD wAddr, BYTE byData )
{
if( wAddr == 0x4016 ) {
if( byData & 0x04 ) {
PPUBANK[ 0 ] = VROMPAGE( 8 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( 9 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( 10 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( 11 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( 12 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( 13 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( 14 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( 15 % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VROMPAGE( 0 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( 1 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( 2 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( 3 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( 4 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( 5 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( 6 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( 7 % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
}
}
if( wAddr == 0x4020 ) {
Map99_Coin = byData;
}
}
示例2: Map47_Set_PPU_Banks
/*-------------------------------------------------------------------*/
void Map47_Set_PPU_Banks()
{
if ( NesHeader.byVRomSize > 0 )
{
if ( Map47_Chr_Swap() )
{
PPUBANK[ 0 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr4 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr5 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr6 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr7 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr01 + 0 ) ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr01 + 1 ) ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr23 + 0 ) ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr23 + 1 ) ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr01 + 0 ) ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr01 + 1 ) ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr23 + 0 ) ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + ( Map47_Chr23 + 1 ) ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr4 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr5 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr6 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( ( ( Map47_Rom_Bank << 7 ) + Map47_Chr7 ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
}
}
}
示例3: Map115_Set_PPU_Banks
/*-------------------------------------------------------------------*/
void Map115_Set_PPU_Banks()
{
if ( NesHeader.byVRomSize > 0 ) {
if( Map115_Reg[0] & 0x80 ) {
PPUBANK[ 0 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr4) % (NesHeader.byVRomSize<<3));
PPUBANK[ 1 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr5) % (NesHeader.byVRomSize<<3));
PPUBANK[ 2 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr6) % (NesHeader.byVRomSize<<3));
PPUBANK[ 3 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr7) % (NesHeader.byVRomSize<<3));
PPUBANK[ 4 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr0) % (NesHeader.byVRomSize<<3));
PPUBANK[ 5 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr1) % (NesHeader.byVRomSize<<3));
PPUBANK[ 6 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr2) % (NesHeader.byVRomSize<<3));
PPUBANK[ 7 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr3) % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr0) % (NesHeader.byVRomSize<<3));
PPUBANK[ 1 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr1) % (NesHeader.byVRomSize<<3));
PPUBANK[ 2 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr2) % (NesHeader.byVRomSize<<3));
PPUBANK[ 3 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr3) % (NesHeader.byVRomSize<<3));
PPUBANK[ 4 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr4) % (NesHeader.byVRomSize<<3));
PPUBANK[ 5 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr5) % (NesHeader.byVRomSize<<3));
PPUBANK[ 6 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr6) % (NesHeader.byVRomSize<<3));
PPUBANK[ 7 ] = VROMPAGE( ((Map115_ExChrSwitch<<8)+Map115_Chr7) % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
}
}
}
示例4: Map193_Sram
/*-------------------------------------------------------------------*/
void Map193_Sram( WORD wAddr, BYTE byData )
{
switch( wAddr ) {
case 0x6000:
PPUBANK[ 0 ] = VROMPAGE( ((byData&0xfc) + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( ((byData&0xfc) + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( ((byData&0xfc) + 2 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( ((byData&0xfc) + 3 ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
break;
case 0x6001:
PPUBANK[ 4 ] = VROMPAGE( ( byData + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( ( byData + 1 ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
break;
case 0x6002:
PPUBANK[ 6 ] = VROMPAGE( ( byData + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( ( byData + 1 ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
break;
case 0x6003:
ROMBANK0 = ROMPAGE( ((byData<<2) + 0 ) % ( NesHeader.byRomSize << 1 ) );
ROMBANK1 = ROMPAGE( ((byData<<2) + 1 ) % ( NesHeader.byRomSize << 1 ) );
ROMBANK2 = ROMPAGE( ((byData<<2) + 2 ) % ( NesHeader.byRomSize << 1 ) );
ROMBANK3 = ROMPAGE( ((byData<<2) + 3 ) % ( NesHeader.byRomSize << 1 ) );
break;
}
}
示例5: Map114_Set_PPU_Banks
/*-------------------------------------------------------------------*/
void Map114_Set_PPU_Banks()
{
if ( NesHeader.byVRomSize > 0 )
{
if ( Map114_Chr_Swap() )
{
PPUBANK[ 0 ] = VROMPAGE( Map114_Chr4 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( Map114_Chr5 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( Map114_Chr6 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( Map114_Chr7 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( ( Map114_Chr01 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( ( Map114_Chr01 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( ( Map114_Chr23 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( ( Map114_Chr23 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VROMPAGE( ( Map114_Chr01 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( ( Map114_Chr01 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( ( Map114_Chr23 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( ( Map114_Chr23 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( Map114_Chr4 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( Map114_Chr5 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( Map114_Chr6 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( Map114_Chr7 % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
}
}
}
示例6: Map185_Write
/*-------------------------------------------------------------------*/
void Map185_Write( WORD wAddr, BYTE byData )
{
/* Set PPU Banks */
if ( byData & 0x03 )
{
PPUBANK[ 0 ] = VROMPAGE( 0 );
PPUBANK[ 1 ] = VROMPAGE( 1 );
PPUBANK[ 2 ] = VROMPAGE( 2 );
PPUBANK[ 3 ] = VROMPAGE( 3 );
PPUBANK[ 4 ] = VROMPAGE( 4 );
PPUBANK[ 5 ] = VROMPAGE( 5 );
PPUBANK[ 6 ] = VROMPAGE( 6 );
PPUBANK[ 7 ] = VROMPAGE( 7 );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = Map185_Dummy_Chr_Rom;
PPUBANK[ 1 ] = Map185_Dummy_Chr_Rom;
PPUBANK[ 2 ] = Map185_Dummy_Chr_Rom;
PPUBANK[ 3 ] = Map185_Dummy_Chr_Rom;
PPUBANK[ 4 ] = Map185_Dummy_Chr_Rom;
PPUBANK[ 5 ] = Map185_Dummy_Chr_Rom;
PPUBANK[ 6 ] = Map185_Dummy_Chr_Rom;
PPUBANK[ 7 ] = Map185_Dummy_Chr_Rom;
InfoNES_SetupChr();
}
}
示例7: Map249_Write
/*-------------------------------------------------------------------*/
void Map249_Write( WORD wAddr, BYTE byData )
{
BYTE byM0,byM1,byM2,byM3,byM4,byM5,byM6,byM7;
switch( wAddr&0xFF01 ) {
case 0x8000:
case 0x8800:
Map249_Reg[0] = byData;
break;
case 0x8001:
case 0x8801:
switch( Map249_Reg[0] & 0x07 ) {
case 0x00:
if( Map249_Spdata == 1 ) {
byM0=byData&0x1;
byM1=(byData&0x02)>>1;
byM2=(byData&0x04)>>2;
byM3=(byData&0x08)>>3;
byM4=(byData&0x10)>>4;
byM5=(byData&0x20)>>5;
byM6=(byData&0x40)>>6;
byM7=(byData&0x80)>>7;
byData=(byM5<<7)|(byM4<<6)|(byM2<<5)|(byM6<<4)|(byM7<<3)|(byM3<<2)|(byM1<<1)|byM0;
}
PPUBANK[ 0 ] = VROMPAGE((byData&0xFE) % (NesHeader.byVRomSize<<3));
PPUBANK[ 1 ] = VROMPAGE((byData|0x01) % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
break;
case 0x01:
if( Map249_Spdata == 1 ) {
byM0=byData&0x1;
byM1=(byData&0x02)>>1;
byM2=(byData&0x04)>>2;
byM3=(byData&0x08)>>3;
byM4=(byData&0x10)>>4;
byM5=(byData&0x20)>>5;
byM6=(byData&0x40)>>6;
byM7=(byData&0x80)>>7;
byData=(byM5<<7)|(byM4<<6)|(byM2<<5)|(byM6<<4)|(byM7<<3)|(byM3<<2)|(byM1<<1)|byM0;
}
PPUBANK[ 2 ] = VROMPAGE((byData&0xFE) % (NesHeader.byVRomSize<<3));
PPUBANK[ 3 ] = VROMPAGE((byData|0x01) % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
break;
case 0x02:
if( Map249_Spdata == 1 ) {
byM0=byData&0x1;
byM1=(byData&0x02)>>1;
byM2=(byData&0x04)>>2;
byM3=(byData&0x08)>>3;
byM4=(byData&0x10)>>4;
byM5=(byData&0x20)>>5;
byM6=(byData&0x40)>>6;
byM7=(byData&0x80)>>7;
byData=(byM5<<7)|(byM4<<6)|(byM2<<5)|(byM6<<4)|(byM7<<3)|(byM3<<2)|(byM1<<1)|byM0;
}
示例8: Map10_PPU
/*-------------------------------------------------------------------*/
void Map10_PPU( WORD wAddr )
{
/* Control Latch Selector */
switch ( wAddr & 0x3ff0 )
{
case 0x0fd0:
/* Latch Control */
latch3.state = 0xfd;
/* Set PPU Banks */
PPUBANK[ 0 ] = VROMPAGE( latch3.lo_bank );
PPUBANK[ 1 ] = VROMPAGE( latch3.lo_bank + 1 );
PPUBANK[ 2 ] = VROMPAGE( latch3.lo_bank + 2 );
PPUBANK[ 3 ] = VROMPAGE( latch3.lo_bank + 3 );
InfoNES_SetupChr();
break;
case 0x0fe0:
/* Latch Control */
latch3.state = 0xfe;
/* Set PPU Banks */
PPUBANK[ 0 ] = VROMPAGE( latch3.hi_bank );
PPUBANK[ 1 ] = VROMPAGE( latch3.hi_bank + 1 );
PPUBANK[ 2 ] = VROMPAGE( latch3.hi_bank + 2 );
PPUBANK[ 3 ] = VROMPAGE( latch3.hi_bank + 3 );
InfoNES_SetupChr();
break;
case 0x1fd0:
/* Latch Control */
latch4.state = 0xfd;
/* Set PPU Banks */
PPUBANK[ 4 ] = VROMPAGE( latch4.lo_bank );
PPUBANK[ 5 ] = VROMPAGE( latch4.lo_bank + 1 );
PPUBANK[ 6 ] = VROMPAGE( latch4.lo_bank + 2 );
PPUBANK[ 7 ] = VROMPAGE( latch4.lo_bank + 3 );
InfoNES_SetupChr();
break;
case 0x1fe0:
/* Latch Control */
latch4.state = 0xfe;
/* Set PPU Banks */
PPUBANK[ 4 ] = VROMPAGE( latch4.hi_bank );
PPUBANK[ 5 ] = VROMPAGE( latch4.hi_bank + 1 );
PPUBANK[ 6 ] = VROMPAGE( latch4.hi_bank + 2 );
PPUBANK[ 7 ] = VROMPAGE( latch4.hi_bank + 3 );
InfoNES_SetupChr();
break;
}
}
示例9: Map251_Set_Banks
/*-------------------------------------------------------------------*/
void Map251_Set_Banks()
{
int nChr[6];
int nPrg[4];
int i ;
for (i = 0; i < 6; i++ ) {
nChr[i] = (Map251_Reg[i]|(Map251_Breg[1]<<4)) & ((Map251_Breg[2]<<4)|0x0F);
}
if( Map251_Reg[8] & 0x80 ) {
PPUBANK[ 0 ] = VROMPAGE(nChr[2] % (NesHeader.byVRomSize<<3));
PPUBANK[ 1 ] = VROMPAGE(nChr[3] % (NesHeader.byVRomSize<<3));
PPUBANK[ 2 ] = VROMPAGE(nChr[4] % (NesHeader.byVRomSize<<3));
PPUBANK[ 3 ] = VROMPAGE(nChr[5] % (NesHeader.byVRomSize<<3));
PPUBANK[ 4 ] = VROMPAGE(nChr[0] % (NesHeader.byVRomSize<<3));
PPUBANK[ 5 ] = VROMPAGE((nChr[0]+1) % (NesHeader.byVRomSize<<3));
PPUBANK[ 6 ] = VROMPAGE(nChr[1] % (NesHeader.byVRomSize<<3));
PPUBANK[ 7 ] = VROMPAGE((nChr[1]+1) % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VROMPAGE(nChr[0] % (NesHeader.byVRomSize<<3));
PPUBANK[ 1 ] = VROMPAGE((nChr[0]+1) % (NesHeader.byVRomSize<<3));
PPUBANK[ 2 ] = VROMPAGE(nChr[1] % (NesHeader.byVRomSize<<3));
PPUBANK[ 3 ] = VROMPAGE((nChr[1]+1) % (NesHeader.byVRomSize<<3));
PPUBANK[ 4 ] = VROMPAGE(nChr[2] % (NesHeader.byVRomSize<<3));
PPUBANK[ 5 ] = VROMPAGE(nChr[3] % (NesHeader.byVRomSize<<3));
PPUBANK[ 6 ] = VROMPAGE(nChr[4] % (NesHeader.byVRomSize<<3));
PPUBANK[ 7 ] = VROMPAGE(nChr[5] % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
}
nPrg[0] = (Map251_Reg[6]&((Map251_Breg[3]&0x3F)^0x3F))|(Map251_Breg[1]);
nPrg[1] = (Map251_Reg[7]&((Map251_Breg[3]&0x3F)^0x3F))|(Map251_Breg[1]);
nPrg[2] = nPrg[3] =((Map251_Breg[3]&0x3F)^0x3F)|(Map251_Breg[1]);
nPrg[2] &= (NesHeader.byRomSize<<1)-1;
if( Map251_Reg[8] & 0x40 ) {
ROMBANK0 = ROMPAGE(nPrg[2] % (NesHeader.byRomSize<<1));
ROMBANK1 = ROMPAGE(nPrg[1] % (NesHeader.byRomSize<<1));
ROMBANK2 = ROMPAGE(nPrg[0] % (NesHeader.byRomSize<<1));
ROMBANK3 = ROMPAGE(nPrg[3] % (NesHeader.byRomSize<<1));
} else {
ROMBANK0 = ROMPAGE(nPrg[0] % (NesHeader.byRomSize<<1));
ROMBANK1 = ROMPAGE(nPrg[1] % (NesHeader.byRomSize<<1));
ROMBANK2 = ROMPAGE(nPrg[2] % (NesHeader.byRomSize<<1));
ROMBANK3 = ROMPAGE(nPrg[3] % (NesHeader.byRomSize<<1));
}
}
示例10: SetBank_PPU
/*-------------------------------------------------------------------*/
void SetBank_PPU()
{
if( NesHeader.byVRomSize > 0 ) {
if( Map245_Reg[0] & 0x80 ) {
PPUBANK[ 0 ] = VROMPAGE( Map245_Chr4 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( Map245_Chr5 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( Map245_Chr6 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( Map245_Chr7 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( ( Map245_Chr01 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( ( Map245_Chr01 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( ( Map245_Chr23 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( ( Map245_Chr23 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = VROMPAGE( ( Map245_Chr01 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 1 ] = VROMPAGE( ( Map245_Chr01 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 2 ] = VROMPAGE( ( Map245_Chr23 + 0 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 3 ] = VROMPAGE( ( Map245_Chr23 + 1 ) % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 4 ] = VROMPAGE( Map245_Chr4 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 5 ] = VROMPAGE( Map245_Chr5 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 6 ] = VROMPAGE( Map245_Chr6 % ( NesHeader.byVRomSize << 3 ) );
PPUBANK[ 7 ] = VROMPAGE( Map245_Chr7 % ( NesHeader.byVRomSize << 3 ) );
InfoNES_SetupChr();
}
} else {
if( Map245_Reg[0] & 0x80 ) {
PPUBANK[ 4 ] = CRAMPAGE( (Map245_Chr01+0)&0x07 );
PPUBANK[ 5 ] = CRAMPAGE( (Map245_Chr01+1)&0x07 );
PPUBANK[ 6 ] = CRAMPAGE( (Map245_Chr23+0)&0x07 );
PPUBANK[ 7 ] = CRAMPAGE( (Map245_Chr23+1)&0x07 );
PPUBANK[ 0 ] = CRAMPAGE( Map245_Chr4&0x07 );
PPUBANK[ 1 ] = CRAMPAGE( Map245_Chr5&0x07 );
PPUBANK[ 2 ] = CRAMPAGE( Map245_Chr6&0x07 );
PPUBANK[ 3 ] = CRAMPAGE( Map245_Chr7&0x07 );
InfoNES_SetupChr();
} else {
PPUBANK[ 0 ] = CRAMPAGE( (Map245_Chr01+0)&0x07 );
PPUBANK[ 1 ] = CRAMPAGE( (Map245_Chr01+1)&0x07 );
PPUBANK[ 2 ] = CRAMPAGE( (Map245_Chr23+0)&0x07 );
PPUBANK[ 3 ] = CRAMPAGE( (Map245_Chr23+1)&0x07 );
PPUBANK[ 4 ] = CRAMPAGE( Map245_Chr4&0x07 );
PPUBANK[ 5 ] = CRAMPAGE( Map245_Chr5&0x07 );
PPUBANK[ 6 ] = CRAMPAGE( Map245_Chr6&0x07 );
PPUBANK[ 7 ] = CRAMPAGE( Map245_Chr7&0x07 );
InfoNES_SetupChr();
}
}
}
示例11: Map72_Write
/*-------------------------------------------------------------------*/
void Map72_Write( WORD wAddr, BYTE byData )
{
BYTE byBank = byData & 0x0f;
if ( byData & 0x80 )
{
/* Set ROM Banks */
byBank <<= 1;
byBank %= ( NesHeader.byRomSize << 1 );
ROMBANK0 = ROMPAGE( byBank );
ROMBANK1 = ROMPAGE( byBank + 1 );
} else
if ( byData & 0x40 )
{
/* Set PPU Banks */
byBank <<= 3;
byBank %= ( NesHeader.byVRomSize << 3 );
PPUBANK[ 0 ] = VROMPAGE( byBank );
PPUBANK[ 1 ] = VROMPAGE( byBank + 1 );
PPUBANK[ 2 ] = VROMPAGE( byBank + 2 );
PPUBANK[ 3 ] = VROMPAGE( byBank + 3 );
PPUBANK[ 4 ] = VROMPAGE( byBank + 4 );
PPUBANK[ 5 ] = VROMPAGE( byBank + 5 );
PPUBANK[ 6 ] = VROMPAGE( byBank + 6 );
PPUBANK[ 7 ] = VROMPAGE( byBank + 7 );
InfoNES_SetupChr();
}
}
示例12: Map62_Write
/*-------------------------------------------------------------------*/
void Map62_Write( WORD wAddr, BYTE byData )
{
switch( wAddr & 0xFF00 ) {
case 0x8100:
ROMBANK0 = ROMPAGE((byData+0) % (NesHeader.byRomSize<<1));
ROMBANK1 = ROMPAGE((byData+1) % (NesHeader.byRomSize<<1));
break;
case 0x8500:
ROMBANK0 = ROMPAGE(byData % (NesHeader.byRomSize<<1));
break;
case 0x8700:
ROMBANK1 = ROMPAGE(byData % (NesHeader.byRomSize<<1));
break;
default:
PPUBANK[ 0 ] = VROMPAGE((byData+0) % (NesHeader.byVRomSize<<3));
PPUBANK[ 1 ] = VROMPAGE((byData+1) % (NesHeader.byVRomSize<<3));
PPUBANK[ 2 ] = VROMPAGE((byData+2) % (NesHeader.byVRomSize<<3));
PPUBANK[ 3 ] = VROMPAGE((byData+3) % (NesHeader.byVRomSize<<3));
PPUBANK[ 4 ] = VROMPAGE((byData+4) % (NesHeader.byVRomSize<<3));
PPUBANK[ 5 ] = VROMPAGE((byData+5) % (NesHeader.byVRomSize<<3));
PPUBANK[ 6 ] = VROMPAGE((byData+6) % (NesHeader.byVRomSize<<3));
PPUBANK[ 7 ] = VROMPAGE((byData+7) % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
break;
}
}
示例13: Map70_Write
/*-------------------------------------------------------------------*/
void Map70_Write( WORD wAddr, BYTE byData )
{
BYTE byChrBank = byData & 0x0f;
BYTE byPrgBank = ( byData & 0x70 ) >> 4;
/* Set ROM Banks */
byPrgBank <<= 1;
byPrgBank %= ( NesHeader.byRomSize << 1 );
ROMBANK0 = ROMPAGE( byPrgBank );
ROMBANK1 = ROMPAGE( byPrgBank + 1 );
/* Set PPU Banks */
byChrBank <<= 3;
byChrBank %= ( NesHeader.byVRomSize << 3 );
PPUBANK[ 0 ] = VROMPAGE( byChrBank + 0 );
PPUBANK[ 1 ] = VROMPAGE( byChrBank + 1 );
PPUBANK[ 2 ] = VROMPAGE( byChrBank + 2 );
PPUBANK[ 3 ] = VROMPAGE( byChrBank + 3 );
PPUBANK[ 4 ] = VROMPAGE( byChrBank + 4 );
PPUBANK[ 5 ] = VROMPAGE( byChrBank + 5 );
PPUBANK[ 6 ] = VROMPAGE( byChrBank + 6 );
PPUBANK[ 7 ] = VROMPAGE( byChrBank + 7 );
InfoNES_SetupChr();
/* Name Table Mirroring */
if ( byData & 0x80 )
{
InfoNES_Mirroring( 2 );
} else {
InfoNES_Mirroring( 3 );
}
}
示例14: Map202_WriteSub
/*-------------------------------------------------------------------*/
void Map202_WriteSub( WORD wAddr, BYTE byData )
{
int bank = (wAddr>>1) & 0x07;
/* Set ROM Banks */
ROMBANK0 = ROMPAGE(((bank<<1)+0) % (NesHeader.byRomSize<<1));
ROMBANK1 = ROMPAGE(((bank<<1)+1) % (NesHeader.byRomSize<<1));
if ((wAddr&0x0c) == 0x0c) {
ROMBANK2 = ROMPAGE((((bank+1)<<1)+0) % (NesHeader.byRomSize<<1));
ROMBANK3 = ROMPAGE((((bank+1)<<1)+1) % (NesHeader.byRomSize<<1));
} else {
ROMBANK2 = ROMPAGE((((bank+0)<<1)+0) % (NesHeader.byRomSize<<1));
ROMBANK3 = ROMPAGE((((bank+0)<<1)+1) % (NesHeader.byRomSize<<1));
}
/* Set PPU Banks */
PPUBANK[0] = VROMPAGE(((bank<<3)+0) % (NesHeader.byVRomSize<<3));
PPUBANK[1] = VROMPAGE(((bank<<3)+1) % (NesHeader.byVRomSize<<3));
PPUBANK[2] = VROMPAGE(((bank<<3)+2) % (NesHeader.byVRomSize<<3));
PPUBANK[3] = VROMPAGE(((bank<<3)+3) % (NesHeader.byVRomSize<<3));
PPUBANK[4] = VROMPAGE(((bank<<3)+4) % (NesHeader.byVRomSize<<3));
PPUBANK[5] = VROMPAGE(((bank<<3)+5) % (NesHeader.byVRomSize<<3));
PPUBANK[6] = VROMPAGE(((bank<<3)+6) % (NesHeader.byVRomSize<<3));
PPUBANK[7] = VROMPAGE(((bank<<3)+7) % (NesHeader.byVRomSize<<3));
InfoNES_SetupChr();
if ( wAddr & 0x01 ) {
InfoNES_Mirroring( 0 );
} else {
InfoNES_Mirroring( 1 );
}
}
示例15: Map10_Init
/*-------------------------------------------------------------------*/
void Map10_Init()
{
int nPage;
/* Initialize Mapper */
MapperInit = Map10_Init;
/* Write to Mapper */
MapperWrite = Map10_Write;
/* Write to SRAM */
MapperSram = Map0_Sram;
/* Write to APU */
MapperApu = Map0_Apu;
/* Read from APU */
MapperReadApu = Map0_ReadApu;
/* Callback at VSync */
MapperVSync = Map0_VSync;
/* Callback at HSync */
MapperHSync = Map0_HSync;
/* Callback at PPU */
MapperPPU = Map10_PPU;
/* Callback at Rendering Screen ( 1:BG, 0:Sprite ) */
MapperRenderScreen = Map0_RenderScreen;
/* Set SRAM Banks */
SRAMBANK = SRAM;
/* Set ROM Banks */
ROMBANK0 = ROMPAGE( 0 );
ROMBANK1 = ROMPAGE( 1 );
ROMBANK2 = ROMLASTPAGE( 1 );
ROMBANK3 = ROMLASTPAGE( 0 );
/* Set PPU Banks */
if ( NesHeader.byVRomSize > 0 )
{
for ( nPage = 0; nPage < 8; ++nPage )
PPUBANK[ nPage ] = VROMPAGE( nPage );
InfoNES_SetupChr();
}
/* Init Latch Selector */
latch3.state = 0xfe;
latch3.lo_bank = 0;
latch3.hi_bank = 0;
latch4.state = 0xfe;
latch4.lo_bank = 0;
latch4.hi_bank = 0;
/* Set up wiring of the interrupt pin */
K6502_Set_Int_Wiring( 1, 1 );
}