mirror of
https://github.com/holub/mame
synced 2025-07-05 01:48:29 +03:00
AFTOR - more wip
This commit is contained in:
parent
17dd9856e5
commit
2130d6d36a
@ -21,47 +21,49 @@ class wico_state : public driver_device
|
||||
public:
|
||||
wico_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_cpu2(*this, "maincpu"),
|
||||
m_ccpu(*this, "ccpu"),
|
||||
m_hcpu(*this, "hcpu"),
|
||||
m_shared_ram(*this, "sharedram"),
|
||||
m_samples(*this, "samples")
|
||||
{ }
|
||||
|
||||
DECLARE_WRITE8_MEMBER(zcres_w);
|
||||
DECLARE_WRITE8_MEMBER(wdogcl_w);
|
||||
DECLARE_READ8_MEMBER(gentmrcl_r);
|
||||
TIMER_DEVICE_CALLBACK_MEMBER(irq_housekeeping);
|
||||
TIMER_DEVICE_CALLBACK_MEMBER(firq_housekeeping);
|
||||
protected:
|
||||
|
||||
// devices
|
||||
required_device<cpu_device> m_maincpu;
|
||||
required_device<cpu_device> m_cpu2;
|
||||
required_device<cpu_device> m_ccpu;
|
||||
required_device<cpu_device> m_hcpu;
|
||||
required_shared_ptr<UINT8> m_shared_ram;
|
||||
required_device<samples_device> m_samples;
|
||||
|
||||
// driver_device overrides
|
||||
virtual void machine_reset();
|
||||
private:
|
||||
UINT8 m_zcen;
|
||||
UINT8 m_gten;
|
||||
bool m_zcen;
|
||||
bool m_gten;
|
||||
UINT8 m_firqtimer;
|
||||
public:
|
||||
DECLARE_DRIVER_INIT(wico);
|
||||
};
|
||||
|
||||
// housekeeping cpu
|
||||
static ADDRESS_MAP_START( wico_map, AS_PROGRAM, 8, wico_state )
|
||||
static ADDRESS_MAP_START( hcpu_map, AS_PROGRAM, 8, wico_state )
|
||||
AM_RANGE(0x0000, 0x07ff) AM_RAM AM_SHARE("sharedram")
|
||||
AM_RANGE(0x1fe0, 0x1fe0) AM_NOP //AM_WRITE(muxld_w)
|
||||
//AM_RANGE(0x1fe0, 0x1fe0) AM_NOP //AM_WRITE(muxld_w)
|
||||
//AM_RANGE(0x1fe1, 0x1fe1) AM_WRITE(store_w)
|
||||
//AM_RANGE(0x1fe2, 0x1fe2) AM_WRITE(muxen_w)
|
||||
//AM_RANGE(0x1fe3, 0x1fe3) AM_WRITE(csols_w)
|
||||
//AM_RANGE(0x1fe4, 0x1fe4) AM_WRITE(msols_w)
|
||||
//AM_RANGE(0x1fe5, 0x1fe5) AM_DEVWRITE("sn76494", sn76494_new_device, write)
|
||||
AM_RANGE(0x1fe6, 0x1fe6) AM_NOP //WRITE(wdogcl_w)
|
||||
//AM_RANGE(0x1fe4, 0x1fe4) AM_READWRITE(msols_r,msols_w)
|
||||
AM_RANGE(0x1fe5, 0x1fe5) AM_DEVWRITE("sn76494", sn76494_new_device, write)
|
||||
AM_RANGE(0x1fe6, 0x1fe6) AM_WRITE(wdogcl_w)
|
||||
AM_RANGE(0x1fe7, 0x1fe7) AM_WRITE(zcres_w)
|
||||
//AM_RANGE(0x1fe8, 0x1fe8) AM_WRITE(dled0_w)
|
||||
//AM_RANGE(0x1fe9, 0x1fe9) AM_WRITE(dled1_w)
|
||||
//AM_RANGE(0x1fea, 0x1fea) AM_WRITE(gentmrcl_w)
|
||||
AM_RANGE(0x1fea, 0x1fea) AM_READ(gentmrcl_r)
|
||||
//AM_RANGE(0x1feb, 0x1feb) AM_READ(lampst_r)
|
||||
//AM_RANGE(0x1fec, 0x1fec) AM_READ(sast_r)
|
||||
//AM_RANGE(0x1fed, 0x1fed) AM_READ(solst1_r)
|
||||
@ -71,19 +73,19 @@ static ADDRESS_MAP_START( wico_map, AS_PROGRAM, 8, wico_state )
|
||||
ADDRESS_MAP_END
|
||||
|
||||
// command cpu
|
||||
static ADDRESS_MAP_START( wico_sub_map, AS_PROGRAM, 8, wico_state )
|
||||
static ADDRESS_MAP_START( ccpu_map, AS_PROGRAM, 8, wico_state )
|
||||
AM_RANGE(0x0000, 0x07ff) AM_RAM AM_SHARE("sharedram") // 2128 2k RAM
|
||||
//AM_RANGE(0x1fe0, 0x1fe0) AM_WRITE(muxld_w) // to display module
|
||||
//AM_RANGE(0x1fe1, 0x1fe1) AM_WRITE(store_w) // enable save to nvram
|
||||
//AM_RANGE(0x1fe2, 0x1fe2) AM_WRITE(muxen_w) // digit to display on diagnostic LED; d0=L will disable main displays
|
||||
//AM_RANGE(0x1fe3, 0x1fe3) AM_WRITE(csols_w) // solenoid column
|
||||
//AM_RANGE(0x1fe4, 0x1fe4) AM_WRITE(msols_w) // solenoid row
|
||||
//AM_RANGE(0x1fe5, 0x1fe5) AM_DEVWRITE("sn76494", sn76494_new_device, write)
|
||||
//AM_RANGE(0x1fe6, 0x1fe6) AM_WRITE(wdogcl_w) // watchdog clear
|
||||
AM_RANGE(0x1fe7, 0x1fe7) AM_WRITE(zcres_w) // enable IRQ on maincpu
|
||||
AM_RANGE(0x1fe5, 0x1fe5) AM_DEVWRITE("sn76494", sn76494_new_device, write)
|
||||
AM_RANGE(0x1fe6, 0x1fe6) AM_WRITE(wdogcl_w) // watchdog clear
|
||||
AM_RANGE(0x1fe7, 0x1fe7) AM_WRITE(zcres_w) // enable IRQ on hcpu
|
||||
//AM_RANGE(0x1fe8, 0x1fe8) AM_WRITE(dled0_w) // turn off diagnostic LED
|
||||
//AM_RANGE(0x1fe9, 0x1fe9) AM_WRITE(dled1_w) // turn on diagnotic LED
|
||||
//AM_RANGE(0x1fea, 0x1fea) AM_WRITE(gentmrcl_w) // enable IRQ on cpu2
|
||||
//AM_RANGE(0x1fe9, 0x1fe9) AM_WRITE(dled1_w) // turn on diagnostic LED
|
||||
AM_RANGE(0x1fea, 0x1fea) AM_READ(gentmrcl_r) // enable IRQ on ccpu
|
||||
//AM_RANGE(0x1feb, 0x1feb) AM_READ(lampst_r) // lamps?
|
||||
//AM_RANGE(0x1fec, 0x1fec) AM_READ(sast_r) // a pwron pulse to d0 L->H
|
||||
//AM_RANGE(0x1fed, 0x1fed) AM_READ(solst1_r) // switches
|
||||
@ -95,12 +97,185 @@ static ADDRESS_MAP_START( wico_sub_map, AS_PROGRAM, 8, wico_state )
|
||||
ADDRESS_MAP_END
|
||||
|
||||
static INPUT_PORTS_START( wico )
|
||||
PORT_START("X0")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_COIN1)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_COIN2)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_START1)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Top Lane 4") PORT_CODE(KEYCODE_Q)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Top Lane 3") PORT_CODE(KEYCODE_W)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Top Lane 2") PORT_CODE(KEYCODE_E)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Top Lane 1") PORT_CODE(KEYCODE_R)
|
||||
PORT_START("X1")
|
||||
PORT_START("X2")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Bumper BR") PORT_CODE(KEYCODE_Y)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Bumper BL") PORT_CODE(KEYCODE_U)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Bumper TR") PORT_CODE(KEYCODE_I)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Bumper TL") PORT_CODE(KEYCODE_O)
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Target BR") PORT_CODE(KEYCODE_OPENBRACE)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Target BL") PORT_CODE(KEYCODE_CLOSEBRACE)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Target TR") PORT_CODE(KEYCODE_BACKSLASH)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Target TL") PORT_CODE(KEYCODE_BACKSPACE)
|
||||
PORT_START("X3")
|
||||
PORT_START("X4")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Oil Pit Release") PORT_CODE(KEYCODE_Z)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Oil Pit Target") PORT_CODE(KEYCODE_C)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Waterhole Release") PORT_CODE(KEYCODE_V)
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Outhole") PORT_CODE(KEYCODE_X)
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Spinner") PORT_CODE(KEYCODE_B)
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Rollunder") PORT_CODE(KEYCODE_N)
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Spinner") PORT_CODE(KEYCODE_M)
|
||||
PORT_START("X5")
|
||||
PORT_START("X6")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L SLingshot") PORT_CODE(KEYCODE_COMMA)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Slingshot") PORT_CODE(KEYCODE_STOP)
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Drop Bank E")
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Drop Bank P")
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Drop Bank A")
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Drop Bank C")
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Drop Bank S")
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Drop Bank E")
|
||||
PORT_START("X7")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Target Zone E")
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Target Zone D")
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Target Zone I")
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Target Zone")
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Target Zone T")
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Target Zone S")
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Target Zone A")
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Target Zone F")
|
||||
PORT_START("X8")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Outlane Target")
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Outlane Target")
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Rollover R Outlane")
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Rollover M Outlane")
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Rollover L Outlane")
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Rollover R Outlane")
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Rollover M Outlane")
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("L Rollover L Outlane")
|
||||
PORT_START("X9")
|
||||
PORT_START("XA")
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Door Slam") PORT_CODE(KEYCODE_B)
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_TILT) PORT_NAME("Playfield Tilt")
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Pendulum Tilt")
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("R Flipper Lane Change")
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Ball Feed Middle")
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Ball Feed Lower")
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("10 points") PORT_CODE(KEYCODE_COLON)
|
||||
PORT_START("XB")
|
||||
PORT_START("XC")
|
||||
PORT_DIPNAME( 0x0f, 0x00, "Chute 1" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( 1C_1C ) )
|
||||
PORT_DIPSETTING( 0x01, DEF_STR( 1C_2C ) )
|
||||
PORT_DIPSETTING( 0x02, DEF_STR( 1C_3C ) )
|
||||
PORT_DIPSETTING( 0x03, DEF_STR( 1C_4C ) )
|
||||
PORT_DIPSETTING( 0x04, DEF_STR( 1C_5C ) )
|
||||
PORT_DIPSETTING( 0x05, DEF_STR( 1C_6C ) )
|
||||
PORT_DIPSETTING( 0x06, DEF_STR( 1C_7C ) )
|
||||
PORT_DIPSETTING( 0x07, "1 coin 10 credits" )
|
||||
PORT_DIPSETTING( 0x08, "1 coin 14 credits" )
|
||||
PORT_DIPSETTING( 0x09, DEF_STR( 2C_1C ) )
|
||||
PORT_DIPSETTING( 0x0a, DEF_STR( 2C_5C ) )
|
||||
PORT_DIPSETTING( 0x0b, DEF_STR( 2C_7C ) )
|
||||
PORT_DIPSETTING( 0x0c, "2 coins 1 credit then 2 coins for 2 more credits" )
|
||||
PORT_DIPSETTING( 0x0d, "1 coin 1 credit up to 3, then 4th coin gives 2 credits" )
|
||||
PORT_DIPSETTING( 0x0e, "1 coin 1 credit, next coin gives 2 credits" )
|
||||
PORT_DIPSETTING( 0x0f, "1st coin 1 credit, 2nd coin 2 more credits, 3rd coin 1 credit, 4th coin 3 more credits" )
|
||||
PORT_DIPNAME( 0x10, 0x00, "Release Targets Spot Wico" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( On ) )
|
||||
PORT_DIPSETTING( 0x10, DEF_STR( Off ) )
|
||||
PORT_DIPNAME( 0x20, 0x00, "Saving Top Lane Lights" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( On ) )
|
||||
PORT_DIPSETTING( 0x20, DEF_STR( Off ) )
|
||||
PORT_DIPNAME( 0x40, 0x00, "Fast Ride Lights Extra Ball" )
|
||||
PORT_DIPSETTING( 0x00, "2" )
|
||||
PORT_DIPSETTING( 0x40, "3" )
|
||||
PORT_DIPNAME( 0x80, 0x80, "Free Play" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x80, DEF_STR( On ) )
|
||||
PORT_START("XD")
|
||||
PORT_DIPNAME( 0x0f, 0x00, "Chute 2" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( 1C_1C ) )
|
||||
PORT_DIPSETTING( 0x01, DEF_STR( 1C_2C ) )
|
||||
PORT_DIPSETTING( 0x02, DEF_STR( 1C_3C ) )
|
||||
PORT_DIPSETTING( 0x03, DEF_STR( 1C_4C ) )
|
||||
PORT_DIPSETTING( 0x04, DEF_STR( 1C_5C ) )
|
||||
PORT_DIPSETTING( 0x05, DEF_STR( 1C_6C ) )
|
||||
PORT_DIPSETTING( 0x06, DEF_STR( 1C_7C ) )
|
||||
PORT_DIPSETTING( 0x07, "1 coin 10 credits" )
|
||||
PORT_DIPSETTING( 0x08, "1 coin 14 credits" )
|
||||
PORT_DIPSETTING( 0x09, DEF_STR( 2C_1C ) )
|
||||
PORT_DIPSETTING( 0x0a, DEF_STR( 2C_5C ) )
|
||||
PORT_DIPSETTING( 0x0b, DEF_STR( 2C_7C ) )
|
||||
PORT_DIPSETTING( 0x0c, "2 coins 1 credit then 2 coins for 2 more credits" )
|
||||
PORT_DIPSETTING( 0x0d, "1 coin 1 credit up to 3, then 4th coin gives 2 credits" )
|
||||
PORT_DIPSETTING( 0x0e, "1 coin 1 credit, next coin gives 2 credits" )
|
||||
PORT_DIPSETTING( 0x0f, "1st coin 1 credit, 2nd coin 2 more credits, 3rd coin 1 credit, 4th coin 3 more credits" )
|
||||
PORT_DIPNAME( 0x10, 0x00, "Drain eject hole on outhole" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x20, DEF_STR( On ) )
|
||||
PORT_DIPNAME( 0x20, 0x00, "2x multi during multiball" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( On ) )
|
||||
PORT_DIPSETTING( 0x20, DEF_STR( Off ) )
|
||||
PORT_DIPNAME( 0xc0, 0x40, "Credits for new High score" )
|
||||
PORT_DIPSETTING( 0x00, "3" )
|
||||
PORT_DIPSETTING( 0x40, "2" )
|
||||
PORT_DIPSETTING( 0x80, "1" )
|
||||
PORT_DIPSETTING( 0xc0, "0" )
|
||||
PORT_START("XE")
|
||||
PORT_DIPNAME( 0x01, 0x00, "Reset left outlane gate" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x20, DEF_STR( On ) )
|
||||
PORT_DIPNAME( 0x06, 0x02, "Maximum credits" )
|
||||
PORT_DIPSETTING( 0x00, "10" )
|
||||
PORT_DIPSETTING( 0x02, "15" )
|
||||
PORT_DIPSETTING( 0x04, "25" )
|
||||
PORT_DIPSETTING( 0x06, "40" )
|
||||
PORT_DIPNAME( 0x08, 0x00, "Extra ball allowed" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( On ) )
|
||||
PORT_DIPSETTING( 0x08, DEF_STR( Off ) )
|
||||
PORT_DIPNAME( 0x10, 0x00, "Level pass payout" )
|
||||
PORT_DIPSETTING( 0x00, "Free Game" )
|
||||
PORT_DIPSETTING( 0x10, "Extra Ball" )
|
||||
PORT_DIPNAME( 0x20, 0x20, "Capture ball in multiball" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x20, DEF_STR( On ) )
|
||||
PORT_DIPNAME( 0x40, 0x00, "Saves multi-lights" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( On ) )
|
||||
PORT_DIPSETTING( 0x40, DEF_STR( Off ) )
|
||||
PORT_DIPNAME( 0x80, 0x80, "One extra ball per ball" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x80, DEF_STR( On ) )
|
||||
PORT_START("XF")
|
||||
PORT_DIPNAME( 0x03, 0x00, "Special bonus" )
|
||||
PORT_DIPSETTING( 0x00, "Free Game" )
|
||||
PORT_DIPSETTING( 0x01, "Extra Ball" )
|
||||
PORT_DIPSETTING( 0x02, "100k points" )
|
||||
PORT_DIPSETTING( 0x03, "Nothing" )
|
||||
PORT_DIPNAME( 0x04, 0x00, "Flip special lights" )
|
||||
PORT_DIPSETTING( 0x00, "Alternate" )
|
||||
PORT_DIPSETTING( 0x04, "Both on" )
|
||||
PORT_DIPNAME( 0x18, 0x08, "Balls" )
|
||||
PORT_DIPSETTING( 0x00, "2" )
|
||||
PORT_DIPSETTING( 0x08, "3" )
|
||||
PORT_DIPSETTING( 0x10, "4" )
|
||||
PORT_DIPSETTING( 0x18, "5" )
|
||||
PORT_DIPNAME( 0x20, 0x00, "Disable Credits display" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x20, DEF_STR( On ) )
|
||||
PORT_DIPNAME( 0x40, 0x00, "Disable Match display" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x40, DEF_STR( On ) )
|
||||
PORT_DIPNAME( 0x80, 0x00, "Self Test" )
|
||||
PORT_DIPSETTING( 0x00, DEF_STR( Off ) )
|
||||
PORT_DIPSETTING( 0x80, DEF_STR( On ) )
|
||||
INPUT_PORTS_END
|
||||
|
||||
void wico_state::machine_reset()
|
||||
{
|
||||
m_hcpu->set_input_line(INPUT_LINE_RESET, ASSERT_LINE);
|
||||
m_zcen = 0;
|
||||
m_gten = 0;
|
||||
m_firqtimer = 0;
|
||||
}
|
||||
|
||||
DRIVER_INIT_MEMBER(wico_state,wico)
|
||||
@ -112,23 +287,35 @@ WRITE8_MEMBER( wico_state::zcres_w )
|
||||
m_zcen = 1;
|
||||
}
|
||||
|
||||
READ8_MEMBER( wico_state::gentmrcl_r )
|
||||
{
|
||||
m_gten = 1;
|
||||
return 0xff;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( wico_state::wdogcl_w )
|
||||
{
|
||||
m_hcpu->set_input_line(INPUT_LINE_RESET, CLEAR_LINE);
|
||||
}
|
||||
|
||||
|
||||
TIMER_DEVICE_CALLBACK_MEMBER( wico_state::irq_housekeeping )
|
||||
{
|
||||
if (m_zcen)
|
||||
generic_pulse_irq_line(m_maincpu, M6809_IRQ_LINE,1);
|
||||
generic_pulse_irq_line(m_hcpu, M6809_IRQ_LINE,1);
|
||||
}
|
||||
|
||||
TIMER_DEVICE_CALLBACK_MEMBER( wico_state::firq_housekeeping )
|
||||
{
|
||||
if (!m_gten)
|
||||
generic_pulse_irq_line(m_maincpu, M6809_FIRQ_LINE,1);
|
||||
if (m_gten)
|
||||
generic_pulse_irq_line(m_hcpu, M6809_FIRQ_LINE,1);
|
||||
|
||||
// Gen. timer irq of command CPU kicks in every 4 interrupts of this timer
|
||||
m_firqtimer++;
|
||||
if (m_firqtimer > 3)
|
||||
if (m_firqtimer > 3) // divided by 4 by U2 74LS393.
|
||||
{
|
||||
generic_pulse_irq_line(m_cpu2, M6809_IRQ_LINE,1);
|
||||
//m_cpu2->set_input_line(M6809_IRQ_LINE, ASSERT_LINE);
|
||||
generic_pulse_irq_line(m_ccpu, M6809_IRQ_LINE,1);
|
||||
m_firqtimer = 0;
|
||||
}
|
||||
}
|
||||
@ -145,12 +332,12 @@ static const sn76496_config psg_intf =
|
||||
|
||||
static MACHINE_CONFIG_START( wico, wico_state )
|
||||
/* basic machine hardware */
|
||||
MCFG_CPU_ADD("maincpu", M6809, 10000000 / 8)
|
||||
MCFG_CPU_PROGRAM_MAP(wico_map)
|
||||
MCFG_CPU_ADD("ccpu", M6809, 10000000 / 8)
|
||||
MCFG_CPU_PROGRAM_MAP(ccpu_map)
|
||||
MCFG_CPU_ADD("hcpu", M6809, 10000000 / 8)
|
||||
MCFG_CPU_PROGRAM_MAP(hcpu_map)
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("irq", wico_state, irq_housekeeping, attotime::from_hz(120)) // zero crossing
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("firq", wico_state, firq_housekeeping, attotime::from_hz(750)) // time generator
|
||||
MCFG_CPU_ADD("cpu2", M6809, 10000000 / 8)
|
||||
MCFG_CPU_PROGRAM_MAP(wico_sub_map)
|
||||
MCFG_NVRAM_ADD_0FILL("nvram")
|
||||
|
||||
/* Video */
|
||||
@ -158,7 +345,7 @@ static MACHINE_CONFIG_START( wico, wico_state )
|
||||
|
||||
/* Sound */
|
||||
MCFG_FRAGMENT_ADD( genpin_audio )
|
||||
MCFG_SOUND_ADD("sn76494", SN76494, 10000000 / 8)
|
||||
MCFG_SOUND_ADD("sn76494", SN76494_NEW, 10000000 / 64)
|
||||
MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.50)
|
||||
MCFG_SOUND_CONFIG(psg_intf)
|
||||
MACHINE_CONFIG_END
|
||||
@ -167,10 +354,10 @@ MACHINE_CONFIG_END
|
||||
/ Af-Tor (1984)
|
||||
/-------------------------------------------------------------------*/
|
||||
ROM_START(aftor)
|
||||
ROM_REGION(0x10000, "maincpu", 0)
|
||||
ROM_REGION(0x10000, "hcpu", 0)
|
||||
ROM_LOAD("u25.bin", 0xf000, 0x1000, CRC(d66e95ff) SHA1(f7e8c51f1b37e7ef560406f1968c12a2043646c5))
|
||||
|
||||
ROM_REGION(0x10000, "cpu2", 0)
|
||||
ROM_REGION(0x10000, "ccpu", 0)
|
||||
ROM_LOAD("u52.bin", 0x8000, 0x2000, CRC(8035b446) SHA1(3ec59015e259c315bf09f4e2046f9d98e2d7a732))
|
||||
ROM_LOAD("u48.bin", 0xe000, 0x2000, CRC(b4406563) SHA1(6d1a9086eb1f6f947eae3a92ccf7a9b7375d85d3))
|
||||
ROM_END
|
||||
|
Loading…
Reference in New Issue
Block a user