Previous 199869 Revisions Next

r25424 Wednesday 25th September, 2013 at 19:18:26 UTC by Robbbert
(MESS) New skeleton [Al Kossow, Robbbert]
-------------------------------------------------
Forward Technology FT-68M
[src/mess]mess.lst mess.mak
[src/mess/drivers]ft68m.c*

trunk/src/mess/drivers/ft68m.c
r0r25424
1/***************************************************************************
2
3Forward Technology FT-68M Multibus card.
4
52013-09-26 Skeleton driver
6
7Chips: HD68000-10, uPD7201C, AM9513APC. Crystal: 19.6608 MHz
8
9Interrupts: INT6 is output of Timer 2, INT7 is output of Timer 3 (refresh),
10            INT5 comes from SIO.
11
12****************************************************************************/
13
14#include "emu.h"
15#include "cpu/m68000/m68000.h"
16#include "machine/terminal.h"
17
18class ft68m_state : public driver_device
19{
20public:
21   ft68m_state(const machine_config &mconfig, device_type type, const char *tag)
22      : driver_device(mconfig, type, tag)
23      , m_p_base(*this, "rambase")
24      , m_maincpu(*this, "maincpu")
25      , m_terminal(*this, TERMINAL_TAG)
26   { }
27
28   DECLARE_WRITE8_MEMBER(kbd_put);
29   DECLARE_READ16_MEMBER(keyin_r);
30   DECLARE_READ16_MEMBER(status_r);
31private:
32   UINT8 m_term_data;
33   virtual void machine_reset();
34   required_shared_ptr<UINT16> m_p_base;
35   required_device<cpu_device> m_maincpu;
36   required_device<generic_terminal_device> m_terminal;
37};
38
39READ16_MEMBER( ft68m_state::keyin_r )
40{
41   UINT16 ret = m_term_data;
42   m_term_data = 0;
43   return ret << 8;
44}
45
46READ16_MEMBER( ft68m_state::status_r )
47{
48   return (m_term_data) ? 0x500 : 0x400;
49}
50
51
52static ADDRESS_MAP_START(ft68m_mem, AS_PROGRAM, 16, ft68m_state)
53   ADDRESS_MAP_UNMAP_HIGH
54   ADDRESS_MAP_GLOBAL_MASK(0xffffff)
55   AM_RANGE(0x000000, 0x1fffff) AM_RAM AM_SHARE("rambase")
56   AM_RANGE(0x200000, 0x201fff) AM_ROM AM_REGION("roms", 0x0000)
57   AM_RANGE(0x400000, 0x401fff) AM_ROM AM_REGION("roms", 0x2000)
58   AM_RANGE(0x600000, 0x600001) AM_READ(keyin_r) AM_DEVWRITE8(TERMINAL_TAG, generic_terminal_device, write, 0xff00)
59   AM_RANGE(0x600002, 0x600003) AM_READ(status_r)
60   //AM_RANGE(0x600000, 0x600003) AM_MIRROR(0x1ffffc) uPD7201 SIO
61   //AM_RANGE(0x800000, 0x800003) AM_MIRROR(0x1ffffc) AM9513 Timer
62   //AM_RANGE(0xa00000, 0xbfffff) Page Map
63   //AM_RANGE(0xc00000, 0xdfffff) Segment Map
64   //AM_RANGE(0xe00000, 0xffffff) Context Register
65ADDRESS_MAP_END
66
67
68/* Input ports */
69static INPUT_PORTS_START( ft68m )
70INPUT_PORTS_END
71
72
73void ft68m_state::machine_reset()
74{
75   UINT8* ROM = memregion("roms")->base();
76   memcpy(m_p_base, ROM, 8);
77   m_maincpu->reset();
78}
79
80WRITE8_MEMBER( ft68m_state::kbd_put )
81{
82   m_term_data = data;
83}
84
85static GENERIC_TERMINAL_INTERFACE( terminal_intf )
86{
87   DEVCB_DRIVER_MEMBER(ft68m_state, kbd_put)
88};
89
90static MACHINE_CONFIG_START( ft68m, ft68m_state )
91   /* basic machine hardware */
92   MCFG_CPU_ADD("maincpu", M68000, XTAL_19_6608MHz / 2)
93   MCFG_CPU_PROGRAM_MAP(ft68m_mem)
94
95   /* video hardware */
96   MCFG_GENERIC_TERMINAL_ADD(TERMINAL_TAG, terminal_intf)
97MACHINE_CONFIG_END
98
99/* ROM definition */
100ROM_START( ft68m )
101   ROM_REGION16_BE(0x4000, "roms", 0)
102   ROM_LOAD16_BYTE(" 23-0009-01c.a4", 0x0000, 0x1000, CRC(0d45fc8d) SHA1(59587cb1c151bfd0d69e708716ed3b0a78aa85ea) )
103   ROM_LOAD16_BYTE(" 23-0008-01c.a1", 0x0001, 0x1000, CRC(d1aa1164) SHA1(05e10f1c594e2acd369949b873a524a9cc37829f) )
104   ROM_LOAD16_BYTE( "33-01.a6", 0x2000, 0x1000, CRC(53fe3c73) SHA1(ad15c74cd8edef9d9716ad0d16f7a95ff2af901f) )
105   ROM_LOAD16_BYTE( "33-00.a3", 0x2001, 0x1000, CRC(06b1cc77) SHA1(12e3314e92f800b3c4ebdf55dcd5351230224788) )
106
107   ROM_REGION(0x700, "proms", 0)
108   ROM_LOAD("23-0010-00.a15", 0x000, 0x020, CRC(20eb1183) SHA1(9b268792b28d858d6b6a1b6c4148af88a8d6b735) )
109   ROM_LOAD("23-0011-00.a14", 0x100, 0x200, CRC(12d9a6be) SHA1(fca99f9c5afc630ac67cbd4e5ba4e5242b826848) )
110   ROM_LOAD("23-0012-00.a16", 0x300, 0x020, CRC(ee1e5a14) SHA1(0d3346cb3b647fa2475bd7b4fa36ea6ecfdaf805) )
111   ROM_LOAD("23-0034-00.e4",  0x400, 0x100, NO_DUMP )
112   ROM_LOAD("23-0037-00.e7",  0x500, 0x100, NO_DUMP )
113   ROM_LOAD("23-0038-00.f1",  0x600, 0x100, NO_DUMP )
114ROM_END
115
116
117/* Driver */
118
119/*    YEAR  NAME   PARENT  COMPAT  MACHINE INPUT   CLASS         INIT    COMPANY           FULLNAME       FLAGS */
120COMP( 198?, ft68m, 0,      0,      ft68m,  ft68m,  driver_device, 0, "Callan Data Systems", "ft68m", GAME_NOT_WORKING | GAME_NO_SOUND_HW )
Property changes on: trunk/src/mess/drivers/ft68m.c
Added: svn:mime-type
   + text/plain
Added: svn:eol-style
   + native
trunk/src/mess/mess.mak
r25423r25424
23902390   $(MESS_DRIVERS)/eacc.o      \
23912391   $(MESS_DRIVERS)/elwro800.o  \
23922392   $(MESS_DRIVERS)/eti660.o    \
2393   $(MESS_DRIVERS)/fidelz80.o  \
23932394   $(MESS_DRIVERS)/fk1.o       \
2394   $(MESS_DRIVERS)/fidelz80.o  \
2395   $(MESS_DRIVERS)/ft68m.o     \
23952396   $(MESS_DRIVERS)/grfd2301.o  \
23962397   $(MESS_DRIVERS)/harriet.o   \
23972398   $(MESS_DRIVERS)/hpz80unk.o  \
trunk/src/mess/mess.lst
r25423r25424
22722272imsai
22732273jade
22742274jonos
2275ft68m

Previous 199869 Revisions Next


© 1997-2024 The MAME Team