From cbca538ae90e1c9ec5f6eefecf859cebb3a50bfd Mon Sep 17 00:00:00 2001 From: Dirk Best Date: Mon, 1 May 2017 13:05:33 +0200 Subject: [PATCH] chinsan: Merge mayumi driver * Interrupt enable and flip screen hooked up for chinsan * NVRAM support for chinsan --- scripts/target/mame/arcade.lua | 1 - src/mame/arcade.flt | 1 - src/mame/drivers/chinsan.cpp | 176 ++++++++++--- src/mame/drivers/mayumi.cpp | 440 --------------------------------- src/mame/mame.lst | 4 +- 5 files changed, 143 insertions(+), 479 deletions(-) delete mode 100644 src/mame/drivers/mayumi.cpp diff --git a/scripts/target/mame/arcade.lua b/scripts/target/mame/arcade.lua index a4f7a27b332..cf3e7f8192a 100644 --- a/scripts/target/mame/arcade.lua +++ b/scripts/target/mame/arcade.lua @@ -3111,7 +3111,6 @@ files { MAME_DIR .. "src/mame/includes/drmicro.h", MAME_DIR .. "src/mame/video/drmicro.cpp", MAME_DIR .. "src/mame/drivers/jantotsu.cpp", - MAME_DIR .. "src/mame/drivers/mayumi.cpp", MAME_DIR .. "src/mame/drivers/mermaid.cpp", MAME_DIR .. "src/mame/includes/mermaid.h", MAME_DIR .. "src/mame/video/mermaid.cpp", diff --git a/src/mame/arcade.flt b/src/mame/arcade.flt index 7a2e75d28cb..b6b27e9724e 100644 --- a/src/mame/arcade.flt +++ b/src/mame/arcade.flt @@ -680,7 +680,6 @@ maygay1b.cpp maygayep.cpp maygaysw.cpp maygayv1.cpp -mayumi.cpp mazerbla.cpp mcatadv.cpp mcr.cpp diff --git a/src/mame/drivers/chinsan.cpp b/src/mame/drivers/chinsan.cpp index 1b2d55b8f99..14bd5ae7cac 100644 --- a/src/mame/drivers/chinsan.cpp +++ b/src/mame/drivers/chinsan.cpp @@ -1,10 +1,12 @@ // license: BSD-3-Clause -// copyright-holders: David Haywood, Dirk Best +// copyright-holders: David Haywood, Uki, Dirk Best /*************************************************************************** Ganbare Chinsan Ooshoubu (がんばれ珍さん!大勝負) + © 1987 Sanritsu - © 1987 Sanritsu + Kiki-Ippatsu Mayumi-chan (危機一髪真由美ちゃん) + © 1988 Victory L.L.C. (developed by Sanritsu) TODO: - Figure out the rest of the dip switches @@ -20,6 +22,7 @@ #include "emu.h" #include "cpu/z80/z80.h" #include "machine/mc8123.h" +#include "machine/nvram.h" #include "machine/i8255.h" #include "sound/2203intf.h" #include "sound/msm5205.h" @@ -42,7 +45,9 @@ public: m_adpcm(*this, "adpcm"), m_inputs_p1{ {*this, "p1_0"}, {*this, "p1_1"}, {*this, "p1_2"}, {*this, "p1_3"}, {*this, "p1_4"} }, m_inputs_p2{ {*this, "p2_0"}, {*this, "p2_1"}, {*this, "p2_2"}, {*this, "p2_3"}, {*this, "p2_4"} }, + m_bank1(*this, "bank1"), m_bank0d(*this, "bank0d"), m_bank1d(*this, "bank1d"), m_tilemap(nullptr), + m_int_enabled(false), m_port_select(0xff), m_adpcm_pos(0), m_adpcm_idle(1), m_adpcm_data(0), m_trigger(0) { } @@ -51,13 +56,13 @@ public: DECLARE_READ8_MEMBER(input_p2_r); DECLARE_READ8_MEMBER(input_p1_r); - DECLARE_PALETTE_INIT(chinsan); uint32_t screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); TILE_GET_INFO_MEMBER(tile_info); DECLARE_WRITE8_MEMBER(adpcm_w); DECLARE_WRITE_LINE_MEMBER(adpcm_int_w); + INTERRUPT_GEN_MEMBER(vblank_int); DECLARE_WRITE8_MEMBER(ctrl_w); DECLARE_DRIVER_INIT(chinsan); @@ -66,18 +71,22 @@ protected: virtual void machine_reset() override; private: - required_device m_maincpu; + required_device m_maincpu; required_shared_ptr m_video_ram; required_shared_ptr m_color_ram; required_device m_gfxdecode; - required_device m_adpcm; + optional_device m_adpcm; required_ioport m_inputs_p1[5]; required_ioport m_inputs_p2[5]; + required_memory_bank m_bank1; + optional_memory_bank m_bank0d; + optional_memory_bank m_bank1d; std::unique_ptr m_decrypted_opcodes; tilemap_t *m_tilemap; + bool m_int_enabled; uint8_t m_port_select; uint32_t m_adpcm_pos; uint8_t m_adpcm_idle; @@ -93,7 +102,7 @@ private: static ADDRESS_MAP_START( chinsan_map, AS_PROGRAM, 8, chinsan_state ) AM_RANGE(0x0000, 0x7fff) AM_ROM AM_RANGE(0x8000, 0xbfff) AM_ROMBANK("bank1") - AM_RANGE(0xc000, 0xdfff) AM_RAM + AM_RANGE(0xc000, 0xdfff) AM_RAM AM_SHARE("nvram") AM_RANGE(0xe000, 0xefff) AM_RAM AM_SHARE("video_ram") AM_RANGE(0xf000, 0xf7ff) AM_RAM AM_SHARE("color_ram") ADDRESS_MAP_END @@ -103,7 +112,7 @@ static ADDRESS_MAP_START( decrypted_opcodes_map, AS_DECRYPTED_OPCODES, 8, chinsa AM_RANGE(0x8000, 0xbfff) AM_ROMBANK("bank1d") ADDRESS_MAP_END -static ADDRESS_MAP_START( chinsan_io, AS_IO, 8, chinsan_state ) +static ADDRESS_MAP_START( chinsan_io_map, AS_IO, 8, chinsan_state ) ADDRESS_MAP_GLOBAL_MASK(0xff) AM_RANGE(0x00, 0x03) AM_DEVREADWRITE("ppi", i8255_device, read, write) AM_RANGE(0x10, 0x11) AM_DEVREADWRITE("ymsnd", ym2203_device, read, write) @@ -111,6 +120,13 @@ static ADDRESS_MAP_START( chinsan_io, AS_IO, 8, chinsan_state ) AM_RANGE(0x30, 0x30) AM_WRITE(ctrl_w) ADDRESS_MAP_END +static ADDRESS_MAP_START( mayumi_io_map, AS_IO, 8, chinsan_state ) + ADDRESS_MAP_GLOBAL_MASK(0xff) + AM_RANGE(0x30, 0x30) AM_READ_PORT("extra") AM_WRITE(ctrl_w) + AM_RANGE(0xc0, 0xc3) AM_DEVREADWRITE("ppi", i8255_device, read, write) + AM_RANGE(0xd0, 0xd1) AM_DEVREADWRITE("ymsnd", ym2203_device, read, write) +ADDRESS_MAP_END + //************************************************************************** // INPUTS @@ -133,7 +149,9 @@ static INPUT_PORTS_START( chinsan ) PORT_DIPSETTING( 0x00, DEF_STR( On )) PORT_DIPSETTING( 0x20, DEF_STR( Off )) PORT_DIPUNKNOWN_DIPLOC(0x40, 0x40, "SW-1:7") - PORT_DIPUNKNOWN_DIPLOC(0x80, 0x80, "SW-1:8") + PORT_DIPNAME(0x80, 0x80, DEF_STR( Flip_Screen )) PORT_DIPLOCATION("SW-1:8") + PORT_DIPSETTING( 0x00, DEF_STR( On )) + PORT_DIPSETTING( 0x80, DEF_STR( Off )) PORT_START("DSW2") PORT_DIPUNKNOWN_DIPLOC(0x01, 0x01, "SW-2:1") @@ -246,6 +264,53 @@ static INPUT_PORTS_START( chinsan ) PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_SERVICE ) INPUT_PORTS_END +static INPUT_PORTS_START( mayumi ) + PORT_INCLUDE(chinsan) + + PORT_MODIFY("DSW1") + PORT_DIPUNKNOWN_DIPLOC(0x01, 0x01, "SW-1:8") + PORT_DIPUNKNOWN_DIPLOC(0x02, 0x02, "SW-1:7") + PORT_DIPNAME( 0x04, 0x04, DEF_STR( Service_Mode )) PORT_DIPLOCATION("SW-1:6") + PORT_DIPSETTING( 0x04, DEF_STR( Off )) + PORT_DIPSETTING( 0x00, DEF_STR( On )) + PORT_DIPNAME( 0x18, 0x00, DEF_STR( Coinage )) PORT_DIPLOCATION("SW-1:5,4") + PORT_DIPSETTING( 0x00, DEF_STR( 1C_1C )) + PORT_DIPSETTING( 0x08, DEF_STR( 1C_2C )) + PORT_DIPSETTING( 0x10, DEF_STR( 1C_3C )) + PORT_DIPSETTING( 0x18, DEF_STR( 2C_1C )) + PORT_DIPUNKNOWN_DIPLOC(0x20, 0x20, "SW-1:3") + PORT_DIPUNKNOWN_DIPLOC(0x40, 0x40, "SW-1:2") + PORT_DIPNAME(0x80, 0x80, DEF_STR( Flip_Screen )) PORT_DIPLOCATION("SW-1:1") + PORT_DIPSETTING( 0x00, DEF_STR( On )) + PORT_DIPSETTING( 0x80, DEF_STR( Off )) + + PORT_MODIFY("DSW2") + PORT_DIPUNKNOWN_DIPLOC(0x01, 0x01, "SW-2:8") + PORT_DIPUNKNOWN_DIPLOC(0x02, 0x02, "SW-2:7") + PORT_DIPUNKNOWN_DIPLOC(0x04, 0x04, "SW-2:6") + PORT_DIPUNKNOWN_DIPLOC(0x08, 0x08, "SW-2:5") + PORT_DIPUNKNOWN_DIPLOC(0x10, 0x10, "SW-2:4") + PORT_DIPUNKNOWN_DIPLOC(0x20, 0x20, "SW-2:3") + PORT_DIPUNKNOWN_DIPLOC(0x40, 0x40, "SW-2:2") + PORT_DIPUNKNOWN_DIPLOC(0x80, 0x80, "SW-2:1") + + PORT_MODIFY("p1_4") + PORT_BIT( 0xff, IP_ACTIVE_LOW, IPT_UNKNOWN ) + + PORT_MODIFY("p2_4") + PORT_BIT( 0xff, IP_ACTIVE_LOW, IPT_UNKNOWN ) + + PORT_START("extra") + PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_UNKNOWN ) + PORT_BIT( 0x40, IP_ACTIVE_LOW , IPT_COIN1 ) + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_UNKNOWN ) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_SERVICE ) PORT_TOGGLE + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_SERVICE1 ) PORT_TOGGLE PORT_NAME("Statistics") + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_UNKNOWN ) + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_UNKNOWN ) + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_MEMORY_RESET ) +INPUT_PORTS_END + //************************************************************************** // INPUT PORT HANDLING @@ -286,19 +351,6 @@ READ8_MEMBER( chinsan_state::input_p2_r ) } -//************************************************************************** -// PALETTE -//************************************************************************** - -PALETTE_INIT_MEMBER( chinsan_state, chinsan ) -{ - uint8_t *src = memregion("color_proms")->base(); - - for (int i = 0; i < 0x100; i++) - palette.set_pen_color(i, pal4bit(src[i + 0x000]), pal4bit(src[i + 0x100]), pal4bit(src[i + 0x200])); -} - - //************************************************************************** // VIDEO EMULATION //************************************************************************** @@ -372,23 +424,48 @@ WRITE_LINE_MEMBER( chinsan_state::adpcm_int_w ) // MACHINE EMULATION //************************************************************************** +INTERRUPT_GEN_MEMBER( chinsan_state::vblank_int ) +{ + if (m_int_enabled) + device.execute().set_input_line(INPUT_LINE_IRQ0, HOLD_LINE); +} + WRITE8_MEMBER( chinsan_state::ctrl_w ) { // 76------ rom bank - // --543210 unknown + // --5432-- unknown + // ------1- flip screen + // -------0 interrupt enable - membank("bank1")->set_entry(data >> 6); - membank("bank1d")->set_entry(data >> 6); + m_int_enabled = bool(BIT(data, 0)); + flip_screen_set(BIT(data, 1)); + + if (m_bank1d.found()) + { + int bank = (BIT(data, 7) << 1) | BIT(data, 6); + m_bank1->set_entry(bank); + m_bank1d->set_entry(bank); + } + else + { + // bank bits have switched for mayumi + int bank = (BIT(data, 6) << 1) | BIT(data, 7); + m_bank1->set_entry(bank); + } } void chinsan_state::machine_start() { m_tilemap = &machine().tilemap().create(*m_gfxdecode, tilemap_get_info_delegate(FUNC(chinsan_state::tile_info), this), TILEMAP_SCAN_ROWS, 8, 8, 64, 32); - membank("bank1")->configure_entries(0, 4, memregion("maincpu")->base() + 0x8000, 0x4000); - membank("bank0d")->set_base(m_decrypted_opcodes.get()); - membank("bank1d")->configure_entries(0, 4, m_decrypted_opcodes.get() + 0x8000, 0x4000); + m_bank1->configure_entries(0, 4, memregion("maincpu")->base() + 0x8000, 0x4000); + if (m_bank0d.found()) + m_bank0d->set_base(m_decrypted_opcodes.get()); + if (m_bank1d.found()) + m_bank1d->configure_entries(0, 4, m_decrypted_opcodes.get() + 0x8000, 0x4000); + + save_item(NAME(m_int_enabled)); save_item(NAME(m_port_select)); save_item(NAME(m_adpcm_pos)); save_item(NAME(m_adpcm_idle)); @@ -398,6 +475,7 @@ void chinsan_state::machine_start() void chinsan_state::machine_reset() { + m_int_enabled = false; m_port_select = 0xff; m_adpcm_pos = 0; m_adpcm_idle = 1; @@ -420,9 +498,11 @@ DRIVER_INIT_MEMBER( chinsan_state, chinsan ) static MACHINE_CONFIG_START( chinsan, chinsan_state ) MCFG_CPU_ADD("maincpu", MC8123, XTAL_10MHz/2) // 317-5012 MCFG_CPU_PROGRAM_MAP(chinsan_map) - MCFG_CPU_IO_MAP(chinsan_io) + MCFG_CPU_IO_MAP(chinsan_io_map) MCFG_CPU_DECRYPTED_OPCODES_MAP(decrypted_opcodes_map) - MCFG_CPU_VBLANK_INT_DRIVER("screen", chinsan_state, irq0_line_hold) + MCFG_CPU_VBLANK_INT_DRIVER("screen", chinsan_state, vblank_int) + + MCFG_NVRAM_ADD_0FILL("nvram") MCFG_DEVICE_ADD("ppi", I8255A, 0) MCFG_I8255_OUT_PORTA_CB(WRITE8(chinsan_state, input_select_w)) @@ -439,8 +519,7 @@ static MACHINE_CONFIG_START( chinsan, chinsan_state ) MCFG_SCREEN_PALETTE("palette") MCFG_GFXDECODE_ADD("gfxdecode", "palette", chinsan) - MCFG_PALETTE_ADD("palette", 256) - MCFG_PALETTE_INIT_OWNER(chinsan_state, chinsan) + MCFG_PALETTE_ADD_RRRRGGGGBBBB_PROMS("palette", 256) // sound hardware MCFG_SPEAKER_STANDARD_MONO("mono") @@ -459,6 +538,18 @@ static MACHINE_CONFIG_START( chinsan, chinsan_state ) MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.50) MACHINE_CONFIG_END +static MACHINE_CONFIG_DERIVED( mayumi, chinsan ) + // standard Z80 instead of MC-8123 + MCFG_DEVICE_REMOVE("maincpu") + MCFG_CPU_ADD("maincpu", Z80, XTAL_10MHz/2) + MCFG_CPU_PROGRAM_MAP(chinsan_map) + MCFG_CPU_IO_MAP(mayumi_io_map) + MCFG_CPU_VBLANK_INT_DRIVER("screen", chinsan_state, vblank_int) + + // no ADPCM + MCFG_DEVICE_REMOVE("adpcm") +MACHINE_CONFIG_END + //************************************************************************** // ROM DEFINITIONS @@ -484,16 +575,33 @@ ROM_START( chinsan ) ROM_REGION( 0x20, "user2", 0 ) ROM_LOAD( "mm60.2c", 0x000, 0x020, CRC(88477178) SHA1(03c1c9e3e88a5ae9970cb4b872ad4b6e4d77a6da) ) - ROM_REGION( 0x300, "color_proms", 0 ) + ROM_REGION( 0x300, "proms", 0 ) ROM_LOAD( "mm63.10n", 0x000, 0x100, CRC(b65e3567) SHA1(f146af51dfaa5b4bf44c4e27f1a0292f8fd07ce9) ) // r ROM_LOAD( "mm62.9n", 0x100, 0x100, CRC(b5a1dbe5) SHA1(770a791c061ce422f860bb8d32f82bbbf9b4d12a) ) // g ROM_LOAD( "mm61.9m", 0x200, 0x100, CRC(57024262) SHA1(e084e6baa3c529217f6f8e37c9dd5f0687ba2fc4) ) // b ROM_END +ROM_START( mayumi ) + ROM_REGION( 0x18000, "maincpu", 0 ) + ROM_LOAD( "my00.bin", 0x00000, 0x08000, CRC(33189e37) SHA1(cbf75f56360ef7da5b7b1207b58cd0d72bcaf207) ) + ROM_LOAD( "my01.bin", 0x08000, 0x10000, CRC(5280fb39) SHA1(cee7653f4353031701ec1608881b37073b178d9f) ) // banked + + ROM_REGION( 0x30000, "gfx1", 0 ) + ROM_LOAD( "my10.bin", 0x00000, 0x10000, CRC(3b4f4f97) SHA1(50bda1484e965f15630bd2e05861d74ddeb0d88e) ) + ROM_LOAD( "my20.bin", 0x10000, 0x10000, CRC(18544029) SHA1(74bd8bb422db33bd7af08afbf9b801bd31a3f199) ) + ROM_LOAD( "my30.bin", 0x20000, 0x10000, CRC(7f22d53f) SHA1(f8e5874ba0fa003ba0d6a504b2169acdf1491484) ) + + ROM_REGION( 0x0300, "proms", 0 ) + ROM_LOAD( "my-9m.bin", 0x0000, 0x0100, CRC(b18fd669) SHA1(e2b1477c1bc49994b0b652d63a2205363aab9a74) ) // r + ROM_LOAD( "my-9l.bin", 0x0100, 0x0100, CRC(f3fef561) SHA1(247f579fe91ad7e516c93a873b2ecca780bf6da0) ) // g + ROM_LOAD( "my-9k.bin", 0x0200, 0x0100, CRC(3e7a8012) SHA1(24129586a1c39f68dad274b5afbdd6c027ab0901) ) // b +ROM_END + //************************************************************************** // SYSTEM DRIVERS //************************************************************************** -// YEAR NAME PARENT MACHINE INPUT CLASS INIT ROTATION COMPANY FULLNAME FLAGS -GAME( 1987, chinsan, 0, chinsan, chinsan, chinsan_state, chinsan, ROT0, "Sanritsu", "Ganbare Chinsan Ooshoubu (MC-8123A, 317-5012)", MACHINE_SUPPORTS_SAVE ) +// YEAR NAME PARENT MACHINE INPUT CLASS INIT ROTATION COMPANY FULLNAME FLAGS +GAME( 1987, chinsan, 0, chinsan, chinsan, chinsan_state, chinsan, ROT0, "Sanritsu", "Ganbare Chinsan Ooshoubu (MC-8123A, 317-5012)", MACHINE_SUPPORTS_SAVE ) +GAME( 1988, mayumi, 0, mayumi, mayumi, driver_device, 0, ROT0, "Victory L.L.C.", "Kiki-Ippatsu Mayumi-chan", MACHINE_SUPPORTS_SAVE ) diff --git a/src/mame/drivers/mayumi.cpp b/src/mame/drivers/mayumi.cpp deleted file mode 100644 index e6787480bc7..00000000000 --- a/src/mame/drivers/mayumi.cpp +++ /dev/null @@ -1,440 +0,0 @@ -// license:BSD-3-Clause -// copyright-holders:Uki -/***************************************************************************** - - Kikiippatsu Mayumi-chan (c) 1988 Victory L.L.C. - - Driver by Uki - -*****************************************************************************/ - -#include "emu.h" -#include "cpu/z80/z80.h" -#include "machine/nvram.h" -#include "machine/i8255.h" -#include "sound/2203intf.h" -#include "screen.h" -#include "speaker.h" - -#define MCLK XTAL_10MHz - - -class mayumi_state : public driver_device -{ -public: - mayumi_state(const machine_config &mconfig, device_type type, const char *tag) - : driver_device(mconfig, type, tag), - m_videoram(*this, "videoram"), - m_i8255(*this, "i8255"), - m_maincpu(*this, "maincpu"), - m_gfxdecode(*this, "gfxdecode") - { } - - /* memory pointers */ - required_shared_ptr m_videoram; - required_device m_i8255; -// uint8_t * m_nvram; // this currently uses generic nvram handlers - - /* video-related */ - tilemap_t *m_tilemap; - - /* misc */ - int m_int_enable; - int m_input_sel; - uint8_t key_matrix_r(uint8_t offset); - DECLARE_WRITE8_MEMBER(mayumi_videoram_w); - DECLARE_WRITE8_MEMBER(bank_sel_w); - DECLARE_WRITE8_MEMBER(input_sel_w); - DECLARE_READ8_MEMBER(key_matrix_1p_r); - DECLARE_READ8_MEMBER(key_matrix_2p_r); - TILE_GET_INFO_MEMBER(get_tile_info); - virtual void machine_start() override; - virtual void machine_reset() override; - virtual void video_start() override; - uint32_t screen_update_mayumi(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); - INTERRUPT_GEN_MEMBER(mayumi_interrupt); - required_device m_maincpu; - required_device m_gfxdecode; -}; - - -/************************************* - * - * Video emulation - * - *************************************/ - -TILE_GET_INFO_MEMBER(mayumi_state::get_tile_info) -{ - int code = m_videoram[tile_index] + (m_videoram[tile_index + 0x800] & 0x1f) * 0x100; - int col = (m_videoram[tile_index + 0x1000] >> 3) & 0x1f; - - SET_TILE_INFO_MEMBER(0, code, col, 0); -} - -void mayumi_state::video_start() -{ - m_tilemap = &machine().tilemap().create(*m_gfxdecode, tilemap_get_info_delegate(FUNC(mayumi_state::get_tile_info),this), TILEMAP_SCAN_ROWS, 8, 8, 64, 32); -} - -WRITE8_MEMBER(mayumi_state::mayumi_videoram_w) -{ - m_videoram[offset] = data; - m_tilemap->mark_tile_dirty(offset & 0x7ff); -} - -uint32_t mayumi_state::screen_update_mayumi(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) -{ - m_tilemap->draw(screen, bitmap, cliprect, 0, 0); - return 0; -} - -/************************************* - * - * Interrupt generator - * - *************************************/ - -INTERRUPT_GEN_MEMBER(mayumi_state::mayumi_interrupt) -{ - if (m_int_enable) - device.execute().set_input_line(0, HOLD_LINE); -} - -/************************************* - * - * Memory handlers - * - *************************************/ - -WRITE8_MEMBER(mayumi_state::bank_sel_w) -{ - int bank = BIT(data, 7) | (BIT(data, 6) << 1); - - membank("bank1")->set_entry(bank); - - m_int_enable = data & 1; - - flip_screen_set(data & 2); -} - -/************************************* - * - * Address maps - * - *************************************/ - -static ADDRESS_MAP_START( mayumi_map, AS_PROGRAM, 8, mayumi_state ) - AM_RANGE(0x0000, 0x7fff) AM_ROM - AM_RANGE(0x8000, 0xbfff) AM_ROMBANK("bank1") - AM_RANGE(0xc000, 0xdfff) AM_RAM AM_SHARE("nvram") - AM_RANGE(0xe000, 0xf7ff) AM_RAM_WRITE(mayumi_videoram_w) AM_SHARE("videoram") -ADDRESS_MAP_END - - -static ADDRESS_MAP_START( mayumi_io_map, AS_IO, 8, mayumi_state ) - ADDRESS_MAP_GLOBAL_MASK(0xff) - AM_RANGE(0x30, 0x30) AM_READ_PORT("IN0") AM_WRITE(bank_sel_w) - AM_RANGE(0xc0, 0xc3) AM_DEVREADWRITE("i8255", i8255_device, read, write) - AM_RANGE(0xd0, 0xd1) AM_DEVREADWRITE("ymsnd", ym2203_device, read, write) -ADDRESS_MAP_END - -/************************************* - * - * Input ports - * - *************************************/ - -static INPUT_PORTS_START( mayumi ) - PORT_START("DSW1") - PORT_DIPNAME( 0x80, 0x80, DEF_STR( Flip_Screen ) ) - PORT_DIPSETTING( 0x80, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x40, 0x40, "Unknown 1-2" ) - PORT_DIPSETTING( 0x40, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x20, 0x20, "Unknown 1-3" ) - PORT_DIPSETTING( 0x20, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x18, 0x00, DEF_STR( Coinage ) ) - PORT_DIPSETTING( 0x18, DEF_STR( 2C_1C ) ) - PORT_DIPSETTING( 0x00, DEF_STR( 1C_1C ) ) - PORT_DIPSETTING( 0x08, DEF_STR( 1C_2C ) ) - PORT_DIPSETTING( 0x10, DEF_STR( 1C_3C ) ) - PORT_DIPNAME( 0x04, 0x04, "Service Mode (DSW 1-6)" ) - PORT_DIPSETTING( 0x04, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x02, 0x02, "Unknown 1-7" ) - PORT_DIPSETTING( 0x02, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x01, 0x01, "Unknown 1-8" ) - PORT_DIPSETTING( 0x01, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - - PORT_START("DSW2") - PORT_DIPNAME( 0x80, 0x80, "Unknown 2-1" ) - PORT_DIPSETTING( 0x80, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x40, 0x40, "Unknown 2-2" ) - PORT_DIPSETTING( 0x40, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x20, 0x20, "Unknown 2-3" ) - PORT_DIPSETTING( 0x20, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x10, 0x10, "Unknown 2-4" ) - PORT_DIPSETTING( 0x10, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x08, 0x08, "Unknown 2-5" ) - PORT_DIPSETTING( 0x08, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x04, 0x04, "Unknown 2-6" ) - PORT_DIPSETTING( 0x04, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x02, 0x02, "Unknown 2-7" ) - PORT_DIPSETTING( 0x02, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - PORT_DIPNAME( 0x01, 0x01, "Unknown 2-8" ) - PORT_DIPSETTING( 0x01, DEF_STR( Off ) ) - PORT_DIPSETTING( 0x00, DEF_STR( On ) ) - - PORT_START("KEY0") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_A ) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_E ) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_I ) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_M ) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_MAHJONG_KAN ) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_START1 ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY1") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_B ) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_F ) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_J ) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_N ) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_MAHJONG_REACH ) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY2") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_C ) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_G ) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_K ) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_CHI ) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_MAHJONG_RON ) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY3") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_D ) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_H ) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_L ) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_PON ) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY4") - PORT_BIT( 0x3f, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY5") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_A ) PORT_PLAYER(2) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_E ) PORT_PLAYER(2) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_I ) PORT_PLAYER(2) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_M ) PORT_PLAYER(2) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_MAHJONG_KAN ) PORT_PLAYER(2) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_START2 ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY6") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_B ) PORT_PLAYER(2) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_F ) PORT_PLAYER(2) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_J ) PORT_PLAYER(2) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_N ) PORT_PLAYER(2) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_MAHJONG_REACH ) PORT_PLAYER(2) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY7") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_C ) PORT_PLAYER(2) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_G ) PORT_PLAYER(2) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_K ) PORT_PLAYER(2) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_CHI ) PORT_PLAYER(2) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_MAHJONG_RON ) PORT_PLAYER(2) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY8") - PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_MAHJONG_D ) PORT_PLAYER(2) - PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_MAHJONG_H ) PORT_PLAYER(2) - PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_MAHJONG_L ) PORT_PLAYER(2) - PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_MAHJONG_PON ) PORT_PLAYER(2) - PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("KEY9") - PORT_BIT( 0x3f, IP_ACTIVE_LOW, IPT_UNKNOWN ) - PORT_BIT( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED ) - - PORT_START("IN0") - PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_UNKNOWN ) - PORT_BIT( 0x40, IP_ACTIVE_LOW , IPT_COIN1 ) - PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_UNKNOWN ) - PORT_SERVICE( 0x10, IP_ACTIVE_HIGH ) - PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_SERVICE2 ) // analyzer - PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_UNKNOWN ) - PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_UNKNOWN ) - PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_MEMORY_RESET ) // memory reset -INPUT_PORTS_END - -WRITE8_MEMBER(mayumi_state::input_sel_w) -{ - m_input_sel = data; -} - -uint8_t mayumi_state::key_matrix_r(uint8_t offset) -{ - int p, i, ret; - static const char *const keynames[2][5] = - { - { "KEY0", "KEY1", "KEY2", "KEY3", "KEY4" }, - { "KEY5", "KEY6", "KEY7", "KEY8", "KEY9" } - }; - - ret = 0xff; - - p = ~m_input_sel & 0x1f; - - for (i = 0; i < 5; i++) - { - if (BIT(p, i)) - ret &= ioport(keynames[offset][i])->read(); - } - - return ret; -} - -READ8_MEMBER(mayumi_state::key_matrix_1p_r) -{ - return key_matrix_r(0); -} - -READ8_MEMBER(mayumi_state::key_matrix_2p_r) -{ - return key_matrix_r(1); -} - -/************************************* - * - * Graphics definitions - * - *************************************/ - -static const gfx_layout charlayout = -{ - 8,8, /* 8*8 characters */ - RGN_FRAC(1,3), /* 8192 characters */ - 3, /* 3 bits per pixel */ - { RGN_FRAC(0,3),RGN_FRAC(1,3),RGN_FRAC(2,3) }, - { STEP8(0,1) }, - { STEP8(0,8) }, - 8*8 -}; - -static GFXDECODE_START( mayumi ) - GFXDECODE_ENTRY( "gfx1", 0x00000, charlayout, 0, 32 ) -GFXDECODE_END - -/************************************* - * - * Machine driver - * - *************************************/ - -void mayumi_state::machine_start() -{ - uint8_t *ROM = memregion("maincpu")->base(); - - membank("bank1")->configure_entries(0, 4, &ROM[0x8000], 0x4000); - membank("bank1")->set_entry(0); - - save_item(NAME(m_int_enable)); - save_item(NAME(m_input_sel)); -} - -void mayumi_state::machine_reset() -{ - m_int_enable = 0; - m_input_sel = 0; -} - -static MACHINE_CONFIG_START( mayumi, mayumi_state ) - - /* basic machine hardware */ - MCFG_CPU_ADD("maincpu", Z80, MCLK/2) /* 5.000 MHz ? */ - MCFG_CPU_PROGRAM_MAP(mayumi_map) - MCFG_CPU_IO_MAP(mayumi_io_map) - MCFG_CPU_VBLANK_INT_DRIVER("screen", mayumi_state, mayumi_interrupt) - - MCFG_DEVICE_ADD("i8255", I8255, 0) - MCFG_I8255_OUT_PORTA_CB(WRITE8(mayumi_state, input_sel_w)) - MCFG_I8255_IN_PORTB_CB(READ8(mayumi_state, key_matrix_2p_r)) - MCFG_I8255_IN_PORTC_CB(READ8(mayumi_state, key_matrix_1p_r)) - - /* video hardware */ - MCFG_SCREEN_ADD("screen", RASTER) - MCFG_SCREEN_REFRESH_RATE(60) - MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500) /* not accurate */) - MCFG_SCREEN_SIZE(64*8, 32*8) - MCFG_SCREEN_VISIBLE_AREA(2*8, 62*8-1, 2*8, 30*8-1) - MCFG_SCREEN_UPDATE_DRIVER(mayumi_state, screen_update_mayumi) - MCFG_SCREEN_PALETTE("palette") - - MCFG_GFXDECODE_ADD("gfxdecode", "palette", mayumi) - MCFG_PALETTE_ADD_RRRRGGGGBBBB_PROMS("palette", 256) - - /* sound hardware */ - MCFG_SPEAKER_STANDARD_MONO("mono") - - MCFG_SOUND_ADD("ymsnd", YM2203, MCLK/4) - MCFG_AY8910_PORT_A_READ_CB(IOPORT("DSW1")) - MCFG_AY8910_PORT_B_READ_CB(IOPORT("DSW2")) - MCFG_SOUND_ROUTE(0, "mono", 0.15) - MCFG_SOUND_ROUTE(1, "mono", 0.15) - MCFG_SOUND_ROUTE(2, "mono", 0.15) - MCFG_SOUND_ROUTE(3, "mono", 0.40) - - MCFG_NVRAM_ADD_0FILL("nvram") - -MACHINE_CONFIG_END - -/************************************* - * - * ROM definition(s) - * - *************************************/ - -ROM_START( mayumi ) - ROM_REGION( 0x18000, "maincpu", 0 ) /* CPU */ - ROM_LOAD( "my00.bin", 0x00000, 0x08000, CRC(33189e37) SHA1(cbf75f56360ef7da5b7b1207b58cd0d72bcaf207) ) - ROM_LOAD( "my01.bin", 0x08000, 0x10000, CRC(5280fb39) SHA1(cee7653f4353031701ec1608881b37073b178d9f) ) // Banked - - ROM_REGION( 0x30000, "gfx1", 0 ) /* gfx */ - ROM_LOAD( "my30.bin", 0x00000, 0x10000, CRC(7f22d53f) SHA1(f8e5874ba0fa003ba0d6a504b2169acdf1491484) ) - ROM_LOAD( "my20.bin", 0x10000, 0x10000, CRC(18544029) SHA1(74bd8bb422db33bd7af08afbf9b801bd31a3f199) ) - ROM_LOAD( "my10.bin", 0x20000, 0x10000, CRC(3b4f4f97) SHA1(50bda1484e965f15630bd2e05861d74ddeb0d88e) ) - - ROM_REGION( 0x0300, "proms", 0 ) /* color PROMs */ - ROM_LOAD( "my-9m.bin", 0x0000, 0x0100, CRC(b18fd669) SHA1(e2b1477c1bc49994b0b652d63a2205363aab9a74) ) // R - ROM_LOAD( "my-9l.bin", 0x0100, 0x0100, CRC(f3fef561) SHA1(247f579fe91ad7e516c93a873b2ecca780bf6da0) ) // G - ROM_LOAD( "my-9k.bin", 0x0200, 0x0100, CRC(3e7a8012) SHA1(24129586a1c39f68dad274b5afbdd6c027ab0901) ) // B -ROM_END - -/************************************* - * - * Game driver(s) - * - *************************************/ - -GAME( 1988, mayumi, 0, mayumi, mayumi, driver_device, 0, ROT0, "Sanritsu / Victory L.L.C.", "Kikiippatsu Mayumi-chan (Japan)", MACHINE_SUPPORTS_SAVE ) diff --git a/src/mame/mame.lst b/src/mame/mame.lst index 6e32e5c9320..d7d3170e25c 100644 --- a/src/mame/mame.lst +++ b/src/mame/mame.lst @@ -9531,6 +9531,7 @@ saiyugoub2 // bootleg @source:chinsan.cpp chinsan // (c) 1987 Sanritsu +mayumi // (c) 1988 Victory L.L.C., made by Sanritsu @source:chqflag.cpp chqflag // GX717 (c) 1988 @@ -19887,9 +19888,6 @@ screenp3a // screenp4 // screenpl // Screenplay -@source:mayumi.cpp -mayumi // (c) 1988 Victory L.L.C., made by Sanritsu - @source:mazerbla.cpp greatgun // (c) 1983 mazerbla // (c) 1983