(nw) stargame : added meat to the bones

This commit is contained in:
Robbbert 2017-09-10 16:53:00 +10:00
parent c696c71153
commit e49274ed93

View File

@ -1,5 +1,5 @@
// license:BSD-3-Clause
// copyright-holders:Ivan Vangelista
// copyright-holders:Robbbert
// PINBALL
// Skeleton driver for Stargame pinballs (2 x Z80, Z80CTC, DAC, AY8910, MEA8000).
// Hardware listing and ROM definitions from PinMAME.
@ -13,6 +13,10 @@
#include "sound/ay8910.h"
#include "sound/dac.h"
#include "sound/mea8000.h"
#include "speaker.h"
#include "machine/74259.h"
#include "machine/gen_latch.h"
#include "machine/watchdog.h"
class stargame_state : public genpin_class
@ -20,31 +24,117 @@ class stargame_state : public genpin_class
public:
stargame_state(const machine_config &mconfig, device_type type, const char *tag)
: genpin_class(mconfig, type, tag)
, m_maincpu(*this, "maincpu") { }
, m_maincpu(*this, "maincpu")
, m_audiocpu(*this, "audiocpu")
, m_ctc(*this, "ctc")
{ }
DECLARE_WRITE8_MEMBER(rint_w);
DECLARE_MACHINE_RESET(stargame);
private:
required_device<cpu_device> m_maincpu;
required_device<cpu_device> m_audiocpu;
required_device<z80ctc_device> m_ctc;
};
static ADDRESS_MAP_START( maincpu_map, AS_PROGRAM, 8, stargame_state )
AM_RANGE(0x0000, 0x3fff) AM_MIRROR(0x4000) AM_ROM
AM_RANGE(0x8000, 0x87ff) AM_MIRROR(0x7800) AM_RAM
ADDRESS_MAP_END
static ADDRESS_MAP_START( maincpu_io, AS_IO, 8, stargame_state )
ADDRESS_MAP_UNMAP_HIGH
ADDRESS_MAP_GLOBAL_MASK(0xff)
AM_RANGE(0x00, 0x00) AM_MIRROR(0x09) AM_DEVWRITE("soundlatch", generic_latch_8_device, write) // CSON - command to the sound cpu - NMI to sound cpu
AM_RANGE(0x10, 0x1f) AM_DEVWRITE("watchdog", watchdog_timer_device, reset_w)
AM_RANGE(0x20, 0x2f) // CSW2 - input lines: P0 to D4; P1 to D5; DAPRI to D6; TEST to D7
AM_RANGE(0x30, 0x3f) // CSW1 - input lines
AM_RANGE(0x40, 0x4f) // CDIG - score display
AM_RANGE(0x50, 0x5f) // CDRIV
AM_RANGE(0x60, 0x67) AM_DEVWRITE("mainlatch", ls259_device, write_d0) // CPOR
AM_RANGE(0x68, 0x69) AM_MIRROR(0x06) // CPOR : 68=CKPRI; 69=CKDIS
AM_RANGE(0x70, 0x73) AM_MIRROR(0x0c) AM_DEVREADWRITE("ctc", z80ctc_device, read, write)
ADDRESS_MAP_END
static ADDRESS_MAP_START( audiocpu_map, AS_PROGRAM, 8, stargame_state )
ADDRESS_MAP_UNMAP_HIGH
AM_RANGE(0x0000, 0x3fff) AM_ROM
AM_RANGE(0x8000, 0x87ff) AM_RAM
AM_RANGE(0x4000, 0x4001) AM_MIRROR(0x3ffe) AM_DEVREADWRITE("mea8000", mea8000_device, read, write)
AM_RANGE(0x8000, 0x87ff) AM_MIRROR(0x3800) AM_RAM
AM_RANGE(0xc000, 0xdfff) AM_WRITE(rint_w) // RINT - turn off interrupt of the audiocpu
AM_RANGE(0xe000, 0xffff) AM_DEVREADWRITE("soundlatch", generic_latch_8_device, read, acknowledge_w) // COMAND - acknowledge NMI and read the sound command
ADDRESS_MAP_END
static ADDRESS_MAP_START( audiocpu_io, AS_IO, 8, stargame_state )
ADDRESS_MAP_GLOBAL_MASK(0x01)
AM_RANGE(0x00, 0x00) AM_DEVREAD("ay", ay8910_device, data_r)
AM_RANGE(0x01, 0x01) AM_DEVWRITE("ay", ay8910_device, data_address_w)
ADDRESS_MAP_END
static INPUT_PORTS_START( stargame )
INPUT_PORTS_END
WRITE8_MEMBER( stargame_state::rint_w )
{
m_audiocpu->set_input_line(INPUT_LINE_IRQ0, CLEAR_LINE);
}
MACHINE_RESET_MEMBER( stargame_state, stargame )
{
m_audiocpu->set_input_line(INPUT_LINE_RESET, ASSERT_LINE); // doesn't do anything? cpu should be stuck in reset until allowed to start by SRESET line
}
static const z80_daisy_config daisy_chain[] =
{
{ "ctc" },
{ nullptr }
};
static MACHINE_CONFIG_START( stargame )
/* basic machine hardware */
MCFG_CPU_ADD("maincpu", Z80, 1000000)
MCFG_CPU_ADD("maincpu", Z80, 15000000 / 4) // clock line marked as CK4 and derived from 15MHz crystal
MCFG_CPU_PROGRAM_MAP(maincpu_map)
MCFG_CPU_IO_MAP(maincpu_io)
MCFG_Z80_DAISY_CHAIN(daisy_chain)
MCFG_CPU_ADD("audiocpu", Z80, 15000000 / 3) // ? check divider - clock line marked as CK6 and derived from 15MHz crystal
MCFG_CPU_PROGRAM_MAP(audiocpu_map)
MCFG_CPU_IO_MAP(audiocpu_io)
MCFG_MACHINE_RESET_OVERRIDE(stargame_state, stargame)
/* video hardware */
//MCFG_DEFAULT_LAYOUT()
MCFG_DEVICE_ADD("ctc", Z80CTC, 15000000 / 4)
MCFG_Z80CTC_INTR_CB(INPUTLINE("maincpu", INPUT_LINE_IRQ0))
MCFG_Z80CTC_ZC0_CB(INPUTLINE("audiocpu", INPUT_LINE_IRQ0)) // SINT - turn on interrupt of the audiocpu
/* sound hardware */
MCFG_FRAGMENT_ADD( genpin_audio )
MCFG_SPEAKER_STANDARD_MONO("measnd")
MCFG_SOUND_ADD("mea8000", MEA8000, 15000000 / 4)
MCFG_SOUND_ROUTE(ALL_OUTPUTS, "measnd", 1.0)
MCFG_SPEAKER_STANDARD_MONO("aysnd")
MCFG_SOUND_ADD("ay", AY8910, 15000000 / 8) // clock line marked as CK2 and derived from 15MHz crystal
MCFG_SOUND_ROUTE(ALL_OUTPUTS, "aysnd", 0.25)
MCFG_DEVICE_ADD("mainlatch", LS259, 0)
MCFG_ADDRESSABLE_LATCH_Q0_OUT_CB(NOOP) // DADIS
MCFG_ADDRESSABLE_LATCH_Q1_OUT_CB(NOOP) // DAPRI
MCFG_ADDRESSABLE_LATCH_Q2_OUT_CB(NOOP) // RJUEGO
MCFG_ADDRESSABLE_LATCH_Q3_OUT_CB(NOOP) // RFLIPPER
MCFG_ADDRESSABLE_LATCH_Q4_OUT_CB(NOOP) // to AUXILLIAR socket
MCFG_ADDRESSABLE_LATCH_Q5_OUT_CB(NOOP) // RFDIS
MCFG_ADDRESSABLE_LATCH_Q6_OUT_CB(INPUTLINE("audiocpu", INPUT_LINE_RESET)) MCFG_DEVCB_INVERT // SRESET
MCFG_ADDRESSABLE_LATCH_Q7_OUT_CB(NOOP) // MAKRES
MCFG_GENERIC_LATCH_8_ADD("soundlatch")
MCFG_GENERIC_LATCH_DATA_PENDING_CB(INPUTLINE("audiocpu", INPUT_LINE_NMI))
MCFG_WATCHDOG_ADD("watchdog")
MACHINE_CONFIG_END
ROM_START(spcship)