/*************************************************************************** Canon Cat driver by Miodrag Milanovic 12/06/2009 Skeleton driver. 15/06/2009 Working driver Pictures: http://www.regnirps.com/Apple6502stuff/apple_iie_cat.htm How to enable the FORTH interpreter (http://canoncat.org/canoncat/enableforth.html) The definitive instructions of going Forth on a Cat, tested on a living Cat. The Canon Cat is programmed with FORTH, a remarkably different programming language in itself. On the Canon Cat, you can access the FORTH interpreter with a special sequence of key presses. Here are exact working instructions thanks to Sandy Bumgarner: - Type Enable Forth Language exactly like that, capitals and all. - Highlight from the En to the ge, exactly [i.e. Leap back to Enable by keeping the left Leap key down while typing E n a, release the leap key, then click both leap keys simultaneously], and press USE FRONT with ERASE (the ANSWER command). - The Cat should beep and flash the ruler. - Then press USE FRONT and the SHIFT keys together and tap the space bar. Note that the cursor stops blinking. Now a Pressing the RETURN key gets the Forth OK and you are 'in' as they say. ToDo: - Floppy drive (3.5", 256kb) - Beeper/speaker - Swyft - figure out the keyboard - Centronics port - RS232C port ****************************************************************************/ #include "emu.h" #include "cpu/m68000/m68000.h" #include "machine/68681.h" #include "machine/nvram.h" class cat_state : public driver_device { public: cat_state(const machine_config &mconfig, device_type type, const char *tag) : driver_device(mconfig, type, tag) , m_p_sram(*this, "p_sram"), m_p_videoram(*this, "p_videoram"){ } DECLARE_WRITE16_MEMBER(cat_video_status_w); DECLARE_WRITE16_MEMBER(cat_test_mode_w); DECLARE_READ16_MEMBER(cat_modem_r); DECLARE_WRITE16_MEMBER(cat_modem_w); DECLARE_READ16_MEMBER(cat_battery_r); DECLARE_WRITE16_MEMBER(cat_printer_w); DECLARE_READ16_MEMBER(cat_floppy_r); DECLARE_WRITE16_MEMBER(cat_floppy_w); DECLARE_READ16_MEMBER(cat_keyboard_r); DECLARE_WRITE16_MEMBER(cat_keyboard_w); DECLARE_WRITE16_MEMBER(cat_video_w); DECLARE_READ16_MEMBER(cat_something_r); optional_shared_ptr m_p_sram; required_shared_ptr m_p_videoram; UINT8 m_duart_inp;// = 0x0e; UINT8 m_video_enable; UINT16 m_pr_cont; UINT8 m_keyboard_line; emu_timer *m_keyboard_timer; DECLARE_MACHINE_START(cat); DECLARE_MACHINE_RESET(cat); DECLARE_VIDEO_START(cat); DECLARE_MACHINE_START(swyft); DECLARE_MACHINE_RESET(swyft); DECLARE_VIDEO_START(swyft); UINT32 screen_update_cat(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); UINT32 screen_update_swyft(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); }; WRITE16_MEMBER( cat_state::cat_video_status_w ) { m_video_enable = BIT( data, 3 ); } WRITE16_MEMBER( cat_state::cat_test_mode_w ) { } READ16_MEMBER( cat_state::cat_modem_r ) { return 0; } WRITE16_MEMBER( cat_state::cat_modem_w ) { } READ16_MEMBER( cat_state::cat_battery_r ) { /* just return that battery is full */ return 0x7fff; } WRITE16_MEMBER( cat_state::cat_printer_w ) { m_pr_cont = data; } READ16_MEMBER( cat_state::cat_floppy_r ) { return 0; } WRITE16_MEMBER( cat_state::cat_floppy_w ) { } READ16_MEMBER( cat_state::cat_keyboard_r ) { UINT16 retVal = 0; // Read country code if (m_pr_cont == 0x0900) retVal = ioport("DIPSW1")->read(); // Regular keyboard read if (m_pr_cont == 0x0800 || m_pr_cont == 0x0a00) { retVal=0xff00; switch(m_keyboard_line) { case 0x01: retVal = ioport("LINE0")->read() << 8; break; case 0x02: retVal = ioport("LINE1")->read() << 8; break; case 0x04: retVal = ioport("LINE2")->read() << 8; break; case 0x08: retVal = ioport("LINE3")->read() << 8; break; case 0x10: retVal = ioport("LINE4")->read() << 8; break; case 0x20: retVal = ioport("LINE5")->read() << 8; break; case 0x40: retVal = ioport("LINE6")->read() << 8; break; case 0x80: retVal = ioport("LINE7")->read() << 8; break; } } return retVal; } WRITE16_MEMBER( cat_state::cat_keyboard_w ) { m_keyboard_line = data >> 8; } WRITE16_MEMBER( cat_state::cat_video_w ) { /* 006500AE , ( HSS HSync Strart 89 ) 006480C2 , ( HST End HSync 96 ) 006400CE , ( HSE End H Line 104 ) 006180B0 , ( VDE Active Lines 344 ) 006100D4 , ( VSS VSync Start 362 ) 006080F4 , ( VST End of VSync 378 ) 00600120 , ( VSE End of Frame 400 ) 006581C0 , ( VOC Video Control Normal Syncs ) */ } READ16_MEMBER( cat_state::cat_something_r ) { return 0x00ff; } static ADDRESS_MAP_START(cat_mem, AS_PROGRAM, 16, cat_state) ADDRESS_MAP_UNMAP_HIGH AM_RANGE(0x00000000, 0x0003ffff) AM_ROM // 256 KB ROM AM_RANGE(0x00040000, 0x00043fff) AM_RAM AM_SHARE("p_sram") // SRAM powered by battery AM_RANGE(0x00200000, 0x0027ffff) AM_ROM AM_REGION("svrom",0x0000) // SV ROM AM_RANGE(0x00400000, 0x0047ffff) AM_RAM AM_SHARE("p_videoram") // 512 KB RAM AM_RANGE(0x00600000, 0x0065ffff) AM_WRITE(cat_video_w) // Video chip AM_RANGE(0x00800000, 0x00800001) AM_READWRITE(cat_floppy_r, cat_floppy_w) AM_RANGE(0x00800002, 0x00800003) AM_WRITE(cat_keyboard_w) AM_RANGE(0x00800008, 0x00800009) AM_READ(cat_something_r) AM_RANGE(0x0080000a, 0x0080000b) AM_READ(cat_keyboard_r) AM_RANGE(0x0080000e, 0x0080000f) AM_READWRITE(cat_battery_r,cat_printer_w) AM_RANGE(0x00810000, 0x0081001f) AM_DEVREADWRITE8_LEGACY("duart68681", duart68681_r, duart68681_w, 0xff ) AM_RANGE(0x00820000, 0x008200ff) AM_READWRITE(cat_modem_r, cat_modem_w)// modem AM_RANGE(0x00840000, 0x00840001) AM_WRITE(cat_video_status_w) // Video status AM_RANGE(0x00860000, 0x00860001) AM_WRITE(cat_test_mode_w) // Test mode ADDRESS_MAP_END static ADDRESS_MAP_START(swyft_mem, AS_PROGRAM, 16, cat_state) ADDRESS_MAP_UNMAP_HIGH AM_RANGE(0x00000000, 0x0000ffff) AM_ROM // 64 KB ROM AM_RANGE(0x00040000, 0x000fffff) AM_RAM AM_SHARE("p_videoram") ADDRESS_MAP_END /* Input ports */ /* 2009-07 FP FIXME: Natural keyboard does not catch all the Shifted chars. No idea of the reason! */ static INPUT_PORTS_START( cat ) PORT_START("DIPSW1") PORT_DIPNAME( 0x8000, 0x8000, "Mode" ) PORT_DIPSETTING( 0x8000, DEF_STR( Normal ) ) PORT_DIPSETTING( 0x0000, "Diagnostic" ) PORT_DIPNAME( 0x7f00,0x7f00, "Country code" ) PORT_DIPSETTING( 0x7f00, "United States" ) PORT_DIPSETTING( 0x7e00, "Canada" ) PORT_DIPSETTING( 0x7d00, "United Kingdom" ) PORT_DIPSETTING( 0x7c00, "Norway" ) PORT_DIPSETTING( 0x7b00, "France" ) PORT_DIPSETTING( 0x7a00, "Denmark" ) PORT_DIPSETTING( 0x7900, "Sweden" ) PORT_DIPSETTING( 0x7800, DEF_STR(Japan) ) PORT_DIPSETTING( 0x7700, "West Germany" ) PORT_DIPSETTING( 0x7600, "Netherlands" ) PORT_DIPSETTING( 0x7500, "Spain" ) PORT_DIPSETTING( 0x7400, "Italy" ) PORT_DIPSETTING( 0x7300, "Latin America" ) PORT_DIPSETTING( 0x7200, "South Africa" ) PORT_DIPSETTING( 0x7100, "Switzerland" ) PORT_DIPSETTING( 0x7000, "ASCII" ) PORT_START("LINE0") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_N) PORT_CHAR('n') PORT_CHAR('N') PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_M) PORT_CHAR('m') PORT_CHAR('M') PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_K) PORT_CHAR('k') PORT_CHAR('K') PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_J) PORT_CHAR('j') PORT_CHAR('J') PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_Y) PORT_CHAR('y') PORT_CHAR('Y') PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_T) PORT_CHAR('t') PORT_CHAR('T') PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CHAR('\xa2') PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CHAR('%') PORT_START("LINE1") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_B) PORT_CHAR('n') PORT_CHAR('B') PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_COMMA) PORT_CHAR(',') PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_L) PORT_CHAR('l') PORT_CHAR('L') PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_H) PORT_CHAR('h') PORT_CHAR('H') PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_U) PORT_CHAR('u') PORT_CHAR('U') PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_R) PORT_CHAR('r') PORT_CHAR('R') PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CHAR('&') PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CHAR('$') PORT_START("LINE2") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_V) PORT_CHAR('v') PORT_CHAR('V') PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_COLON) PORT_CHAR(';') PORT_CHAR(':') PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_G) PORT_CHAR('g') PORT_CHAR('G') PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_I) PORT_CHAR('i') PORT_CHAR('I') PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_UNUSED) PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CHAR('*') PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CHAR('#') PORT_START("LINE3") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_C) PORT_CHAR('c') PORT_CHAR('C') PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Left USE FRONT") PORT_CODE(KEYCODE_LCONTROL) PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_QUOTE) PORT_CHAR('\'') PORT_CHAR('"') PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_F) PORT_CHAR('f') PORT_CHAR('F') PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_O) PORT_CHAR('o') PORT_CHAR('O') PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_E) PORT_CHAR('e') PORT_CHAR('E') PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_9) PORT_CHAR('9') PORT_CHAR('(') PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_UNUSED) PORT_START("LINE4") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_X) PORT_CHAR('x') PORT_CHAR('X') PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Right USE FRONT") PORT_CODE(KEYCODE_RCONTROL) PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Right Shift") PORT_CODE(KEYCODE_F12) PORT_CHAR(UCHAR_SHIFT_1) PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_D) PORT_CHAR('d') PORT_CHAR('D') PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_P) PORT_CHAR('p') PORT_CHAR('P') PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_W) PORT_CHAR('w') PORT_CHAR('W') PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_0) PORT_CHAR('0') PORT_CHAR(')') PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CHAR('@') PORT_START("LINE5") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_Z) PORT_CHAR('z') PORT_CHAR('Z') PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ') PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Return") PORT_CODE(KEYCODE_ENTER) PORT_CHAR(13) PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_S) PORT_CHAR('s') PORT_CHAR('S') PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_OPENBRACE) PORT_CHAR('\xbd') PORT_CHAR('\xbc') PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_Q) PORT_CHAR('q') PORT_CHAR('Q') PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') PORT_CHAR('_') PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CHAR('!') PORT_START("LINE6") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Left Shift") PORT_CODE(KEYCODE_F1) PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Left LEAP") PORT_CODE(KEYCODE_LALT) PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_SLASH) PORT_CHAR('/') PORT_CHAR('?') PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_A) PORT_CHAR('a') PORT_CHAR('A') PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_CLOSEBRACE) PORT_CHAR(']') PORT_CHAR('[') PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_TAB) PORT_CHAR('\t') PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_EQUALS) PORT_CHAR('=') PORT_CHAR('+') PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_UNUSED) PORT_START("LINE7") PORT_BIT(0x01, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Shift") PORT_CODE(KEYCODE_RSHIFT) PORT_CODE(KEYCODE_LSHIFT) PORT_BIT(0x02, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Right Leap") PORT_CODE(KEYCODE_RALT) PORT_BIT(0x04, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Page") PORT_CODE(KEYCODE_PGUP) PORT_CODE(KEYCODE_PGDN) PORT_BIT(0x08, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Shift Lock") PORT_CODE(KEYCODE_CAPSLOCK) PORT_BIT(0x10, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("Backspace") PORT_CODE(KEYCODE_BACKSPACE) PORT_BIT(0x20, IP_ACTIVE_LOW, IPT_UNUSED) PORT_BIT(0x40, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_NAME("UNDO") PORT_CODE(KEYCODE_BACKSLASH) PORT_BIT(0x80, IP_ACTIVE_LOW, IPT_KEYBOARD) PORT_CODE(KEYCODE_TILDE) PORT_CHAR('\xb1') PORT_CHAR('\xb0') INPUT_PORTS_END static INPUT_PORTS_START( swyft ) INPUT_PORTS_END static TIMER_CALLBACK(keyboard_callback) { machine.device("maincpu")->execute().set_input_line(M68K_IRQ_1, ASSERT_LINE); } static IRQ_CALLBACK(cat_int_ack) { device->machine().device("maincpu")->execute().set_input_line(M68K_IRQ_1,CLEAR_LINE); return M68K_INT_ACK_AUTOVECTOR; } MACHINE_START_MEMBER(cat_state,cat) { m_duart_inp = 0x0e; m_keyboard_timer = machine().scheduler().timer_alloc(FUNC(keyboard_callback)); machine().device("nvram")->set_base(m_p_sram, 0x4000); } MACHINE_RESET_MEMBER(cat_state,cat) { machine().device("maincpu")->execute().set_irq_acknowledge_callback(cat_int_ack); m_keyboard_timer->adjust(attotime::zero, 0, attotime::from_hz(120)); } VIDEO_START_MEMBER(cat_state,cat) { } UINT32 cat_state::screen_update_cat(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) { UINT16 code; int y, x, b; int addr = 0; if (m_video_enable == 1) { for (y = 0; y < 344; y++) { int horpos = 0; for (x = 0; x < 42; x++) { code = m_p_videoram[addr++]; for (b = 15; b >= 0; b--) { bitmap.pix16(y, horpos++) = (code >> b) & 0x01; } } } } else { const rectangle black_area(0, 672 - 1, 0, 344 - 1); bitmap.fill(0, black_area); } return 0; } static TIMER_CALLBACK( swyft_reset ) { memset(machine.device("maincpu")->memory().space(AS_PROGRAM)->get_read_ptr(0xe2341), 0xff, 1); } MACHINE_START_MEMBER(cat_state,swyft) { } MACHINE_RESET_MEMBER(cat_state,swyft) { machine().scheduler().timer_set(attotime::from_usec(10), FUNC(swyft_reset)); } VIDEO_START_MEMBER(cat_state,swyft) { } UINT32 cat_state::screen_update_swyft(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) { UINT16 code; int y, x, b; int addr = 0; for (y = 0; y < 242; y++) { int horpos = 0; for (x = 0; x < 20; x++) { code = m_p_videoram[addr++]; for (b = 15; b >= 0; b--) { bitmap.pix16(y, horpos++) = (code >> b) & 0x01; } } } return 0; } static void duart_irq_handler(device_t *device, int state, UINT8 vector) { //logerror("duart_irq_handler\n"); } static void duart_tx(device_t *device, int channel, UINT8 data) { } static UINT8 duart_input(device_t *device) { cat_state *state = device->machine().driver_data(); if (state->m_duart_inp != 0) { state->m_duart_inp = 0; return 0x0e; } else { state->m_duart_inp = 0x0e; return 0x00; } } static const duart68681_config cat_duart68681_config = { duart_irq_handler, duart_tx, duart_input, NULL }; static MACHINE_CONFIG_START( cat, cat_state ) /* basic machine hardware */ MCFG_CPU_ADD("maincpu",M68000, XTAL_5MHz) MCFG_CPU_PROGRAM_MAP(cat_mem) MCFG_MACHINE_START_OVERRIDE(cat_state,cat) MCFG_MACHINE_RESET_OVERRIDE(cat_state,cat) /* video hardware */ MCFG_SCREEN_ADD("screen", RASTER) MCFG_SCREEN_REFRESH_RATE(50) MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500)) /* not accurate */ MCFG_SCREEN_SIZE(672, 344) MCFG_SCREEN_VISIBLE_AREA(0, 672-1, 0, 344-1) MCFG_SCREEN_UPDATE_DRIVER(cat_state, screen_update_cat) MCFG_PALETTE_LENGTH(2) MCFG_PALETTE_INIT(black_and_white) MCFG_VIDEO_START_OVERRIDE(cat_state,cat) MCFG_DUART68681_ADD( "duart68681", XTAL_5MHz, cat_duart68681_config ) MCFG_NVRAM_ADD_0FILL("nvram") MACHINE_CONFIG_END static MACHINE_CONFIG_START( swyft, cat_state ) /* basic machine hardware */ MCFG_CPU_ADD("maincpu",M68000, XTAL_5MHz) MCFG_CPU_PROGRAM_MAP(swyft_mem) MCFG_MACHINE_START_OVERRIDE(cat_state,swyft) MCFG_MACHINE_RESET_OVERRIDE(cat_state,swyft) /* video hardware */ MCFG_SCREEN_ADD("screen", RASTER) MCFG_SCREEN_REFRESH_RATE(50) MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500)) /* not accurate */ MCFG_SCREEN_SIZE(320, 242) MCFG_SCREEN_VISIBLE_AREA(0, 320-1, 0, 242-1) MCFG_SCREEN_UPDATE_DRIVER(cat_state, screen_update_swyft) MCFG_PALETTE_LENGTH(2) MCFG_PALETTE_INIT(black_and_white) MCFG_VIDEO_START_OVERRIDE(cat_state,swyft) MACHINE_CONFIG_END /* ROM definition */ ROM_START( swyft ) ROM_REGION( 0x10000, "maincpu", ROMREGION_ERASEFF ) ROM_LOAD( "infoapp.lo", 0x0000, 0x8000, CRC(52c1bd66) SHA1(b3266d72970f9d64d94d405965b694f5dcb23bca) ) ROM_LOAD( "infoapp.hi", 0x8000, 0x8000, CRC(83505015) SHA1(693c914819dd171114a8c408f399b56b470f6be0) ) ROM_END ROM_START( cat ) ROM_REGION( 0x40000, "maincpu", ROMREGION_ERASEFF ) // SYS ROM ROM_LOAD16_BYTE( "r240l0.bin", 0x00001, 0x10000, CRC(1b89bdc4) SHA1(39c639587dc30f9d6636b46d0465f06272838432) ) ROM_LOAD16_BYTE( "r240h0.bin", 0x00000, 0x10000, CRC(94f89b8c) SHA1(6c336bc30636a02c625d31f3057ec86bf4d155fc) ) ROM_LOAD16_BYTE( "r240l1.bin", 0x20001, 0x10000, CRC(1a73be4f) SHA1(e2de2cb485f78963368fb8ceba8fb66ca56dba34) ) ROM_LOAD16_BYTE( "r240h1.bin", 0x20000, 0x10000, CRC(898dd9f6) SHA1(93e791dd4ed7e4afa47a04df6fdde359e41c2075) ) ROM_REGION( 0x80000, "svrom", ROMREGION_ERASEFF ) ROM_END /* Driver */ /* YEAR NAME PARENT COMPAT MACHINE INPUT INIT COMPANY FULLNAME FLAGS */ COMP( 1985, swyft,0, 0, swyft, swyft, driver_device, 0, "Information Applicance Inc", "Swyft", GAME_NOT_WORKING | GAME_NO_SOUND) COMP( 1987, cat, swyft, 0, cat, cat, driver_device, 0, "Canon", "Cat", GAME_NOT_WORKING | GAME_NO_SOUND)