Microkit: It sort of works, but with major issues. (nw)
This commit is contained in:
parent
15e03e7760
commit
0c2f2f103e
@ -6,35 +6,126 @@
|
|||||||
|
|
||||||
http://www.vintagecomputer.net/browse_thread.cfm?id=511
|
http://www.vintagecomputer.net/browse_thread.cfm?id=511
|
||||||
|
|
||||||
*/
|
Press CR or LF to get the * prompt.
|
||||||
|
Commands:
|
||||||
|
$Pxxxx - Jump to address xxxx
|
||||||
|
?Mxxxx yyyy - Dump memory starting at xxxx for yyyy bytes
|
||||||
|
!Mxxxx yy zz... - Write data (yy etc) to memory xxxx. Data gets entered when you
|
||||||
|
press the space after the data.
|
||||||
|
|
||||||
|
There's no sound or storage facilities, therefore no software.
|
||||||
|
|
||||||
|
ToDo:
|
||||||
|
- No technical manual or schematic available, so the entire driver is bodgy guesswork.
|
||||||
|
- Address 0 needs to be read/writeable, otherwise the numbers you enter will get
|
||||||
|
internally corrupted.
|
||||||
|
- Address 8000 is IDL which hangs the system, so program counter is preset to 8001.
|
||||||
|
- The keyboard is hooked up serially, which is ok, but the output to the terminal
|
||||||
|
is rubbish, so parallel is used so you can at least see something.
|
||||||
|
- When you enter commands, you can't see what you're doing.
|
||||||
|
- When you enter numbers, they display as rubbish or act as control codes. They
|
||||||
|
internally work though.
|
||||||
|
- The computer looks like a rack-mount metal box with a rudimentary front panel.
|
||||||
|
Buttons are: Reset; Load; Run program; Run Utility
|
||||||
|
There is a RUN LED.
|
||||||
|
None of these items are emulated.
|
||||||
|
It also has a power switch and lamp, and a fuse.
|
||||||
|
|
||||||
|
*****************************************************************************************/
|
||||||
|
|
||||||
#include "emu.h"
|
#include "emu.h"
|
||||||
#include "cpu/cosmac/cosmac.h"
|
#include "cpu/cosmac/cosmac.h"
|
||||||
|
#include "bus/rs232/rs232.h"
|
||||||
|
#include "machine/terminal.h"
|
||||||
|
|
||||||
|
|
||||||
class microkit_state : public driver_device
|
class microkit_state : public driver_device
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
microkit_state(const machine_config &mconfig, device_type type, const char *tag)
|
microkit_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||||
: driver_device(mconfig, type, tag)
|
: driver_device(mconfig, type, tag)
|
||||||
|
, m_maincpu(*this, "maincpu")
|
||||||
|
, m_rs232(*this, "rs232")
|
||||||
|
, m_terminal(*this, "terminal")
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
|
DECLARE_READ_LINE_MEMBER(clear_r);
|
||||||
|
DECLARE_WRITE8_MEMBER(ram_w);
|
||||||
|
DECLARE_READ8_MEMBER(ram_r);
|
||||||
|
|
||||||
|
private:
|
||||||
|
virtual void machine_reset();
|
||||||
|
UINT8 m_resetcnt;
|
||||||
|
UINT8 m_ram_data;
|
||||||
|
required_device<cosmac_device> m_maincpu;
|
||||||
|
required_device<rs232_port_device> m_rs232;
|
||||||
|
required_device<generic_terminal_device> m_terminal;
|
||||||
};
|
};
|
||||||
|
|
||||||
static ADDRESS_MAP_START( microkit_mem, AS_PROGRAM, 8, microkit_state )
|
static ADDRESS_MAP_START( microkit_mem, AS_PROGRAM, 8, microkit_state )
|
||||||
AM_RANGE(0x0000, 0x01ff) AM_ROM AM_REGION("maincpu", 0)
|
AM_RANGE(0x0000, 0x0000) AM_READWRITE(ram_r,ram_w)
|
||||||
|
AM_RANGE(0x8000, 0x81ff) AM_ROM AM_REGION("maincpu", 0)
|
||||||
|
AM_RANGE(0x8200, 0x83ff) AM_RAM
|
||||||
ADDRESS_MAP_END
|
ADDRESS_MAP_END
|
||||||
|
|
||||||
static ADDRESS_MAP_START( microkit_io, AS_IO, 8, microkit_state )
|
static ADDRESS_MAP_START( microkit_io, AS_IO, 8, microkit_state )
|
||||||
|
AM_RANGE(0x07, 0x07) AM_WRITENOP // writes a lots of zeros here
|
||||||
ADDRESS_MAP_END
|
ADDRESS_MAP_END
|
||||||
|
|
||||||
static INPUT_PORTS_START( microkit )
|
static INPUT_PORTS_START( microkit )
|
||||||
INPUT_PORTS_END
|
INPUT_PORTS_END
|
||||||
|
|
||||||
|
READ_LINE_MEMBER( microkit_state::clear_r )
|
||||||
|
{
|
||||||
|
if (m_resetcnt < 0x10)
|
||||||
|
m_maincpu->set_state_int(COSMAC_R0, 0x8001); // skip IDL
|
||||||
|
if (m_resetcnt < 0x20)
|
||||||
|
m_resetcnt++;
|
||||||
|
// set reset pin to normal
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
READ8_MEMBER( microkit_state::ram_r )
|
||||||
|
{
|
||||||
|
return m_ram_data;
|
||||||
|
}
|
||||||
|
|
||||||
|
WRITE8_MEMBER( microkit_state::ram_w )
|
||||||
|
{
|
||||||
|
m_ram_data = data;
|
||||||
|
if (data > 0 && data < 0x80)
|
||||||
|
m_terminal->write(space, 0, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
void microkit_state::machine_reset()
|
||||||
|
{
|
||||||
|
m_resetcnt = 0;
|
||||||
|
m_ram_data = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static DEVICE_INPUT_DEFAULTS_START( serial_keyb )
|
||||||
|
DEVICE_INPUT_DEFAULTS( "RS232_TXBAUD", 0xff, RS232_BAUD_300 )
|
||||||
|
DEVICE_INPUT_DEFAULTS( "RS232_RXBAUD", 0xff, RS232_BAUD_300 )
|
||||||
|
DEVICE_INPUT_DEFAULTS( "RS232_STARTBITS", 0xff, RS232_STARTBITS_1 )
|
||||||
|
DEVICE_INPUT_DEFAULTS( "RS232_DATABITS", 0xff, RS232_DATABITS_8 )
|
||||||
|
DEVICE_INPUT_DEFAULTS( "RS232_PARITY", 0xff, RS232_PARITY_NONE )
|
||||||
|
DEVICE_INPUT_DEFAULTS( "RS232_STOPBITS", 0xff, RS232_STOPBITS_2 )
|
||||||
|
DEVICE_INPUT_DEFAULTS_END
|
||||||
|
|
||||||
|
|
||||||
static MACHINE_CONFIG_START( microkit, microkit_state )
|
static MACHINE_CONFIG_START( microkit, microkit_state )
|
||||||
// basic machine hardware
|
// basic machine hardware
|
||||||
MCFG_CPU_ADD("maincpu", CDP1801, 2000000)
|
MCFG_CPU_ADD("maincpu", CDP1802, 1750000)
|
||||||
MCFG_CPU_PROGRAM_MAP(microkit_mem)
|
MCFG_CPU_PROGRAM_MAP(microkit_mem)
|
||||||
MCFG_CPU_IO_MAP(microkit_io)
|
MCFG_CPU_IO_MAP(microkit_io)
|
||||||
MCFG_COSMAC_WAIT_CALLBACK(VCC)
|
MCFG_COSMAC_WAIT_CALLBACK(VCC)
|
||||||
|
MCFG_COSMAC_CLEAR_CALLBACK(READLINE(microkit_state, clear_r))
|
||||||
|
|
||||||
|
/* video hardware */
|
||||||
|
MCFG_RS232_PORT_ADD("rs232", default_rs232_devices, "keyboard")
|
||||||
|
MCFG_RS232_RXD_HANDLER(DEVWRITELINE("maincpu", cosmac_device, ef4_w))
|
||||||
|
MCFG_DEVICE_CARD_DEVICE_INPUT_DEFAULTS("keyboard", serial_keyb)
|
||||||
|
MCFG_DEVICE_ADD("terminal", GENERIC_TERMINAL, 0)
|
||||||
MACHINE_CONFIG_END
|
MACHINE_CONFIG_END
|
||||||
|
|
||||||
ROM_START( microkit )
|
ROM_START( microkit )
|
||||||
|
Loading…
Reference in New Issue
Block a user