(MESS) Altos5: little more progress, now getting a bdos error.

This commit is contained in:
Robbbert 2013-06-09 11:26:51 +00:00
parent 2c03b5aebb
commit 702c80268d

View File

@ -4,10 +4,9 @@
Boots, terminal works, memory banking works. Boots, terminal works, memory banking works.
Error when reading floppy disk (record not found) Error when reading floppy disk (bdos error)
ToDo: ToDo:
- DMA has its own memory banking, activated by BUSACK
- Get floppy to read the disk (only ones found are .TD0 format) - Get floppy to read the disk (only ones found are .TD0 format)
- Further work once the floppy is fixed - Further work once the floppy is fixed
@ -34,6 +33,7 @@ public:
m_pio1(*this, "z80pio_1"), m_pio1(*this, "z80pio_1"),
m_dart(*this, "z80dart"), m_dart(*this, "z80dart"),
m_sio (*this, "z80sio"), m_sio (*this, "z80sio"),
m_dma (*this, "z80dma"),
m_ctc (*this, "z80ctc"), m_ctc (*this, "z80ctc"),
m_fdc (*this, "fdc"), m_fdc (*this, "fdc"),
m_floppy0(*this, "fdc:0"), m_floppy0(*this, "fdc:0"),
@ -52,20 +52,24 @@ public:
DECLARE_DRIVER_INIT(altos5); DECLARE_DRIVER_INIT(altos5);
TIMER_DEVICE_CALLBACK_MEMBER(ctc_tick); TIMER_DEVICE_CALLBACK_MEMBER(ctc_tick);
DECLARE_WRITE_LINE_MEMBER(ctc_z1_w); DECLARE_WRITE_LINE_MEMBER(ctc_z1_w);
DECLARE_WRITE_LINE_MEMBER(busreq_w);
UINT8 m_port08; UINT8 m_port08;
UINT8 m_port09; UINT8 m_port09;
UINT8 *m_p_prom; UINT8 *m_p_prom;
bool m_ipl; bool m_ipl;
offs_t m_curr_bank;
floppy_image_device *m_floppy;
void fdc_intrq_w(bool state); void fdc_intrq_w(bool state);
void fdc_drq_w(bool state); void fdc_drq_w(bool state);
UINT8 convert(offs_t offset, bool state); UINT8 convert(offs_t offset, bool state);
void setup_banks(); void setup_banks(UINT8 source);
virtual void machine_reset(); virtual void machine_reset();
required_device<cpu_device> m_maincpu; required_device<cpu_device> m_maincpu;
required_device<z80pio_device> m_pio0; required_device<z80pio_device> m_pio0;
required_device<z80pio_device> m_pio1; required_device<z80pio_device> m_pio1;
required_device<z80dart_device> m_dart; required_device<z80dart_device> m_dart;
required_device<z80sio0_device> m_sio; required_device<z80sio0_device> m_sio;
required_device<z80dma_device> m_dma;
required_device<z80ctc_device> m_ctc; required_device<z80ctc_device> m_ctc;
required_device<fd1797_t> m_fdc; required_device<fd1797_t> m_fdc;
required_device<floppy_connector> m_floppy0; required_device<floppy_connector> m_floppy0;
@ -126,12 +130,19 @@ UINT8 altos5_state::convert(offs_t offset, bool state)
return data & 0x3f; return data & 0x3f;
} }
void altos5_state::setup_banks() void altos5_state::setup_banks(UINT8 source)
{ {
// WPRT | template | cpu bank offs_t offs,temp;
offs_t offs = ((~m_port09 & 0x20) << 3) | ((m_port09 & 0x06) << 5) | ((m_port09 & 0x18) << 1); // WPRT | template | dma bank / cpu bank
offs_t temp = offs;
if (source == 1) // use DMA banks only if BUSACK is asserted
offs = ((~m_port09 & 0x20) << 3) | ((m_port09 & 0x06) << 5) | ((m_port09 & 0xc0) >> 2);
else
offs = ((~m_port09 & 0x20) << 3) | ((m_port09 & 0x06) << 5) | ((m_port09 & 0x18) << 1);
temp = offs;
if ((source == 2) || (temp != m_curr_bank))
{
membank("bankr0")->set_entry(convert(offs++, 0)); membank("bankr0")->set_entry(convert(offs++, 0));
membank("bankr1")->set_entry(convert(offs++, 0)); membank("bankr1")->set_entry(convert(offs++, 0));
membank("bankr2")->set_entry(convert(offs++, 0)); membank("bankr2")->set_entry(convert(offs++, 0));
@ -149,30 +160,35 @@ void altos5_state::setup_banks()
membank("bankre")->set_entry(convert(offs++, 0)); membank("bankre")->set_entry(convert(offs++, 0));
membank("bankrf")->set_entry(convert(offs++, 0)); membank("bankrf")->set_entry(convert(offs++, 0));
membank("bankw0")->set_entry(convert(temp++, 1)); offs = temp;
membank("bankw1")->set_entry(convert(temp++, 1)); membank("bankw0")->set_entry(convert(offs++, 1));
membank("bankw2")->set_entry(convert(temp++, 1)); membank("bankw1")->set_entry(convert(offs++, 1));
membank("bankw3")->set_entry(convert(temp++, 1)); membank("bankw2")->set_entry(convert(offs++, 1));
membank("bankw4")->set_entry(convert(temp++, 1)); membank("bankw3")->set_entry(convert(offs++, 1));
membank("bankw5")->set_entry(convert(temp++, 1)); membank("bankw4")->set_entry(convert(offs++, 1));
membank("bankw6")->set_entry(convert(temp++, 1)); membank("bankw5")->set_entry(convert(offs++, 1));
membank("bankw7")->set_entry(convert(temp++, 1)); membank("bankw6")->set_entry(convert(offs++, 1));
membank("bankw8")->set_entry(convert(temp++, 1)); membank("bankw7")->set_entry(convert(offs++, 1));
membank("bankw9")->set_entry(convert(temp++, 1)); membank("bankw8")->set_entry(convert(offs++, 1));
membank("bankwa")->set_entry(convert(temp++, 1)); membank("bankw9")->set_entry(convert(offs++, 1));
membank("bankwb")->set_entry(convert(temp++, 1)); membank("bankwa")->set_entry(convert(offs++, 1));
membank("bankwc")->set_entry(convert(temp++, 1)); membank("bankwb")->set_entry(convert(offs++, 1));
membank("bankwd")->set_entry(convert(temp++, 1)); membank("bankwc")->set_entry(convert(offs++, 1));
membank("bankwe")->set_entry(convert(temp++, 1)); membank("bankwd")->set_entry(convert(offs++, 1));
membank("bankwf")->set_entry(convert(temp++, 1)); membank("bankwe")->set_entry(convert(offs++, 1));
membank("bankwf")->set_entry(convert(offs++, 1));
}
m_curr_bank = temp;
} }
void altos5_state::machine_reset() void altos5_state::machine_reset()
{ {
m_curr_bank = 0;
m_port08 = 0; m_port08 = 0;
m_port09 = 0; m_port09 = 0;
m_ipl = 1; m_ipl = 1;
setup_banks(); setup_banks(2);
m_maincpu->reset(); m_maincpu->reset();
} }
@ -192,7 +208,7 @@ static const z80_daisy_config daisy_chain_intf[] =
WRITE8_MEMBER( altos5_state::port14_w ) WRITE8_MEMBER( altos5_state::port14_w )
{ {
m_ipl = 0; m_ipl = 0;
setup_banks(); setup_banks(2);
} }
READ8_MEMBER(altos5_state::memory_read_byte) READ8_MEMBER(altos5_state::memory_read_byte)
@ -219,11 +235,20 @@ WRITE8_MEMBER(altos5_state::io_write_byte)
return prog_space.write_byte(offset, data); return prog_space.write_byte(offset, data);
} }
WRITE_LINE_MEMBER( altos5_state::busreq_w )
{
// since our Z80 has no support for BUSACK, we assume it is granted immediately
m_maincpu->set_input_line(Z80_INPUT_LINE_BUSRQ, state);
m_maincpu->set_input_line(INPUT_LINE_HALT, state); // do we need this?
m_dma->bai_w(state); // tell dma that bus has been granted
setup_banks(state); // adjust banking for dma or cpu
}
static Z80DMA_INTERFACE( dma_intf ) static Z80DMA_INTERFACE( dma_intf )
{ {
DEVCB_CPU_INPUT_LINE("maincpu", INPUT_LINE_HALT), // actually BUSRQ DEVCB_DRIVER_LINE_MEMBER(altos5_state, busreq_w),
DEVCB_CPU_INPUT_LINE("maincpu", INPUT_LINE_IRQ0), DEVCB_CPU_INPUT_LINE("maincpu", INPUT_LINE_IRQ0),
DEVCB_NULL, DEVCB_NULL, // BAO, not used
DEVCB_DRIVER_MEMBER(altos5_state, memory_read_byte), DEVCB_DRIVER_MEMBER(altos5_state, memory_read_byte),
DEVCB_DRIVER_MEMBER(altos5_state, memory_write_byte), DEVCB_DRIVER_MEMBER(altos5_state, memory_write_byte),
DEVCB_DRIVER_MEMBER(altos5_state, io_read_byte), DEVCB_DRIVER_MEMBER(altos5_state, io_read_byte),
@ -280,7 +305,10 @@ d7: IRQ from FDC
*/ */
READ8_MEMBER( altos5_state::port08_r ) READ8_MEMBER( altos5_state::port08_r )
{ {
return m_port08 | 0x07; UINT8 data = m_port08 | 0x87;
if (m_floppy)
data |= ((UINT8)m_floppy->twosid_r() << 3); // get number of sides
return data;
} }
/* /*
@ -298,22 +326,21 @@ d6: SS (H = side 2)
*/ */
WRITE8_MEMBER( altos5_state::port08_w ) WRITE8_MEMBER( altos5_state::port08_w )
{ {
m_port08 = data; m_port08 = data & 0x70;
floppy_image_device *floppy = NULL; m_floppy = NULL;
if (BIT(data, 5)) if (BIT(data, 5))
floppy = m_floppy1->get_device(); m_floppy = m_floppy1->get_device();
else else
floppy = m_floppy0->get_device(); m_floppy = m_floppy0->get_device();
m_fdc->set_floppy(floppy); m_fdc->set_floppy(m_floppy);
if (floppy) if (m_floppy)
{ {
floppy->mon_w(0); m_floppy->mon_w(0);
floppy->ss_w(BIT(data, 6)); m_floppy->ss_w(BIT(data, 6));
m_fdc->dden_w(!BIT(data, 4)); m_fdc->dden_w(!BIT(data, 4));
m_port08 |= ((UINT8)floppy->twosid_r() << 3); // get number of sides
} }
} }
@ -326,7 +353,7 @@ d6, 7: DMA bank select (not emulated)
WRITE8_MEMBER( altos5_state::port09_w ) WRITE8_MEMBER( altos5_state::port09_w )
{ {
m_port09 = data; m_port09 = data;
setup_banks(); setup_banks(2);
} }
// parallel port // parallel port
@ -379,7 +406,7 @@ static Z80SIO_INTERFACE( sio_intf )
DEVCB_NULL, // out data DEVCB_NULL, // out data
DEVCB_NULL, // DTR DEVCB_NULL, // DTR
DEVCB_NULL, // RTS DEVCB_NULL, // RTS
DEVCB_NULL, // WRDY DEVCB_NULL, // WRDY connects to (altos5_state, fdc_intrq_w),
DEVCB_NULL, // SYNC DEVCB_NULL, // SYNC
// console#1 // console#1
@ -412,27 +439,26 @@ SLOT_INTERFACE_END
void altos5_state::fdc_intrq_w(bool state) void altos5_state::fdc_intrq_w(bool state)
{ {
m_port08 = (m_port08 & 0x7f) | ((UINT8)(state) << 7); UINT8 data = m_port08 | ((UINT8)(state) << 7);
m_pio0->port_a_write(m_port08); m_pio0->port_a_write(data);
} }
void altos5_state::fdc_drq_w(bool state) void altos5_state::fdc_drq_w(bool state)
{ {
// To DMA pin 25 - SDMA m_dma->rdy_w(state);
} }
DRIVER_INIT_MEMBER( altos5_state, altos5 ) DRIVER_INIT_MEMBER( altos5_state, altos5 )
{ {
floppy_connector *con = machine().device<floppy_connector>("fdc:0");
floppy_image_device *floppy = con ? con->get_device() : 0;
if (floppy)
{
m_fdc->set_floppy(floppy);
m_fdc->setup_intrq_cb(fd1797_t::line_cb(FUNC(altos5_state::fdc_intrq_w), this)); m_fdc->setup_intrq_cb(fd1797_t::line_cb(FUNC(altos5_state::fdc_intrq_w), this));
m_fdc->setup_drq_cb(fd1797_t::line_cb(FUNC(altos5_state::fdc_drq_w), this)); m_fdc->setup_drq_cb(fd1797_t::line_cb(FUNC(altos5_state::fdc_drq_w), this));
floppy->ss_w(0); floppy_connector *con = machine().device<floppy_connector>("fdc:0");
m_floppy = con ? con->get_device() : 0;
if (m_floppy)
{
m_fdc->set_floppy(m_floppy);
m_floppy->ss_w(0);
} }