mirror of
https://github.com/holub/mame
synced 2025-04-16 05:24:54 +03:00
commit
d266cd0a09
@ -3054,6 +3054,7 @@ files {
|
||||
MAME_DIR .. "src/mame/drivers/d6800.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/d6809.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/daruma.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/didact.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/digel804.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/dim68k.cpp",
|
||||
MAME_DIR .. "src/mame/drivers/dm7000.cpp",
|
||||
|
536
src/mame/drivers/didact.cpp
Normal file
536
src/mame/drivers/didact.cpp
Normal file
@ -0,0 +1,536 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Joakim Larsson Edstrom
|
||||
/*
|
||||
* The Didact Esselte 100 CPU board
|
||||
*__________________________________________________________________________________________________________
|
||||
* |
|
||||
*__________________________________________________________________________________________________________|
|
||||
*
|
||||
* The Didact Mikrodator 6802 CPU board by lars Björklund 1983
|
||||
*__________________________________________________________________________________________________________
|
||||
* |
|
||||
*__________________________________________________________________________________________________________|
|
||||
*
|
||||
* The Didact Mp68A CPU board, by Anders Andersson 1979
|
||||
*__________________________________________________________________________________________________________
|
||||
* 74138 |
|
||||
* +------+ +-------+ +--+ |
|
||||
* | 7402 | | 74490 | | | +-------+ +--+ |
|
||||
* +-------+ +------+ +-------+ | | | | | | |
|
||||
* | | 2112 2112 | | | EXP | | | |
|
||||
* | ROM | +--+ +--+ +--+ | ANS | |P | |
|
||||
* | 7641 | | | | | | ION | |I | |
|
||||
* | | |A | |B | +-----+ | BUSES | |A | |
|
||||
* | 512x8 | | | | | | | | (2 x) | | | |
|
||||
* | | +--+ +--+ | | | FOR | |A | |
|
||||
* +-------+ RAMS 4x256x4 | | | | | | |
|
||||
* ROMS 2x512x8 2112 2112 | | | KEY | |E | |
|
||||
* +-------+ +--+ +--+ |CPU | | BOARD | +------+ |X | |
|
||||
* | | | | | | |6800 | | | | | |P | |
|
||||
* | ROM | |A | |B | | | | AND | | | |A | |
|
||||
* | 7641 | | | | | | | | | | | |N | |
|
||||
* | | +--+ +--+ | | | I/O | | 6820 | |S | |
|
||||
* | 512x8 | 512 bytes RAM | | | BOARDS| | PIA | |I | |
|
||||
* +-------+ | | | | | #1 | |O | +-----+
|
||||
* 1024 bytes ROM | | | | | | |N | | |
|
||||
* +-----+ | | | | | | PIA A | |
|
||||
* 7402 7412 | | | | |B | EXPANSION| |
|
||||
* +--+ +--+ | | | | |U | CONNECTOR| |
|
||||
* | | | | | | | | |S | | _|
|
||||
* | | | | | | | | | | J4 | |
|
||||
* | | | | | | +------+ | | | |_
|
||||
* +--+ +--+ +--------+ | | | | | |
|
||||
* +-+ | 96LS02 | | | | | | |
|
||||
* R * * * R |T| +--------+ | | | | | |
|
||||
* O X A |R| | | | | | |
|
||||
* M * * * M |M| Oscillator circuits +-------+ +--+ | |
|
||||
* |_| J1 J2 J3 +-----+
|
||||
*__________________________________________________________________________________________________________|
|
||||
*
|
||||
* The Didact Mp68A Keypad and Display board, tb16a, Anders Andersson 1979
|
||||
*______________________________________________________
|
||||
* +oooo+ |
|
||||
* 6064 +-------+ |cass| |
|
||||
* +--+ | 9368 | +----+ +--+|
|
||||
* +-------+ |B | +-------+ | ||
|
||||
* | 74132 | |CD| 145 |E ||
|
||||
* +-------+ |DI| +--+ 132 |X ||
|
||||
* +------+------+ | S| | | +--+ |P ||
|
||||
* | | | | P| | | | | |A ||
|
||||
* | RES |(led) | +--+ | | | | |N ||
|
||||
* | | * | +--+ | | |S ||
|
||||
* +------+------+------+------+ +--+ |I ||
|
||||
* | | | | | |O ||
|
||||
* | ADR | RUN | SST | REG | |N ||
|
||||
* | 0 | 4 | 8 | C | | ||
|
||||
* +------+------+------+------+ |C ||
|
||||
* | | | | | |O ||
|
||||
* | STA | STO | BPR | BPS | |N ||
|
||||
* | 1 | 5 | 9 | D | |N ||
|
||||
* +------+------+------+------+ +------+ |E ||
|
||||
* | | | | | | | |C ||
|
||||
* | EXF | EXB | MOV | PRM | | | |T ||
|
||||
* | 2 | 6 | A | E | | | |O ||
|
||||
* +------+------+------+------+ | 6820 | |R ||
|
||||
* | | | | | | PIA | | ||
|
||||
* | CLR | REL | REC | PLA | | #2 | | ||
|
||||
* | 3 | 7 | B | F | | | | ||
|
||||
* +------+------+------+------+ | | | ||
|
||||
* +-------+ +-------+ +------+ | | | ||
|
||||
* | 74148 | | 74148 | | 7400 | | | | ||
|
||||
* +-------+ +-------+ +------+ | | +--+|
|
||||
* | | |
|
||||
* +---------+ +------+ J1 |
|
||||
*________| ___ |___________________________________|
|
||||
* | _|||_ |
|
||||
* /|_| |_|\
|
||||
*
|
||||
*
|
||||
* History of Didact
|
||||
*------------------
|
||||
* Didact Läromedelsproduktion was started in Linköping in Sweden by Anders Andersson, Arne Kullbjer and
|
||||
* Lars Björklund. They constructed a series of microcomputers for educational purposes such as "Mikrodator 6802",
|
||||
* Esselte 100 and the Candela computer for the swedish schools to educate the students in assembly programming
|
||||
* and BASIC for electro mechanical applications such as stepper motors, simple process control, buttons
|
||||
* and LED:s. Didact designs were marketed by Esselte Studium to the swedish schools. The Candela computer
|
||||
* was designed to be the big breakthough and was based on OS9 but lost the battle of the swedish schools to
|
||||
* the Compis computer by TeleNova which was based on CP/M initially but later both lost to IBM PC.
|
||||
*
|
||||
* Misc links about the boards supported by this driver.
|
||||
*-----------------------------------------------------
|
||||
* http://www.elektronikforumet.com/forum/viewtopic.php?f=11&t=51424
|
||||
* http://kilroy71.fastmail.fm/gallery/Miscellaneous/20120729_019.jpg
|
||||
* http://elektronikforumet.com/forum/download/file.php?id=63988&mode=view
|
||||
* http://elektronikforumet.com/forum/viewtopic.php?f=2&t=79576&start=150#p1203915
|
||||
*
|
||||
* TODO:
|
||||
* Didact designs: mp68a, md6802, Esselte 100, Candela
|
||||
* --------------------------------------------------------------------------
|
||||
* - Add PCB layouts OK
|
||||
* - Dump ROM:s, OK OK
|
||||
* - Keyboard OK
|
||||
* - Display/CRT OK
|
||||
* - Clickable Artwork RQ
|
||||
* - Sound NA
|
||||
* - Cassette i/f
|
||||
* - Expansion bus
|
||||
* - Expansion overlay
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#include "emu.h"
|
||||
#include "cpu/m6800/m6800.h"
|
||||
#include "machine/6821pia.h" // For all boards
|
||||
#include "video/dm9368.h" // For the mp68a
|
||||
|
||||
#define VERBOSE 0
|
||||
|
||||
#define LOG(x) do { if (VERBOSE) logerror x; } while (0)
|
||||
#if VERBOSE == 2
|
||||
#define logerror printf
|
||||
#endif
|
||||
|
||||
#ifdef _MSC_VER
|
||||
#define FUNCNAME __func__
|
||||
#else
|
||||
#define FUNCNAME __PRETTY_FUNCTION__
|
||||
#endif
|
||||
|
||||
/* Esselte 100 driver class */
|
||||
class e100_state : public driver_device
|
||||
{
|
||||
public:
|
||||
e100_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_pia1(*this, "pia1"),
|
||||
m_pia2(*this, "pia2")
|
||||
{ }
|
||||
required_device<m6802_cpu_device> m_maincpu;
|
||||
|
||||
protected:
|
||||
required_device<pia6821_device> m_pia1;
|
||||
required_device<pia6821_device> m_pia2;
|
||||
};
|
||||
|
||||
/* Mikrodator 6802 driver class */
|
||||
class md6802_state : public driver_device
|
||||
{
|
||||
public:
|
||||
md6802_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_pia1(*this, "pia1"),
|
||||
m_pia2(*this, "pia2")
|
||||
{ }
|
||||
required_device<m6802_cpu_device> m_maincpu;
|
||||
|
||||
protected:
|
||||
required_device<pia6821_device> m_pia1;
|
||||
required_device<pia6821_device> m_pia2;
|
||||
};
|
||||
|
||||
|
||||
/* Didact mp68a driver class */
|
||||
// Just a statement that the real mp68a hardware was designed with 6820 and not 6821
|
||||
// They are functional equivalents BUT has different electrical characteristics.
|
||||
#define pia6820_device pia6821_device
|
||||
#define PIA6820 PIA6821
|
||||
class mp68a_state : public driver_device
|
||||
{
|
||||
public:
|
||||
mp68a_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag)
|
||||
,m_maincpu(*this, "maincpu")
|
||||
,m_io_line0(*this, "LINE0")
|
||||
,m_io_line1(*this, "LINE1")
|
||||
,m_io_line2(*this, "LINE2")
|
||||
,m_io_line3(*this, "LINE3")
|
||||
,m_io_line4(*this, "LINE4")
|
||||
,m_line0(0)
|
||||
,m_line1(0)
|
||||
,m_line2(0)
|
||||
,m_line3(0)
|
||||
,m_shift(0)
|
||||
,m_digit0(*this, "digit0")
|
||||
,m_digit1(*this, "digit1")
|
||||
,m_digit2(*this, "digit2")
|
||||
,m_digit3(*this, "digit3")
|
||||
,m_digit4(*this, "digit4")
|
||||
,m_digit5(*this, "digit5")
|
||||
,m_pia1(*this, "pia1")
|
||||
,m_pia2(*this, "pia2")
|
||||
{ }
|
||||
|
||||
required_device<m6800_cpu_device> m_maincpu;
|
||||
|
||||
required_ioport m_io_line0;
|
||||
required_ioport m_io_line1;
|
||||
required_ioport m_io_line2;
|
||||
required_ioport m_io_line3;
|
||||
required_ioport m_io_line4;
|
||||
UINT8 m_line0;
|
||||
UINT8 m_line1;
|
||||
UINT8 m_line2;
|
||||
UINT8 m_line3;
|
||||
UINT8 m_shift;
|
||||
|
||||
// The display segment driver device
|
||||
required_device<dm9368_device> m_digit0;
|
||||
required_device<dm9368_device> m_digit1;
|
||||
required_device<dm9368_device> m_digit2;
|
||||
required_device<dm9368_device> m_digit3;
|
||||
required_device<dm9368_device> m_digit4;
|
||||
required_device<dm9368_device> m_digit5;
|
||||
|
||||
DECLARE_READ8_MEMBER( pia2_kbA_r );
|
||||
DECLARE_WRITE8_MEMBER( pia2_kbA_w );
|
||||
DECLARE_READ8_MEMBER( pia2_kbB_r );
|
||||
DECLARE_WRITE8_MEMBER( pia2_kbB_w );
|
||||
DECLARE_READ_LINE_MEMBER( pia2_cb1_r );
|
||||
|
||||
virtual void machine_start() override;
|
||||
TIMER_DEVICE_CALLBACK_MEMBER(scan_artwork);
|
||||
protected:
|
||||
required_device<pia6820_device> m_pia1;
|
||||
required_device<pia6820_device> m_pia2;
|
||||
};
|
||||
|
||||
READ8_MEMBER( mp68a_state::pia2_kbA_r )
|
||||
{
|
||||
LOG(("--->%s\n", FUNCNAME));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mp68a_state::pia2_kbA_w )
|
||||
{
|
||||
UINT8 m_lednum;
|
||||
|
||||
#if VERBOSE > 1
|
||||
static UINT8 display[] = {' ',' ',' ',' ',' ',' ',' ',' ','\0'};
|
||||
const UINT8 hex[] = {' ','0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
|
||||
#endif
|
||||
|
||||
/* Display memory is at $702 to $708 in AAAADD format (A=address digit, D=Data digit)
|
||||
but we are using data read from the port. */
|
||||
m_lednum = (data >> 4) & 0x07;
|
||||
|
||||
switch (m_lednum)
|
||||
{
|
||||
case 0: m_digit0->a_w(data & 0x0f); break;
|
||||
case 1: m_digit1->a_w(data & 0x0f); break;
|
||||
case 2: m_digit2->a_w(data & 0x0f); break;
|
||||
case 3: m_digit3->a_w(data & 0x0f); break;
|
||||
case 4: m_digit4->a_w(data & 0x0f); break;
|
||||
case 5: m_digit5->a_w(data & 0x0f); break;
|
||||
case 7: break; // used as an 'unselect' by the ROM between digit accesses.
|
||||
default: logerror("Wrong digit index %d\n", m_lednum);
|
||||
}
|
||||
|
||||
#if VERBOSE > 1
|
||||
display[(data >> 4) & 0x07] = hex[data & 0x0f];
|
||||
LOG(("--->%s(%02x) ==> %s\n", FUNCNAME, data, display));
|
||||
#endif
|
||||
}
|
||||
|
||||
READ8_MEMBER( mp68a_state::pia2_kbB_r )
|
||||
{
|
||||
UINT8 a012, line, pb;
|
||||
|
||||
LOG(("--->%s %02x %02x %02x %02x %02x => ", FUNCNAME, m_line0, m_line1, m_line2, m_line3, m_shift));
|
||||
|
||||
a012 = 0;
|
||||
if ((line = (m_line0 | m_line1)) != 0)
|
||||
{
|
||||
a012 = 8;
|
||||
while (a012 > 0 && !(line & (1 << --a012)));
|
||||
a012 += 8;
|
||||
}
|
||||
if ( a012 == 0 && (line = ((m_line2) | m_line3)) != 0)
|
||||
{
|
||||
a012 = 8;
|
||||
while (a012 > 0 && !(line & (1 << --a012)));
|
||||
}
|
||||
|
||||
pb = a012; // A0-A2 -> PB0-PB3
|
||||
if (m_shift)
|
||||
{
|
||||
pb |= 0x80; // Set shift bit (PB7)
|
||||
m_shift = 0; // Reset flip flop
|
||||
set_led_status(machine(), 0, m_shift);
|
||||
LOG( ("SHIFT is released\n") );
|
||||
}
|
||||
|
||||
LOG(("%02x\n", pb));
|
||||
|
||||
return pb;
|
||||
}
|
||||
|
||||
WRITE8_MEMBER( mp68a_state::pia2_kbB_w )
|
||||
{
|
||||
LOG(("--->%s(%02x)\n", FUNCNAME, data));
|
||||
}
|
||||
|
||||
READ_LINE_MEMBER( mp68a_state::pia2_cb1_r )
|
||||
{
|
||||
m_line0 = m_io_line0->read();
|
||||
m_line1 = m_io_line1->read();
|
||||
m_line2 = m_io_line2->read();
|
||||
m_line3 = m_io_line3->read();
|
||||
|
||||
#if VERBOSE
|
||||
if ((m_line0 | m_line1 | m_line2 | m_line3) != 0)
|
||||
LOG(("%s()-->%02x %02x %02x %02x\n", FUNCNAME, m_line0, m_line1, m_line2, m_line3));
|
||||
#endif
|
||||
|
||||
return (m_line0 | m_line1 | m_line2 | m_line3) != 0 ? 0 : 1;
|
||||
}
|
||||
|
||||
void mp68a_state::machine_start()
|
||||
{
|
||||
LOG(("--->%s()\n", FUNCNAME));
|
||||
|
||||
/* register for state saving */
|
||||
save_item(NAME(m_shift));
|
||||
}
|
||||
|
||||
// This map is derived from info in "TEMAL 100 - teknisk manual Esselte 100"
|
||||
static ADDRESS_MAP_START( e100_map, AS_PROGRAM, 8, e100_state )
|
||||
AM_RANGE(0x0000, 0x1fff) AM_RAM
|
||||
AM_RANGE(0xc000, 0xc3ff) AM_RAM AM_SHARE("videoram")
|
||||
AM_RANGE(0xc808, 0xc80b) AM_DEVREADWRITE("pia1", pia6821_device, read, write)
|
||||
AM_RANGE(0xc810, 0xc813) AM_DEVREADWRITE("pia2", pia6821_device, read, write)
|
||||
AM_RANGE(0xd000, 0xffff) AM_ROM AM_REGION("maincpu", 0xd0000)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
// This address map is traced from schema
|
||||
static ADDRESS_MAP_START( md6802_map, AS_PROGRAM, 8, md6802_state )
|
||||
AM_RANGE(0x0000, 0x1fff) AM_RAM AM_MIRROR(0x1800)
|
||||
AM_RANGE(0xa000, 0xa003) AM_DEVREADWRITE("pia1", pia6821_device, read, write) AM_MIRROR(0x1ffc)
|
||||
AM_RANGE(0xc000, 0xc003) AM_DEVREADWRITE("pia2", pia6821_device, read, write) AM_MIRROR(0x1ffc)
|
||||
AM_RANGE(0xe000, 0xffff) AM_ROM AM_MIRROR(0x1800) AM_REGION("maincpu", 0xe000)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
// This address map is traced from pcb
|
||||
static ADDRESS_MAP_START( mp68a_map, AS_PROGRAM, 8, mp68a_state )
|
||||
AM_RANGE(0x0000, 0x00ff) AM_RAM AM_MIRROR(0xf000)
|
||||
AM_RANGE(0x0500, 0x0503) AM_DEVREADWRITE("pia1", pia6820_device, read, write) AM_MIRROR(0xf0fc)
|
||||
AM_RANGE(0x0600, 0x0603) AM_DEVREADWRITE("pia2", pia6820_device, read, write) AM_MIRROR(0xf0fc)
|
||||
AM_RANGE(0x0700, 0x07ff) AM_RAM AM_MIRROR(0xf000)
|
||||
AM_RANGE(0x0800, 0x0bff) AM_ROM AM_MIRROR(0xf400) AM_REGION("maincpu", 0x0800)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
/* Input ports */
|
||||
static INPUT_PORTS_START( e100 )
|
||||
INPUT_PORTS_END
|
||||
|
||||
static INPUT_PORTS_START( md6802 )
|
||||
INPUT_PORTS_END
|
||||
|
||||
static INPUT_PORTS_START( mp68a )
|
||||
PORT_START("LINE0") /* KEY ROW 0 */
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("C") PORT_CODE(KEYCODE_C) PORT_CHAR('C')
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("D") PORT_CODE(KEYCODE_D) PORT_CHAR('D')
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("E") PORT_CODE(KEYCODE_E) PORT_CHAR('E')
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("F") PORT_CODE(KEYCODE_F) PORT_CHAR('F')
|
||||
PORT_BIT(0x0f, IP_ACTIVE_HIGH, IPT_UNUSED )
|
||||
|
||||
PORT_START("LINE1") /* KEY ROW 1 */
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("8") PORT_CODE(KEYCODE_8) PORT_CHAR('8')
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("9") PORT_CODE(KEYCODE_9) PORT_CHAR('9')
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("A") PORT_CODE(KEYCODE_A) PORT_CHAR('A')
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("B") PORT_CODE(KEYCODE_B) PORT_CHAR('B')
|
||||
PORT_BIT(0xf0, IP_ACTIVE_HIGH, IPT_UNUSED )
|
||||
|
||||
PORT_START("LINE2") /* KEY ROW 2 */
|
||||
PORT_BIT(0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("4") PORT_CODE(KEYCODE_4) PORT_CHAR('4')
|
||||
PORT_BIT(0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("5") PORT_CODE(KEYCODE_5) PORT_CHAR('5')
|
||||
PORT_BIT(0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("6") PORT_CODE(KEYCODE_6) PORT_CHAR('6')
|
||||
PORT_BIT(0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("7") PORT_CODE(KEYCODE_7) PORT_CHAR('7')
|
||||
PORT_BIT(0x0f, IP_ACTIVE_HIGH, IPT_UNUSED )
|
||||
|
||||
PORT_START("LINE3") /* KEY ROW 3 */
|
||||
PORT_BIT(0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("0") PORT_CODE(KEYCODE_0) PORT_CHAR('0')
|
||||
PORT_BIT(0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("1") PORT_CODE(KEYCODE_1) PORT_CHAR('1')
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("2") PORT_CODE(KEYCODE_2) PORT_CHAR('2')
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("3") PORT_CODE(KEYCODE_3) PORT_CHAR('3')
|
||||
PORT_BIT(0xf0, IP_ACTIVE_HIGH, IPT_UNUSED )
|
||||
|
||||
PORT_START("LINE4") /* Special KEY ROW for reset and Shift/'*' keys */
|
||||
PORT_BIT(0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("*") PORT_CODE(KEYCODE_LSHIFT) PORT_CODE(KEYCODE_RSHIFT) PORT_CHAR('*')
|
||||
PORT_BIT(0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_NAME("Reset") PORT_CODE(KEYCODE_F12)
|
||||
PORT_BIT(0xf3, IP_ACTIVE_HIGH, IPT_UNUSED )
|
||||
INPUT_PORTS_END
|
||||
|
||||
TIMER_DEVICE_CALLBACK_MEMBER(mp68a_state::scan_artwork)
|
||||
{
|
||||
// LOG(("--->%s()\n", FUNCNAME));
|
||||
|
||||
// Poll the artwork Reset key
|
||||
if ( (m_io_line4->read() & 0x04) )
|
||||
{
|
||||
LOG( ("RESET is pressed, resetting the CPU\n") );
|
||||
m_shift = 0;
|
||||
set_led_status(machine(), 0, m_shift);
|
||||
m_maincpu->reset();
|
||||
|
||||
}
|
||||
|
||||
// Poll the artwork SHIFT/* key
|
||||
else if ( (m_io_line4->read() & 0x08) )
|
||||
{
|
||||
LOG( ("SHIFT is set\n") );
|
||||
m_shift = 1;
|
||||
set_led_status(machine(), 0, m_shift);
|
||||
}
|
||||
}
|
||||
|
||||
static MACHINE_CONFIG_START( e100, e100_state )
|
||||
MCFG_CPU_ADD("maincpu", M6802, XTAL_4MHz/4)
|
||||
MCFG_CPU_PROGRAM_MAP(e100_map)
|
||||
|
||||
/* devices */
|
||||
MCFG_DEVICE_ADD("pia1", PIA6821, 0)
|
||||
MCFG_DEVICE_ADD("pia2", PIA6821, 0)
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
static MACHINE_CONFIG_START( md6802, md6802_state )
|
||||
MCFG_CPU_ADD("maincpu", M6802, XTAL_4MHz/4)
|
||||
MCFG_CPU_PROGRAM_MAP(md6802_map)
|
||||
|
||||
/* devices */
|
||||
MCFG_DEVICE_ADD("pia1", PIA6821, 0)
|
||||
MCFG_DEVICE_ADD("pia2", PIA6821, 0)
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
static MACHINE_CONFIG_START( mp68a, mp68a_state )
|
||||
MCFG_CPU_ADD("maincpu", M6800, XTAL_4MHz/4)
|
||||
MCFG_CPU_PROGRAM_MAP(mp68a_map)
|
||||
|
||||
/* Devices */
|
||||
/* PIA #1 0x500-0x503 - used differently by laborations and loaded software */
|
||||
MCFG_DEVICE_ADD("pia1", PIA6820, 0)
|
||||
|
||||
/* PIA #2 Keyboard & Display 0x600-0x603 */
|
||||
MCFG_DEVICE_ADD("pia2", PIA6820, 0)
|
||||
/* --init----------------------- */
|
||||
/* 0x0BAF 0x601 (Control A) = 0x30 - CA2 is low and enable DDRA */
|
||||
/* 0x0BB1 0x603 (Control B) = 0x30 - CB2 is low and enable DDRB */
|
||||
/* 0x0BB5 0x600 (DDR A) = 0xFF - Port A all outputs and set to 0 (zero) */
|
||||
/* 0x0BB9 0x602 (DDR B) = 0x50 - Port B two outputs and set to 0 (zero9 */
|
||||
/* 0x0BBD 0x601 (Control A) = 0x34 - CA2 is low and lock DDRA */
|
||||
/* 0x0BBF 0x603 (Control B) = 0x34 - CB2 is low and lock DDRB */
|
||||
/* 0x0BC3 0x602 (Port B) = 0x40 - Turn on display via RBI* on */
|
||||
/* --execution-wait for key loop-- */
|
||||
/* 0x086B Update display sequnc, see below */
|
||||
/* 0x0826 CB1 read = 0x603 (Control B) - is a key presssed? */
|
||||
MCFG_PIA_WRITEPA_HANDLER(WRITE8(mp68a_state, pia2_kbA_w))
|
||||
MCFG_PIA_READPA_HANDLER(READ8(mp68a_state, pia2_kbA_r))
|
||||
MCFG_PIA_WRITEPB_HANDLER(WRITE8(mp68a_state, pia2_kbB_w))
|
||||
MCFG_PIA_READPB_HANDLER(READ8(mp68a_state, pia2_kbB_r))
|
||||
MCFG_PIA_READCB1_HANDLER(READLINE(mp68a_state, pia2_cb1_r))
|
||||
MCFG_PIA_IRQA_HANDLER(DEVWRITELINE("maincpu", m6800_cpu_device, irq_line)) /* Not used by ROM. Combined trace to CPU IRQ with IRQB */
|
||||
MCFG_PIA_IRQB_HANDLER(DEVWRITELINE("maincpu", m6800_cpu_device, irq_line)) /* Not used by ROM. Combined trace to CPU IRQ with IRQA */
|
||||
|
||||
/* Display - sequence outputting all '0':s at start */
|
||||
/* 0x086B 0x600 (Port A) = 0x00 */
|
||||
/* 0x086B 0x600 (Port A) = 0x70 */
|
||||
/* 0x086B 0x600 (Port A) = 0x10 */
|
||||
/* 0x086B 0x600 (Port A) = 0x70 */
|
||||
/* 0x086B 0x600 (Port A) = 0x20 */
|
||||
/* 0x086B 0x600 (Port A) = 0x70 */
|
||||
/* 0x086B 0x600 (Port A) = 0x30 */
|
||||
/* 0x086B 0x600 (Port A) = 0x70 */
|
||||
/* 0x086B 0x600 (Port A) = 0x40 */
|
||||
/* 0x086B 0x600 (Port A) = 0x70 */
|
||||
/* 0x086B 0x600 (Port A) = 0x50 */
|
||||
/* 0x086B 0x600 (Port A) = 0x70 */
|
||||
MCFG_DEVICE_ADD("digit0", DM9368, 0)
|
||||
MCFG_OUTPUT_INDEX(0)
|
||||
MCFG_DEVICE_ADD("digit1", DM9368, 0)
|
||||
MCFG_OUTPUT_INDEX(1)
|
||||
MCFG_DEVICE_ADD("digit2", DM9368, 0)
|
||||
MCFG_OUTPUT_INDEX(2)
|
||||
MCFG_DEVICE_ADD("digit3", DM9368, 0)
|
||||
MCFG_OUTPUT_INDEX(3)
|
||||
MCFG_DEVICE_ADD("digit4", DM9368, 0)
|
||||
MCFG_OUTPUT_INDEX(4)
|
||||
MCFG_DEVICE_ADD("digit5", DM9368, 0)
|
||||
MCFG_OUTPUT_INDEX(5)
|
||||
|
||||
MCFG_TIMER_DRIVER_ADD_PERIODIC("artwork_timer", mp68a_state, scan_artwork, attotime::from_hz(10))
|
||||
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
// TODO: Get a ROM set
|
||||
ROM_START( e100 )
|
||||
ROM_REGION(0x10000, "maincpu", 0)
|
||||
ROM_LOAD( "e100U201.bin", 0xd000, 0x0800, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
ROM_LOAD( "e100U202.bin", 0xd800, 0x0800, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
ROM_LOAD( "e100U203.bin", 0xe000, 0x0800, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
ROM_LOAD( "e100U204.bin", 0xe800, 0x0800, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
ROM_LOAD( "e100U205.bin", 0xf000, 0x0800, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
ROM_LOAD( "e100U206.bin", 0xf800, 0x0800, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
ROM_END
|
||||
|
||||
// TODO split ROM image into proper ROM set
|
||||
ROM_START( md6802 ) // ROM image from http://elektronikforumet.com/forum/viewtopic.php?f=2&t=79576&start=135#p1203640
|
||||
ROM_REGION(0x10000, "maincpu", 0)
|
||||
ROM_LOAD( "DIDACT.bin", 0xe000, 0x0800, CRC(50430b1d) SHA1(8e2172a9ae95b04f20aa14177df2463a286c8465) )
|
||||
// ROM_LOAD( "md6802-1.bin", 0xf800, 0xf9ff, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
// ROM_LOAD( "md6802-2.bin", 0xfa00, 0xfbff, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
// ROM_LOAD( "md6802-3.bin", 0xfc00, 0xfdff, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
// ROM_LOAD( "md6802-4.bin", 0xfe00, 0xffff, CRC(0ff53e1f) SHA1(52002ee22c032775dac383d408c44abe9244724f) )
|
||||
ROM_END
|
||||
|
||||
ROM_START( mp68a ) // ROM image from http://elektronikforumet.com/forum/viewtopic.php?f=2&t=79576&start=135#p1203640
|
||||
ROM_REGION(0x10000, "maincpu", 0)
|
||||
ROM_LOAD( "didactA.bin", 0x0800, 0x0200, CRC(aa05e1ce) SHA1(9ce8223efd274045b43ceca3529e037e16e99fdf) )
|
||||
ROM_LOAD( "didactB.bin", 0x0a00, 0x0200, CRC(592898dc) SHA1(2962f4817712cae97f3ab37b088fc73e66535ff8) )
|
||||
ROM_END
|
||||
|
||||
// YEAR NAME PARENT COMPAT MACHINE INPUT CLASS INIT COMPANY FULLNAME FLAGS
|
||||
COMP( 1979, mp68a, 0, 0, mp68a, mp68a, driver_device, 0, "Didact AB", "mp68a", 0 )
|
||||
COMP( 1982, e100, 0, 0, e100, e100, driver_device, 0, "Didact AB", "Esselte 100", MACHINE_IS_SKELETON )
|
||||
COMP( 1983, md6802, 0, 0, md6802, md6802, driver_device, 0, "Didact AB", "Mikrodator 6802", MACHINE_IS_SKELETON )
|
@ -2373,6 +2373,7 @@ c80
|
||||
ds348 //Sigtron Daruma
|
||||
mc1000
|
||||
d6809
|
||||
mp68a
|
||||
mk85
|
||||
mk90
|
||||
elwro800
|
||||
|
Loading…
Reference in New Issue
Block a user