mirror of
https://github.com/holub/mame
synced 2025-04-21 07:52:35 +03:00
Splitted Seibu Cup Soccer bootlegs into own driver (nw)
This commit is contained in:
parent
1b811de735
commit
8347973e18
@ -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",
|
||||
|
@ -995,6 +995,7 @@ segaxbd.cpp
|
||||
segaybd.cpp
|
||||
seibuspi.cpp
|
||||
seicross.cpp
|
||||
seicupbl.cpp
|
||||
sengokmj.cpp
|
||||
senjyo.cpp
|
||||
seta.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 )
|
||||
|
578
src/mame/drivers/seicupbl.cpp
Normal file
578
src/mame/drivers/seicupbl.cpp
Normal file
@ -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<cpu_device> m_maincpu;
|
||||
required_device<cpu_device> m_audiocpu;
|
||||
required_device<okim6295_device> m_oki;
|
||||
optional_device<generic_latch_8_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 )
|
@ -1,5 +1,5 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Angelo Salese
|
||||
// copyright-holders:<author_name>
|
||||
/*****************************************************************************
|
||||
*
|
||||
* template for CPU cores
|
||||
|
@ -1,5 +1,5 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Angelo Salese
|
||||
// copyright-holders:<author_name>
|
||||
/*****************************************************************************
|
||||
*
|
||||
* template for CPU cores
|
||||
|
@ -1,5 +1,5 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Angelo Salese
|
||||
// copyright-holders:<author_name>
|
||||
/***************************************************************************
|
||||
|
||||
Template for skeleton device
|
||||
|
@ -1,5 +1,5 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Angelo Salese
|
||||
// copyright-holders:<author_name>
|
||||
/***************************************************************************
|
||||
|
||||
Template for skeleton device
|
||||
|
@ -1,5 +1,5 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Angelo Salese
|
||||
// copyright-holders:<author_name>
|
||||
/***************************************************************************
|
||||
|
||||
Template for skeleton drivers
|
||||
|
@ -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<okim6295_device> m_oki;
|
||||
required_device<gfxdecode_device> m_gfxdecode;
|
||||
required_device<palette_device> m_palette;
|
||||
optional_device<generic_latch_8_device> m_soundlatch;
|
||||
optional_device<raiden2cop_device> m_raiden2cop;
|
||||
};
|
||||
|
||||
|
@ -24,8 +24,8 @@ const device_type SEIBU_COP_BOOTLEG = &device_creator<seibu_cop_bootleg_device>;
|
||||
|
||||
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<legionna_state>();
|
||||
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
|
||||
}
|
||||
}
|
||||
|
@ -21,7 +21,7 @@ protected:
|
||||
private:
|
||||
UINT16 *m_cop_mcu_ram;
|
||||
|
||||
required_device<raiden2cop_device> m_raiden2cop;
|
||||
//required_device<raiden2cop_device> m_raiden2cop;
|
||||
};
|
||||
|
||||
extern const device_type SEIBU_COP_BOOTLEG;
|
||||
|
Loading…
Reference in New Issue
Block a user