mirror of
https://github.com/holub/mame
synced 2025-04-22 08:22:15 +03:00
chinsan: Merge mayumi driver
* Interrupt enable and flip screen hooked up for chinsan * NVRAM support for chinsan
This commit is contained in:
parent
da75918b5d
commit
cbca538ae9
@ -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",
|
||||
|
@ -680,7 +680,6 @@ maygay1b.cpp
|
||||
maygayep.cpp
|
||||
maygaysw.cpp
|
||||
maygayv1.cpp
|
||||
mayumi.cpp
|
||||
mazerbla.cpp
|
||||
mcatadv.cpp
|
||||
mcr.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<mc8123_device> m_maincpu;
|
||||
required_device<z80_device> m_maincpu;
|
||||
required_shared_ptr<uint8_t> m_video_ram;
|
||||
required_shared_ptr<uint8_t> m_color_ram;
|
||||
required_device<gfxdecode_device> m_gfxdecode;
|
||||
required_device<msm5205_device> m_adpcm;
|
||||
optional_device<msm5205_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<uint8_t[]> 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 )
|
||||
|
@ -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<uint8_t> m_videoram;
|
||||
required_device<i8255_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<cpu_device> m_maincpu;
|
||||
required_device<gfxdecode_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 )
|
@ -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
|
||||
|
Loading…
Reference in New Issue
Block a user