forked from sin365/AxibugEmuOnline
101 lines
2.3 KiB
C++
101 lines
2.3 KiB
C++
|
//////////////////////////////////////////////////////////////////////////
|
||
|
// Mapper235 150-in-1 //
|
||
|
//////////////////////////////////////////////////////////////////////////
|
||
|
void Mapper235::Reset()
|
||
|
{
|
||
|
for( INT i = 0; i < 0x2000; i++ ) {
|
||
|
DRAM[i] = 0xFF;
|
||
|
}
|
||
|
SetPROM_32K_Bank( 0 );
|
||
|
|
||
|
if( PROM_8K_SIZE == 32*2 ) { // 20-in-1
|
||
|
dip_s=dip_s&3;
|
||
|
dip_s++;
|
||
|
// if(dip_s==4) dip_s=0;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
void Mapper235::Write( WORD addr, BYTE data )
|
||
|
{
|
||
|
BYTE prg = ((addr&0x0300)>>3)|(addr&0x001F);
|
||
|
BYTE bus = 0;
|
||
|
|
||
|
if( PROM_8K_SIZE == 64*2 ) {
|
||
|
// 100-in-1
|
||
|
switch( addr & 0x0300 ) {
|
||
|
case 0x0000: break;
|
||
|
case 0x0100: bus = 1; break;
|
||
|
case 0x0200: bus = 1; break;
|
||
|
case 0x0300: bus = 1; break;
|
||
|
}
|
||
|
} else if( PROM_8K_SIZE == 128*2 ) {
|
||
|
// 150-in-1
|
||
|
switch( addr & 0x0300 ) {
|
||
|
case 0x0000: break;
|
||
|
case 0x0100: bus = 1; break;
|
||
|
case 0x0200: prg = (prg&0x1F)|0x20; break;
|
||
|
case 0x0300: bus = 1; break;
|
||
|
}
|
||
|
} else if( PROM_8K_SIZE == 192*2 ) {
|
||
|
// 150-in-1
|
||
|
switch( addr & 0x0300 ) {
|
||
|
case 0x0000: break;
|
||
|
case 0x0100: bus = 1; break;
|
||
|
case 0x0200: prg = (prg&0x1F)|0x20; break;
|
||
|
case 0x0300: prg = (prg&0x1F)|0x40; break;
|
||
|
}
|
||
|
} else if( PROM_8K_SIZE == 256*2 ) {
|
||
|
}
|
||
|
|
||
|
if( addr & 0x0800 ) {
|
||
|
if( addr & 0x1000 ) {
|
||
|
SetPROM_8K_Bank( 4, prg*4+2 );
|
||
|
SetPROM_8K_Bank( 5, prg*4+3 );
|
||
|
SetPROM_8K_Bank( 6, prg*4+2 );
|
||
|
SetPROM_8K_Bank( 7, prg*4+3 );
|
||
|
} else {
|
||
|
SetPROM_8K_Bank( 4, prg*4+0 );
|
||
|
SetPROM_8K_Bank( 5, prg*4+1 );
|
||
|
SetPROM_8K_Bank( 6, prg*4+0 );
|
||
|
SetPROM_8K_Bank( 7, prg*4+1 );
|
||
|
}
|
||
|
} else {
|
||
|
SetPROM_32K_Bank( prg );
|
||
|
}
|
||
|
|
||
|
if( bus ) {
|
||
|
SetPROM_Bank( 4, DRAM, BANKTYPE_ROM );
|
||
|
SetPROM_Bank( 5, DRAM, BANKTYPE_ROM );
|
||
|
SetPROM_Bank( 6, DRAM, BANKTYPE_ROM );
|
||
|
SetPROM_Bank( 7, DRAM, BANKTYPE_ROM );
|
||
|
}
|
||
|
|
||
|
if( addr & 0x0400 ) {
|
||
|
SetVRAM_Mirror( VRAM_MIRROR4L );
|
||
|
} else if( addr & 0x2000 ) {
|
||
|
SetVRAM_Mirror( VRAM_HMIRROR );
|
||
|
} else {
|
||
|
SetVRAM_Mirror( VRAM_VMIRROR );
|
||
|
}
|
||
|
|
||
|
if( PROM_8K_SIZE == 32*2 ) { // 20-in-1
|
||
|
if(addr==0x8000){
|
||
|
if(data&0x80){
|
||
|
SetPROM_16K_Bank(4, data&0x1F);
|
||
|
SetPROM_16K_Bank(6, data&0x1F);
|
||
|
}else{
|
||
|
SetPROM_32K_Bank((data&0x1F)>>1);
|
||
|
}
|
||
|
if(data&0x40) SetVRAM_Mirror( VRAM_HMIRROR );
|
||
|
else SetVRAM_Mirror( VRAM_VMIRROR );
|
||
|
}
|
||
|
if(addr==0x8003){
|
||
|
// SetPROM_16K_Bank(4, dip_s);
|
||
|
SetPROM_8K_Bank(4, dip_s);
|
||
|
// SetPROM_8K_Bank(5, dip_s);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|