rbmk.cpp: Use device finder; remove NMI interrupt from AT89C4051 MCU which has no NMI line (nw)

This commit is contained in:
AJR 2018-05-20 17:34:31 -04:00
parent cc8fc1e6bd
commit ddb7f3b18a

View File

@ -69,14 +69,17 @@ class rbmk_state : public driver_device
{ {
public: public:
rbmk_state(const machine_config &mconfig, device_type type, const char *tag) rbmk_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag), : driver_device(mconfig, type, tag)
m_vidram2(*this, "vidram2"), , m_vidram2(*this, "vidram2")
m_vidram(*this, "vidram"), , m_vidram(*this, "vidram")
m_maincpu(*this, "maincpu"), , m_maincpu(*this, "maincpu")
m_mcu(*this, "mcu"), , m_mcu(*this, "mcu")
m_eeprom(*this, "eeprom"), , m_eeprom(*this, "eeprom")
m_gfxdecode(*this, "gfxdecode"), , m_gfxdecode(*this, "gfxdecode")
m_palette(*this, "palette") { } , m_palette(*this, "palette")
, m_ymsnd(*this, "ymsnd")
{
}
void rbmk(machine_config &config); void rbmk(machine_config &config);
void rbspm(machine_config &config); void rbspm(machine_config &config);
@ -93,6 +96,7 @@ private:
required_device<eeprom_serial_93cxx_device> m_eeprom; required_device<eeprom_serial_93cxx_device> m_eeprom;
required_device<gfxdecode_device> m_gfxdecode; required_device<gfxdecode_device> m_gfxdecode;
required_device<palette_device> m_palette; required_device<palette_device> m_palette;
required_device<ym2151_device> m_ymsnd;
uint16_t m_tilebank; uint16_t m_tilebank;
uint8_t m_mux_data; uint8_t m_mux_data;
@ -114,7 +118,6 @@ private:
DECLARE_WRITE16_MEMBER(eeprom_w); DECLARE_WRITE16_MEMBER(eeprom_w);
uint32_t screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); uint32_t screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
INTERRUPT_GEN_MEMBER(mcu_irq);
}; };
@ -210,7 +213,7 @@ READ8_MEMBER(rbmk_state::mcu_io_r)
{ {
if(m_mux_data & 8) if(m_mux_data & 8)
{ {
return machine().device<ym2151_device>("ymsnd")->read(space, offset & 1); return m_ymsnd->read(space, offset & 1);
} }
else if(m_mux_data & 4) else if(m_mux_data & 4)
{ {
@ -226,7 +229,7 @@ READ8_MEMBER(rbmk_state::mcu_io_r)
WRITE8_MEMBER(rbmk_state::mcu_io_w) WRITE8_MEMBER(rbmk_state::mcu_io_w)
{ {
if(m_mux_data & 8) { machine().device<ym2151_device>("ymsnd")->write(space, offset & 1, data); } if(m_mux_data & 8) { m_ymsnd->write(space, offset & 1, data); }
else if(m_mux_data & 4) else if(m_mux_data & 4)
{ {
//printf("%02x %02x W\n",offset,data); //printf("%02x %02x W\n",offset,data);
@ -561,11 +564,6 @@ uint32_t rbmk_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap,
return 0; return 0;
} }
INTERRUPT_GEN_MEMBER(rbmk_state::mcu_irq)
{
m_mcu->pulse_input_line(INPUT_LINE_NMI, attotime::zero);
}
MACHINE_CONFIG_START(rbmk_state::rbmk) MACHINE_CONFIG_START(rbmk_state::rbmk)
MCFG_DEVICE_ADD("maincpu", M68000, 22000000 /2) MCFG_DEVICE_ADD("maincpu", M68000, 22000000 /2)
MCFG_DEVICE_PROGRAM_MAP(rbmk_mem) MCFG_DEVICE_PROGRAM_MAP(rbmk_mem)
@ -575,7 +573,6 @@ MACHINE_CONFIG_START(rbmk_state::rbmk)
MCFG_DEVICE_PROGRAM_MAP(mcu_mem) MCFG_DEVICE_PROGRAM_MAP(mcu_mem)
MCFG_DEVICE_IO_MAP(mcu_io) MCFG_DEVICE_IO_MAP(mcu_io)
MCFG_MCS51_PORT_P3_OUT_CB(WRITE8(*this, rbmk_state, mcu_io_mux_w)) MCFG_MCS51_PORT_P3_OUT_CB(WRITE8(*this, rbmk_state, mcu_io_mux_w))
MCFG_DEVICE_VBLANK_INT_DRIVER("screen", rbmk_state, mcu_irq)
MCFG_DEVICE_ADD("gfxdecode", GFXDECODE, "palette", gfx_rbmk) MCFG_DEVICE_ADD("gfxdecode", GFXDECODE, "palette", gfx_rbmk)