qtsbc: Rewrite driver based on SBC-880 schematics

This commit is contained in:
AJR 2018-03-14 14:35:17 -04:00
parent a652a4d686
commit 8e56666a88

View File

@ -1,21 +1,18 @@
// license:BSD-3-Clause
// copyright-holders:Robbbert
// copyright-holders:Robbbert, AJR
/***************************************************************************
QT Computer Systems SBC +2/4
2009-12-11 Skeleton driver.
This looks like the same system as the Compu/Time SBC-880 Processor Board.
Currently it crashes. There's a memory move routine at 50A4, and after
a few turns it is told to move E603 bytes which corrupts everything.
Chips: P8251, D8253C, MK3880N-4 (Z80). 3x 6-sw dips. Unmarked crystal.
Doesn't appear to be any ram?
EPROM: D2716-2; RAM: 2x MM2114N-3L.
There's a blue jumper marked 4M and 2M. Assumed to be selectable CPU clock.
Also assumed this is what the "2/4" in the name refers to.
A blue jumper marked 4M and 2M (between U11 and U12) selects the CPU clock.
Feature list from QT ad:
- 1K RAM (which can be located at any 1K boundary) plus one each
@ -47,51 +44,409 @@ public:
qtsbc_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag)
, m_maincpu(*this, "maincpu")
, m_pit(*this, "pit")
, m_usart(*this, "usart")
, m_dsw(*this, "DSW%u", 1)
, m_jumpers(*this, "JUMPERS")
, m_cpu_speed(*this, "SPEED")
, m_eprom(*this, "maincpu")
, m_p_ram(*this, "ram")
{ }
DECLARE_READ8_MEMBER( qtsbc_43_r );
void qtsbc(machine_config &config);
void io_map(address_map &map);
void mem_map(address_map &map);
private:
DECLARE_READ8_MEMBER(memory_read);
DECLARE_WRITE8_MEMBER(memory_write);
DECLARE_READ8_MEMBER(io_read);
DECLARE_WRITE8_MEMBER(io_write);
virtual void machine_start() override;
virtual void machine_reset() override;
required_device<cpu_device> m_maincpu;
required_device<pit8253_device> m_pit;
required_device<i8251_device> m_usart;
required_ioport_array<3> m_dsw;
required_ioport m_jumpers;
required_ioport m_cpu_speed;
required_region_ptr<u8> m_eprom;
required_shared_ptr<u8> m_p_ram;
bool m_power_on;
};
READ8_MEMBER( qtsbc_state::qtsbc_43_r )
READ8_MEMBER(qtsbc_state::memory_read)
{
return 0; // this controls where the new ram program gets built at. 0 = 0xE000.
ioport_value jumpers = m_jumpers->read();
ioport_value dsw3 = m_dsw[2]->read();
bool eprom_addressed = (offset & (BIT(jumpers, 2) ? 0xf800 : 0xfc00)) >> 10 == dsw3;
if (eprom_addressed && !machine().side_effects_disabled())
m_power_on = false;
if ((m_power_on && !BIT(jumpers, 1)) || (eprom_addressed && !BIT(jumpers, 0)))
{
offset &= BIT(jumpers, 2) ? 0x07ff : 0x03ff;
return m_eprom[offset];
}
#ifdef NOT_IMPLEMENTED_CURRENTLY
else if ((offset & 0xfc00) >> 10 == m_dsw[1]->read())
{
offset &= 0x03ff;
return m_ram[offset];
}
#endif
else
{
if (offset == 0xe377)
return 0x80;
// TODO: S-100 bus
return m_p_ram[offset];
}
}
void qtsbc_state::mem_map(address_map &map)
WRITE8_MEMBER(qtsbc_state::memory_write)
{
map.unmap_value_high();
map(0x0000, 0xffff).ram().share("ram").region("maincpu", 0);
#ifdef NOT_IMPLEMENTED_CURRENTLY
if ((offset & 0xfc00) >> 10 == m_dsw[1]->read())
{
offset &= 0x03ff;
m_ram[offset] = data;
}
else
#endif
{
// TODO: S-100 bus
m_p_ram[offset] = data;
}
}
void qtsbc_state::io_map(address_map &map)
READ8_MEMBER(qtsbc_state::io_read)
{
map.unmap_value_high();
map.global_mask(0xff);
map(0x00, 0x03).rw("pit", FUNC(pit8253_device::read), FUNC(pit8253_device::write));
map(0x06, 0x06).rw("uart", FUNC(i8251_device::data_r), FUNC(i8251_device::data_w));
map(0x07, 0x07).rw("uart", FUNC(i8251_device::status_r), FUNC(i8251_device::control_w));
map(0x43, 0x43).r(this, FUNC(qtsbc_state::qtsbc_43_r));
if ((offset & 0xf8) >> 3 == (m_dsw[0]->read() & 0x1f))
{
switch (offset & 7)
{
case 0:
case 1:
case 2:
case 3:
default:
return m_pit->read(space, offset & 3);
case 4:
case 5:
// TODO: 8-bit parallel input port
return 0xff;
case 6:
return m_usart->data_r(space, 0);
case 7:
return m_usart->status_r(space, 0);
}
}
else
{
// TODO: S-100 bus (no address mirroring)
logerror("Input from %04X\n", offset);
// Ports 40 and 43 are for some sort of off-board RAM
// Bit 0 of 43 is some sort of busy signal; bits 1-3 select some memory size factor
if ((offset & 0xff) == 0x43)
return 0x00;
// Ports 08, 10 and 80 also used for read access
return 0xff;
}
}
WRITE8_MEMBER(qtsbc_state::io_write)
{
if ((offset & 0x00f8) >> 3 == (m_dsw[0]->read() & 0x1f))
{
switch (offset & 7)
{
case 0:
case 1:
case 2:
case 3:
default:
m_pit->write(space, offset & 3, data);
break;
case 4:
case 5:
// TODO: 8-bit parallel output port
break;
case 6:
m_usart->data_w(space, 0, data);
break;
case 7:
m_usart->control_w(space, 0, data);
break;
}
}
else
{
// TODO: S-100 bus (no address mirroring)
logerror("Output %02X to %04X\n", data, offset);
}
}
ADDRESS_MAP_START(qtsbc_state::mem_map)
ADDRESS_MAP_UNMAP_HIGH
AM_RANGE(0x0000, 0xffff) AM_RAM AM_SHARE("ram")
AM_RANGE(0x0000, 0xffff) AM_READWRITE(memory_read, memory_write)
ADDRESS_MAP_END
ADDRESS_MAP_START(qtsbc_state::io_map)
ADDRESS_MAP_UNMAP_HIGH
AM_RANGE(0x0000, 0xffff) AM_READWRITE(io_read, io_write)
ADDRESS_MAP_END
/* Input ports */
static INPUT_PORTS_START( qtsbc )
PORT_START("DSW1")
PORT_DIPNAME(0x1f, 0x00, "On-Board I/O Ports") PORT_DIPLOCATION("SW1:1,2,3,4,5")
PORT_DIPSETTING(0x00, "00-07")
PORT_DIPSETTING(0x01, "08-0F")
PORT_DIPSETTING(0x02, "10-17")
PORT_DIPSETTING(0x03, "18-1F")
PORT_DIPSETTING(0x04, "20-27")
PORT_DIPSETTING(0x05, "28-2F")
PORT_DIPSETTING(0x06, "30-37")
PORT_DIPSETTING(0x07, "38-3F")
PORT_DIPSETTING(0x08, "40-47")
PORT_DIPSETTING(0x09, "48-4F")
PORT_DIPSETTING(0x0a, "50-57")
PORT_DIPSETTING(0x0b, "58-5F")
PORT_DIPSETTING(0x0c, "60-67")
PORT_DIPSETTING(0x0d, "68-6F")
PORT_DIPSETTING(0x0e, "70-77")
PORT_DIPSETTING(0x0f, "78-7F")
PORT_DIPSETTING(0x10, "80-87")
PORT_DIPSETTING(0x11, "88-8F")
PORT_DIPSETTING(0x12, "90-87")
PORT_DIPSETTING(0x13, "98-9F")
PORT_DIPSETTING(0x14, "A0-A7")
PORT_DIPSETTING(0x15, "A8-AF")
PORT_DIPSETTING(0x16, "B0-B7")
PORT_DIPSETTING(0x17, "B8-BF")
PORT_DIPSETTING(0x18, "C0-C7")
PORT_DIPSETTING(0x19, "C8-CF")
PORT_DIPSETTING(0x1a, "D0-D7")
PORT_DIPSETTING(0x1b, "D8-DF")
PORT_DIPSETTING(0x1c, "E0-E7")
PORT_DIPSETTING(0x1d, "E8-EF")
PORT_DIPSETTING(0x1e, "F0-F7")
PORT_DIPSETTING(0x1f, "F8-FF")
PORT_DIPUNUSED(0x20, 0x20) PORT_DIPLOCATION("SW1:6")
PORT_START("DSW2")
PORT_DIPNAME(0x3f, 0x37, "On-Board RAM Address") PORT_DIPLOCATION("SW2:6,5,4,3,2,1")
PORT_DIPSETTING(0x00, "0000-03FF")
PORT_DIPSETTING(0x01, "0400-07FF")
PORT_DIPSETTING(0x02, "0800-0BFF")
PORT_DIPSETTING(0x03, "0C00-0FFF")
PORT_DIPSETTING(0x04, "1000-13FF")
PORT_DIPSETTING(0x05, "1400-17FF")
PORT_DIPSETTING(0x06, "1800-1BFF")
PORT_DIPSETTING(0x07, "1C00-1FFF")
PORT_DIPSETTING(0x08, "2000-23FF")
PORT_DIPSETTING(0x09, "2400-27FF")
PORT_DIPSETTING(0x0a, "2800-2BFF")
PORT_DIPSETTING(0x0b, "2C00-2FFF")
PORT_DIPSETTING(0x0c, "3000-33FF")
PORT_DIPSETTING(0x0d, "3400-37FF")
PORT_DIPSETTING(0x0e, "3800-3BFF")
PORT_DIPSETTING(0x0f, "3C00-3FFF")
PORT_DIPSETTING(0x10, "4000-43FF")
PORT_DIPSETTING(0x11, "4400-47FF")
PORT_DIPSETTING(0x12, "4800-4BFF")
PORT_DIPSETTING(0x13, "4C00-4FFF")
PORT_DIPSETTING(0x14, "5000-53FF")
PORT_DIPSETTING(0x15, "5400-57FF")
PORT_DIPSETTING(0x16, "5800-5BFF")
PORT_DIPSETTING(0x17, "5C00-5FFF")
PORT_DIPSETTING(0x18, "6000-63FF")
PORT_DIPSETTING(0x19, "6400-67FF")
PORT_DIPSETTING(0x1a, "6800-6BFF")
PORT_DIPSETTING(0x1b, "6C00-6FFF")
PORT_DIPSETTING(0x1c, "7000-73FF")
PORT_DIPSETTING(0x1d, "7400-77FF")
PORT_DIPSETTING(0x1e, "7800-7BFF")
PORT_DIPSETTING(0x1f, "7C00-7FFF")
PORT_DIPSETTING(0x20, "8000-83FF")
PORT_DIPSETTING(0x21, "8400-87FF")
PORT_DIPSETTING(0x22, "8800-8BFF")
PORT_DIPSETTING(0x23, "8C00-8FFF")
PORT_DIPSETTING(0x24, "9000-93FF")
PORT_DIPSETTING(0x25, "9400-97FF")
PORT_DIPSETTING(0x26, "9800-9BFF")
PORT_DIPSETTING(0x27, "9C00-9FFF")
PORT_DIPSETTING(0x28, "A000-A3FF")
PORT_DIPSETTING(0x29, "A400-A7FF")
PORT_DIPSETTING(0x2a, "A800-ABFF")
PORT_DIPSETTING(0x2b, "AC00-AFFF")
PORT_DIPSETTING(0x2c, "B000-B3FF")
PORT_DIPSETTING(0x2d, "B400-B7FF")
PORT_DIPSETTING(0x2e, "B800-BBFF")
PORT_DIPSETTING(0x2f, "BC00-BFFF")
PORT_DIPSETTING(0x30, "C000-C3FF")
PORT_DIPSETTING(0x31, "C400-C7FF")
PORT_DIPSETTING(0x32, "C800-CBFF")
PORT_DIPSETTING(0x33, "CC00-CFFF")
PORT_DIPSETTING(0x34, "D000-D3FF")
PORT_DIPSETTING(0x35, "D400-D7FF")
PORT_DIPSETTING(0x36, "D800-DBFF")
PORT_DIPSETTING(0x37, "DC00-DFFF")
PORT_DIPSETTING(0x38, "E000-E3FF")
PORT_DIPSETTING(0x39, "E400-E7FF")
PORT_DIPSETTING(0x3a, "E800-EBFF")
PORT_DIPSETTING(0x3b, "EC00-EFFF")
PORT_DIPSETTING(0x3c, "F000-F3FF")
PORT_DIPSETTING(0x3d, "F400-F7FF")
PORT_DIPSETTING(0x3e, "F800-FBFF")
PORT_DIPSETTING(0x3f, "FC00-FFFF")
PORT_START("DSW3")
PORT_DIPNAME(0x3f, 0x14, "On-Board EPROM Address") PORT_DIPLOCATION("SW3:6,5,4,3,2,1")
PORT_DIPSETTING(0x00, "0000-03FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x01, "0400-07FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x02, "0800-0BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x03, "0C00-0FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x04, "1000-13FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x05, "1400-17FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x06, "1800-1BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x07, "1C00-1FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x08, "2000-23FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x09, "2400-27FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x0a, "2800-2BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x0b, "2C00-2FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x0c, "3000-33FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x0d, "3400-37FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x0e, "3800-3BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x0f, "3C00-3FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x10, "4000-43FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x11, "4400-47FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x12, "4800-4BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x13, "4C00-4FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x14, "5000-53FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x15, "5400-57FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x16, "5800-5BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x17, "5C00-5FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x18, "6000-63FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x19, "6400-67FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x1a, "6800-6BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x1b, "6C00-6FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x1c, "7000-73FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x1d, "7400-77FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x1e, "7800-7BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x1f, "7C00-7FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x20, "8000-83FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x21, "8400-87FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x22, "8800-8BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x23, "8C00-8FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x24, "9000-93FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x25, "9400-97FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x26, "9800-9BFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x27, "9C00-9FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x28, "A000-A3FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x29, "A400-A7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x2a, "A800-ABFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x2b, "AC00-AFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x2c, "B000-B3FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x2d, "B400-B7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x2e, "B800-BBFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x2f, "BC00-BFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x30, "C000-C3FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x31, "C400-C7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x32, "C800-CBFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x33, "CC00-CFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x34, "D000-D3FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x35, "D400-D7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x36, "D800-DBFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x37, "DC00-DFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x38, "E000-E3FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x39, "E400-E7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x3a, "E800-EBFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x3b, "EC00-EFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x3c, "F000-F3FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x3d, "F400-F7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x3e, "F800-FBFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x3f, "FC00-FFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x00)
PORT_DIPSETTING(0x00, "0000-07FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x02, "0800-0FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x04, "1000-17FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x06, "1800-1FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x08, "2000-27FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x0a, "2800-2FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x0c, "3000-37FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x0e, "3800-3FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x10, "4000-47FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x12, "4800-4FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x14, "5000-57FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x16, "5800-5FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x18, "6000-67FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x1a, "6800-6FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x1c, "7000-77FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x1e, "7800-7FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x20, "8000-87FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x22, "8800-8FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x24, "9000-97FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x26, "9800-9FFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x28, "A000-A7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x2a, "A800-AFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x2c, "B000-B7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x2e, "B800-BFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x30, "C000-C7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x32, "C800-CFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x34, "D000-D7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x36, "D800-DFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x38, "E000-E7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x3a, "E800-EFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x3c, "F000-F7FF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_DIPSETTING(0x3e, "F800-FFFF") PORT_CONDITION("JUMPERS", 0x04, EQUALS, 0x04)
PORT_START("JUMPERS")
PORT_DIPNAME(0x02, 0x00, "Power-On Jump") PORT_DIPLOCATION("T to U:1")
PORT_DIPSETTING(0x02, DEF_STR(Off)) // T to U open
PORT_DIPSETTING(0x00, DEF_STR(On)) // T to U shorted
PORT_DIPNAME(0x01, 0x01, "EPROM Phantom Mode") PORT_DIPLOCATION("Q to R:1") PORT_CONDITION("JUMPERS", 0x02, EQUALS, 0x00)
PORT_DIPSETTING(0x00, DEF_STR(Off)) // Q to R shorted
PORT_DIPSETTING(0x01, DEF_STR(On)) // Q to R open
PORT_DIPNAME(0x01, 0x00, "On-Board EPROM") PORT_DIPLOCATION("Q to R:1") PORT_CONDITION("JUMPERS", 0x02, EQUALS, 0x02)
PORT_DIPSETTING(0x01, "Disabled") // Q to R open
PORT_DIPSETTING(0x00, "Enabled") // Q to R shorted
PORT_DIPNAME(0x04, 0x04, "On-Board EPROM Size") PORT_DIPLOCATION("P to O:1")
PORT_DIPSETTING(0x00, "1K x 8 (2708)") // P to O shorted
PORT_DIPSETTING(0x04, "2K x 8 (2716)") // P to O open
PORT_START("SPEED")
PORT_CONFNAME(0x01, 0x01, "CPU Speed")
PORT_CONFSETTING(0x00, "2 MHz")
PORT_CONFSETTING(0x01, "4 MHz")
INPUT_PORTS_END
void qtsbc_state::machine_start()
{
subdevice<i8251_device>("usart")->write_cts(0);
save_item(NAME(m_power_on));
}
void qtsbc_state::machine_reset()
{
uint8_t* bios = memregion("maincpu")->base()+0x10000;
memcpy(m_p_ram, bios, 0x800);
m_power_on = true;
m_maincpu->set_unscaled_clock(BIT(m_cpu_speed->read(), 0) ? 4_MHz_XTAL : 4_MHz_XTAL / 2);
}
static DEVICE_INPUT_DEFAULTS_START( terminal )
@ -105,32 +460,34 @@ DEVICE_INPUT_DEFAULTS_END
MACHINE_CONFIG_START(qtsbc_state::qtsbc)
/* basic machine hardware */
MCFG_CPU_ADD("maincpu",Z80, XTAL(4'000'000)) // Mostek MK3880
MCFG_CPU_ADD("maincpu", Z80, 4_MHz_XTAL) // Mostek MK3880
MCFG_CPU_PROGRAM_MAP(mem_map)
MCFG_CPU_IO_MAP(io_map)
/* video hardware */
MCFG_DEVICE_ADD("pit", PIT8253, 0) // U9
MCFG_PIT8253_CLK0(XTAL(4'000'000) / 2) /* Timer 0: baud rate gen for 8251 */
MCFG_PIT8253_OUT0_HANDLER(DEVWRITELINE("uart", i8251_device, write_txc))
MCFG_DEVCB_CHAIN_OUTPUT(DEVWRITELINE("uart", i8251_device, write_rxc))
MCFG_PIT8253_CLK0(4_MHz_XTAL / 2) /* Timer 0: baud rate gen for 8251 */
MCFG_PIT8253_OUT0_HANDLER(DEVWRITELINE("usart", i8251_device, write_txc))
MCFG_DEVCB_CHAIN_OUTPUT(DEVWRITELINE("usart", i8251_device, write_rxc))
MCFG_PIT8253_CLK1(4_MHz_XTAL / 2)
MCFG_PIT8253_OUT1_HANDLER(DEVWRITELINE("pit", pit8253_device, write_clk2))
MCFG_DEVICE_ADD("uart", I8251, 0) // U8
MCFG_DEVICE_ADD("usart", I8251, 0) // U8
MCFG_I8251_TXD_HANDLER(DEVWRITELINE("rs232", rs232_port_device, write_txd))
MCFG_I8251_DTR_HANDLER(DEVWRITELINE("rs232", rs232_port_device, write_dtr))
MCFG_I8251_RTS_HANDLER(DEVWRITELINE("rs232", rs232_port_device, write_rts))
MCFG_RS232_PORT_ADD("rs232", default_rs232_devices, "terminal")
MCFG_RS232_RXD_HANDLER(DEVWRITELINE("uart", i8251_device, write_rxd))
MCFG_RS232_DSR_HANDLER(DEVWRITELINE("uart", i8251_device, write_dsr))
MCFG_RS232_CTS_HANDLER(DEVWRITELINE("uart", i8251_device, write_cts))
MCFG_RS232_RXD_HANDLER(DEVWRITELINE("usart", i8251_device, write_rxd))
MCFG_RS232_DSR_HANDLER(DEVWRITELINE("usart", i8251_device, write_dsr)) // actually from pin 11, "Reverse Channel Transmit"
MCFG_RS232_CTS_HANDLER(DEVWRITELINE("rs232", rs232_port_device, write_rts))
MCFG_RS232_DCD_HANDLER(DEVWRITELINE("rs232", rs232_port_device, write_dtr))
MCFG_DEVICE_CARD_DEVICE_INPUT_DEFAULTS("terminal", terminal) // must be exactly here
MACHINE_CONFIG_END
/* ROM definition */
ROM_START( qtsbc )
ROM_REGION( 0x10800, "maincpu", ROMREGION_ERASEFF )
ROM_LOAD( "qtsbc.u23", 0x10000, 0x0800, CRC(823fd942) SHA1(64c4f74dd069ae4d43d301f5e279185f32a1efa0))
ROM_REGION( 0x0800, "maincpu", ROMREGION_ERASEFF )
ROM_LOAD( "qtsbc.u23", 0x0000, 0x0800, CRC(823fd942) SHA1(64c4f74dd069ae4d43d301f5e279185f32a1efa0))
ROM_END
/* Driver */