//////////////////////////////////////////////////////////////////////////
// Mapper082  Taito C075                                                //
//////////////////////////////////////////////////////////////////////////
void	Mapper082::Reset()
{
	reg = 0;

	SetPROM_32K_Bank( 0, 1, PROM_8K_SIZE-2, PROM_8K_SIZE-1 );

	if( VROM_8K_SIZE ) {
		SetVROM_8K_Bank( 0 );
	}

	SetVRAM_Mirror( VRAM_VMIRROR );
}

void	Mapper082::WriteLow( WORD addr, BYTE data )
{
	switch( addr ) {
		case	0x7EF0:
			if( reg ) {
				SetVROM_2K_Bank( 4, data>>1 );
			} else {
				SetVROM_2K_Bank( 0, data>>1 );
			}
			break;

		case	0x7EF1:
			if( reg ) {
				SetVROM_2K_Bank( 6, data>>1 );
			} else {
				SetVROM_2K_Bank( 2, data>>1 );
			}
			break;

		case	0x7EF2:
			if( reg ) SetVROM_1K_Bank( 0, data );
			else	  SetVROM_1K_Bank( 4, data );
			break;
		case	0x7EF3:
			if( reg ) SetVROM_1K_Bank( 1, data );
			else	  SetVROM_1K_Bank( 5, data );
			break;
		case	0x7EF4:
			if( reg ) SetVROM_1K_Bank( 2, data );
			else	  SetVROM_1K_Bank( 6, data );
			break;
		case	0x7EF5:
			if( reg ) SetVROM_1K_Bank( 3, data );
			else	  SetVROM_1K_Bank( 7, data );
			break;

		case	0x7EF6:
			reg = data & 0x02;
			if( data & 0x01 ) SetVRAM_Mirror( VRAM_VMIRROR );
			else		  SetVRAM_Mirror( VRAM_HMIRROR );
			break;

		case	0x7EFA:
			SetPROM_8K_Bank( 4, data>>2 );
			break;
		case	0x7EFB:
			SetPROM_8K_Bank( 5, data>>2 );
			break;
		case	0x7EFC:
			SetPROM_8K_Bank( 6, data>>2 );
			break;
		default:
			Mapper::WriteLow( addr, data );
			break;
	}
}

void	Mapper082::SaveState( LPBYTE p )
{
	p[0] = reg;
}

void	Mapper082::LoadState( LPBYTE p )
{
	reg = p[0];
}