From 8347973e18992ad92eeccb489b1c5b896cfda78a Mon Sep 17 00:00:00 2001 From: angelosa Date: Sun, 3 Jul 2016 17:49:42 +0200 Subject: [PATCH] Splitted Seibu Cup Soccer bootlegs into own driver (nw) --- scripts/target/mame/arcade.lua | 1 + src/mame/arcade.flt | 1 + src/mame/drivers/legionna.cpp | 307 ---------------- src/mame/drivers/seicupbl.cpp | 578 +++++++++++++++++++++++++++++++ src/mame/etc/template_cpu.cpp | 2 +- src/mame/etc/template_cpu.h | 2 +- src/mame/etc/template_device.cpp | 2 +- src/mame/etc/template_device.h | 2 +- src/mame/etc/template_driver.cpp | 2 +- src/mame/includes/legionna.h | 3 - src/mame/machine/seicop.cpp | 28 +- src/mame/machine/seicop.h | 2 +- 12 files changed, 590 insertions(+), 340 deletions(-) create mode 100644 src/mame/drivers/seicupbl.cpp diff --git a/scripts/target/mame/arcade.lua b/scripts/target/mame/arcade.lua index e83cc986b28..cf54dbe31aa 100644 --- a/scripts/target/mame/arcade.lua +++ b/scripts/target/mame/arcade.lua @@ -3259,6 +3259,7 @@ files { MAME_DIR .. "src/mame/drivers/legionna.cpp", MAME_DIR .. "src/mame/includes/legionna.h", MAME_DIR .. "src/mame/video/legionna.cpp", + MAME_DIR .. "src/mame/drivers/seicupbl.cpp", MAME_DIR .. "src/mame/drivers/metlfrzr.cpp", MAME_DIR .. "src/mame/drivers/mustache.cpp", MAME_DIR .. "src/mame/includes/mustache.h", diff --git a/src/mame/arcade.flt b/src/mame/arcade.flt index 46ce6839c70..d663b173402 100644 --- a/src/mame/arcade.flt +++ b/src/mame/arcade.flt @@ -995,6 +995,7 @@ segaxbd.cpp segaybd.cpp seibuspi.cpp seicross.cpp +seicupbl.cpp sengokmj.cpp senjyo.cpp seta.cpp diff --git a/src/mame/drivers/legionna.cpp b/src/mame/drivers/legionna.cpp index 9abdad78f1c..f570a8c3416 100644 --- a/src/mame/drivers/legionna.cpp +++ b/src/mame/drivers/legionna.cpp @@ -351,47 +351,6 @@ static ADDRESS_MAP_START( cupsocs_mem, AS_PROGRAM, 16, legionna_state ) AM_RANGE(0x11e000, 0x11ffff) AM_RAM /*Stack Ram*/ ADDRESS_MAP_END -static ADDRESS_MAP_START( cupsocbl_mem, AS_PROGRAM, 16, legionna_state ) - AM_IMPORT_FROM( legionna_cop_mem ) - AM_RANGE(0x000000, 0x0fffff) AM_ROM - //AM_RANGE(0x100000, 0x1003ff) AM_RAM - AM_RANGE(0x100600, 0x10060f) AM_DEVREADWRITE("crtc", seibu_crtc_device, read, write)//? - AM_RANGE(0x100640, 0x10067f) AM_DEVREADWRITE("crtc", seibu_crtc_device, read, write) - AM_RANGE(0x100680, 0x100681) AM_WRITENOP // irq ack? - AM_RANGE(0x100700, 0x100701) AM_READ_PORT("DSW1") - AM_RANGE(0x100704, 0x100705) AM_READ_PORT("PLAYERS12") - AM_RANGE(0x100708, 0x100709) AM_READ_PORT("PLAYERS34") - AM_RANGE(0x10070c, 0x10070d) AM_READ_PORT("SYSTEM") - AM_RANGE(0x100000, 0x1007ff) AM_DEVREADWRITE("seibucop_boot", seibu_cop_bootleg_device, copdxbl_0_r,copdxbl_0_w) AM_SHARE("cop_mcu_ram") - AM_RANGE(0x100800, 0x100fff) AM_RAM // _WRITE(legionna_background_w) AM_SHARE("back_data") - AM_RANGE(0x101000, 0x1017ff) AM_RAM // _WRITE(legionna_foreground_w) AM_SHARE("fore_data") - AM_RANGE(0x101800, 0x101fff) AM_RAM // _WRITE(legionna_midground_w) AM_SHARE("mid_data") - AM_RANGE(0x102000, 0x102fff) AM_RAM // _WRITE(legionna_text_w) AM_SHARE("textram") - AM_RANGE(0x103000, 0x103fff) AM_RAM // _DEVWRITE("palette", palette_device, write) AM_SHARE("palette") - AM_RANGE(0x104000, 0x104fff) AM_RAM - AM_RANGE(0x105000, 0x106fff) AM_RAM - AM_RANGE(0x107000, 0x1077ff) AM_RAM AM_SHARE("spriteram") - AM_RANGE(0x107800, 0x107fff) AM_RAM /*Ani Dsp(?) Ram*/ - AM_RANGE(0x108000, 0x10ffff) AM_RAM - AM_RANGE(0x110000, 0x119fff) AM_RAM - AM_RANGE(0x11a000, 0x11dfff) AM_RAM - AM_RANGE(0x11e000, 0x11ffff) AM_RAM /*Stack Ram*/ -ADDRESS_MAP_END - - -WRITE8_MEMBER(legionna_state::okim_rombank_w) -{ -// popmessage("%08x",0x40000 * (data & 0x07)); - m_oki->set_bank_base(0x40000 * (data & 0x7)); -} - -static ADDRESS_MAP_START( cupsocbl_sound_mem, AS_PROGRAM, 8, legionna_state ) - AM_RANGE(0x0000, 0x7fff) AM_ROM - AM_RANGE(0x8000, 0x87ff) AM_RAM - AM_RANGE(0x9000, 0x9000) AM_WRITE(okim_rombank_w) - AM_RANGE(0x9800, 0x9800) AM_DEVREADWRITE("oki", okim6295_device, read, write) - AM_RANGE(0xa000, 0xa000) AM_DEVREAD("soundlatch", generic_latch_8_device, read) -ADDRESS_MAP_END /*****************************************************************************/ @@ -1450,54 +1409,6 @@ static MACHINE_CONFIG_DERIVED( cupsocs, cupsoc ) MCFG_CPU_PROGRAM_MAP(cupsocs_mem) MACHINE_CONFIG_END -static MACHINE_CONFIG_START( cupsocbl, legionna_state ) - - /* basic machine hardware */ - MCFG_CPU_ADD("maincpu", M68000,12000000) - MCFG_CPU_PROGRAM_MAP(cupsocbl_mem) - MCFG_CPU_VBLANK_INT_DRIVER("screen", legionna_state, irq4_line_hold) /* VBL */ - - MCFG_DEVICE_SEIBUCOP_BOOTLEG_ADD("seibucop_boot") - MCFG_DEVICE_ADD("raiden2cop", RAIDEN2COP, 0) // TODO: what? - MCFG_RAIDEN2COP_VIDEORAM_OUT_CB(WRITE16(legionna_state, videowrite_cb_w)) - - - /*Different Sound hardware*/ - //SEIBU_SOUND_SYSTEM_CPU(14318180/4) - MCFG_CPU_ADD("audiocpu", Z80,14318180/4) - MCFG_CPU_PROGRAM_MAP(cupsocbl_sound_mem) - //MCFG_PERIODIC_INT("screen", nmi_line_pulse) - - /* video hardware */ - MCFG_SCREEN_ADD("screen", RASTER) - MCFG_SCREEN_REFRESH_RATE(60) - MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0)) - MCFG_SCREEN_SIZE(42*8, 36*8) - MCFG_SCREEN_VISIBLE_AREA(0*8, 40*8-1, 0*8, 30*8-1) - MCFG_SCREEN_UPDATE_DRIVER(legionna_state, screen_update_grainbow) - MCFG_SCREEN_PALETTE("palette") - - MCFG_DEVICE_ADD("crtc", SEIBU_CRTC, 0) - MCFG_SEIBU_CRTC_LAYER_EN_CB(WRITE16(legionna_state, tilemap_enable_w)) - MCFG_SEIBU_CRTC_LAYER_SCROLL_CB(WRITE16(legionna_state, tile_scroll_w)) - MCFG_SEIBU_CRTC_REG_1A_CB(WRITE16(legionna_state, tile_vreg_1a_w)) - - MCFG_GFXDECODE_ADD("gfxdecode", "palette", heatbrl_csb) - - MCFG_PALETTE_ADD_INIT_BLACK("palette", 128*16) - //MCFG_PALETTE_FORMAT(xBBBBBGGGGGRRRRR) - - MCFG_VIDEO_START_OVERRIDE(legionna_state,cupsoc) - - /* sound hardware */ - MCFG_SPEAKER_STANDARD_MONO("mono") - - MCFG_GENERIC_LATCH_8_ADD("soundlatch") - - MCFG_OKIM6295_ADD("oki", 1000000, OKIM6295_PIN7_HIGH) - MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 1.0) -MACHINE_CONFIG_END - /*************************************************************************** Game driver(s) @@ -2469,221 +2380,6 @@ ROM_START( olysoc92b ) ROM_LOAD( "copx-d1.bin", 0x000000, 0x080000, CRC(029bc402) SHA1(0f64e4c32d95abfa3920b39ed3cf0cc6eb50191b) ) ROM_END -/* - -Seibu Cup Soccer - Seibu - Bootleg - -2 boards - -1st board - -(snd) -1 x z80 -1 x oki 6295 -sc_01 (prg) -sc_02 and sc_03 (data) - -(prg) -1 x 68000 -sc_04 and sc_05 - -(gfx) -2 x ti tpc1020 -from sc_06 to sc_11 - -2nd board - -(gfx) -1 x actel pl84c -from sc_12 to sc_15 - -*/ - -ROM_START( cupsocsb ) - ROM_REGION( 0x100000, "maincpu", 0 ) /* 68000 Code */ - ROM_LOAD16_BYTE( "sc_04.bin", 0x00001, 0x80000, CRC(22566087) SHA1(4392f46ca50cc9947823a5190aa25f5e9654aa0d) ) - ROM_LOAD16_BYTE( "sc_05.bin", 0x00000, 0x80000, CRC(2f977dff) SHA1(4d8d6e7d06ce17bb7292072965911f8b1f1067e2) ) - - ROM_REGION( 0x10000, "audiocpu", 0 ) /* Z80 code */ - ROM_LOAD( "sc_01.bin", 0x000000, 0x08000, CRC(cea39d6d) SHA1(f0b79c03ffafdd1e57673d6d4836becbe415110b) ) - ROM_CONTINUE( 0x000000, 0x08000 ) - - ROM_REGION( 0x200000, "sprite", ROMREGION_INVERT ) /* bootleg sprite gfx */ - ROM_LOAD( "sc_07.bin", 0x000000, 0x080000, CRC(dcb29d01) SHA1(72b4234622605f0ab03f21fdb6a61c6dac36000d) ) - ROM_LOAD( "sc_06.bin", 0x080000, 0x080000, CRC(2dc70e05) SHA1(f1d0beb8428a7e1d7c7818e6719abdc543b2fa80) ) - ROM_COPY( "sprite", 0x000000, 0x100000, 0x100000 ) - - ROM_REGION( 0x200000, "test1", 0 ) /* bootleg tile gfx */ - ROM_LOAD16_BYTE( "sc_09.bin", 0x000000, 0x080000, CRC(695b6342) SHA1(dfccb43789021ba2568b9284ae61e64f7f89b152) ) - ROM_LOAD16_BYTE( "sc_10.bin", 0x000001, 0x080000, CRC(27e172b8) SHA1(ed86db2f42c8061607d46f2407b0130aaf692a02) ) - ROM_LOAD16_BYTE( "sc_08.bin", 0x100000, 0x080000, CRC(637120f3) SHA1(b4b2ad192e46ff80d4cb440d7fb6dac215a353ed) ) - ROM_LOAD16_BYTE( "sc_11.bin", 0x100001, 0x080000, CRC(0cd5ca5e) SHA1(a59665e543e9383355de2576e6693348ec356591) ) - - ROM_REGION( 0x020000, "char", ROMREGION_INVERT ) - ROM_COPY( "test1", 0x080000, 0x00000, 0x020000 ) - - ROM_REGION( 0x100000, "gfx3", ROMREGION_INVERT ) /* MBK tiles */ - ROM_COPY( "test1", 0x000000, 0x00000, 0x080000 ) - ROM_COPY( "test1", 0x100000, 0x80000, 0x080000 ) - - ROM_REGION( 0x100000, "gfx4", ROMREGION_INVERT ) /* not used */ - ROM_COPY("gfx3",0x000000,0x00000,0x100000) - - ROM_REGION( 0x080000, "gfx5", ROMREGION_INVERT ) /* BK3 tiles */ - ROM_COPY( "test1", 0x180000, 0x00000, 0x080000 ) - - ROM_REGION( 0x080000, "gfx6", ROMREGION_INVERT ) /* LBK tiles */ - ROM_COPY( "gfx5", 0x000000, 0x00000, 0x080000 ) - - ROM_REGION( 0x100000, "adpcm", ROMREGION_ERASEFF ) /* ADPCM samples */ - ROM_LOAD( "sc_02.bin", 0x000000, 0x020000, CRC(a70d4f03) SHA1(c2482e624c8a828a94206a36d10c1021ad8ca1d0) ) - ROM_LOAD( "sc_03.bin", 0x080000, 0x080000, CRC(6e254d12) SHA1(857779dbd276b688201a8ea3afd5817e38acad2e) ) - - ROM_REGION( 0x200000, "oki", ROMREGION_ERASEFF ) - ROM_COPY( "adpcm", 0x00000, 0x000000, 0x20000 ) //bank 0 - ROM_COPY( "adpcm", 0x00000, 0x020000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x100000, 0x20000 ) //bank 4 - ROM_COPY( "adpcm", 0x80000, 0x120000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x140000, 0x20000 ) //bank 5 - ROM_COPY( "adpcm", 0xa0000, 0x160000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x180000, 0x20000 ) //bank 6 - ROM_COPY( "adpcm", 0xc0000, 0x1a0000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x1c0000, 0x20000 ) //bank 7 - ROM_COPY( "adpcm", 0xe0000, 0x1e0000, 0x20000 ) - - - /* these are maths tables, for whatever COP replacement the bootlegs use */ - ROM_REGION( 0x500000, "unknown0", 0 ) - ROM_LOAD16_BYTE( "sc_13.bin", 0x00000, 0x010000, CRC(229bddd8) SHA1(0924bf29db9c5a970546f154e7752697fdce6a58) ) - ROM_LOAD16_BYTE( "sc_12.bin", 0x00001, 0x010000, CRC(dabfa826) SHA1(0db587c846755491b169ef7751ba8e7cdc2607e6) ) - ROM_REGION( 0x500000, "unknown1", 0 ) - ROM_LOAD16_BYTE( "sc_15.bin", 0x00000, 0x080000, CRC(8fd87e65) SHA1(acc9fd0289fa9ab60bec16d3e642039380e5180a) ) - ROM_LOAD16_BYTE( "sc_14.bin", 0x00001, 0x080000, CRC(566086c2) SHA1(b7d09ce978f99ecc0d1975b31330ed49317701d5) ) -ROM_END - -/* slight changes in the program roms compared to above set, all remaining roms were the same */ -ROM_START( cupsocsb2 ) - ROM_REGION( 0x100000, "maincpu", 0 ) /* 68000 Code */ - ROM_LOAD16_BYTE( "4", 0x00001, 0x80000, CRC(83db76f8) SHA1(ffcd0a728de58871b945c15cc27da374b587e170) ) - ROM_LOAD16_BYTE( "5", 0x00000, 0x80000, CRC(c01e88c6) SHA1(8f90261792343c92ddd877ab8a2480b5aac82961) ) - - ROM_REGION( 0x10000, "audiocpu", 0 ) /* Z80 code */ - ROM_LOAD( "sc_01.bin", 0x000000, 0x08000, CRC(cea39d6d) SHA1(f0b79c03ffafdd1e57673d6d4836becbe415110b) ) - ROM_CONTINUE( 0x000000, 0x08000 ) - - ROM_REGION( 0x200000, "sprite", ROMREGION_INVERT ) /* bootleg sprite gfx */ - ROM_LOAD( "sc_07.bin", 0x000000, 0x080000, CRC(dcb29d01) SHA1(72b4234622605f0ab03f21fdb6a61c6dac36000d) ) - ROM_LOAD( "sc_06.bin", 0x080000, 0x080000, CRC(2dc70e05) SHA1(f1d0beb8428a7e1d7c7818e6719abdc543b2fa80) ) - ROM_COPY( "sprite", 0x00000, 0x100000, 0x100000 ) - - ROM_REGION( 0x200000, "test1", 0 ) /* bootleg tile gfx */ - ROM_LOAD16_BYTE( "sc_09.bin", 0x000000, 0x080000, CRC(695b6342) SHA1(dfccb43789021ba2568b9284ae61e64f7f89b152) ) - ROM_LOAD16_BYTE( "sc_10.bin", 0x000001, 0x080000, CRC(27e172b8) SHA1(ed86db2f42c8061607d46f2407b0130aaf692a02) ) - ROM_LOAD16_BYTE( "sc_08.bin", 0x100000, 0x080000, CRC(637120f3) SHA1(b4b2ad192e46ff80d4cb440d7fb6dac215a353ed) ) - ROM_LOAD16_BYTE( "sc_11.bin", 0x100001, 0x080000, CRC(0cd5ca5e) SHA1(a59665e543e9383355de2576e6693348ec356591) ) - - ROM_REGION( 0x020000, "char", ROMREGION_INVERT ) - ROM_COPY( "test1", 0x080000, 0x00000, 0x020000 ) - - ROM_REGION( 0x100000, "gfx3", ROMREGION_INVERT ) /* MBK tiles */ - ROM_COPY( "test1", 0x00000, 0x00000, 0x080000 ) - ROM_COPY( "test1", 0x100000, 0x80000, 0x080000 ) - - ROM_REGION( 0x100000, "gfx4", ROMREGION_INVERT ) /* not used */ - ROM_COPY("gfx3",0x00000,0x00000,0x100000) - - ROM_REGION( 0x080000, "gfx5", ROMREGION_INVERT ) /* BK3 tiles */ - ROM_COPY( "test1", 0x180000, 0x00000, 0x080000 ) - - ROM_REGION( 0x080000, "gfx6", ROMREGION_INVERT ) /* LBK tiles */ - ROM_COPY( "gfx5", 0x00000, 0x00000, 0x080000 ) - - ROM_REGION( 0x100000, "adpcm", ROMREGION_ERASEFF ) /* ADPCM samples */ - ROM_LOAD( "sc_02.bin", 0x000000, 0x020000, CRC(a70d4f03) SHA1(c2482e624c8a828a94206a36d10c1021ad8ca1d0) ) - ROM_LOAD( "sc_03.bin", 0x080000, 0x080000, CRC(6e254d12) SHA1(857779dbd276b688201a8ea3afd5817e38acad2e) ) - - ROM_REGION( 0x200000, "oki", ROMREGION_ERASEFF ) - ROM_COPY( "adpcm", 0x00000, 0x000000, 0x20000 ) //bank 0 - ROM_COPY( "adpcm", 0x00000, 0x020000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x100000, 0x20000 ) //bank 4 - ROM_COPY( "adpcm", 0x80000, 0x120000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x140000, 0x20000 ) //bank 5 - ROM_COPY( "adpcm", 0xa0000, 0x160000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x180000, 0x20000 ) //bank 6 - ROM_COPY( "adpcm", 0xc0000, 0x1a0000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x1c0000, 0x20000 ) //bank 7 - ROM_COPY( "adpcm", 0xe0000, 0x1e0000, 0x20000 ) - - - /* these are maths tables, for whatever COP replacement the bootlegs use */ - ROM_REGION( 0x500000, "unknown0", 0 ) - ROM_LOAD16_BYTE( "sc_13.bin", 0x00000, 0x010000, CRC(229bddd8) SHA1(0924bf29db9c5a970546f154e7752697fdce6a58) ) - ROM_LOAD16_BYTE( "sc_12.bin", 0x00001, 0x010000, CRC(dabfa826) SHA1(0db587c846755491b169ef7751ba8e7cdc2607e6) ) - ROM_REGION( 0x500000, "unknown1", 0 ) - ROM_LOAD16_BYTE( "sc_15.bin", 0x00000, 0x080000, CRC(8fd87e65) SHA1(acc9fd0289fa9ab60bec16d3e642039380e5180a) ) - ROM_LOAD16_BYTE( "sc_14.bin", 0x00001, 0x080000, CRC(566086c2) SHA1(b7d09ce978f99ecc0d1975b31330ed49317701d5) ) -ROM_END - -ROM_START( cupsocsb3 ) - ROM_REGION( 0x100000, "maincpu", 0 ) /* 68000 Code */ - ROM_LOAD16_BYTE( "4.bin", 0x00001, 0x80000, CRC(f615058f) SHA1(f7c0eb6b9f8dcdc8b13f8e5b03f46252a87a6c0f) ) // sldh - ROM_LOAD16_BYTE( "5.bin", 0x00000, 0x80000, CRC(6500edf2) SHA1(1a617b18b4997c24af53601c98e9a0efbe637a4b) ) // sldh - - ROM_REGION( 0x10000, "audiocpu", 0 ) /* Z80 code */ - ROM_LOAD( "sc_01.bin", 0x000000, 0x08000, CRC(cea39d6d) SHA1(f0b79c03ffafdd1e57673d6d4836becbe415110b) ) - ROM_CONTINUE( 0x000000, 0x08000 ) - - ROM_REGION( 0x200000, "sprite", ROMREGION_INVERT ) /* bootleg sprite gfx */ - ROM_LOAD( "sc_07.bin", 0x000000, 0x080000, CRC(dcb29d01) SHA1(72b4234622605f0ab03f21fdb6a61c6dac36000d) ) - ROM_LOAD( "sc_06.bin", 0x080000, 0x080000, CRC(2dc70e05) SHA1(f1d0beb8428a7e1d7c7818e6719abdc543b2fa80) ) - ROM_COPY( "sprite", 0x00000, 0x100000, 0x100000 ) - - ROM_REGION( 0x200000, "test1", 0 ) /* bootleg tile gfx */ - ROM_LOAD16_BYTE( "sc_09.bin", 0x000000, 0x080000, CRC(695b6342) SHA1(dfccb43789021ba2568b9284ae61e64f7f89b152) ) - ROM_LOAD16_BYTE( "sc_10.bin", 0x000001, 0x080000, CRC(27e172b8) SHA1(ed86db2f42c8061607d46f2407b0130aaf692a02) ) - ROM_LOAD16_BYTE( "sc_08.bin", 0x100000, 0x080000, CRC(637120f3) SHA1(b4b2ad192e46ff80d4cb440d7fb6dac215a353ed) ) - ROM_LOAD16_BYTE( "sc_11.bin", 0x100001, 0x080000, CRC(0cd5ca5e) SHA1(a59665e543e9383355de2576e6693348ec356591) ) - - ROM_REGION( 0x020000, "char", ROMREGION_INVERT ) - ROM_COPY( "test1", 0x080000, 0x00000, 0x020000 ) - - ROM_REGION( 0x100000, "gfx3", ROMREGION_INVERT ) /* MBK tiles */ - ROM_COPY( "test1", 0x00000, 0x00000, 0x080000 ) - ROM_COPY( "test1", 0x100000, 0x80000, 0x080000 ) - - ROM_REGION( 0x100000, "gfx4", ROMREGION_INVERT ) /* not used */ - ROM_COPY("gfx3",0x00000,0x00000,0x100000) - - ROM_REGION( 0x080000, "gfx5", ROMREGION_INVERT ) /* BK3 tiles */ - ROM_COPY( "test1", 0x180000, 0x00000, 0x080000 ) - - ROM_REGION( 0x080000, "gfx6", ROMREGION_INVERT ) /* LBK tiles */ - ROM_COPY( "gfx5", 0x00000, 0x00000, 0x080000 ) - - ROM_REGION( 0x100000, "adpcm", ROMREGION_ERASEFF ) /* ADPCM samples */ - ROM_LOAD( "sc_02.bin", 0x000000, 0x020000, CRC(a70d4f03) SHA1(c2482e624c8a828a94206a36d10c1021ad8ca1d0) ) - ROM_LOAD( "sc_03.bin", 0x080000, 0x080000, CRC(6e254d12) SHA1(857779dbd276b688201a8ea3afd5817e38acad2e) ) - - ROM_REGION( 0x200000, "oki", ROMREGION_ERASEFF ) - ROM_COPY( "adpcm", 0x00000, 0x000000, 0x20000 ) //bank 0 - ROM_COPY( "adpcm", 0x00000, 0x020000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x100000, 0x20000 ) //bank 4 - ROM_COPY( "adpcm", 0x80000, 0x120000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x140000, 0x20000 ) //bank 5 - ROM_COPY( "adpcm", 0xa0000, 0x160000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x180000, 0x20000 ) //bank 6 - ROM_COPY( "adpcm", 0xc0000, 0x1a0000, 0x20000 ) - ROM_COPY( "adpcm", 0x00000, 0x1c0000, 0x20000 ) //bank 7 - ROM_COPY( "adpcm", 0xe0000, 0x1e0000, 0x20000 ) - - /* these are maths tables, for whatever COP replacement the bootlegs use */ - ROM_REGION( 0x500000, "unknown0", 0 ) - ROM_LOAD16_BYTE( "sc_13.bin", 0x00000, 0x010000, CRC(229bddd8) SHA1(0924bf29db9c5a970546f154e7752697fdce6a58) ) - ROM_LOAD16_BYTE( "sc_12.bin", 0x00001, 0x010000, CRC(dabfa826) SHA1(0db587c846755491b169ef7751ba8e7cdc2607e6) ) - ROM_REGION( 0x500000, "unknown1", 0 ) - ROM_LOAD16_BYTE( "sc_15.bin", 0x00000, 0x080000, CRC(8fd87e65) SHA1(acc9fd0289fa9ab60bec16d3e642039380e5180a) ) - ROM_LOAD16_BYTE( "sc_14.bin", 0x00001, 0x080000, CRC(566086c2) SHA1(b7d09ce978f99ecc0d1975b31330ed49317701d5) ) -ROM_END @@ -2770,9 +2466,6 @@ GAME( 1992, cupsoca, cupsoc, cupsoc, cupsoc, legionna_state, cupsoc, RO GAME( 1992, cupsocb, cupsoc, cupsoc, cupsoc, legionna_state, cupsocs, ROT0, "Seibu Kaihatsu", "Seibu Cup Soccer (set 3)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) GAME( 1992, cupsocs, cupsoc, cupsocs, cupsoc, legionna_state, cupsocs, ROT0, "Seibu Kaihatsu", "Seibu Cup Soccer :Selection: (set 1)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) GAME( 1992, cupsocs2, cupsoc, cupsocs, cupsoc, legionna_state, cupsocs, ROT0, "Seibu Kaihatsu", "Seibu Cup Soccer :Selection: (set 2)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) -GAME( 1992, cupsocsb, cupsoc, cupsocbl, cupsoc, legionna_state, cupsoc, ROT0, "bootleg", "Seibu Cup Soccer :Selection: (bootleg, set 1)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) -GAME( 1992, cupsocsb2,cupsoc, cupsocbl, cupsoc, legionna_state, cupsoc, ROT0, "bootleg", "Seibu Cup Soccer :Selection: (bootleg, set 2)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) -GAME( 1992, cupsocsb3,cupsoc, cupsocbl, cupsoc, legionna_state, cupsoc, ROT0, "bootleg", "Seibu Cup Soccer :Selection: (bootleg, set 3)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) GAME( 1992, olysoc92, cupsoc, cupsoc, cupsoc, legionna_state, olysoc92, ROT0, "Seibu Kaihatsu", "Olympic Soccer '92 (set 1)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) GAME( 1992, olysoc92a,cupsoc, cupsoc, cupsoc, legionna_state, olysoc92, ROT0, "Seibu Kaihatsu", "Olympic Soccer '92 (set 2)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) GAME( 1992, olysoc92b,cupsoc, cupsoc, cupsoc, legionna_state, olysoc92, ROT0, "Seibu Kaihatsu", "Olympic Soccer '92 (set 3)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) diff --git a/src/mame/drivers/seicupbl.cpp b/src/mame/drivers/seicupbl.cpp new file mode 100644 index 00000000000..b0f43dbdcb8 --- /dev/null +++ b/src/mame/drivers/seicupbl.cpp @@ -0,0 +1,578 @@ +// license:BSD-3-Clause +// copyright-holders:Angelo Salese +/*************************************************************************** + +Template for skeleton drivers + +***************************************************************************/ + + +#include "emu.h" +#include "cpu/z80/z80.h" +#include "cpu/m68000/m68000.h" +#include "machine/seicop.h" +#include "sound/okim6295.h" +#include "machine/gen_latch.h" + +#define MAIN_CLOCK XTAL_8MHz + +class seicupbl_state : public driver_device +{ +public: + seicupbl_state(const machine_config &mconfig, device_type type, const char *tag) + : driver_device(mconfig, type, tag), + m_maincpu(*this, "maincpu"), + m_audiocpu(*this, "audiocpu"), + m_oki(*this, "oki"), + m_soundlatch(*this, "soundlatch") + { } + + // devices + required_device m_maincpu; + required_device m_audiocpu; + required_device m_oki; + optional_device m_soundlatch; + + // screen updates + UINT32 screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); + DECLARE_PALETTE_INIT(seicupbl); + DECLARE_WRITE8_MEMBER(okim_rombank_w); + DECLARE_WRITE8_MEMBER(sound_cmd_w); + +protected: + // driver_device overrides + virtual void machine_start(); + virtual void machine_reset(); + + virtual void video_start(); +}; + +void seicupbl_state::video_start() +{ +} + +UINT32 seicupbl_state::screen_update( screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect ) +{ + return 0; +} + +WRITE8_MEMBER(seicupbl_state::sound_cmd_w) +{ + m_soundlatch->write(space, 0, data & 0xff); + m_audiocpu->set_input_line(INPUT_LINE_NMI, PULSE_LINE ); +} + +static ADDRESS_MAP_START( cupsocbl_mem, AS_PROGRAM, 16, seicupbl_state ) +// AM_IMPORT_FROM( legionna_cop_mem ) + AM_RANGE(0x000000, 0x0fffff) AM_ROM + //AM_RANGE(0x100000, 0x1003ff) AM_RAM + //AM_RANGE(0x100600, 0x10060f) AM_DEVREADWRITE("crtc", seibu_crtc_device, read, write)//? + //AM_RANGE(0x100640, 0x10067f) AM_DEVREADWRITE("crtc", seibu_crtc_device, read, write) + AM_RANGE(0x100400, 0x1005ff) AM_DEVREADWRITE("seibucop_boot", seibu_cop_bootleg_device, copdxbl_0_r,copdxbl_0_w) AM_SHARE("cop_mcu_ram") + AM_RANGE(0x100680, 0x100681) AM_WRITENOP // irq ack? + AM_RANGE(0x100700, 0x100701) AM_READ_PORT("DSW1") + AM_RANGE(0x100704, 0x100705) AM_READ_PORT("PLAYERS12") + AM_RANGE(0x100708, 0x100709) AM_READ_PORT("PLAYERS34") + AM_RANGE(0x10070c, 0x10070d) AM_READ_PORT("SYSTEM") + AM_RANGE(0x100740, 0x100741) AM_WRITE8(sound_cmd_w,0x00ff) +// AM_RANGE(0x100800, 0x100fff) AM_RAM // _WRITE(legionna_background_w) AM_SHARE("back_data") +// AM_RANGE(0x101000, 0x1017ff) AM_RAM // _WRITE(legionna_foreground_w) AM_SHARE("fore_data") +// AM_RANGE(0x101800, 0x101fff) AM_RAM // _WRITE(legionna_midground_w) AM_SHARE("mid_data") +// AM_RANGE(0x102000, 0x102fff) AM_RAM // _WRITE(legionna_text_w) AM_SHARE("textram") + AM_RANGE(0x103000, 0x103fff) AM_RAM_DEVWRITE("palette", palette_device, write) AM_SHARE("palette") + AM_RANGE(0x104000, 0x104fff) AM_RAM + AM_RANGE(0x105000, 0x106fff) AM_RAM +// AM_RANGE(0x107000, 0x1077ff) AM_RAM AM_SHARE("spriteram") + AM_RANGE(0x107800, 0x107fff) AM_RAM /*Ani Dsp(?) Ram*/ + AM_RANGE(0x108000, 0x10ffff) AM_RAM + AM_RANGE(0x110000, 0x119fff) AM_RAM + AM_RANGE(0x11a000, 0x11dfff) AM_RAM + AM_RANGE(0x11e000, 0x11ffff) AM_RAM /*Stack Ram*/ +ADDRESS_MAP_END + +WRITE8_MEMBER(seicupbl_state::okim_rombank_w) +{ +// popmessage("%08x",0x40000 * (data & 0x07)); + m_oki->set_bank_base(0x40000 * (data & 0x7)); +} + +static ADDRESS_MAP_START( cupsocbl_sound_mem, AS_PROGRAM, 8, seicupbl_state ) + AM_RANGE(0x0000, 0x7fff) AM_ROM + AM_RANGE(0x8000, 0x87ff) AM_RAM + AM_RANGE(0x9000, 0x9000) AM_WRITE(okim_rombank_w) + AM_RANGE(0x9800, 0x9800) AM_DEVREADWRITE("oki", okim6295_device, read, write) + AM_RANGE(0xa000, 0xa000) AM_DEVREAD("soundlatch", generic_latch_8_device, read) +ADDRESS_MAP_END + + +static INPUT_PORTS_START( cupsoc ) + //SEIBU_COIN_INPUTS /* coin inputs read through sound cpu */ + + PORT_START("SYSTEM") + PORT_BIT( 0x0001, IP_ACTIVE_LOW, IPT_START1 ) + PORT_BIT( 0x0002, IP_ACTIVE_LOW, IPT_START2 ) + PORT_BIT( 0x0004, IP_ACTIVE_LOW, IPT_UNKNOWN ) //TEST + PORT_BIT( 0x0008, IP_ACTIVE_LOW, IPT_SERVICE2 ) + PORT_BIT( 0x00f0, IP_ACTIVE_LOW, IPT_UNUSED ) + PORT_BIT( 0x0100, IP_ACTIVE_LOW, IPT_START3 ) + PORT_BIT( 0x0200, IP_ACTIVE_LOW, IPT_START4 ) + PORT_BIT( 0xfc00, IP_ACTIVE_LOW, IPT_UNKNOWN ) + + PORT_START("PLAYERS12") + PORT_BIT( 0x0001, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY PORT_PLAYER(1) + PORT_BIT( 0x0002, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY PORT_PLAYER(1) + PORT_BIT( 0x0004, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY PORT_PLAYER(1) + PORT_BIT( 0x0008, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY PORT_PLAYER(1) + PORT_BIT( 0x0010, IP_ACTIVE_LOW, IPT_BUTTON1 ) PORT_PLAYER(1) + PORT_BIT( 0x0020, IP_ACTIVE_LOW, IPT_BUTTON2 ) PORT_PLAYER(1) + PORT_BIT( 0x0040, IP_ACTIVE_LOW, IPT_BUTTON3 ) PORT_PLAYER(1) + PORT_BIT( 0x0080, IP_ACTIVE_LOW, IPT_COIN1 ) + PORT_BIT( 0x0100, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY PORT_PLAYER(2) + PORT_BIT( 0x0200, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY PORT_PLAYER(2) + PORT_BIT( 0x0400, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY PORT_PLAYER(2) + PORT_BIT( 0x0800, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY PORT_PLAYER(2) + PORT_BIT( 0x1000, IP_ACTIVE_LOW, IPT_BUTTON1 ) PORT_PLAYER(2) + PORT_BIT( 0x2000, IP_ACTIVE_LOW, IPT_BUTTON2 ) PORT_PLAYER(2) + PORT_BIT( 0x4000, IP_ACTIVE_LOW, IPT_BUTTON3 ) PORT_PLAYER(2) + PORT_BIT( 0x8000, IP_ACTIVE_LOW, IPT_COIN2 ) + + PORT_START("PLAYERS34") + PORT_BIT( 0x0001, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY PORT_PLAYER(3) + PORT_BIT( 0x0002, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY PORT_PLAYER(3) + PORT_BIT( 0x0004, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY PORT_PLAYER(3) + PORT_BIT( 0x0008, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY PORT_PLAYER(3) + PORT_BIT( 0x0010, IP_ACTIVE_LOW, IPT_BUTTON1 ) PORT_PLAYER(3) + PORT_BIT( 0x0020, IP_ACTIVE_LOW, IPT_BUTTON2 ) PORT_PLAYER(3) + PORT_BIT( 0x0040, IP_ACTIVE_LOW, IPT_BUTTON3 ) PORT_PLAYER(3) + PORT_BIT( 0x0080, IP_ACTIVE_LOW, IPT_UNKNOWN ) //TEST + PORT_BIT( 0x0100, IP_ACTIVE_LOW, IPT_JOYSTICK_UP ) PORT_8WAY PORT_PLAYER(4) + PORT_BIT( 0x0200, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN ) PORT_8WAY PORT_PLAYER(4) + PORT_BIT( 0x0400, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT ) PORT_8WAY PORT_PLAYER(4) + PORT_BIT( 0x0800, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT ) PORT_8WAY PORT_PLAYER(4) + PORT_BIT( 0x1000, IP_ACTIVE_LOW, IPT_BUTTON1 ) PORT_PLAYER(4) + PORT_BIT( 0x2000, IP_ACTIVE_LOW, IPT_BUTTON2 ) PORT_PLAYER(4) + PORT_BIT( 0x4000, IP_ACTIVE_LOW, IPT_BUTTON3 ) PORT_PLAYER(4) + PORT_BIT( 0x8000, IP_ACTIVE_LOW, IPT_SERVICE1 ) + + PORT_START("DSW1") + PORT_DIPNAME( 0x0007, 0x0007, "Coin 1 (3)" ) + PORT_DIPSETTING( 0x0000, DEF_STR( 4C_1C ) ) + PORT_DIPSETTING( 0x0001, DEF_STR( 3C_1C ) ) + PORT_DIPSETTING( 0x0002, DEF_STR( 2C_1C ) ) + PORT_DIPSETTING( 0x0007, DEF_STR( 1C_1C ) ) + PORT_DIPSETTING( 0x0006, DEF_STR( 1C_2C ) ) + PORT_DIPSETTING( 0x0005, DEF_STR( 1C_3C ) ) + PORT_DIPSETTING( 0x0004, DEF_STR( 1C_4C ) ) + PORT_DIPSETTING( 0x0003, DEF_STR( 1C_6C ) ) + PORT_DIPNAME( 0x0038, 0x0038, "Coin 2 (4)" ) + PORT_DIPSETTING( 0x0000, DEF_STR( 4C_1C ) ) + PORT_DIPSETTING( 0x0008, DEF_STR( 3C_1C ) ) + PORT_DIPSETTING( 0x0010, DEF_STR( 2C_1C ) ) + PORT_DIPSETTING( 0x0038, DEF_STR( 1C_1C ) ) + PORT_DIPSETTING( 0x0030, DEF_STR( 1C_2C ) ) + PORT_DIPSETTING( 0x0028, DEF_STR( 1C_3C ) ) + PORT_DIPSETTING( 0x0020, DEF_STR( 1C_4C ) ) + PORT_DIPSETTING( 0x0018, DEF_STR( 1C_6C ) ) + PORT_DIPNAME( 0x0040, 0x0040, "Staring Coin" ) + PORT_DIPSETTING( 0x0040, DEF_STR( Normal ) ) + PORT_DIPSETTING( 0x0000, "x2" ) + PORT_DIPNAME( 0x0080, 0x0080, DEF_STR( Flip_Screen ) ) + PORT_DIPSETTING( 0x0080, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x0000, DEF_STR( On ) ) + PORT_DIPNAME( 0x0300, 0x0300, "Time vs Computer" ) + PORT_DIPSETTING( 0x0200, "1:30" ) + PORT_DIPSETTING( 0x0300, "2:00" ) + PORT_DIPSETTING( 0x0100, "2:30" ) + PORT_DIPSETTING( 0x0000, "3:00" ) + PORT_DIPNAME( 0x0c00, 0x0c00, "Time vs Player, 2 Players" ) + PORT_DIPSETTING( 0x0800, "2:00" ) + PORT_DIPSETTING( 0x0c00, "2:30" ) + PORT_DIPSETTING( 0x0400, "3:00" ) + PORT_DIPSETTING( 0x0000, "x:xx" ) + PORT_DIPNAME( 0x3000, 0x3000, "Time vs Player, 3 Players" ) + PORT_DIPSETTING( 0x2000, "2:30" ) + PORT_DIPSETTING( 0x3000, "3:00" ) + PORT_DIPSETTING( 0x1000, "3:30" ) + PORT_DIPSETTING( 0x0000, "x:xx" ) + PORT_DIPNAME( 0xc000, 0xc000, "Time vs Player, 4 Players" ) + PORT_DIPSETTING( 0x8000, "3:00" ) + PORT_DIPSETTING( 0xc000, "3:30" ) + PORT_DIPSETTING( 0x4000, "4:00" ) + PORT_DIPSETTING( 0x0000, "x:xx" ) + + PORT_START("DSW2") + PORT_DIPNAME( 0x0003, 0x0003, DEF_STR( Difficulty ) ) + PORT_DIPSETTING( 0x0003, DEF_STR( Normal ) ) + PORT_DIPSETTING( 0x0002, DEF_STR( Easy ) ) + PORT_DIPSETTING( 0x0001, DEF_STR( Hard ) ) + PORT_DIPSETTING( 0x0000, DEF_STR( Hardest ) ) + PORT_DIPNAME( 0x000c, 0x0000, "Players / Coin Mode" ) + PORT_DIPSETTING( 0x0000, "4 Players / 1 Coin Slot" ) + PORT_DIPSETTING( 0x0004, "4 Players / 4 Coin Slots" ) + PORT_DIPSETTING( 0x0008, "4 Players / 2 Coin Slots" ) + PORT_DIPSETTING( 0x000c, "2 Players" ) + PORT_DIPNAME( 0x0010, 0x0010, DEF_STR( Demo_Sounds ) ) + PORT_DIPSETTING( 0x0000, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x0010, DEF_STR( On ) ) + PORT_DIPNAME( 0x0020, 0x0020, DEF_STR( Service_Mode ) ) + PORT_DIPSETTING( 0x0020, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x0000, DEF_STR( On ) ) + PORT_DIPNAME( 0x0040, 0x0040, DEF_STR( Unused ) ) + PORT_DIPSETTING( 0x0040, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x0000, DEF_STR( On ) ) + PORT_DIPNAME( 0x0080, 0x0080, DEF_STR( Unused ) ) + PORT_DIPSETTING( 0x0080, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x0000, DEF_STR( On ) ) + // probably not mapped, service lists 3*8 dips + PORT_DIPNAME( 0xff00, 0xff00, DEF_STR( Unused ) ) + PORT_DIPSETTING( 0xff00, DEF_STR( Off ) ) + PORT_DIPSETTING( 0x0000, DEF_STR( On ) ) +INPUT_PORTS_END + +static const gfx_layout charlayout = +{ + 8,8, + RGN_FRAC(1,1), + 1, + { RGN_FRAC(0,1) }, + { 0, 1, 2, 3, 4, 5, 6, 7 }, + { 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8 }, + 8*8 +}; + +static GFXDECODE_START( seicupbl ) + GFXDECODE_ENTRY( "gfx1", 0, charlayout, 0, 1 ) +GFXDECODE_END + + +void seicupbl_state::machine_start() +{ +} + +void seicupbl_state::machine_reset() +{ +} + + +PALETTE_INIT_MEMBER(seicupbl_state, seicupbl) +{ +} + +static const gfx_layout cupsocsb_spritelayout = +{ + 16,16, + RGN_FRAC(1,1), + 4, + { 0,1,2,3 }, + { 4,0,12,8,20,16,28,24, 512+4, 512+0, 512+12, 512+8, 512+20, 512+16, 512+28, 512+24 }, + { 0*32, 1*32, 2*32, 3*32, 4*32, 5*32, 6*32, 7*32, 8*32, 9*32, 10*32, 11*32, 12*32, 13*32, 14*32, 15*32 }, + 32*32 +}; + +static const gfx_layout cupsocsb_8x8_tilelayout = +{ + 8,8, + RGN_FRAC(1,1), + 4, + { 8,12,0,4 }, + { 0,3,2,1,16,19,18,17 }, + { 0*32, 1*32, 2*32, 3*32, 4*32, 5*32, 6*32, 7*32 }, + 8*32 +}; + + +static const gfx_layout cupsocsb_tilelayout = +{ + 16,16, + RGN_FRAC(1,1), + 4, + { 8,12,0,4 }, + { 0,3,2,1,16,19,18,17, 512+0,512+3,512+2,512+1,512+16,512+19,512+18,512+17 }, + { 0*32, 1*32, 2*32, 3*32, 4*32, 5*32, 6*32, 7*32, 8*32, 9*32, 10*32, 11*32, 12*32, 13*32, 14*32, 15*32 }, + 32*32 +}; + + +static GFXDECODE_START( seicupbl_csb ) + GFXDECODE_ENTRY( "char", 0, cupsocsb_8x8_tilelayout, 48*16, 16 ) + GFXDECODE_ENTRY( "gfx3", 0, cupsocsb_tilelayout, 0*16, 32 ) + GFXDECODE_ENTRY( "gfx4", 0, cupsocsb_tilelayout, 32*16, 16 ) /* unused */ + GFXDECODE_ENTRY( "sprite", 0, cupsocsb_spritelayout, 0*16, 8*16 ) + GFXDECODE_ENTRY( "gfx5", 0, cupsocsb_tilelayout, 32*16, 16 ) + GFXDECODE_ENTRY( "gfx6", 0, cupsocsb_tilelayout, 16*16, 16 ) +GFXDECODE_END + + +static MACHINE_CONFIG_START( cupsocbl, seicupbl_state ) + + /* basic machine hardware */ + MCFG_CPU_ADD("maincpu", M68000,12000000) + MCFG_CPU_PROGRAM_MAP(cupsocbl_mem) + MCFG_CPU_VBLANK_INT_DRIVER("screen", seicupbl_state, irq4_line_hold) /* VBL */ + + MCFG_DEVICE_SEIBUCOP_BOOTLEG_ADD("seibucop_boot") + + /*Different Sound hardware*/ + //SEIBU_SOUND_SYSTEM_CPU(14318180/4) + MCFG_CPU_ADD("audiocpu", Z80,14318180/4) + MCFG_CPU_PROGRAM_MAP(cupsocbl_sound_mem) + //MCFG_PERIODIC_INT("screen", nmi_line_pulse) + + /* video hardware */ + MCFG_SCREEN_ADD("screen", RASTER) + MCFG_SCREEN_REFRESH_RATE(60) + MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0)) + MCFG_SCREEN_SIZE(42*8, 36*8) + MCFG_SCREEN_VISIBLE_AREA(0*8, 40*8-1, 0*8, 30*8-1) + MCFG_SCREEN_UPDATE_DRIVER(seicupbl_state, screen_update) + MCFG_SCREEN_PALETTE("palette") + + //MCFG_DEVICE_ADD("crtc", SEIBU_CRTC, 0) + //MCFG_SEIBU_CRTC_LAYER_EN_CB(WRITE16(seicupbl_state, tilemap_enable_w)) + //MCFG_SEIBU_CRTC_LAYER_SCROLL_CB(WRITE16(seicupbl_state, tile_scroll_w)) + //MCFG_SEIBU_CRTC_REG_1A_CB(WRITE16(seicupbl_state, tile_vreg_1a_w)) + + MCFG_GFXDECODE_ADD("gfxdecode", "palette", seicupbl_csb) + + MCFG_PALETTE_ADD_INIT_BLACK("palette", 128*16) + MCFG_PALETTE_FORMAT(xBBBBBGGGGGRRRRR) + +// MCFG_VIDEO_START_OVERRIDE(seicupbl_state,cupsoc) + + /* sound hardware */ + MCFG_SPEAKER_STANDARD_MONO("mono") + + MCFG_GENERIC_LATCH_8_ADD("soundlatch") + + MCFG_OKIM6295_ADD("oki", 1000000, OKIM6295_PIN7_HIGH) + MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 1.0) +MACHINE_CONFIG_END + + + +/*************************************************************************** + + Machine driver(s) + +***************************************************************************/ + +/* + +Seibu Cup Soccer - Seibu - Bootleg + +2 boards + +1st board + +(snd) +1 x z80 +1 x oki 6295 +sc_01 (prg) +sc_02 and sc_03 (data) + +(prg) +1 x 68000 +sc_04 and sc_05 + +(gfx) +2 x ti tpc1020 +from sc_06 to sc_11 + +2nd board + +(gfx) +1 x actel pl84c +from sc_12 to sc_15 + +*/ + +ROM_START( cupsocsb ) + ROM_REGION( 0x100000, "maincpu", 0 ) /* 68000 Code */ + ROM_LOAD16_BYTE( "sc_04.bin", 0x00001, 0x80000, CRC(22566087) SHA1(4392f46ca50cc9947823a5190aa25f5e9654aa0d) ) + ROM_LOAD16_BYTE( "sc_05.bin", 0x00000, 0x80000, CRC(2f977dff) SHA1(4d8d6e7d06ce17bb7292072965911f8b1f1067e2) ) + + ROM_REGION( 0x10000, "audiocpu", 0 ) /* Z80 code */ + ROM_LOAD( "sc_01.bin", 0x000000, 0x08000, CRC(cea39d6d) SHA1(f0b79c03ffafdd1e57673d6d4836becbe415110b) ) + ROM_CONTINUE( 0x000000, 0x08000 ) + + ROM_REGION( 0x200000, "sprite", ROMREGION_INVERT ) /* bootleg sprite gfx */ + ROM_LOAD( "sc_07.bin", 0x000000, 0x080000, CRC(dcb29d01) SHA1(72b4234622605f0ab03f21fdb6a61c6dac36000d) ) + ROM_LOAD( "sc_06.bin", 0x080000, 0x080000, CRC(2dc70e05) SHA1(f1d0beb8428a7e1d7c7818e6719abdc543b2fa80) ) + ROM_COPY( "sprite", 0x000000, 0x100000, 0x100000 ) + + ROM_REGION( 0x200000, "test1", 0 ) /* bootleg tile gfx */ + ROM_LOAD16_BYTE( "sc_09.bin", 0x000000, 0x080000, CRC(695b6342) SHA1(dfccb43789021ba2568b9284ae61e64f7f89b152) ) + ROM_LOAD16_BYTE( "sc_10.bin", 0x000001, 0x080000, CRC(27e172b8) SHA1(ed86db2f42c8061607d46f2407b0130aaf692a02) ) + ROM_LOAD16_BYTE( "sc_08.bin", 0x100000, 0x080000, CRC(637120f3) SHA1(b4b2ad192e46ff80d4cb440d7fb6dac215a353ed) ) + ROM_LOAD16_BYTE( "sc_11.bin", 0x100001, 0x080000, CRC(0cd5ca5e) SHA1(a59665e543e9383355de2576e6693348ec356591) ) + + ROM_REGION( 0x020000, "char", ROMREGION_INVERT ) + ROM_COPY( "test1", 0x080000, 0x00000, 0x020000 ) + + ROM_REGION( 0x100000, "gfx3", ROMREGION_INVERT ) /* MBK tiles */ + ROM_COPY( "test1", 0x000000, 0x00000, 0x080000 ) + ROM_COPY( "test1", 0x100000, 0x80000, 0x080000 ) + + ROM_REGION( 0x100000, "gfx4", ROMREGION_INVERT ) /* not used */ + ROM_COPY("gfx3",0x000000,0x00000,0x100000) + + ROM_REGION( 0x080000, "gfx5", ROMREGION_INVERT ) /* BK3 tiles */ + ROM_COPY( "test1", 0x180000, 0x00000, 0x080000 ) + + ROM_REGION( 0x080000, "gfx6", ROMREGION_INVERT ) /* LBK tiles */ + ROM_COPY( "gfx5", 0x000000, 0x00000, 0x080000 ) + + ROM_REGION( 0x100000, "adpcm", ROMREGION_ERASEFF ) /* ADPCM samples */ + ROM_LOAD( "sc_02.bin", 0x000000, 0x020000, CRC(a70d4f03) SHA1(c2482e624c8a828a94206a36d10c1021ad8ca1d0) ) + ROM_LOAD( "sc_03.bin", 0x080000, 0x080000, CRC(6e254d12) SHA1(857779dbd276b688201a8ea3afd5817e38acad2e) ) + + ROM_REGION( 0x200000, "oki", ROMREGION_ERASEFF ) + ROM_COPY( "adpcm", 0x00000, 0x000000, 0x20000 ) //bank 0 + ROM_COPY( "adpcm", 0x00000, 0x020000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x100000, 0x20000 ) //bank 4 + ROM_COPY( "adpcm", 0x80000, 0x120000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x140000, 0x20000 ) //bank 5 + ROM_COPY( "adpcm", 0xa0000, 0x160000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x180000, 0x20000 ) //bank 6 + ROM_COPY( "adpcm", 0xc0000, 0x1a0000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x1c0000, 0x20000 ) //bank 7 + ROM_COPY( "adpcm", 0xe0000, 0x1e0000, 0x20000 ) + + + /* these are maths tables, for whatever COP replacement the bootlegs use */ + ROM_REGION( 0x500000, "unknown0", 0 ) + ROM_LOAD16_BYTE( "sc_13.bin", 0x00000, 0x010000, CRC(229bddd8) SHA1(0924bf29db9c5a970546f154e7752697fdce6a58) ) + ROM_LOAD16_BYTE( "sc_12.bin", 0x00001, 0x010000, CRC(dabfa826) SHA1(0db587c846755491b169ef7751ba8e7cdc2607e6) ) + ROM_REGION( 0x500000, "unknown1", 0 ) + ROM_LOAD16_BYTE( "sc_15.bin", 0x00000, 0x080000, CRC(8fd87e65) SHA1(acc9fd0289fa9ab60bec16d3e642039380e5180a) ) + ROM_LOAD16_BYTE( "sc_14.bin", 0x00001, 0x080000, CRC(566086c2) SHA1(b7d09ce978f99ecc0d1975b31330ed49317701d5) ) +ROM_END + +/* slight changes in the program roms compared to above set, all remaining roms were the same */ +ROM_START( cupsocsb2 ) + ROM_REGION( 0x100000, "maincpu", 0 ) /* 68000 Code */ + ROM_LOAD16_BYTE( "4", 0x00001, 0x80000, CRC(83db76f8) SHA1(ffcd0a728de58871b945c15cc27da374b587e170) ) + ROM_LOAD16_BYTE( "5", 0x00000, 0x80000, CRC(c01e88c6) SHA1(8f90261792343c92ddd877ab8a2480b5aac82961) ) + + ROM_REGION( 0x10000, "audiocpu", 0 ) /* Z80 code */ + ROM_LOAD( "sc_01.bin", 0x000000, 0x08000, CRC(cea39d6d) SHA1(f0b79c03ffafdd1e57673d6d4836becbe415110b) ) + ROM_CONTINUE( 0x000000, 0x08000 ) + + ROM_REGION( 0x200000, "sprite", ROMREGION_INVERT ) /* bootleg sprite gfx */ + ROM_LOAD( "sc_07.bin", 0x000000, 0x080000, CRC(dcb29d01) SHA1(72b4234622605f0ab03f21fdb6a61c6dac36000d) ) + ROM_LOAD( "sc_06.bin", 0x080000, 0x080000, CRC(2dc70e05) SHA1(f1d0beb8428a7e1d7c7818e6719abdc543b2fa80) ) + ROM_COPY( "sprite", 0x00000, 0x100000, 0x100000 ) + + ROM_REGION( 0x200000, "test1", 0 ) /* bootleg tile gfx */ + ROM_LOAD16_BYTE( "sc_09.bin", 0x000000, 0x080000, CRC(695b6342) SHA1(dfccb43789021ba2568b9284ae61e64f7f89b152) ) + ROM_LOAD16_BYTE( "sc_10.bin", 0x000001, 0x080000, CRC(27e172b8) SHA1(ed86db2f42c8061607d46f2407b0130aaf692a02) ) + ROM_LOAD16_BYTE( "sc_08.bin", 0x100000, 0x080000, CRC(637120f3) SHA1(b4b2ad192e46ff80d4cb440d7fb6dac215a353ed) ) + ROM_LOAD16_BYTE( "sc_11.bin", 0x100001, 0x080000, CRC(0cd5ca5e) SHA1(a59665e543e9383355de2576e6693348ec356591) ) + + ROM_REGION( 0x020000, "char", ROMREGION_INVERT ) + ROM_COPY( "test1", 0x080000, 0x00000, 0x020000 ) + + ROM_REGION( 0x100000, "gfx3", ROMREGION_INVERT ) /* MBK tiles */ + ROM_COPY( "test1", 0x00000, 0x00000, 0x080000 ) + ROM_COPY( "test1", 0x100000, 0x80000, 0x080000 ) + + ROM_REGION( 0x100000, "gfx4", ROMREGION_INVERT ) /* not used */ + ROM_COPY("gfx3",0x00000,0x00000,0x100000) + + ROM_REGION( 0x080000, "gfx5", ROMREGION_INVERT ) /* BK3 tiles */ + ROM_COPY( "test1", 0x180000, 0x00000, 0x080000 ) + + ROM_REGION( 0x080000, "gfx6", ROMREGION_INVERT ) /* LBK tiles */ + ROM_COPY( "gfx5", 0x00000, 0x00000, 0x080000 ) + + ROM_REGION( 0x100000, "adpcm", ROMREGION_ERASEFF ) /* ADPCM samples */ + ROM_LOAD( "sc_02.bin", 0x000000, 0x020000, CRC(a70d4f03) SHA1(c2482e624c8a828a94206a36d10c1021ad8ca1d0) ) + ROM_LOAD( "sc_03.bin", 0x080000, 0x080000, CRC(6e254d12) SHA1(857779dbd276b688201a8ea3afd5817e38acad2e) ) + + ROM_REGION( 0x200000, "oki", ROMREGION_ERASEFF ) + ROM_COPY( "adpcm", 0x00000, 0x000000, 0x20000 ) //bank 0 + ROM_COPY( "adpcm", 0x00000, 0x020000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x100000, 0x20000 ) //bank 4 + ROM_COPY( "adpcm", 0x80000, 0x120000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x140000, 0x20000 ) //bank 5 + ROM_COPY( "adpcm", 0xa0000, 0x160000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x180000, 0x20000 ) //bank 6 + ROM_COPY( "adpcm", 0xc0000, 0x1a0000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x1c0000, 0x20000 ) //bank 7 + ROM_COPY( "adpcm", 0xe0000, 0x1e0000, 0x20000 ) + + + /* these are maths tables, for whatever COP replacement the bootlegs use */ + ROM_REGION( 0x500000, "unknown0", 0 ) + ROM_LOAD16_BYTE( "sc_13.bin", 0x00000, 0x010000, CRC(229bddd8) SHA1(0924bf29db9c5a970546f154e7752697fdce6a58) ) + ROM_LOAD16_BYTE( "sc_12.bin", 0x00001, 0x010000, CRC(dabfa826) SHA1(0db587c846755491b169ef7751ba8e7cdc2607e6) ) + ROM_REGION( 0x500000, "unknown1", 0 ) + ROM_LOAD16_BYTE( "sc_15.bin", 0x00000, 0x080000, CRC(8fd87e65) SHA1(acc9fd0289fa9ab60bec16d3e642039380e5180a) ) + ROM_LOAD16_BYTE( "sc_14.bin", 0x00001, 0x080000, CRC(566086c2) SHA1(b7d09ce978f99ecc0d1975b31330ed49317701d5) ) +ROM_END + +ROM_START( cupsocsb3 ) + ROM_REGION( 0x100000, "maincpu", 0 ) /* 68000 Code */ + ROM_LOAD16_BYTE( "4.bin", 0x00001, 0x80000, CRC(f615058f) SHA1(f7c0eb6b9f8dcdc8b13f8e5b03f46252a87a6c0f) ) // sldh + ROM_LOAD16_BYTE( "5.bin", 0x00000, 0x80000, CRC(6500edf2) SHA1(1a617b18b4997c24af53601c98e9a0efbe637a4b) ) // sldh + + ROM_REGION( 0x10000, "audiocpu", 0 ) /* Z80 code */ + ROM_LOAD( "sc_01.bin", 0x000000, 0x08000, CRC(cea39d6d) SHA1(f0b79c03ffafdd1e57673d6d4836becbe415110b) ) + ROM_CONTINUE( 0x000000, 0x08000 ) + + ROM_REGION( 0x200000, "sprite", ROMREGION_INVERT ) /* bootleg sprite gfx */ + ROM_LOAD( "sc_07.bin", 0x000000, 0x080000, CRC(dcb29d01) SHA1(72b4234622605f0ab03f21fdb6a61c6dac36000d) ) + ROM_LOAD( "sc_06.bin", 0x080000, 0x080000, CRC(2dc70e05) SHA1(f1d0beb8428a7e1d7c7818e6719abdc543b2fa80) ) + ROM_COPY( "sprite", 0x00000, 0x100000, 0x100000 ) + + ROM_REGION( 0x200000, "test1", 0 ) /* bootleg tile gfx */ + ROM_LOAD16_BYTE( "sc_09.bin", 0x000000, 0x080000, CRC(695b6342) SHA1(dfccb43789021ba2568b9284ae61e64f7f89b152) ) + ROM_LOAD16_BYTE( "sc_10.bin", 0x000001, 0x080000, CRC(27e172b8) SHA1(ed86db2f42c8061607d46f2407b0130aaf692a02) ) + ROM_LOAD16_BYTE( "sc_08.bin", 0x100000, 0x080000, CRC(637120f3) SHA1(b4b2ad192e46ff80d4cb440d7fb6dac215a353ed) ) + ROM_LOAD16_BYTE( "sc_11.bin", 0x100001, 0x080000, CRC(0cd5ca5e) SHA1(a59665e543e9383355de2576e6693348ec356591) ) + + ROM_REGION( 0x020000, "char", ROMREGION_INVERT ) + ROM_COPY( "test1", 0x080000, 0x00000, 0x020000 ) + + ROM_REGION( 0x100000, "gfx3", ROMREGION_INVERT ) /* MBK tiles */ + ROM_COPY( "test1", 0x00000, 0x00000, 0x080000 ) + ROM_COPY( "test1", 0x100000, 0x80000, 0x080000 ) + + ROM_REGION( 0x100000, "gfx4", ROMREGION_INVERT ) /* not used */ + ROM_COPY("gfx3",0x00000,0x00000,0x100000) + + ROM_REGION( 0x080000, "gfx5", ROMREGION_INVERT ) /* BK3 tiles */ + ROM_COPY( "test1", 0x180000, 0x00000, 0x080000 ) + + ROM_REGION( 0x080000, "gfx6", ROMREGION_INVERT ) /* LBK tiles */ + ROM_COPY( "gfx5", 0x00000, 0x00000, 0x080000 ) + + ROM_REGION( 0x100000, "adpcm", ROMREGION_ERASEFF ) /* ADPCM samples */ + ROM_LOAD( "sc_02.bin", 0x000000, 0x020000, CRC(a70d4f03) SHA1(c2482e624c8a828a94206a36d10c1021ad8ca1d0) ) + ROM_LOAD( "sc_03.bin", 0x080000, 0x080000, CRC(6e254d12) SHA1(857779dbd276b688201a8ea3afd5817e38acad2e) ) + + ROM_REGION( 0x200000, "oki", ROMREGION_ERASEFF ) + ROM_COPY( "adpcm", 0x00000, 0x000000, 0x20000 ) //bank 0 + ROM_COPY( "adpcm", 0x00000, 0x020000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x100000, 0x20000 ) //bank 4 + ROM_COPY( "adpcm", 0x80000, 0x120000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x140000, 0x20000 ) //bank 5 + ROM_COPY( "adpcm", 0xa0000, 0x160000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x180000, 0x20000 ) //bank 6 + ROM_COPY( "adpcm", 0xc0000, 0x1a0000, 0x20000 ) + ROM_COPY( "adpcm", 0x00000, 0x1c0000, 0x20000 ) //bank 7 + ROM_COPY( "adpcm", 0xe0000, 0x1e0000, 0x20000 ) + + /* these are maths tables, for whatever COP replacement the bootlegs use */ + ROM_REGION( 0x500000, "unknown0", 0 ) + ROM_LOAD16_BYTE( "sc_13.bin", 0x00000, 0x010000, CRC(229bddd8) SHA1(0924bf29db9c5a970546f154e7752697fdce6a58) ) + ROM_LOAD16_BYTE( "sc_12.bin", 0x00001, 0x010000, CRC(dabfa826) SHA1(0db587c846755491b169ef7751ba8e7cdc2607e6) ) + ROM_REGION( 0x500000, "unknown1", 0 ) + ROM_LOAD16_BYTE( "sc_15.bin", 0x00000, 0x080000, CRC(8fd87e65) SHA1(acc9fd0289fa9ab60bec16d3e642039380e5180a) ) + ROM_LOAD16_BYTE( "sc_14.bin", 0x00001, 0x080000, CRC(566086c2) SHA1(b7d09ce978f99ecc0d1975b31330ed49317701d5) ) +ROM_END + + +GAME( 1992, cupsocsb, cupsoc, cupsocbl, cupsoc, driver_device, 0, ROT0, "bootleg", "Seibu Cup Soccer :Selection: (bootleg, set 1)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) +GAME( 1992, cupsocsb2,cupsoc, cupsocbl, cupsoc, driver_device, 0, ROT0, "bootleg", "Seibu Cup Soccer :Selection: (bootleg, set 2)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) +GAME( 1992, cupsocsb3,cupsoc, cupsocbl, cupsoc, driver_device, 0, ROT0, "bootleg", "Seibu Cup Soccer :Selection: (bootleg, set 3)", MACHINE_UNEMULATED_PROTECTION | MACHINE_NOT_WORKING ) diff --git a/src/mame/etc/template_cpu.cpp b/src/mame/etc/template_cpu.cpp index 3f85ad1dddc..b6900258a43 100644 --- a/src/mame/etc/template_cpu.cpp +++ b/src/mame/etc/template_cpu.cpp @@ -1,5 +1,5 @@ // license:BSD-3-Clause -// copyright-holders:Angelo Salese +// copyright-holders: /***************************************************************************** * * template for CPU cores diff --git a/src/mame/etc/template_cpu.h b/src/mame/etc/template_cpu.h index 04b06ef0ff5..ac877c5ef64 100644 --- a/src/mame/etc/template_cpu.h +++ b/src/mame/etc/template_cpu.h @@ -1,5 +1,5 @@ // license:BSD-3-Clause -// copyright-holders:Angelo Salese +// copyright-holders: /***************************************************************************** * * template for CPU cores diff --git a/src/mame/etc/template_device.cpp b/src/mame/etc/template_device.cpp index 8bc48c8e5de..2e325d909d3 100644 --- a/src/mame/etc/template_device.cpp +++ b/src/mame/etc/template_device.cpp @@ -1,5 +1,5 @@ // license:BSD-3-Clause -// copyright-holders:Angelo Salese +// copyright-holders: /*************************************************************************** Template for skeleton device diff --git a/src/mame/etc/template_device.h b/src/mame/etc/template_device.h index 409c9cb3ad3..2173165181c 100644 --- a/src/mame/etc/template_device.h +++ b/src/mame/etc/template_device.h @@ -1,5 +1,5 @@ // license:BSD-3-Clause -// copyright-holders:Angelo Salese +// copyright-holders: /*************************************************************************** Template for skeleton device diff --git a/src/mame/etc/template_driver.cpp b/src/mame/etc/template_driver.cpp index c233db1b6ba..27aa3c1fb1c 100644 --- a/src/mame/etc/template_driver.cpp +++ b/src/mame/etc/template_driver.cpp @@ -1,5 +1,5 @@ // license:BSD-3-Clause -// copyright-holders:Angelo Salese +// copyright-holders: /*************************************************************************** Template for skeleton drivers diff --git a/src/mame/includes/legionna.h b/src/mame/includes/legionna.h index 83bea98223b..463c9228eca 100644 --- a/src/mame/includes/legionna.h +++ b/src/mame/includes/legionna.h @@ -23,7 +23,6 @@ public: m_oki(*this, "oki"), m_gfxdecode(*this, "gfxdecode"), m_palette(*this, "palette"), - m_soundlatch(*this, "soundlatch"), m_raiden2cop(*this, "raiden2cop") { memset(scrollvals, 0, sizeof(UINT16)*6); @@ -60,7 +59,6 @@ public: DECLARE_WRITE16_MEMBER(legionna_midground_w); DECLARE_WRITE16_MEMBER(legionna_foreground_w); DECLARE_WRITE16_MEMBER(legionna_text_w); - DECLARE_WRITE8_MEMBER(okim_rombank_w); DECLARE_READ16_MEMBER(sound_comms_r); DECLARE_WRITE16_MEMBER(sound_comms_w); DECLARE_WRITE16_MEMBER(denjinmk_setgfxbank); @@ -100,7 +98,6 @@ public: required_device m_oki; required_device m_gfxdecode; required_device m_palette; - optional_device m_soundlatch; optional_device m_raiden2cop; }; diff --git a/src/mame/machine/seicop.cpp b/src/mame/machine/seicop.cpp index 7588bb1b41e..e0509530d08 100644 --- a/src/mame/machine/seicop.cpp +++ b/src/mame/machine/seicop.cpp @@ -24,8 +24,8 @@ const device_type SEIBU_COP_BOOTLEG = &device_creator; seibu_cop_bootleg_device::seibu_cop_bootleg_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) : device_t(mconfig, SEIBU_COP_BOOTLEG, "Seibu COP (Bootleg)", tag, owner, clock, "seibu_cop_boot", __FILE__), - m_cop_mcu_ram(nullptr), - m_raiden2cop(*this, ":raiden2cop") + m_cop_mcu_ram(nullptr) + //m_raiden2cop(*this, ":raiden2cop") { } @@ -72,25 +72,11 @@ READ16_MEMBER( seibu_cop_bootleg_device::copdxbl_0_r ) logerror("%06x: COPX unhandled read returning %04x from offset %04x\n", space.device().safe_pc(), retvalue, offset*2); return retvalue; } - - - - //case (0x47e/2): - //case (0x5b0/2): - //case (0x5b4/2): - // return m_cop_mcu_ram[offset]; - - case (0x700/2): return space.machine().root_device().ioport("DSW1")->read(); - case (0x704/2): return space.machine().root_device().ioport("PLAYERS12")->read(); - case (0x708/2): return space.machine().root_device().ioport("PLAYERS34")->read(); - case (0x70c/2): return space.machine().root_device().ioport("SYSTEM")->read(); - case (0x71c/2): return space.machine().root_device().ioport("DSW2")->read(); } } WRITE16_MEMBER( seibu_cop_bootleg_device::copdxbl_0_w ) { - legionna_state *state = space.machine().driver_data(); COMBINE_DATA(&m_cop_mcu_ram[offset]); switch(offset) @@ -101,7 +87,7 @@ WRITE16_MEMBER( seibu_cop_bootleg_device::copdxbl_0_w ) break; } - + #if 0 case (0x500/2): case (0x502/2): case (0x504/2): @@ -209,12 +195,6 @@ WRITE16_MEMBER( seibu_cop_bootleg_device::copdxbl_0_w ) case (0x66a/2): { state->m_scrollram16[5] = m_cop_mcu_ram[offset]; break; } case (0x66c/2): { state->m_scrollram16[6] = m_cop_mcu_ram[offset] - 0x1f0; break; } case (0x66e/2): { state->m_scrollram16[7] = m_cop_mcu_ram[offset]; break; } - - case (0x740/2): - { - state->m_soundlatch->write(space, 0, data & 0xff); - state->m_audiocpu->set_input_line(INPUT_LINE_NMI, PULSE_LINE ); - break; - } + #endif } } diff --git a/src/mame/machine/seicop.h b/src/mame/machine/seicop.h index f7a2c7f0ab1..9e508c6e615 100644 --- a/src/mame/machine/seicop.h +++ b/src/mame/machine/seicop.h @@ -21,7 +21,7 @@ protected: private: UINT16 *m_cop_mcu_ram; - required_device m_raiden2cop; + //required_device m_raiden2cop; }; extern const device_type SEIBU_COP_BOOTLEG;