Various improvements to Yumefuda / Alba ZG driver [Angelo Salese]

* Hooked up basic mc6845 crtc, fixing resolution and refresh rate;
* Hooked up the ppi8255;
* Hooked up some previously unemulated system inputs;
* Added coin counter / coin lockout and added proper flip screen bit;
* Corrected system clock;
This commit is contained in:
Angelo Salese 2009-07-27 22:13:36 +00:00
parent 1a86a296a2
commit e2728b54fd

View File

@ -10,12 +10,14 @@ Notes:
from 1991. from 1991.
TODO: TODO:
-Add coin counter,coin lock etc.; -Player-2 inputs are unemulated;
-Controls dynamically changes if you turn on the Panel Type DIP-SW,I'd imagine that the "royal
panel" is just a dedicated panel for this game;
-"Custom RAM" emulation: might be a (weak) protection device or related to the "Back-up RAM NG" -"Custom RAM" emulation: might be a (weak) protection device or related to the "Back-up RAM NG"
msg that pops up at every start-up. msg that pops up at every start-up.
-Video emulation requires a major conversion to the HD46505SP C.R.T. chip (MC6845 clone) -Video emulation requires a major conversion to the HD46505SP C.R.T. chip (MC6845 clone),
there's an heavy x offsetting with the flip screen right now due of that (sets register
0x0d to 0x80 when the screen is upside-down)
-You can actually configure the coin chutes / coin lockout active high/low (!), obviously
MAME isn't really suitable for it at the current time;
============================================================================================ ============================================================================================
Code disassembling Code disassembling
@ -55,6 +57,8 @@ Code disassembling
#include "cpu/z80/z80.h" #include "cpu/z80/z80.h"
#include "machine/eeprom.h" #include "machine/eeprom.h"
#include "sound/ay8910.h" #include "sound/ay8910.h"
#include "video/mc6845.h"
#include "machine/8255ppi.h"
static tilemap *bg_tilemap; static tilemap *bg_tilemap;
static UINT8 mux_data; static UINT8 mux_data;
@ -62,7 +66,7 @@ static int bank;
static UINT8 *cus_ram; static UINT8 *cus_ram;
static UINT8 prot_lock; static UINT8 prot_lock;
#define MASTER_CLOCK XTAL_12MHz
static TILE_GET_INFO( y_get_bg_tile_info ) static TILE_GET_INFO( y_get_bg_tile_info )
{ {
@ -102,7 +106,7 @@ static const gfx_layout charlayout =
}; };
static GFXDECODE_START( yumefuda ) static GFXDECODE_START( yumefuda )
GFXDECODE_ENTRY( "gfx1", 0x0000, charlayout, 0, 0x10 ) GFXDECODE_ENTRY( "gfx1", 0x0000, charlayout, 0, 8 )
GFXDECODE_END GFXDECODE_END
@ -145,35 +149,29 @@ static WRITE8_HANDLER( eeprom_w )
eeprom_set_clock_line((data & 0x08) ? ASSERT_LINE : CLEAR_LINE); eeprom_set_clock_line((data & 0x08) ? ASSERT_LINE : CLEAR_LINE);
} }
static WRITE8_HANDLER( port_c0_w )
static READ8_DEVICE_HANDLER( eeprom_r )
{ {
// logerror("PC %04x (Port $c0) value written %02x\n",cpu_get_pc(space->cpu),data); return ((~eeprom_read_bit() & 0x01)<<6) | (input_port_read(device->machine, "SYSTEM") & ~0x40);
} }
static READ8_DEVICE_HANDLER( mux_r )
static READ8_HANDLER( eeprom_r )
{
return ((~eeprom_read_bit() & 0x01)<<6) | (0xff & ~0x40);
}
static READ8_HANDLER( mux_r )
{ {
switch(mux_data) switch(mux_data)
{ {
case 0x00: return input_port_read(space->machine, "IN0"); case 0x00: return input_port_read(device->machine, "IN0");
case 0x01: return input_port_read(space->machine, "IN1"); case 0x01: return input_port_read(device->machine, "IN1");
case 0x02: return input_port_read(space->machine, "IN2"); case 0x02: return input_port_read(device->machine, "IN2");
case 0x04: return input_port_read(space->machine, "IN3"); case 0x04: return input_port_read(device->machine, "IN3");
case 0x08: return input_port_read(space->machine, "IN4"); case 0x08: return input_port_read(device->machine, "IN4");
case 0x10: return input_port_read(space->machine, "IN5"); case 0x10: return input_port_read(device->machine, "IN5");
case 0x20: return input_port_read(space->machine, "IN6"); case 0x20: return input_port_read(device->machine, "IN6");
} }
//popmessage("%02x",mux_data);
return 0xff; return 0xff;
} }
static WRITE8_HANDLER( mux_w ) static WRITE8_DEVICE_HANDLER( mux_w )
{ {
int new_bank = (data&0xc0)>>6; int new_bank = (data&0xc0)>>6;
@ -182,32 +180,25 @@ static WRITE8_HANDLER( mux_w )
//0x14000 bonus game //0x14000 bonus game
//0x16000 ? //0x16000 ?
if(bank!=new_bank) { if(bank!=new_bank) {
UINT8 *ROM = memory_region(space->machine, "maincpu"); UINT8 *ROM = memory_region(device->machine, "maincpu");
UINT32 bankaddress; UINT32 bankaddress;
bank = new_bank; bank = new_bank;
bankaddress = 0x10000 + 0x2000 * bank; bankaddress = 0x10000 + 0x2000 * bank;
memory_set_bankptr(space->machine, 1, &ROM[bankaddress]); memory_set_bankptr(device->machine, 1, &ROM[bankaddress]);
} }
mux_data = data & ~0xc0; mux_data = data & ~0xc0;
} }
static WRITE8_HANDLER( yumefuda_videoregs_w ) static WRITE8_DEVICE_HANDLER( yumefuda_output_w )
{ {
static UINT8 address; coin_counter_w(0,~data & 4);
coin_counter_w(1,~data & 2);
if(offset == 0) coin_lockout_global_w(data & 1);
address = data; //data & 0x10 hopper-c (active LOW)
else //data & 0x08 divider (active HIGH)
{ flip_screen_set(device->machine, ~data & 0x20);
switch(address)
{
case 0x0d: flip_screen_set(space->machine, data & 0x80); break;
default:
logerror("Video Register %02x called with %02x data\n",address,data);
}
}
} }
static const ay8910_interface ay8910_config = static const ay8910_interface ay8910_config =
@ -216,10 +207,34 @@ static const ay8910_interface ay8910_config =
AY8910_DEFAULT_LOADS, AY8910_DEFAULT_LOADS,
DEVCB_INPUT_PORT("DSW1"), DEVCB_INPUT_PORT("DSW1"),
DEVCB_INPUT_PORT("DSW2"), DEVCB_INPUT_PORT("DSW2"),
DEVCB_NULL, DEVCB_HANDLER(yumefuda_output_w),
DEVCB_NULL DEVCB_NULL
}; };
static const mc6845_interface mc6845_intf =
{
"screen", /* screen we are acting on */
8, /* number of pixels per video memory address */
NULL, /* before pixel update callback */
NULL, /* row update callback */
NULL, /* after pixel update callback */
DEVCB_NULL, /* callback for display state changes */
DEVCB_NULL, /* callback for cursor state changes */
DEVCB_NULL, /* HSYNC callback */
DEVCB_NULL, /* VSYNC callback */
NULL /* update address callback */
};
static const ppi8255_interface ppi8255_intf =
{
DEVCB_NULL, /* Port A read */
DEVCB_HANDLER(eeprom_r), /* Port B read */
DEVCB_HANDLER(mux_r), /* Port C read */
DEVCB_HANDLER(mux_w), /* Port A write */
DEVCB_NULL, /* Port B write */
DEVCB_NULL /* Port C write */
};
/***************************************************************************************/ /***************************************************************************************/
static ADDRESS_MAP_START( main_map, ADDRESS_SPACE_PROGRAM, 8 ) static ADDRESS_MAP_START( main_map, ADDRESS_SPACE_PROGRAM, 8 )
@ -237,13 +252,12 @@ ADDRESS_MAP_END
static ADDRESS_MAP_START( port_map, ADDRESS_SPACE_IO, 8 ) static ADDRESS_MAP_START( port_map, ADDRESS_SPACE_IO, 8 )
ADDRESS_MAP_GLOBAL_MASK(0xff) ADDRESS_MAP_GLOBAL_MASK(0xff)
AM_RANGE(0x00, 0x01) AM_WRITE(yumefuda_videoregs_w) // HD46505SP video registers AM_RANGE(0x00, 0x00) AM_DEVWRITE("crtc", mc6845_address_w)
AM_RANGE(0x01, 0x01) AM_DEVWRITE("crtc", mc6845_register_w)
AM_RANGE(0x40, 0x40) AM_DEVREAD("ay", ay8910_r) AM_RANGE(0x40, 0x40) AM_DEVREAD("ay", ay8910_r)
AM_RANGE(0x40, 0x41) AM_DEVWRITE("ay", ay8910_address_data_w) AM_RANGE(0x40, 0x41) AM_DEVWRITE("ay", ay8910_address_data_w)
AM_RANGE(0x80, 0x80) AM_WRITE(mux_w) AM_RANGE(0x80, 0x83) AM_DEVREADWRITE("ppi8255_0", ppi8255_r, ppi8255_w)
AM_RANGE(0x81, 0x81) AM_READ(eeprom_r) AM_RANGE(0xc0, 0xc0) AM_WRITE(watchdog_reset_w)
AM_RANGE(0x82, 0x82) AM_READ(mux_r)
AM_RANGE(0xc0, 0xc0) AM_WRITE(port_c0_w) // video timing
ADDRESS_MAP_END ADDRESS_MAP_END
static MACHINE_RESET( yumefuda ) static MACHINE_RESET( yumefuda )
@ -256,7 +270,7 @@ static MACHINE_RESET( yumefuda )
static MACHINE_DRIVER_START( yumefuda ) static MACHINE_DRIVER_START( yumefuda )
/* basic machine hardware */ /* basic machine hardware */
MDRV_CPU_ADD("maincpu", Z80 , 6000000) /*???*/ MDRV_CPU_ADD("maincpu", Z80 , MASTER_CLOCK/2) /* xtal is 12 Mhz, unknown divider*/
MDRV_CPU_PROGRAM_MAP(main_map) MDRV_CPU_PROGRAM_MAP(main_map)
MDRV_CPU_IO_MAP(port_map) MDRV_CPU_IO_MAP(port_map)
MDRV_CPU_VBLANK_INT("screen", irq0_line_hold) MDRV_CPU_VBLANK_INT("screen", irq0_line_hold)
@ -264,6 +278,10 @@ static MACHINE_DRIVER_START( yumefuda )
MDRV_MACHINE_RESET(yumefuda) MDRV_MACHINE_RESET(yumefuda)
MDRV_NVRAM_HANDLER(93C46) MDRV_NVRAM_HANDLER(93C46)
MDRV_WATCHDOG_VBLANK_INIT(8) // timing is unknown
MDRV_PPI8255_ADD( "ppi8255_0", ppi8255_intf )
/* video hardware */ /* video hardware */
MDRV_SCREEN_ADD("screen", RASTER) MDRV_SCREEN_ADD("screen", RASTER)
MDRV_SCREEN_REFRESH_RATE(60) MDRV_SCREEN_REFRESH_RATE(60)
@ -272,6 +290,8 @@ static MACHINE_DRIVER_START( yumefuda )
MDRV_SCREEN_SIZE(32*8, 32*8) MDRV_SCREEN_SIZE(32*8, 32*8)
MDRV_SCREEN_VISIBLE_AREA(0, 32*8-1, 0, 32*8-1) MDRV_SCREEN_VISIBLE_AREA(0, 32*8-1, 0, 32*8-1)
MDRV_MC6845_ADD("crtc", H46505, MASTER_CLOCK/16, mc6845_intf) /* hand tuned to get ~60 fps */
MDRV_GFXDECODE( yumefuda ) MDRV_GFXDECODE( yumefuda )
MDRV_PALETTE_LENGTH(0x80) MDRV_PALETTE_LENGTH(0x80)
@ -281,7 +301,7 @@ static MACHINE_DRIVER_START( yumefuda )
/* sound hardware */ /* sound hardware */
MDRV_SPEAKER_STANDARD_MONO("mono") MDRV_SPEAKER_STANDARD_MONO("mono")
MDRV_SOUND_ADD("ay", AY8910, 1500000) MDRV_SOUND_ADD("ay", AY8910, MASTER_CLOCK/16) /* guessed to use the same xtal as the crtc */
MDRV_SOUND_CONFIG(ay8910_config) MDRV_SOUND_CONFIG(ay8910_config)
MDRV_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.50) MDRV_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.50)
MACHINE_DRIVER_END MACHINE_DRIVER_END
@ -289,10 +309,20 @@ MACHINE_DRIVER_END
/***************************************************************************************/ /***************************************************************************************/
static INPUT_PORTS_START( yumefuda ) static INPUT_PORTS_START( yumefuda )
PORT_START("SYSTEM")
PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_SERVICE1 ) PORT_NAME("Reset SW") //doesn't work?
PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_SERVICE2 ) PORT_NAME("Meter SW")
PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_OTHER ) PORT_NAME("Coin Out")
PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_OTHER ) PORT_NAME("Pay Out")
PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_SERVICE3 ) PORT_NAME("Init SW")
PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_SPECIAL ) //eeprom read bit
PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START("IN0") PORT_START("IN0")
PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_OTHER ) PORT_NAME("P1 Flip-Flop") PORT_CODE(KEYCODE_F) PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_OTHER ) PORT_NAME("P1 Flip-Flop") PORT_CODE(KEYCODE_F)
PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_OTHER ) PORT_NAME("Coupon Credit") PORT_CODE(KEYCODE_7) PORT_IMPULSE(2) //coupon PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_COIN3 ) PORT_NAME("Coupon") PORT_IMPULSE(2) //coupon
PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_OTHER ) PORT_NAME("Note Credit") PORT_CODE(KEYCODE_6) PORT_IMPULSE(2) //note PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_COIN2 ) PORT_NAME("Note") PORT_IMPULSE(2) //note
PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_COIN1 ) PORT_IMPULSE(2) PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_COIN1 ) PORT_IMPULSE(2)
PORT_BIT( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED ) PORT_BIT( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
@ -348,9 +378,7 @@ static INPUT_PORTS_START( yumefuda )
PORT_DIPNAME( 0x01, 0x01, "Learn Mode" )//SW Dip-Switches PORT_DIPNAME( 0x01, 0x01, "Learn Mode" )//SW Dip-Switches
PORT_DIPSETTING( 0x01, DEF_STR( Off ) ) PORT_DIPSETTING( 0x01, DEF_STR( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR( On ) ) PORT_DIPSETTING( 0x00, DEF_STR( On ) )
PORT_DIPNAME( 0x02, 0x02, DEF_STR( Service_Mode ) ) PORT_SERVICE( 0x02, IP_ACTIVE_LOW )
PORT_DIPSETTING( 0x02, DEF_STR( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR( On ) )
PORT_DIPNAME( 0x04, 0x04, "Hopper Payout" ) PORT_DIPNAME( 0x04, 0x04, "Hopper Payout" )
PORT_DIPSETTING( 0x04, "Hanafuda Type" )//hanaawase PORT_DIPSETTING( 0x04, "Hanafuda Type" )//hanaawase
PORT_DIPSETTING( 0x00, "Royal Type" ) PORT_DIPSETTING( 0x00, "Royal Type" )
@ -363,7 +391,7 @@ static INPUT_PORTS_START( yumefuda )
PORT_DIPNAME( 0x20, 0x20, DEF_STR( Unused ) ) PORT_DIPNAME( 0x20, 0x20, DEF_STR( Unused ) )
PORT_DIPSETTING( 0x20, DEF_STR( Off ) ) PORT_DIPSETTING( 0x20, DEF_STR( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR( On ) ) PORT_DIPSETTING( 0x00, DEF_STR( On ) )
PORT_DIPNAME( 0x40, 0x00, DEF_STR( Flip_Screen ) )//Screen Orientation PORT_DIPNAME( 0x40, 0x40, DEF_STR( Flip_Screen ) )//Screen Orientation
PORT_DIPSETTING( 0x40, DEF_STR( Off ) ) PORT_DIPSETTING( 0x40, DEF_STR( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR( On ) ) PORT_DIPSETTING( 0x00, DEF_STR( On ) )
PORT_DIPNAME( 0x80, 0x80, DEF_STR( Cabinet ) )//Screen Flip PORT_DIPNAME( 0x80, 0x80, DEF_STR( Cabinet ) )//Screen Flip
@ -386,4 +414,4 @@ ROM_START( yumefuda )
ROM_LOAD("zg001003.u3", 0xc000, 0x4000, CRC(5822ff27) SHA1(d40fa0790de3c912f770ef8f610bd8c42bc3500f)) ROM_LOAD("zg001003.u3", 0xc000, 0x4000, CRC(5822ff27) SHA1(d40fa0790de3c912f770ef8f610bd8c42bc3500f))
ROM_END ROM_END
GAME( 1991, yumefuda, 0, yumefuda, yumefuda, 0, ROT0, "Alba", "(Medal) Yumefuda [BET]", 0 ) GAME( 1991, yumefuda, 0, yumefuda, yumefuda, 0, ROT0, "Alba", "(Medal) Yumefuda [BET]", GAME_NO_COCKTAIL )