mirror of
https://github.com/holub/mame
synced 2025-10-05 08:41:31 +03:00
(nw) dms86 : added devices but commented out as not working
This commit is contained in:
parent
d9eaaf2151
commit
f3a161d3f4
@ -7,16 +7,21 @@
|
||||
11/01/2010 Skeleton driver.
|
||||
|
||||
Monitor commands:
|
||||
A
|
||||
A Display incoming terminal data in hex
|
||||
B boot to HiNet
|
||||
C copy memory
|
||||
D dump memory to screen
|
||||
F fill memory
|
||||
G go (eg G address [breakpoint])
|
||||
I in port
|
||||
L memory test
|
||||
M memory test
|
||||
O out port (e.g. O 84 77)
|
||||
P
|
||||
P set segment
|
||||
S write a byte to memory
|
||||
T
|
||||
T type ascii string into the address set by D or S
|
||||
X display registers
|
||||
? help
|
||||
: load intel hex format file
|
||||
|
||||
|
||||
Note that bit 3 of port 82 is tested at boot. If low, the computer bypasses
|
||||
@ -26,73 +31,68 @@ the monitor and goes straight to "Joining HiNet".
|
||||
|
||||
#include "emu.h"
|
||||
#include "cpu/i86/i86.h"
|
||||
#include "machine/z80ctc.h"
|
||||
#include "machine/z80sio.h"
|
||||
#include "machine/clock.h"
|
||||
#include "bus/rs232/rs232.h"
|
||||
#include "machine/terminal.h"
|
||||
|
||||
#define TERMINAL_TAG "terminal"
|
||||
|
||||
class dms86_state : public driver_device
|
||||
{
|
||||
public:
|
||||
dms86_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_terminal(*this, TERMINAL_TAG)
|
||||
{
|
||||
}
|
||||
: driver_device(mconfig, type, tag)
|
||||
, m_maincpu(*this, "maincpu")
|
||||
{ }
|
||||
|
||||
DECLARE_READ16_MEMBER( dms86_82_r );
|
||||
DECLARE_READ16_MEMBER( dms86_84_r );
|
||||
DECLARE_READ16_MEMBER( dms86_86_r );
|
||||
DECLARE_READ16_MEMBER( dms86_9a_r );
|
||||
DECLARE_READ16_MEMBER( port82_r );
|
||||
DECLARE_READ16_MEMBER( port9a_r );
|
||||
DECLARE_READ16_MEMBER( port9c_r );
|
||||
void kbd_put(u8 data);
|
||||
|
||||
protected:
|
||||
required_device<cpu_device> m_maincpu;
|
||||
required_device<generic_terminal_device> m_terminal;
|
||||
uint8_t *m_ram;
|
||||
uint8_t m_term_data;
|
||||
private:
|
||||
u8 m_term_data;
|
||||
virtual void machine_reset() override;
|
||||
required_device<cpu_device> m_maincpu;
|
||||
};
|
||||
|
||||
READ16_MEMBER( dms86_state::dms86_82_r )
|
||||
|
||||
READ16_MEMBER( dms86_state::port82_r )
|
||||
{
|
||||
// HiNet / Monitor switch
|
||||
|
||||
return 0xff;
|
||||
return 8;
|
||||
}
|
||||
|
||||
READ16_MEMBER( dms86_state::dms86_84_r )
|
||||
READ16_MEMBER( dms86_state::port9a_r )
|
||||
{
|
||||
return m_term_data ? 0x40 : 0;
|
||||
}
|
||||
|
||||
READ16_MEMBER( dms86_state::port9c_r )
|
||||
{
|
||||
uint8_t ret = m_term_data;
|
||||
m_term_data = 0;
|
||||
return ret;
|
||||
}
|
||||
|
||||
READ16_MEMBER( dms86_state::dms86_86_r )
|
||||
{
|
||||
return 4 | (m_term_data ? 1 : 0);
|
||||
}
|
||||
|
||||
READ16_MEMBER( dms86_state::dms86_9a_r )
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
static ADDRESS_MAP_START(dms86_mem, AS_PROGRAM, 16, dms86_state)
|
||||
static ADDRESS_MAP_START(mem_map, AS_PROGRAM, 16, dms86_state)
|
||||
ADDRESS_MAP_UNMAP_HIGH
|
||||
AM_RANGE(0x00000, 0x1ffff) AM_RAM
|
||||
AM_RANGE(0xfe000, 0xfffff) AM_ROM AM_REGION("user1",0)
|
||||
AM_RANGE(0xfe000, 0xfffff) AM_ROM AM_REGION("roms",0)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
static ADDRESS_MAP_START(dms86_io, AS_IO, 16, dms86_state)
|
||||
static ADDRESS_MAP_START(io_map, AS_IO, 16, dms86_state)
|
||||
ADDRESS_MAP_UNMAP_HIGH
|
||||
ADDRESS_MAP_GLOBAL_MASK(0xff)
|
||||
AM_RANGE(0x82, 0x83) AM_READ(dms86_82_r)
|
||||
AM_RANGE(0x84, 0x85) AM_READ(dms86_84_r) AM_DEVWRITE8(TERMINAL_TAG, generic_terminal_device, write, 0xff)
|
||||
AM_RANGE(0x86, 0x87) AM_READ(dms86_86_r)
|
||||
AM_RANGE(0x9A, 0x9B) AM_READ(dms86_9a_r)
|
||||
AM_RANGE(0x9c, 0x9d) AM_DEVWRITE8(TERMINAL_TAG, generic_terminal_device, write, 0xff)
|
||||
AM_RANGE(0x82, 0x83) AM_READ(port82_r)
|
||||
//AM_RANGE(0x80, 0x87) AM_DEVREADWRITE8("sio1", z80sio_device, ba_cd_r, ba_cd_w, 0x00ff)
|
||||
AM_RANGE(0x88, 0x8f) AM_DEVREADWRITE8("ctc", z80ctc_device, read, write, 0x00ff)
|
||||
AM_RANGE(0x90, 0x97) AM_DEVREADWRITE8("sio2", z80sio_device, ba_cd_r, ba_cd_w, 0x00ff)
|
||||
AM_RANGE(0x9A, 0x9B) AM_READ(port9a_r) // parallel SASI port
|
||||
AM_RANGE(0x9c, 0x9d) AM_READ(port9c_r) AM_DEVWRITE8("terminal", generic_terminal_device, write, 0xff)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
/* Input ports */
|
||||
@ -111,18 +111,45 @@ void dms86_state::kbd_put(u8 data)
|
||||
|
||||
static MACHINE_CONFIG_START( dms86 )
|
||||
/* basic machine hardware */
|
||||
MCFG_CPU_ADD("maincpu",I8086, XTAL_9_8304MHz)
|
||||
MCFG_CPU_PROGRAM_MAP(dms86_mem)
|
||||
MCFG_CPU_IO_MAP(dms86_io)
|
||||
MCFG_CPU_ADD("maincpu", I8086, XTAL_14_7456MHz / 3) // according to the manual... hmm
|
||||
MCFG_CPU_PROGRAM_MAP(mem_map)
|
||||
MCFG_CPU_IO_MAP(io_map)
|
||||
|
||||
// According to the manual the clock is 14,765,600 / 4 but that couldn't possibly work.
|
||||
// By maths, clock should be 9600*32*4*16 = 19,660,800 but not working either
|
||||
// So, commented out because it makes the whole thing crawl, only get 18% on my machine
|
||||
//MCFG_DEVICE_ADD("ctc_clock", CLOCK, 19660800) //XTAL_14_7456MHz / 4)
|
||||
//MCFG_CLOCK_SIGNAL_HANDLER(DEVWRITELINE("ctc" ,z80ctc_device, trg0))
|
||||
//MCFG_DEVCB_CHAIN_OUTPUT(DEVWRITELINE("ctc" ,z80ctc_device, trg1))
|
||||
//MCFG_DEVCB_CHAIN_OUTPUT(DEVWRITELINE("ctc" ,z80ctc_device, trg2))
|
||||
|
||||
MCFG_DEVICE_ADD(TERMINAL_TAG, GENERIC_TERMINAL, 0)
|
||||
MCFG_DEVICE_ADD("ctc", Z80CTC, XTAL_14_7456MHz / 3)
|
||||
//MCFG_Z80CTC_INTR_CB(INPUTLINE("maincpu", INPUT_LINE_IRQ0)) // frame rate interrupt to maincpu
|
||||
MCFG_Z80CTC_ZC0_CB(DEVWRITELINE("sio1", z80sio_device, rxtxcb_w)) // SIO1 Ch B
|
||||
MCFG_Z80CTC_ZC1_CB(DEVWRITELINE("sio1", z80sio_device, txca_w)) // SIO1 Ch A
|
||||
MCFG_DEVCB_CHAIN_OUTPUT(DEVWRITELINE("sio1" ,z80sio_device, rxca_w))
|
||||
MCFG_Z80CTC_ZC2_CB(DEVWRITELINE("sio2", z80sio_device, rxtxcb_w)) // SIO2
|
||||
MCFG_DEVCB_CHAIN_OUTPUT(DEVWRITELINE("sio2" ,z80sio_device, rxca_w))
|
||||
MCFG_DEVCB_CHAIN_OUTPUT(DEVWRITELINE("sio2" ,z80sio_device, rxca_w))
|
||||
|
||||
MCFG_DEVICE_ADD("sio1", Z80SIO, XTAL_14_7456MHz / 3)
|
||||
MCFG_Z80SIO_OUT_TXDB_CB(DEVWRITELINE("rs232", rs232_port_device, write_txd))
|
||||
MCFG_Z80SIO_OUT_DTRB_CB(DEVWRITELINE("rs232", rs232_port_device, write_dtr))
|
||||
MCFG_Z80SIO_OUT_RTSB_CB(DEVWRITELINE("rs232", rs232_port_device, write_rts))
|
||||
|
||||
MCFG_RS232_PORT_ADD("rs232", default_rs232_devices, nullptr)
|
||||
MCFG_RS232_RXD_HANDLER(DEVWRITELINE("sio1", z80sio_device, rxb_w))
|
||||
MCFG_RS232_DCD_HANDLER(DEVWRITELINE("sio1", z80sio_device, dcdb_w))
|
||||
MCFG_RS232_CTS_HANDLER(DEVWRITELINE("sio1", z80sio_device, ctsb_w)) MCFG_DEVCB_INVERT
|
||||
|
||||
MCFG_DEVICE_ADD("sio2", Z80SIO, XTAL_14_7456MHz / 3)
|
||||
MCFG_DEVICE_ADD("terminal", GENERIC_TERMINAL, 0)
|
||||
MCFG_GENERIC_TERMINAL_KEYBOARD_CB(PUT(dms86_state, kbd_put))
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
/* ROM definition */
|
||||
ROM_START( dms86 )
|
||||
ROM_REGION( 0x2000, "user1", ROMREGION_ERASEFF )
|
||||
ROM_REGION( 0x2000, "roms", ROMREGION_ERASEFF )
|
||||
ROM_LOAD16_BYTE( "hns-86_54-8678.bin", 0x0000, 0x1000, CRC(95f58e1c) SHA1(6fc8f087f0c887d8b429612cd035c6c1faab570c))
|
||||
ROM_LOAD16_BYTE( "hns-86_54-8677.bin", 0x0001, 0x1000, CRC(78fad756) SHA1(ddcbff1569ec6975b8489935cdcfa80eba413502))
|
||||
ROM_END
|
||||
|
@ -152,7 +152,7 @@ static ADDRESS_MAP_START( hpz80unk_io, AS_IO, 8, hpz80unk_state )
|
||||
AM_RANGE(0x04, 0x04) AM_READWRITE(port04_r,port04_w) // uart2 data
|
||||
AM_RANGE(0x0d, 0x0d) AM_READ(port0d_r) // uart3 status
|
||||
AM_RANGE(0x0e, 0x0e) AM_WRITE(port0e_w) // uart3 data
|
||||
AM_RANGE(0x1d, 0x1e) // top of memory is written here, little-endian
|
||||
AM_RANGE(0x1d, 0x1e) // top of memory is written here, big-endian
|
||||
AM_RANGE(0x1f, 0x1f) AM_READ_PORT("DSW") // select which uarts to use
|
||||
AM_RANGE(0xfc, 0xfc) AM_READ(portfc_r)
|
||||
ADDRESS_MAP_END
|
||||
|
Loading…
Reference in New Issue
Block a user