pc8801, pc88va: required_device (nw)

This commit is contained in:
cracyc 2018-05-20 15:31:50 -05:00
parent ee820fde51
commit cc8fc1e6bd
2 changed files with 71 additions and 58 deletions

View File

@ -308,6 +308,8 @@ public:
m_maincpu(*this, "maincpu"), m_maincpu(*this, "maincpu"),
m_screen(*this, "screen"), m_screen(*this, "screen"),
m_fdccpu(*this, "fdccpu"), m_fdccpu(*this, "fdccpu"),
m_fdc(*this, "upd765"),
m_fdd(*this, "upd765:%u", 0U),
m_pic(*this, I8214_TAG), m_pic(*this, I8214_TAG),
m_rtc(*this, UPD1990A_TAG), m_rtc(*this, UPD1990A_TAG),
m_cassette(*this, "cassette"), m_cassette(*this, "cassette"),
@ -316,10 +318,22 @@ public:
m_opn(*this, "opn"), m_opn(*this, "opn"),
m_palette(*this, "palette") m_palette(*this, "palette")
{ } { }
void pc8801mc(machine_config &config);
void pc8801fh(machine_config &config);
void pc8801(machine_config &config);
void pc8801ma(machine_config &config);
protected:
virtual void video_start() override;
virtual void machine_start() override;
virtual void machine_reset() override;
private:
required_device<cpu_device> m_maincpu; required_device<cpu_device> m_maincpu;
required_device<screen_device> m_screen; required_device<screen_device> m_screen;
required_device<cpu_device> m_fdccpu; required_device<cpu_device> m_fdccpu;
required_device<upd765a_device> m_fdc;
required_device_array<floppy_connector, 2> m_fdd;
optional_device<i8214_device> m_pic; optional_device<i8214_device> m_pic;
required_device<upd1990a_device> m_rtc; required_device<upd1990a_device> m_rtc;
required_device<cassette_image_device> m_cassette; required_device<cassette_image_device> m_cassette;
@ -474,20 +488,10 @@ public:
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);
DECLARE_PALETTE_INIT(pc8801); DECLARE_PALETTE_INIT(pc8801);
void pc8801mc(machine_config &config);
void pc8801fh(machine_config &config);
void pc8801(machine_config &config);
void pc8801ma(machine_config &config);
void pc8801_io(address_map &map); void pc8801_io(address_map &map);
void pc8801_mem(address_map &map); void pc8801_mem(address_map &map);
void pc8801fdc_io(address_map &map); void pc8801fdc_io(address_map &map);
void pc8801fdc_mem(address_map &map); void pc8801fdc_mem(address_map &map);
protected:
virtual void video_start() override;
virtual void machine_start() override;
virtual void machine_reset() override;
public:
DECLARE_MACHINE_RESET(pc8801_clock_speed); DECLARE_MACHINE_RESET(pc8801_clock_speed);
DECLARE_MACHINE_RESET(pc8801_dic); DECLARE_MACHINE_RESET(pc8801_dic);
DECLARE_MACHINE_RESET(pc8801_cdrom); DECLARE_MACHINE_RESET(pc8801_cdrom);
@ -1881,20 +1885,20 @@ void pc8801_state::pc8801fdc_mem(address_map &map)
TIMER_CALLBACK_MEMBER(pc8801_state::pc8801fd_upd765_tc_to_zero) TIMER_CALLBACK_MEMBER(pc8801_state::pc8801fd_upd765_tc_to_zero)
{ {
//printf("0\n"); //printf("0\n");
machine().device<upd765a_device>("upd765")->tc_w(false); m_fdc->tc_w(false);
} }
WRITE8_MEMBER(pc8801_state::upd765_mc_w) WRITE8_MEMBER(pc8801_state::upd765_mc_w)
{ {
machine().device<floppy_connector>("upd765:0")->get_device()->mon_w(!(data & 1)); m_fdd[0]->get_device()->mon_w(!(data & 1));
machine().device<floppy_connector>("upd765:1")->get_device()->mon_w(!(data & 2)); m_fdd[1]->get_device()->mon_w(!(data & 2));
} }
READ8_MEMBER(pc8801_state::upd765_tc_r) READ8_MEMBER(pc8801_state::upd765_tc_r)
{ {
//printf("%04x 1\n",m_fdccpu->pc()); //printf("%04x 1\n",m_fdccpu->pc());
machine().device<upd765a_device>("upd765")->tc_w(true); m_fdc->tc_w(true);
//TODO: I'm not convinced that this works correctly with current hook-up ... 1000 usec is needed by Aploon, a bigger value breaks Alpha. //TODO: I'm not convinced that this works correctly with current hook-up ... 1000 usec is needed by Aploon, a bigger value breaks Alpha.
//OTOH, 50 seems more than enough for the new upd... //OTOH, 50 seems more than enough for the new upd...
machine().scheduler().timer_set(attotime::from_usec(50), timer_expired_delegate(FUNC(pc8801_state::pc8801fd_upd765_tc_to_zero),this)); machine().scheduler().timer_set(attotime::from_usec(50), timer_expired_delegate(FUNC(pc8801_state::pc8801fd_upd765_tc_to_zero),this));
@ -1910,10 +1914,10 @@ WRITE8_MEMBER(pc8801_state::fdc_irq_vector_w)
WRITE8_MEMBER(pc8801_state::fdc_drive_mode_w) WRITE8_MEMBER(pc8801_state::fdc_drive_mode_w)
{ {
logerror("FDC drive mode %02x\n", data); logerror("FDC drive mode %02x\n", data);
machine().device<floppy_connector>("upd765:0")->get_device()->set_rpm(data & 0x01 ? 360 : 300); m_fdd[0]->get_device()->set_rpm(data & 0x01 ? 360 : 300);
machine().device<floppy_connector>("upd765:1")->get_device()->set_rpm(data & 0x02 ? 360 : 300); m_fdd[1]->get_device()->set_rpm(data & 0x02 ? 360 : 300);
machine().device<upd765a_device>("upd765")->set_rate(data & 0x20 ? 500000 : 250000); m_fdc->set_rate(data & 0x20 ? 500000 : 250000);
} }
void pc8801_state::pc8801fdc_io(address_map &map) void pc8801_state::pc8801fdc_io(address_map &map)
@ -2403,9 +2407,9 @@ INTERRUPT_GEN_MEMBER(pc8801_state::pc8801_vrtc_irq)
void pc8801_state::machine_start() void pc8801_state::machine_start()
{ {
machine().device<floppy_connector>("upd765:0")->get_device()->set_rpm(300); m_fdd[0]->get_device()->set_rpm(300);
machine().device<floppy_connector>("upd765:1")->get_device()->set_rpm(300); m_fdd[1]->get_device()->set_rpm(300);
machine().device<upd765a_device>("upd765")->set_rate(250000); m_fdc->set_rate(250000);
m_rtc->cs_w(1); m_rtc->cs_w(1);
m_rtc->oe_w(1); m_rtc->oe_w(1);

View File

@ -80,15 +80,29 @@ public:
m_maincpu(*this, "maincpu"), m_maincpu(*this, "maincpu"),
m_screen(*this, "screen"), m_screen(*this, "screen"),
m_fdc(*this, "upd765"), m_fdc(*this, "upd765"),
m_fdd(*this, "upd765:%u", 0U),
m_dmac(*this, "dmac"), m_dmac(*this, "dmac"),
m_pic1(*this, "pic8259_master"),
m_pic2(*this, "pic8259_slave"),
m_palram(*this, "palram"), m_palram(*this, "palram"),
m_gfxdecode(*this, "gfxdecode"), m_gfxdecode(*this, "gfxdecode"),
m_palette(*this, "palette") { } m_palette(*this, "palette") { }
void pc88va(machine_config &config);
protected:
virtual void machine_start() override;
virtual void machine_reset() override;
virtual void video_start() override;
virtual void device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr) override;
private:
required_device<cpu_device> m_maincpu; required_device<cpu_device> m_maincpu;
required_device<screen_device> m_screen; required_device<screen_device> m_screen;
required_device<upd765a_device> m_fdc; required_device<upd765a_device> m_fdc;
required_device_array<floppy_connector, 2> m_fdd;
required_device<am9517a_device> m_dmac; required_device<am9517a_device> m_dmac;
required_device<pic8259_device> m_pic1;
required_device<pic8259_device> m_pic2;
required_shared_ptr<uint16_t> m_palram; required_shared_ptr<uint16_t> m_palram;
uint16_t m_bank_reg; uint16_t m_bank_reg;
uint16_t m_screen_ctrl_reg; uint16_t m_screen_ctrl_reg;
@ -138,9 +152,6 @@ public:
DECLARE_WRITE16_MEMBER(video_pri_w); DECLARE_WRITE16_MEMBER(video_pri_w);
DECLARE_READ8_MEMBER(backupram_dsw_r); DECLARE_READ8_MEMBER(backupram_dsw_r);
DECLARE_WRITE8_MEMBER(sys_port1_w); DECLARE_WRITE8_MEMBER(sys_port1_w);
virtual void machine_start() override;
virtual void machine_reset() override;
virtual void video_start() override;
uint32_t screen_update_pc88va(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect); uint32_t screen_update_pc88va(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect);
INTERRUPT_GEN_MEMBER(pc88va_vrtc_irq); INTERRUPT_GEN_MEMBER(pc88va_vrtc_irq);
DECLARE_READ8_MEMBER(cpu_8255_c_r); DECLARE_READ8_MEMBER(cpu_8255_c_r);
@ -168,8 +179,8 @@ public:
DECLARE_WRITE_LINE_MEMBER(pc88va_tc_w); DECLARE_WRITE_LINE_MEMBER(pc88va_tc_w);
DECLARE_READ8_MEMBER(fdc_dma_r); DECLARE_READ8_MEMBER(fdc_dma_r);
DECLARE_WRITE8_MEMBER(fdc_dma_w); DECLARE_WRITE8_MEMBER(fdc_dma_w);
DECLARE_READ8_MEMBER(dma_memr_cb); DECLARE_READ8_MEMBER(dma_memr_cb);
DECLARE_WRITE8_MEMBER(dma_memw_cb); DECLARE_WRITE8_MEMBER(dma_memw_cb);
DECLARE_WRITE_LINE_MEMBER(fdc_irq); DECLARE_WRITE_LINE_MEMBER(fdc_irq);
DECLARE_WRITE_LINE_MEMBER(fdc_drq); DECLARE_WRITE_LINE_MEMBER(fdc_drq);
@ -189,13 +200,11 @@ DECLARE_WRITE8_MEMBER(dma_memw_cb);
void execute_spron_cmd(); void execute_spron_cmd();
void execute_sprsw_cmd(); void execute_sprsw_cmd();
void pc88va(machine_config &config);
void pc88va_io_map(address_map &map); void pc88va_io_map(address_map &map);
void pc88va_map(address_map &map); void pc88va_map(address_map &map);
void pc88va_z80_io_map(address_map &map); void pc88va_z80_io_map(address_map &map);
void pc88va_z80_map(address_map &map); void pc88va_z80_map(address_map &map);
protected: protected:
virtual void device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr) override;
required_device<gfxdecode_device> m_gfxdecode; required_device<gfxdecode_device> m_gfxdecode;
required_device<palette_device> m_palette; required_device<palette_device> m_palette;
}; };
@ -1067,20 +1076,20 @@ TIMER_CALLBACK_MEMBER(pc88va_state::pc88va_fdc_timer)
{ {
if(m_fdc_ctrl_2 & 4) // XTMASK if(m_fdc_ctrl_2 & 4) // XTMASK
{ {
machine().device<pic8259_device>( "pic8259_slave")->ir3_w(0); m_pic2->ir3_w(0);
machine().device<pic8259_device>( "pic8259_slave")->ir3_w(1); m_pic2->ir3_w(1);
} }
} }
TIMER_CALLBACK_MEMBER(pc88va_state::pc88va_fdc_motor_start_0) TIMER_CALLBACK_MEMBER(pc88va_state::pc88va_fdc_motor_start_0)
{ {
machine().device<floppy_connector>("upd765:0")->get_device()->mon_w(0); m_fdd[0]->get_device()->mon_w(0);
m_fdc_motor_status[0] = 1; m_fdc_motor_status[0] = 1;
} }
TIMER_CALLBACK_MEMBER(pc88va_state::pc88va_fdc_motor_start_1) TIMER_CALLBACK_MEMBER(pc88va_state::pc88va_fdc_motor_start_1)
{ {
machine().device<floppy_connector>("upd765:1")->get_device()->mon_w(0); m_fdd[1]->get_device()->mon_w(0);
m_fdc_motor_status[1] = 1; m_fdc_motor_status[1] = 1;
} }
@ -1089,10 +1098,10 @@ void pc88va_state::pc88va_fdc_update_ready(floppy_image_device *, int)
bool ready = m_fdc_ctrl_2 & 0x40; bool ready = m_fdc_ctrl_2 & 0x40;
floppy_image_device *floppy; floppy_image_device *floppy;
floppy = machine().device<floppy_connector>("upd765:0")->get_device(); floppy = m_fdd[0]->get_device();
if(floppy && ready) if(floppy && ready)
ready = floppy->ready_r(); ready = floppy->ready_r();
floppy = machine().device<floppy_connector>("upd765:1")->get_device(); floppy = m_fdd[1]->get_device();
if(floppy && ready) if(floppy && ready)
ready = floppy->ready_r(); ready = floppy->ready_r();
@ -1120,10 +1129,10 @@ WRITE8_MEMBER(pc88va_state::pc88va_fdc_w)
---- --xx RV1/RV0: Drive 1/0 mode selection (0) 2D and 2DD mode (1) 2HD mode ---- --xx RV1/RV0: Drive 1/0 mode selection (0) 2D and 2DD mode (1) 2HD mode
*/ */
case 0x02: // FDC control port 0 case 0x02: // FDC control port 0
machine().device<floppy_connector>("upd765:0")->get_device()->set_rpm(data & 0x01 ? 360 : 300); m_fdd[0]->get_device()->set_rpm(data & 0x01 ? 360 : 300);
machine().device<floppy_connector>("upd765:1")->get_device()->set_rpm(data & 0x02 ? 360 : 300); m_fdd[1]->get_device()->set_rpm(data & 0x02 ? 360 : 300);
machine().device<upd765a_device>("upd765")->set_rate(data & 0x20 ? 500000 : 250000); m_fdc->set_rate(data & 0x20 ? 500000 : 250000);
break; break;
/* /*
---- x--- PCM: ? ---- x--- PCM: ?
@ -1132,7 +1141,7 @@ WRITE8_MEMBER(pc88va_state::pc88va_fdc_w)
case 0x04: case 0x04:
if(data & 1) if(data & 1)
{ {
machine().device<floppy_connector>("upd765:0")->get_device()->mon_w(1); m_fdd[0]->get_device()->mon_w(1);
if(m_fdc_motor_status[0] == 0) if(m_fdc_motor_status[0] == 0)
timer_set(attotime::from_msec(505), TIMER_PC88VA_FDC_MOTOR_START_0); timer_set(attotime::from_msec(505), TIMER_PC88VA_FDC_MOTOR_START_0);
else else
@ -1141,7 +1150,7 @@ WRITE8_MEMBER(pc88va_state::pc88va_fdc_w)
if(data & 2) if(data & 2)
{ {
machine().device<floppy_connector>("upd765:1")->get_device()->mon_w(1); m_fdd[1]->get_device()->mon_w(1);
if(m_fdc_motor_status[1] == 0) if(m_fdc_motor_status[1] == 0)
timer_set(attotime::from_msec(505), TIMER_PC88VA_FDC_MOTOR_START_1); timer_set(attotime::from_msec(505), TIMER_PC88VA_FDC_MOTOR_START_1);
else else
@ -1165,7 +1174,7 @@ WRITE8_MEMBER(pc88va_state::pc88va_fdc_w)
m_dmac->dreq2_w(1); m_dmac->dreq2_w(1);
if(data & 0x80) // correct? if(data & 0x80) // correct?
machine().device<upd765a_device>("upd765")->reset(); m_fdc->reset();
m_fdc_ctrl_2 = data; m_fdc_ctrl_2 = data;
@ -1199,8 +1208,8 @@ TIMER_CALLBACK_MEMBER(pc88va_state::t3_mouse_callback)
{ {
if(m_timer3_io_reg & 0x80) if(m_timer3_io_reg & 0x80)
{ {
machine().device<pic8259_device>("pic8259_slave")->ir5_w(0); m_pic2->ir5_w(0);
machine().device<pic8259_device>("pic8259_slave")->ir5_w(1); m_pic2->ir5_w(1);
m_t3_mouse_timer->adjust(attotime::from_hz(120 >> (m_timer3_io_reg & 3))); m_t3_mouse_timer->adjust(attotime::from_hz(120 >> (m_timer3_io_reg & 3)));
} }
} }
@ -1217,7 +1226,7 @@ WRITE8_MEMBER(pc88va_state::timer3_ctrl_reg_w)
m_t3_mouse_timer->adjust(attotime::from_hz(120 >> (m_timer3_io_reg & 3))); m_t3_mouse_timer->adjust(attotime::from_hz(120 >> (m_timer3_io_reg & 3)));
else else
{ {
machine().device<pic8259_device>("pic8259_slave")->ir5_w(0); m_pic2->ir5_w(0);
m_t3_mouse_timer->adjust(attotime::never); m_t3_mouse_timer->adjust(attotime::never);
} }
} }
@ -1329,7 +1338,7 @@ void pc88va_state::pc88va_io_map(address_map &map)
TIMER_CALLBACK_MEMBER(pc88va_state::pc8801fd_upd765_tc_to_zero) TIMER_CALLBACK_MEMBER(pc88va_state::pc8801fd_upd765_tc_to_zero)
{ {
machine().device<upd765a_device>("upd765")->tc_w(false); m_fdc->tc_w(false);
} }
/* FDC subsytem CPU */ /* FDC subsytem CPU */
@ -1342,7 +1351,7 @@ void pc88va_state::pc88va_z80_map(address_map &map)
READ8_MEMBER(pc88va_state::upd765_tc_r) READ8_MEMBER(pc88va_state::upd765_tc_r)
{ {
machine().device<upd765a_device>("upd765")->tc_w(true); m_fdc->tc_w(true);
timer_set(attotime::from_usec(50), TIMER_PC8801FD_UPD765_TC_TO_ZERO); timer_set(attotime::from_usec(50), TIMER_PC8801FD_UPD765_TC_TO_ZERO);
return 0; return 0;
} }
@ -1354,8 +1363,8 @@ WRITE8_MEMBER(pc88va_state::fdc_irq_vector_w)
WRITE8_MEMBER(pc88va_state::upd765_mc_w) WRITE8_MEMBER(pc88va_state::upd765_mc_w)
{ {
machine().device<floppy_connector>("upd765:0")->get_device()->mon_w(!(data & 1)); m_fdd[0]->get_device()->mon_w(!(data & 1));
machine().device<floppy_connector>("upd765:1")->get_device()->mon_w(!(data & 2)); m_fdd[1]->get_device()->mon_w(!(data & 2));
} }
void pc88va_state::pc88va_z80_io_map(address_map &map) void pc88va_state::pc88va_z80_io_map(address_map &map)
@ -1651,7 +1660,7 @@ WRITE8_MEMBER(pc88va_state::r232_ctrl_portc_w)
READ8_MEMBER(pc88va_state::get_slave_ack) READ8_MEMBER(pc88va_state::get_slave_ack)
{ {
if (offset==7) { // IRQ = 7 if (offset==7) { // IRQ = 7
return machine().device<pic8259_device>( "pic8259_slave")->acknowledge(); return m_pic2->acknowledge();
} }
return 0x00; return 0x00;
} }
@ -1661,17 +1670,17 @@ void pc88va_state::machine_start()
m_t3_mouse_timer = timer_alloc(TIMER_T3_MOUSE_CALLBACK); m_t3_mouse_timer = timer_alloc(TIMER_T3_MOUSE_CALLBACK);
m_t3_mouse_timer->adjust(attotime::never); m_t3_mouse_timer->adjust(attotime::never);
floppy_image_device *floppy; floppy_image_device *floppy;
floppy = machine().device<floppy_connector>("upd765:0")->get_device(); floppy = m_fdd[0]->get_device();
if(floppy) if(floppy)
floppy->setup_ready_cb(floppy_image_device::ready_cb(&pc88va_state::pc88va_fdc_update_ready, this)); floppy->setup_ready_cb(floppy_image_device::ready_cb(&pc88va_state::pc88va_fdc_update_ready, this));
floppy = machine().device<floppy_connector>("upd765:1")->get_device(); floppy = m_fdd[1]->get_device();
if(floppy) if(floppy)
floppy->setup_ready_cb(floppy_image_device::ready_cb(&pc88va_state::pc88va_fdc_update_ready, this)); floppy->setup_ready_cb(floppy_image_device::ready_cb(&pc88va_state::pc88va_fdc_update_ready, this));
machine().device<floppy_connector>("upd765:0")->get_device()->set_rpm(300); m_fdd[0]->get_device()->set_rpm(300);
machine().device<floppy_connector>("upd765:1")->get_device()->set_rpm(300); m_fdd[1]->get_device()->set_rpm(300);
machine().device<upd765a_device>("upd765")->set_rate(250000); m_fdc->set_rate(250000);
} }
void pc88va_state::machine_reset() void pc88va_state::machine_reset()
@ -1707,16 +1716,16 @@ void pc88va_state::machine_reset()
INTERRUPT_GEN_MEMBER(pc88va_state::pc88va_vrtc_irq) INTERRUPT_GEN_MEMBER(pc88va_state::pc88va_vrtc_irq)
{ {
machine().device<pic8259_device>("pic8259_master")->ir2_w(0); m_pic1->ir2_w(0);
machine().device<pic8259_device>("pic8259_master")->ir2_w(1); m_pic1->ir2_w(1);
} }
WRITE_LINE_MEMBER(pc88va_state::pc88va_pit_out0_changed) WRITE_LINE_MEMBER(pc88va_state::pc88va_pit_out0_changed)
{ {
if(state) if(state)
{ {
machine().device<pic8259_device>("pic8259_master")->ir0_w(0); m_pic1->ir0_w(0);
machine().device<pic8259_device>("pic8259_master")->ir0_w(1); m_pic1->ir0_w(1);
} }
} }
@ -1731,8 +1740,8 @@ WRITE_LINE_MEMBER( pc88va_state::fdc_irq )
if(m_fdc_mode && state) if(m_fdc_mode && state)
{ {
//printf("%d\n",state); //printf("%d\n",state);
machine().device<pic8259_device>( "pic8259_slave")->ir3_w(0); m_pic2->ir3_w(0);
machine().device<pic8259_device>( "pic8259_slave")->ir3_w(1); m_pic2->ir3_w(1);
} }
#if TEST_SUBFDC #if TEST_SUBFDC
else else