mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-13 19:59:07 +01:00
[Core/MS] improved Japanese Master System I/O chip (315-5297) emulation (verified on real hardware by Charles MacDonald)
This commit is contained in:
parent
949e60ee32
commit
01030f1a76
Binary file not shown.
Binary file not shown.
Before Width: | Height: | Size: 3.2 MiB After Width: | Height: | Size: 3.2 MiB |
Binary file not shown.
Before Width: | Height: | Size: 3.3 MiB After Width: | Height: | Size: 3.3 MiB |
@ -4,8 +4,8 @@
|
|||||||
*
|
*
|
||||||
* Support for Master System (315-5216, 315-5237 & 315-5297), Game Gear & Mega Drive I/O chips
|
* Support for Master System (315-5216, 315-5237 & 315-5297), Game Gear & Mega Drive I/O chips
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Charles Mac Donald (original code)
|
* Copyright (C) 1998-2003 Charles Mac Donald (original code)
|
||||||
* Copyright (C) 2007-2014 Eke-Eke (Genesis Plus GX)
|
* Copyright (C) 2007-2016 Eke-Eke (Genesis Plus GX)
|
||||||
*
|
*
|
||||||
* Redistribution and use of this code or any derivative works are permitted
|
* Redistribution and use of this code or any derivative works are permitted
|
||||||
* provided that the following conditions are met:
|
* provided that the following conditions are met:
|
||||||
@ -438,13 +438,6 @@ void io_z80_write(unsigned int offset, unsigned int data, unsigned int cycles)
|
|||||||
port[0].data_w((data << 1) & 0x60, (~data << 5) & 0x60);
|
port[0].data_w((data << 1) & 0x60, (~data << 5) & 0x60);
|
||||||
port[1].data_w((data >> 1) & 0x60, (~data << 3) & 0x60);
|
port[1].data_w((data >> 1) & 0x60, (~data << 3) & 0x60);
|
||||||
|
|
||||||
/* Japanese model specific */
|
|
||||||
if (region_code == REGION_JAPAN_NTSC)
|
|
||||||
{
|
|
||||||
/* Reading TH & TR pins always return 0 when set as output */
|
|
||||||
data &= 0x0F;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check for TH low-to-high transitions on both ports */
|
/* Check for TH low-to-high transitions on both ports */
|
||||||
if ((!(io_reg[0x0F] & 0x80) && (data & 0x80)) ||
|
if ((!(io_reg[0x0F] & 0x80) && (data & 0x80)) ||
|
||||||
(!(io_reg[0x0F] & 0x20) && (data & 0x20)))
|
(!(io_reg[0x0F] & 0x20) && (data & 0x20)))
|
||||||
@ -453,6 +446,13 @@ void io_z80_write(unsigned int offset, unsigned int data, unsigned int cycles)
|
|||||||
hvc_latch = hctab[cycles % MCYCLES_PER_LINE] | 0x10000;
|
hvc_latch = hctab[cycles % MCYCLES_PER_LINE] | 0x10000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Japanese model specific */
|
||||||
|
if (region_code == REGION_JAPAN_NTSC)
|
||||||
|
{
|
||||||
|
/* Reading TH & TR pins always return 0 when set as output */
|
||||||
|
data &= 0x0F;
|
||||||
|
}
|
||||||
|
|
||||||
/* Update I/O Control register */
|
/* Update I/O Control register */
|
||||||
io_reg[0x0F] = data;
|
io_reg[0x0F] = data;
|
||||||
}
|
}
|
||||||
|
@ -4,8 +4,8 @@
|
|||||||
*
|
*
|
||||||
* Support for Master System (315-5216, 315-5237 & 315-5297), Game Gear & Mega Drive I/O chips
|
* Support for Master System (315-5216, 315-5237 & 315-5297), Game Gear & Mega Drive I/O chips
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Charles Mac Donald (original code)
|
* Copyright (C) 1998-2003 Charles Mac Donald (original code)
|
||||||
* Copyright (C) 2007-2014 Eke-Eke (Genesis Plus GX)
|
* Copyright (C) 2007-2016 Eke-Eke (Genesis Plus GX)
|
||||||
*
|
*
|
||||||
* Redistribution and use of this code or any derivative works are permitted
|
* Redistribution and use of this code or any derivative works are permitted
|
||||||
* provided that the following conditions are met:
|
* provided that the following conditions are met:
|
||||||
|
@ -4,8 +4,8 @@
|
|||||||
*
|
*
|
||||||
* Support for SG-1000, Mark-III, Master System, Game Gear & Mega Drive ports access
|
* Support for SG-1000, Mark-III, Master System, Game Gear & Mega Drive ports access
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Charles Mac Donald (original code)
|
* Copyright (C) 1998-2003 Charles Mac Donald (original code)
|
||||||
* Copyright (C) 2007-2015 Eke-Eke (Genesis Plus GX)
|
* Copyright (C) 2007-2016 Eke-Eke (Genesis Plus GX)
|
||||||
*
|
*
|
||||||
* Redistribution and use of this code or any derivative works are permitted
|
* Redistribution and use of this code or any derivative works are permitted
|
||||||
* provided that the following conditions are met:
|
* provided that the following conditions are met:
|
||||||
@ -468,20 +468,45 @@ void z80_ms_port_w(unsigned int port, unsigned char data)
|
|||||||
|
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
/* write FM chip if enabled */
|
/* check if YM2413 chip is enabled */
|
||||||
if (!(port & 4) && (config.ym2413 & 1))
|
if (config.ym2413 & 1)
|
||||||
{
|
{
|
||||||
fm_write(Z80.cycles, port, data);
|
|
||||||
|
|
||||||
/* 315-5297 I/O chip decodes bit 1 to enable/disable PSG output */
|
|
||||||
if (region_code == REGION_JAPAN_NTSC)
|
if (region_code == REGION_JAPAN_NTSC)
|
||||||
{
|
{
|
||||||
io_reg[6] = (data & 2) ? 0xFF : 0x00;
|
/* 315-5297 I/O chip decodes full address range */
|
||||||
SN76489_Config(Z80.cycles, config.psg_preamp, config.psgBoostNoise, io_reg[6]);
|
port &= 0xFF;
|
||||||
}
|
|
||||||
|
/* internal YM2413 chip */
|
||||||
|
if ((port == 0xF0) || (port == 0xF1))
|
||||||
|
{
|
||||||
|
fm_write(Z80.cycles, port, data);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Audio control register (315-5297 I/O chip specific) */
|
||||||
|
if (port == 0xF2)
|
||||||
|
{
|
||||||
|
/* D1 D0
|
||||||
|
-----
|
||||||
|
0 0 : enable only PSG output (power-on default)
|
||||||
|
0 1 : enable only FM output
|
||||||
|
1 0 : disable both PSG & FM output
|
||||||
|
1 1 : enable both PSG and FM output
|
||||||
|
*/
|
||||||
|
SN76489_Config(Z80.cycles, config.psg_preamp, config.psgBoostNoise, ((data + 1) & 0x02) ? 0x00 : 0xFF);
|
||||||
|
fm_write(Z80.cycles, 0x02, data);
|
||||||
|
io_reg[6] = data;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (!(port & 4))
|
||||||
|
{
|
||||||
|
/* external FM board */
|
||||||
|
fm_write(Z80.cycles, port, data);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
z80_unused_port_w(port & 0xFF, data);
|
z80_unused_port_w(port & 0xFF, data);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -519,19 +544,41 @@ unsigned char z80_ms_port_r(unsigned int port)
|
|||||||
}
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
{
|
||||||
|
if (region_code == REGION_JAPAN_NTSC)
|
||||||
|
{
|
||||||
|
/* 315-5297 I/O chip decodes full address range */
|
||||||
|
port &= 0xFF;
|
||||||
|
|
||||||
|
if (port == 0xF2)
|
||||||
|
{
|
||||||
|
/* D7-D5 : C-SYNC counter (not emulated)
|
||||||
|
D4-D2 : Always zero
|
||||||
|
D1 : Mute control bit 1
|
||||||
|
D0 : Mute control bit 0
|
||||||
|
*/
|
||||||
|
return io_reg[0x06] & 0x03;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((port == 0xC0) || (port == 0xC1) || (port == 0xDC) || (port == 0xDD))
|
||||||
|
{
|
||||||
|
/* read I/O ports if enabled */
|
||||||
|
if (!(io_reg[0x0E] & 0x04))
|
||||||
|
{
|
||||||
|
return io_z80_read(port & 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return z80_unused_port_r(port);
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
uint8 data = 0xFF;
|
uint8 data = 0xFF;
|
||||||
|
|
||||||
/* read FM chip if enabled */
|
/* read FM board if enabled */
|
||||||
if (!(port & 4) && (config.ym2413 & 1))
|
if (!(port & 4) && (config.ym2413 & 1))
|
||||||
{
|
{
|
||||||
data = YM2413Read();
|
data = YM2413Read();
|
||||||
|
|
||||||
/* 315-5297 I/O chip decodes full address range */
|
|
||||||
if (region_code == REGION_JAPAN_NTSC)
|
|
||||||
{
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* read I/O ports if enabled */
|
/* read I/O ports if enabled */
|
||||||
@ -543,9 +590,9 @@ unsigned char z80_ms_port_r(unsigned int port)
|
|||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------------*/
|
/*--------------------------------------------------------------------------*/
|
||||||
/* Mark III port handlers */
|
/* Mark III port handlers */
|
||||||
/*--------------------------------------------------------------------------*/
|
/*--------------------------------------------------------------------------*/
|
||||||
|
@ -4,8 +4,8 @@
|
|||||||
*
|
*
|
||||||
* Support for SG-1000, Mark-III, Master System, Game Gear & Mega Drive ports access
|
* Support for SG-1000, Mark-III, Master System, Game Gear & Mega Drive ports access
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Charles Mac Donald (original code)
|
* Copyright (C) 1998-2003 Charles Mac Donald (original code)
|
||||||
* Copyright (C) 2007-2015 Eke-Eke (Genesis Plus GX)
|
* Copyright (C) 2007-2016 Eke-Eke (Genesis Plus GX)
|
||||||
*
|
*
|
||||||
* Redistribution and use of this code or any derivative works are permitted
|
* Redistribution and use of this code or any derivative works are permitted
|
||||||
* provided that the following conditions are met:
|
* provided that the following conditions are met:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user