mirror of
https://github.com/holub/mame
synced 2025-10-05 08:41:31 +03:00
(MESS) New skeleton [Al Kossow, Robbbert]
------------------------------------------------- Forward Technology FT-68M
This commit is contained in:
parent
ae13e9a9fb
commit
118b344adc
1
.gitattributes
vendored
1
.gitattributes
vendored
@ -6297,6 +6297,7 @@ src/mess/drivers/fmtowns.c svneol=native#text/plain
|
||||
src/mess/drivers/fp1100.c svneol=native#text/plain
|
||||
src/mess/drivers/fp200.c svneol=native#text/plain
|
||||
src/mess/drivers/fp6000.c svneol=native#text/plain
|
||||
src/mess/drivers/ft68m.c svneol=native#text/plain
|
||||
src/mess/drivers/galaxy.c svneol=native#text/plain
|
||||
src/mess/drivers/galeb.c svneol=native#text/plain
|
||||
src/mess/drivers/gamecom.c svneol=native#text/plain
|
||||
|
120
src/mess/drivers/ft68m.c
Normal file
120
src/mess/drivers/ft68m.c
Normal file
@ -0,0 +1,120 @@
|
||||
/***************************************************************************
|
||||
|
||||
Forward Technology FT-68M Multibus card.
|
||||
|
||||
2013-09-26 Skeleton driver
|
||||
|
||||
Chips: HD68000-10, uPD7201C, AM9513APC. Crystal: 19.6608 MHz
|
||||
|
||||
Interrupts: INT6 is output of Timer 2, INT7 is output of Timer 3 (refresh),
|
||||
INT5 comes from SIO.
|
||||
|
||||
****************************************************************************/
|
||||
|
||||
#include "emu.h"
|
||||
#include "cpu/m68000/m68000.h"
|
||||
#include "machine/terminal.h"
|
||||
|
||||
class ft68m_state : public driver_device
|
||||
{
|
||||
public:
|
||||
ft68m_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag)
|
||||
, m_p_base(*this, "rambase")
|
||||
, m_maincpu(*this, "maincpu")
|
||||
, m_terminal(*this, TERMINAL_TAG)
|
||||
{ }
|
||||
|
||||
DECLARE_WRITE8_MEMBER(kbd_put);
|
||||
DECLARE_READ16_MEMBER(keyin_r);
|
||||
DECLARE_READ16_MEMBER(status_r);
|
||||
private:
|
||||
UINT8 m_term_data;
|
||||
virtual void machine_reset();
|
||||
required_shared_ptr<UINT16> m_p_base;
|
||||
required_device<cpu_device> m_maincpu;
|
||||
required_device<generic_terminal_device> m_terminal;
|
||||
};
|
||||
|
||||
READ16_MEMBER( ft68m_state::keyin_r )
|
||||
{
|
||||
UINT16 ret = m_term_data;
|
||||
m_term_data = 0;
|
||||
return ret << 8;
|
||||
}
|
||||
|
||||
READ16_MEMBER( ft68m_state::status_r )
|
||||
{
|
||||
return (m_term_data) ? 0x500 : 0x400;
|
||||
}
|
||||
|
||||
|
||||
static ADDRESS_MAP_START(ft68m_mem, AS_PROGRAM, 16, ft68m_state)
|
||||
ADDRESS_MAP_UNMAP_HIGH
|
||||
ADDRESS_MAP_GLOBAL_MASK(0xffffff)
|
||||
AM_RANGE(0x000000, 0x1fffff) AM_RAM AM_SHARE("rambase")
|
||||
AM_RANGE(0x200000, 0x201fff) AM_ROM AM_REGION("roms", 0x0000)
|
||||
AM_RANGE(0x400000, 0x401fff) AM_ROM AM_REGION("roms", 0x2000)
|
||||
AM_RANGE(0x600000, 0x600001) AM_READ(keyin_r) AM_DEVWRITE8(TERMINAL_TAG, generic_terminal_device, write, 0xff00)
|
||||
AM_RANGE(0x600002, 0x600003) AM_READ(status_r)
|
||||
//AM_RANGE(0x600000, 0x600003) AM_MIRROR(0x1ffffc) uPD7201 SIO
|
||||
//AM_RANGE(0x800000, 0x800003) AM_MIRROR(0x1ffffc) AM9513 Timer
|
||||
//AM_RANGE(0xa00000, 0xbfffff) Page Map
|
||||
//AM_RANGE(0xc00000, 0xdfffff) Segment Map
|
||||
//AM_RANGE(0xe00000, 0xffffff) Context Register
|
||||
ADDRESS_MAP_END
|
||||
|
||||
|
||||
/* Input ports */
|
||||
static INPUT_PORTS_START( ft68m )
|
||||
INPUT_PORTS_END
|
||||
|
||||
|
||||
void ft68m_state::machine_reset()
|
||||
{
|
||||
UINT8* ROM = memregion("roms")->base();
|
||||
memcpy(m_p_base, ROM, 8);
|
||||
m_maincpu->reset();
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( ft68m_state::kbd_put )
|
||||
{
|
||||
m_term_data = data;
|
||||
}
|
||||
|
||||
static GENERIC_TERMINAL_INTERFACE( terminal_intf )
|
||||
{
|
||||
DEVCB_DRIVER_MEMBER(ft68m_state, kbd_put)
|
||||
};
|
||||
|
||||
static MACHINE_CONFIG_START( ft68m, ft68m_state )
|
||||
/* basic machine hardware */
|
||||
MCFG_CPU_ADD("maincpu", M68000, XTAL_19_6608MHz / 2)
|
||||
MCFG_CPU_PROGRAM_MAP(ft68m_mem)
|
||||
|
||||
/* video hardware */
|
||||
MCFG_GENERIC_TERMINAL_ADD(TERMINAL_TAG, terminal_intf)
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
/* ROM definition */
|
||||
ROM_START( ft68m )
|
||||
ROM_REGION16_BE(0x4000, "roms", 0)
|
||||
ROM_LOAD16_BYTE(" 23-0009-01c.a4", 0x0000, 0x1000, CRC(0d45fc8d) SHA1(59587cb1c151bfd0d69e708716ed3b0a78aa85ea) )
|
||||
ROM_LOAD16_BYTE(" 23-0008-01c.a1", 0x0001, 0x1000, CRC(d1aa1164) SHA1(05e10f1c594e2acd369949b873a524a9cc37829f) )
|
||||
ROM_LOAD16_BYTE( "33-01.a6", 0x2000, 0x1000, CRC(53fe3c73) SHA1(ad15c74cd8edef9d9716ad0d16f7a95ff2af901f) )
|
||||
ROM_LOAD16_BYTE( "33-00.a3", 0x2001, 0x1000, CRC(06b1cc77) SHA1(12e3314e92f800b3c4ebdf55dcd5351230224788) )
|
||||
|
||||
ROM_REGION(0x700, "proms", 0)
|
||||
ROM_LOAD("23-0010-00.a15", 0x000, 0x020, CRC(20eb1183) SHA1(9b268792b28d858d6b6a1b6c4148af88a8d6b735) )
|
||||
ROM_LOAD("23-0011-00.a14", 0x100, 0x200, CRC(12d9a6be) SHA1(fca99f9c5afc630ac67cbd4e5ba4e5242b826848) )
|
||||
ROM_LOAD("23-0012-00.a16", 0x300, 0x020, CRC(ee1e5a14) SHA1(0d3346cb3b647fa2475bd7b4fa36ea6ecfdaf805) )
|
||||
ROM_LOAD("23-0034-00.e4", 0x400, 0x100, NO_DUMP )
|
||||
ROM_LOAD("23-0037-00.e7", 0x500, 0x100, NO_DUMP )
|
||||
ROM_LOAD("23-0038-00.f1", 0x600, 0x100, NO_DUMP )
|
||||
ROM_END
|
||||
|
||||
|
||||
/* Driver */
|
||||
|
||||
/* YEAR NAME PARENT COMPAT MACHINE INPUT CLASS INIT COMPANY FULLNAME FLAGS */
|
||||
COMP( 198?, ft68m, 0, 0, ft68m, ft68m, driver_device, 0, "Callan Data Systems", "ft68m", GAME_NOT_WORKING | GAME_NO_SOUND_HW )
|
@ -2272,3 +2272,4 @@ lft1510
|
||||
imsai
|
||||
jade
|
||||
jonos
|
||||
ft68m
|
||||
|
@ -2390,8 +2390,9 @@ $(MESSOBJ)/skeleton.a: \
|
||||
$(MESS_DRIVERS)/eacc.o \
|
||||
$(MESS_DRIVERS)/elwro800.o \
|
||||
$(MESS_DRIVERS)/eti660.o \
|
||||
$(MESS_DRIVERS)/fk1.o \
|
||||
$(MESS_DRIVERS)/fidelz80.o \
|
||||
$(MESS_DRIVERS)/fk1.o \
|
||||
$(MESS_DRIVERS)/ft68m.o \
|
||||
$(MESS_DRIVERS)/grfd2301.o \
|
||||
$(MESS_DRIVERS)/harriet.o \
|
||||
$(MESS_DRIVERS)/hpz80unk.o \
|
||||
|
Loading…
Reference in New Issue
Block a user