trunk/src/mess/drivers/mbee.c
| r243505 | r243506 | |
| 30 | 30 | - Although certain models came with particular drives as standard, users could add |
| 31 | 31 | the other size if they wished. We support both sizes on any model. |
| 32 | 32 | |
| 33 | | Microbee Standard / Plus memory map |
| 34 | | |
| 35 | | 0000-7FFF RAM |
| 36 | | 8000-BFFF SYSTEM roms |
| 37 | | C000-DFFF Edasm or WBee (edasm.rom or wbeee12.rom, optional) |
| 38 | | E000-EFFF Telcom 1.2 (netrom.ic34; optional) |
| 39 | | F000-F7FF Video RAM |
| 40 | | F800-FFFF PCG RAM (graphics) |
| 41 | | |
| 42 | | Microbee IC memory map (preliminary) |
| 43 | | |
| 44 | | 0000-7FFF RAM |
| 45 | | 8000-BFFF SYSTEM roms (bas522a.rom, bas522b.rom) |
| 46 | | C000-DFFF Edasm or WBee (edasm.rom or wbeee12.rom, optional) |
| 47 | | E000-EFFF Telcom (optional) |
| 48 | | F000-F7FF Video RAM |
| 49 | | F800-FFFF PCG RAM (graphics), Colour RAM (banked) |
| 50 | | |
| 51 | | Microbee 56KB ROM memory map (preliminary) |
| 52 | | |
| 53 | | 0000-DFFF RAM |
| 54 | | E000-EFFF ROM 56kb.rom CP/M bootstrap loader |
| 55 | | F000-F7FF Video RAM |
| 56 | | F800-FFFF PCG RAM (graphics), Colour RAM (banked) |
| 57 | | |
| 58 | 33 | Early machines have 'standard' video (128 hires characters). |
| 59 | 34 | Later machines had the option of 'premium' video which |
| 60 | 35 | provides thousands of hires characters, enough to simulate |
| r243505 | r243506 | |
| 65 | 40 | This rom can be replaced with the Dreamdisk Chip-8 rom. |
| 66 | 41 | Note that Telcom 3.21 is 8k, it uses a rombank switch |
| 67 | 42 | (by reading port 0A) to swap between the two halves. |
| 68 | | See Telcom notes below. |
| 43 | See Telcom notes below. |
| 69 | 44 | |
| 70 | 45 | EDASM - Jump to C000, usually the Editor/Assembler package. |
| 71 | 46 | |
| r243505 | r243506 | |
| 75 | 50 | |
| 76 | 51 | These early colour computers have a PROM to create the foreground palette. |
| 77 | 52 | |
| 78 | | |
| 79 | 53 | Notes about the printer: |
| 80 | 54 | - When computer turned on, defaults to 1200 baud serial printer |
| 81 | 55 | - Change it to parallel by entering OUTL#1 |
| r243505 | r243506 | |
| 96 | 70 | - Telcom 1.2 (used in mbeeic) has a bug. If you enter NET CLOCK, the status line is |
| 97 | 71 | filled with inverse K. You can fix this from Basic by doing NET CLOCK 3 times. |
| 98 | 72 | |
| 73 | Notes about Disk System |
| 74 | - Ports 44 to 47 are for standard connection to FD2793. |
| 75 | - Port 48 is used for drive/side/density select on write, and intrq/drq on read. |
| 76 | intrq and drq are OR'd together, then gated to bit 7 of the data bus whenever |
| 77 | port 48 is activated on read. There are no interrupts used. |
| 78 | |
| 79 | Tests of old keyboard. Start mbeeic. |
| 80 | 1. Load ASTEROIDS PLUS, stay in attract mode, hold down spacebar, |
| 81 | it should only fire bullets. If it sometimes starts turning, |
| 82 | thrusting or using the shield, then there is a problem. |
| 83 | |
| 84 | 2. Load SCAVENGER and make sure it doesn't go to the next level |
| 85 | until you find the Exit. |
| 86 | |
| 87 | 3. At the Basic prompt, type in EDASM press enter. At the memory size |
| 88 | prompt press enter. Now, make sure the keyboard works properly. |
| 89 | |
| 99 | 90 | *************************************************************************** |
| 100 | 91 | |
| 101 | 92 | TODO/not working: |
| 102 | 93 | |
| 103 | 94 | - Printer needs to be understood and fixed. |
| 104 | | - Keyboard loses characters if you type at a normal rate. |
| 105 | | - Fix Paste (it loses most of the characters) |
| 106 | 95 | |
| 96 | - 256tc: Paste ignores shift key |
| 97 | - All others: Paste drops most characters, shift operates randomly. |
| 98 | |
| 107 | 99 | - various fdc issues: |
| 108 | 100 | - B drive doesn't work. |
| 109 | 101 | - some disks cause MESS to freeze. |
| 110 | 102 | - ENMF pin missing from wd_fdc. |
| 111 | 103 | - incorrect timing for track register causes 256tc failure to boot a disk. |
| 112 | | - 56k model takes about 2 minutes to boot a disk if loaded via command line. |
| 113 | | |
| 104 | - 56k model takes 120 seconds to boot a disk if loaded via command line. |
| 105 | |
| 106 | - mbeeppc, mbee128p: In Basic, keyboard loses characters. Works fine in Wordbee. |
| 107 | |
| 114 | 108 | - 256tc: At the menu, if F2 pressed to activate the Monitor, the emulated machine |
| 115 | 109 | crashes due to a bug in z80pio emulation. |
| 116 | | |
| 110 | |
| 117 | 111 | - 256tc: Keyboard ROM U60 needs to be dumped. |
| 118 | 112 | - 128k: GOLD PAL needs to be dumped for the bankswitching. |
| 119 | 113 | - 64k: RED PAL needs to be dumped for the bankswitching. |
| r243505 | r243506 | |
| 125 | 119 | |
| 126 | 120 | - Mouse: a few programs support the use of a serial mouse which interfaced |
| 127 | 121 | directly to the Z80PIO. However there's little info to be found. |
| 122 | PIO B3 to ground activates the mouse pointer in Shell v3.01. |
| 128 | 123 | |
| 129 | | *************************************************************************** |
| 124 | *******************************************************************************/ |
| 130 | 125 | |
| 131 | | Description of Disk System |
| 132 | | |
| 133 | | - Ports 44 to 47 are for standard connection to FD2793. |
| 134 | | - Port 48 is used for drive/side/density select on write, |
| 135 | | and intrq/drq on read. |
| 136 | | intrq and drq are OR'd together, then gated to bit 7 of the |
| 137 | | data bus whenever port 48 is activated on read. There are |
| 138 | | no interrupts used. |
| 139 | | |
| 140 | | ****************************************************************************/ |
| 141 | | |
| 142 | | |
| 143 | 126 | #include "includes/mbee.h" |
| 144 | 127 | #include "formats/mbee_cas.h" |
| 145 | 128 | |
| 146 | | |
| 147 | 129 | #define XTAL_13_5MHz 13500000 |
| 148 | 130 | |
| 149 | 131 | /********** NOTE !!! *********************************************************** |
| r243505 | r243506 | |
| 156 | 138 | ADDRESS_MAP_UNMAP_HIGH |
| 157 | 139 | AM_RANGE(0x0000, 0x0fff) AM_RAMBANK("boot") |
| 158 | 140 | AM_RANGE(0x1000, 0x3fff) AM_RAM |
| 159 | | AM_RANGE(0x4000, 0x7fff) AM_WRITENOP /* Needed because quickload to here will crash MESS otherwise */ |
| 141 | AM_RANGE(0x4000, 0x7fff) AM_WRITENOP // Needed because quickload to here will crash MESS |
| 160 | 142 | AM_RANGE(0x8000, 0xefff) AM_ROM |
| 161 | 143 | AM_RANGE(0xf000, 0xf7ff) AM_READWRITE(mbee_low_r, mbee_low_w) |
| 162 | 144 | AM_RANGE(0xf800, 0xffff) AM_READWRITE(mbee_high_r, mbee_high_w) |
| r243505 | r243506 | |
| 312 | 294 | ADDRESS_MAP_GLOBAL_MASK(0xff) |
| 313 | 295 | ADDRESS_MAP_UNMAP_HIGH |
| 314 | 296 | AM_RANGE(0x00, 0x03) AM_DEVREADWRITE("z80pio", z80pio_device, read_alt, write_alt) |
| 297 | AM_RANGE(0x04, 0x04) AM_WRITE(mbee_04_w) |
| 298 | AM_RANGE(0x06, 0x06) AM_WRITE(mbee_06_w) |
| 299 | AM_RANGE(0x07, 0x07) AM_READ(mbee_07_r) |
| 315 | 300 | AM_RANGE(0x08, 0x08) AM_READWRITE(mbeeic_08_r, mbeeic_08_w) |
| 316 | 301 | AM_RANGE(0x0b, 0x0b) AM_READWRITE(mbee_0b_r, mbee_0b_w) |
| 317 | 302 | AM_RANGE(0x0c, 0x0c) AM_READWRITE(m6545_status_r, m6545_index_w) |
| r243505 | r243506 | |
| 363 | 348 | ADDRESS_MAP_END |
| 364 | 349 | |
| 365 | 350 | static INPUT_PORTS_START( mbee ) |
| 366 | | PORT_START("X0") /* IN0 KEY ROW 0 [000] */ |
| 351 | PORT_START("X.0") /* IN0 KEY ROW 0 [000] */ |
| 367 | 352 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("@") PORT_CODE(KEYCODE_ASTERISK) PORT_CHAR('@') PORT_CHAR('`') |
| 368 | 353 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("A") PORT_CODE(KEYCODE_A) PORT_CHAR('a') PORT_CHAR('A') PORT_CHAR(0x01) |
| 369 | 354 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("B") PORT_CODE(KEYCODE_B) PORT_CHAR('b') PORT_CHAR('B') PORT_CHAR(0x02) |
| r243505 | r243506 | |
| 373 | 358 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F") PORT_CODE(KEYCODE_F) PORT_CHAR('f') PORT_CHAR('F') PORT_CHAR(0x06) |
| 374 | 359 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("G") PORT_CODE(KEYCODE_G) PORT_CHAR('g') PORT_CHAR('G') PORT_CHAR(0x07) |
| 375 | 360 | |
| 376 | | PORT_START("X1") /* IN1 KEY ROW 1 [080] */ |
| 361 | PORT_START("X.1") /* IN1 KEY ROW 1 [080] */ |
| 377 | 362 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("H") PORT_CODE(KEYCODE_H) PORT_CHAR('h') PORT_CHAR('H') PORT_CHAR(0x08) |
| 378 | 363 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("I") PORT_CODE(KEYCODE_I) PORT_CHAR('i') PORT_CHAR('I') PORT_CHAR(0x09) |
| 379 | 364 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("J") PORT_CODE(KEYCODE_J) PORT_CHAR('j') PORT_CHAR('J') PORT_CHAR(0x0a) |
| r243505 | r243506 | |
| 383 | 368 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("N") PORT_CODE(KEYCODE_N) PORT_CHAR('n') PORT_CHAR('N') PORT_CHAR(0x0e) |
| 384 | 369 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("O") PORT_CODE(KEYCODE_O) PORT_CHAR('o') PORT_CHAR('O') PORT_CHAR(0x0f) |
| 385 | 370 | |
| 386 | | PORT_START("X2") /* IN2 KEY ROW 2 [100] */ |
| 371 | PORT_START("X.2") /* IN2 KEY ROW 2 [100] */ |
| 387 | 372 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("P") PORT_CODE(KEYCODE_P) PORT_CHAR('p') PORT_CHAR('P') PORT_CHAR(0x10) |
| 388 | 373 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Q") PORT_CODE(KEYCODE_Q) PORT_CHAR('q') PORT_CHAR('Q') PORT_CHAR(0x11) |
| 389 | 374 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("R") PORT_CODE(KEYCODE_R) PORT_CHAR('r') PORT_CHAR('R') PORT_CHAR(0x12) |
| r243505 | r243506 | |
| 393 | 378 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("V") PORT_CODE(KEYCODE_V) PORT_CHAR('v') PORT_CHAR('V') PORT_CHAR(0x16) |
| 394 | 379 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("W") PORT_CODE(KEYCODE_W) PORT_CHAR('w') PORT_CHAR('W') PORT_CHAR(0x17) |
| 395 | 380 | |
| 396 | | PORT_START("X3") /* IN3 KEY ROW 3 [180] */ |
| 381 | PORT_START("X.3") /* IN3 KEY ROW 3 [180] */ |
| 397 | 382 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("X") PORT_CODE(KEYCODE_X) PORT_CHAR('x') PORT_CHAR('X') PORT_CHAR(0x18) |
| 398 | 383 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Y") PORT_CODE(KEYCODE_Y) PORT_CHAR('u') PORT_CHAR('Y') PORT_CHAR(0x19) |
| 399 | 384 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Z") PORT_CODE(KEYCODE_Z) PORT_CHAR('z') PORT_CHAR('Z') PORT_CHAR(0x1a) |
| r243505 | r243506 | |
| 403 | 388 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("^") PORT_CODE(KEYCODE_TILDE) PORT_CHAR('^') PORT_CHAR('~') PORT_CHAR(0x1e) |
| 404 | 389 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Delete") PORT_CODE(KEYCODE_DEL) PORT_CHAR(8) PORT_CHAR(0x5f) PORT_CHAR(0x1f) // port_char not working - hijacked |
| 405 | 390 | |
| 406 | | PORT_START("X4") /* IN4 KEY ROW 4 [200] */ |
| 391 | PORT_START("X.4") /* IN4 KEY ROW 4 [200] */ |
| 407 | 392 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("0") PORT_CODE(KEYCODE_0) PORT_CHAR('0') |
| 408 | 393 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("1 !") PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CHAR('!') |
| 409 | 394 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("2 \"") PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CHAR('\"') |
| r243505 | r243506 | |
| 413 | 398 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("6 &") PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CHAR('&') |
| 414 | 399 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("7 '") PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CHAR('\'') |
| 415 | 400 | |
| 416 | | PORT_START("X5") /* IN5 KEY ROW 5 [280] */ |
| 401 | PORT_START("X.5") /* IN5 KEY ROW 5 [280] */ |
| 417 | 402 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("8 (") PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CHAR('(') |
| 418 | 403 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("9 )") PORT_CODE(KEYCODE_9) PORT_CHAR('9') PORT_CHAR(')') |
| 419 | 404 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("; +") PORT_CODE(KEYCODE_COLON) PORT_CHAR(';') PORT_CHAR('+') |
| r243505 | r243506 | |
| 423 | 408 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME(". >") PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') PORT_CHAR('>') |
| 424 | 409 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("/ ?") PORT_CODE(KEYCODE_SLASH) PORT_CHAR('/') PORT_CHAR('?') |
| 425 | 410 | |
| 426 | | PORT_START("X6") /* IN6 KEY ROW 6 [300] */ |
| 411 | PORT_START("X.6") /* IN6 KEY ROW 6 [300] */ |
| 427 | 412 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Escape") PORT_CODE(KEYCODE_ESC) PORT_CHAR(27) |
| 428 | 413 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Backspace") PORT_CODE(KEYCODE_BACKSPACE) PORT_CHAR(8) |
| 429 | 414 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Tab") PORT_CODE(KEYCODE_TAB) PORT_CHAR(9) |
| r243505 | r243506 | |
| 433 | 418 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Break") PORT_CODE(KEYCODE_END) PORT_CHAR(3) |
| 434 | 419 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Space") PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ') |
| 435 | 420 | |
| 436 | | PORT_START("X7") /* IN7 KEY ROW 7 [380] */ |
| 421 | PORT_START("X.7") /* IN7 KEY ROW 7 [380] */ |
| 437 | 422 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("(Up)") PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP)) |
| 438 | 423 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Ctrl") PORT_CODE(KEYCODE_LCONTROL) |
| 439 | 424 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("(Down)") PORT_CODE(KEYCODE_DOWN) PORT_CHAR(UCHAR_MAMEKEY(DOWN)) |
| r243505 | r243506 | |
| 465 | 450 | INPUT_PORTS_END |
| 466 | 451 | |
| 467 | 452 | static INPUT_PORTS_START( mbee256 ) |
| 468 | | PORT_START("X0") /* IN0 KEY ROW 0 [+00] */ |
| 453 | PORT_START("Y.0") /* IN0 KEY ROW 0 [+00] */ |
| 469 | 454 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F1") PORT_CODE(KEYCODE_F1) |
| 470 | 455 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Escape") PORT_CODE(KEYCODE_ESC) PORT_CHAR(27) |
| 471 | 456 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Tab") PORT_CODE(KEYCODE_TAB) PORT_CHAR(9) |
| r243505 | r243506 | |
| 474 | 459 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("DEL (num)") PORT_CODE(KEYCODE_DEL_PAD) |
| 475 | 460 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Space") PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ') |
| 476 | 461 | |
| 477 | | PORT_START("X1") /* IN1 KEY ROW 1 [+08] */ |
| 462 | PORT_START("Y.1") /* IN1 KEY ROW 1 [+08] */ |
| 478 | 463 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F2") PORT_CODE(KEYCODE_F2) |
| 479 | 464 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("1 !") PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CHAR('!') |
| 480 | 465 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Q") PORT_CODE(KEYCODE_Q) PORT_CHAR('q') PORT_CHAR('Q') PORT_CHAR(0x11) |
| r243505 | r243506 | |
| 483 | 468 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Linefeed") PORT_CODE(KEYCODE_HOME) PORT_CHAR(10) |
| 484 | 469 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Insert") PORT_CODE(KEYCODE_INSERT) |
| 485 | 470 | |
| 486 | | PORT_START("X2") /* IN2 KEY ROW 2 [+10] */ |
| 471 | PORT_START("Y.2") /* IN2 KEY ROW 2 [+10] */ |
| 487 | 472 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F3") PORT_CODE(KEYCODE_F3) |
| 488 | 473 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("2 @") PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CHAR('@') |
| 489 | 474 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("W") PORT_CODE(KEYCODE_W) PORT_CHAR('w') PORT_CHAR('W') PORT_CHAR(0x17) |
| r243505 | r243506 | |
| 493 | 478 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("3 (num)") PORT_CODE(KEYCODE_3_PAD) |
| 494 | 479 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Z") PORT_CODE(KEYCODE_Z) PORT_CHAR('z') PORT_CHAR('Z') PORT_CHAR(0x1a) |
| 495 | 480 | |
| 496 | | PORT_START("X3") /* IN3 KEY ROW 3 [+18] */ |
| 481 | PORT_START("Y.3") /* IN3 KEY ROW 3 [+18] */ |
| 497 | 482 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F4") PORT_CODE(KEYCODE_F4) |
| 498 | 483 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("3 #") PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CHAR('#') |
| 499 | 484 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("E") PORT_CODE(KEYCODE_E) PORT_CHAR('e') PORT_CHAR('E') PORT_CHAR(0x05) |
| r243505 | r243506 | |
| 503 | 488 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("6 (num)") PORT_CODE(KEYCODE_6_PAD) |
| 504 | 489 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("X") PORT_CODE(KEYCODE_X) PORT_CHAR('x') PORT_CHAR('X') PORT_CHAR(0x18) |
| 505 | 490 | |
| 506 | | PORT_START("X4") /* IN4 KEY ROW 4 [+20] */ |
| 491 | PORT_START("Y.4") /* IN4 KEY ROW 4 [+20] */ |
| 507 | 492 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F5") PORT_CODE(KEYCODE_F5) |
| 508 | 493 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("4 $") PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CHAR('$') |
| 509 | 494 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("R") PORT_CODE(KEYCODE_R) PORT_CHAR('r') PORT_CHAR('R') PORT_CHAR(0x12) |
| r243505 | r243506 | |
| 513 | 498 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("9 (num)") PORT_CODE(KEYCODE_9_PAD) |
| 514 | 499 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("C") PORT_CODE(KEYCODE_C) PORT_CHAR('c') PORT_CHAR('C') PORT_CHAR(0x03) |
| 515 | 500 | |
| 516 | | PORT_START("X5") /* IN5 KEY ROW 5 [+28] */ |
| 501 | PORT_START("Y.5") /* IN5 KEY ROW 5 [+28] */ |
| 517 | 502 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F6") PORT_CODE(KEYCODE_F6) |
| 518 | 503 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("5 %") PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CHAR('%') |
| 519 | 504 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("T") PORT_CODE(KEYCODE_T) PORT_CHAR('t') PORT_CHAR('T') PORT_CHAR(0x14) |
| r243505 | r243506 | |
| 523 | 508 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("4 (num)") PORT_CODE(KEYCODE_4_PAD) |
| 524 | 509 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("V") PORT_CODE(KEYCODE_V) PORT_CHAR('v') PORT_CHAR('V') PORT_CHAR(0x16) |
| 525 | 510 | |
| 526 | | PORT_START("X6") /* IN6 KEY ROW 6 [+30] */ |
| 511 | PORT_START("Y.6") /* IN6 KEY ROW 6 [+30] */ |
| 527 | 512 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F7") PORT_CODE(KEYCODE_F7) |
| 528 | 513 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("6 &") PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CHAR('&') |
| 529 | 514 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Y") PORT_CODE(KEYCODE_Y) PORT_CHAR('y') PORT_CHAR('Y') PORT_CHAR(0x19) |
| r243505 | r243506 | |
| 533 | 518 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("(Right)") PORT_CODE(KEYCODE_RIGHT) PORT_CHAR(UCHAR_MAMEKEY(RIGHT)) |
| 534 | 519 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("B") PORT_CODE(KEYCODE_B) PORT_CHAR('b') PORT_CHAR('B') PORT_CHAR(0x02) |
| 535 | 520 | |
| 536 | | PORT_START("X7") /* IN7 KEY ROW 7 [+38] */ |
| 521 | PORT_START("Y.7") /* IN7 KEY ROW 7 [+38] */ |
| 537 | 522 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F8") PORT_CODE(KEYCODE_F8) |
| 538 | 523 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("7 &") PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CHAR('&') |
| 539 | 524 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("U") PORT_CODE(KEYCODE_U) PORT_CHAR('u') PORT_CHAR('U') PORT_CHAR(0x15) |
| r243505 | r243506 | |
| 541 | 526 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("(Left)") PORT_CODE(KEYCODE_LEFT) PORT_CHAR(UCHAR_MAMEKEY(LEFT)) |
| 542 | 527 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("N") PORT_CODE(KEYCODE_N) PORT_CHAR('n') PORT_CHAR('N') PORT_CHAR(0x0e) |
| 543 | 528 | |
| 544 | | PORT_START("X8") /* IN0 KEY ROW 0 [+40] */ |
| 529 | PORT_START("Y.8") /* IN0 KEY ROW 0 [+40] */ |
| 545 | 530 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F9") PORT_CODE(KEYCODE_F9) |
| 546 | 531 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("8 *") PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CHAR('*') |
| 547 | 532 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("I") PORT_CODE(KEYCODE_I) PORT_CHAR('i') PORT_CHAR('I') PORT_CHAR(0x09) |
| r243505 | r243506 | |
| 549 | 534 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("(Up)") PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP)) |
| 550 | 535 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("M") PORT_CODE(KEYCODE_M) PORT_CHAR('m') PORT_CHAR('M') PORT_CHAR(0x0d) |
| 551 | 536 | |
| 552 | | PORT_START("X9") /* IN1 KEY ROW 1 [+48] */ |
| 537 | PORT_START("Y.9") /* IN1 KEY ROW 1 [+48] */ |
| 553 | 538 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F10") PORT_CODE(KEYCODE_F10) |
| 554 | 539 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("9 (") PORT_CODE(KEYCODE_9) PORT_CHAR('9') PORT_CHAR('(') |
| 555 | 540 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("O") PORT_CODE(KEYCODE_O) PORT_CHAR('o') PORT_CHAR('O') PORT_CHAR(0x0f) |
| r243505 | r243506 | |
| 558 | 543 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Enter") PORT_CODE(KEYCODE_ENTER) PORT_CODE(KEYCODE_ENTER_PAD) PORT_CHAR(13) |
| 559 | 544 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME(", <") PORT_CODE(KEYCODE_COMMA) PORT_CHAR(',') PORT_CHAR('<') |
| 560 | 545 | |
| 561 | | PORT_START("X10") /* IN2 KEY ROW 2 [+50] */ |
| 546 | PORT_START("Y.10") /* IN2 KEY ROW 2 [+50] */ |
| 562 | 547 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F11") PORT_CODE(KEYCODE_F11) |
| 563 | 548 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("0 )") PORT_CODE(KEYCODE_0) PORT_CHAR('0') PORT_CHAR(')') |
| 564 | 549 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("P") PORT_CODE(KEYCODE_P) PORT_CHAR('p') PORT_CHAR('P') PORT_CHAR(0x10) |
| r243505 | r243506 | |
| 568 | 553 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("\\ |") PORT_CODE(KEYCODE_BACKSLASH) PORT_CHAR('\\') PORT_CHAR('|') PORT_CHAR(0x1c) |
| 569 | 554 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME(". >") PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') PORT_CHAR('>') |
| 570 | 555 | |
| 571 | | PORT_START("X11") /* IN3 KEY ROW 3 [+58] */ |
| 556 | PORT_START("Y.11") /* IN3 KEY ROW 3 [+58] */ |
| 572 | 557 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("F12") PORT_CODE(KEYCODE_F12) |
| 573 | 558 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("-") PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') PORT_CHAR('_') |
| 574 | 559 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("[ {") PORT_CODE(KEYCODE_OPENBRACE) PORT_CHAR('[') PORT_CHAR('{') PORT_CHAR(0x1b) |
| r243505 | r243506 | |
| 577 | 562 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("] }") PORT_CODE(KEYCODE_CLOSEBRACE) PORT_CHAR(']') PORT_CHAR('}') PORT_CHAR(0x1d) |
| 578 | 563 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("/ ?") PORT_CODE(KEYCODE_SLASH) PORT_CHAR('/') PORT_CHAR('?') |
| 579 | 564 | |
| 580 | | PORT_START("X12") /* IN4 KEY ROW 4 [+60] */ |
| 565 | PORT_START("Y.12") /* IN4 KEY ROW 4 [+60] */ |
| 581 | 566 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Shift") PORT_CODE(KEYCODE_LSHIFT) PORT_CODE(KEYCODE_RSHIFT) PORT_CHAR(UCHAR_SHIFT_1) |
| 582 | 567 | |
| 583 | | PORT_START("X13") /* IN5 KEY ROW 5 [+68] */ |
| 568 | PORT_START("Y.13") /* IN5 KEY ROW 5 [+68] */ |
| 584 | 569 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Ctrl") PORT_CODE(KEYCODE_LCONTROL) PORT_CODE(KEYCODE_RCONTROL) PORT_CHAR(UCHAR_SHIFT_2) |
| 585 | 570 | |
| 586 | | PORT_START("X14") /* IN6 KEY ROW 6 [+70] */ |
| 571 | PORT_START("Y.14") /* IN6 KEY ROW 6 [+70] */ |
| 587 | 572 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Alt") PORT_CODE(KEYCODE_LALT) PORT_CODE(KEYCODE_RALT) |
| 588 | 573 | |
| 589 | 574 | // Autorun on quickload |
| r243505 | r243506 | |
| 619 | 604 | 8*16 /* every char takes 16 bytes */ |
| 620 | 605 | }; |
| 621 | 606 | |
| 622 | | static GFXDECODE_START( mbee ) |
| 607 | static GFXDECODE_START( mono ) |
| 623 | 608 | GFXDECODE_ENTRY( "gfx", 0x0000, mbee_charlayout, 0, 1 ) |
| 624 | 609 | GFXDECODE_END |
| 625 | 610 | |
| 626 | | static GFXDECODE_START( mbeeic ) |
| 611 | static GFXDECODE_START( standard ) |
| 627 | 612 | GFXDECODE_ENTRY( "gfx", 0x0000, mbee_charlayout, 0, 48 ) |
| 628 | 613 | GFXDECODE_END |
| 629 | 614 | |
| 630 | | static GFXDECODE_START( mbeeppc ) |
| 615 | static GFXDECODE_START( premium ) |
| 631 | 616 | GFXDECODE_ENTRY( "gfx", 0x0000, mbee_charlayout, 0, 8 ) |
| 632 | 617 | GFXDECODE_END |
| 633 | 618 | |
| r243505 | r243506 | |
| 662 | 647 | MCFG_SCREEN_VISIBLE_AREA(0*8, 64*8-1, 0, 19*16-1) |
| 663 | 648 | MCFG_SCREEN_UPDATE_DRIVER(mbee_state, screen_update_mbee) |
| 664 | 649 | |
| 665 | | MCFG_GFXDECODE_ADD("gfxdecode", "palette", mbee) |
| 650 | MCFG_GFXDECODE_ADD("gfxdecode", "palette", mono) |
| 666 | 651 | MCFG_PALETTE_ADD_MONOCHROME_AMBER("palette") // usually sold with amber or green monitor |
| 667 | 652 | |
| 668 | | MCFG_VIDEO_START_OVERRIDE(mbee_state, mbee) |
| 653 | MCFG_VIDEO_START_OVERRIDE(mbee_state, mono) |
| 669 | 654 | |
| 670 | 655 | /* sound hardware */ |
| 671 | 656 | MCFG_SPEAKER_STANDARD_MONO("mono") |
| r243505 | r243506 | |
| 678 | 663 | MCFG_MC6845_ADD("crtc", SY6545_1, "screen", XTAL_12MHz / 8) |
| 679 | 664 | MCFG_MC6845_SHOW_BORDER_AREA(false) |
| 680 | 665 | MCFG_MC6845_CHAR_WIDTH(8) |
| 681 | | MCFG_MC6845_UPDATE_ROW_CB(mbee_state, mbee_update_row) |
| 682 | | MCFG_MC6845_ADDR_CHANGED_CB(mbee_state, mbee_update_addr) |
| 666 | MCFG_MC6845_UPDATE_ROW_CB(mbee_state, mono_update_row) |
| 667 | MCFG_MC6845_ADDR_CHANGED_CB(mbee_state, crtc_update_addr) |
| 683 | 668 | MCFG_MC6845_OUT_VSYNC_CB(WRITELINE(mbee_state, crtc_vs)) |
| 684 | 669 | |
| 685 | 670 | MCFG_QUICKLOAD_ADD("quickload", mbee_state, mbee, "mwb,com,bee", 2) |
| r243505 | r243506 | |
| 718 | 703 | MCFG_SCREEN_VISIBLE_AREA(0, 80*8-1, 0, 19*16-1) |
| 719 | 704 | MCFG_SCREEN_UPDATE_DRIVER(mbee_state, screen_update_mbee) |
| 720 | 705 | |
| 721 | | MCFG_GFXDECODE_ADD("gfxdecode", "palette", mbeeic) |
| 706 | MCFG_GFXDECODE_ADD("gfxdecode", "palette", standard) |
| 722 | 707 | |
| 723 | 708 | MCFG_PALETTE_ADD("palette", 96) |
| 724 | | MCFG_PALETTE_INIT_OWNER(mbee_state, mbeeic) |
| 709 | MCFG_PALETTE_INIT_OWNER(mbee_state, standard) |
| 725 | 710 | |
| 726 | | MCFG_VIDEO_START_OVERRIDE(mbee_state, mbeeic) |
| 711 | MCFG_VIDEO_START_OVERRIDE(mbee_state, standard) |
| 727 | 712 | |
| 728 | 713 | /* sound hardware */ |
| 729 | 714 | MCFG_SPEAKER_STANDARD_MONO("mono") |
| r243505 | r243506 | |
| 736 | 721 | MCFG_MC6845_ADD("crtc", SY6545_1, "screen", XTAL_13_5MHz / 8) |
| 737 | 722 | MCFG_MC6845_SHOW_BORDER_AREA(false) |
| 738 | 723 | MCFG_MC6845_CHAR_WIDTH(8) |
| 739 | | MCFG_MC6845_UPDATE_ROW_CB(mbee_state, mbeeic_update_row) |
| 740 | | MCFG_MC6845_ADDR_CHANGED_CB(mbee_state, mbee_update_addr) |
| 724 | MCFG_MC6845_UPDATE_ROW_CB(mbee_state, colour_update_row) |
| 725 | MCFG_MC6845_ADDR_CHANGED_CB(mbee_state, crtc_update_addr) |
| 741 | 726 | MCFG_MC6845_OUT_VSYNC_CB(WRITELINE(mbee_state, crtc_vs)) |
| 742 | 727 | |
| 743 | 728 | MCFG_QUICKLOAD_ADD("quickload", mbee_state, mbee, "mwb,com,bee", 2) |
| r243505 | r243506 | |
| 773 | 758 | MCFG_CPU_MODIFY( "maincpu" ) |
| 774 | 759 | MCFG_CPU_PROGRAM_MAP(mbeeppc_mem) |
| 775 | 760 | MCFG_CPU_IO_MAP(mbeeppc_io) |
| 776 | | MCFG_VIDEO_START_OVERRIDE(mbee_state, mbeeppc) |
| 777 | | MCFG_GFXDECODE_MODIFY("gfxdecode", mbeeppc) |
| 761 | MCFG_VIDEO_START_OVERRIDE(mbee_state, premium) |
| 762 | MCFG_GFXDECODE_MODIFY("gfxdecode", premium) |
| 778 | 763 | MCFG_PALETTE_MODIFY("palette") |
| 779 | 764 | MCFG_PALETTE_ENTRIES(16) |
| 780 | | MCFG_PALETTE_INIT_OWNER(mbee_state, mbeeppc) |
| 781 | | |
| 782 | | MCFG_DEVICE_REMOVE("crtc") |
| 783 | | MCFG_MC6845_ADD("crtc", SY6545_1, "screen", XTAL_13_5MHz / 8) |
| 784 | | MCFG_MC6845_SHOW_BORDER_AREA(false) |
| 785 | | MCFG_MC6845_CHAR_WIDTH(8) |
| 786 | | MCFG_MC6845_UPDATE_ROW_CB(mbee_state, mbeeppc_update_row) |
| 787 | | MCFG_MC6845_ADDR_CHANGED_CB(mbee_state, mbee_update_addr) |
| 788 | | MCFG_MC6845_OUT_VSYNC_CB(WRITELINE(mbee_state, crtc_vs)) |
| 765 | MCFG_PALETTE_INIT_OWNER(mbee_state, premium) |
| 789 | 766 | MACHINE_CONFIG_END |
| 790 | 767 | |
| 791 | 768 | static MACHINE_CONFIG_DERIVED( mbee56, mbeeic ) |
| r243505 | r243506 | |
| 805 | 782 | MCFG_CPU_PROGRAM_MAP(mbee256_mem) |
| 806 | 783 | MCFG_CPU_IO_MAP(mbee128_io) |
| 807 | 784 | MCFG_MACHINE_RESET_OVERRIDE(mbee_state, mbee128) |
| 785 | MCFG_MC146818_ADD( "rtc", XTAL_32_768kHz ) |
| 808 | 786 | MACHINE_CONFIG_END |
| 809 | 787 | |
| 810 | 788 | static MACHINE_CONFIG_DERIVED( mbee128p, mbeeppc ) |
| r243505 | r243506 | |
| 812 | 790 | MCFG_CPU_PROGRAM_MAP(mbee256_mem) |
| 813 | 791 | MCFG_CPU_IO_MAP(mbee128_io) |
| 814 | 792 | MCFG_MACHINE_RESET_OVERRIDE(mbee_state, mbee128) |
| 793 | MCFG_MC146818_ADD( "rtc", XTAL_32_768kHz ) |
| 815 | 794 | MCFG_WD2793x_ADD("fdc", XTAL_4MHz / 4) |
| 816 | 795 | MCFG_WD_FDC_INTRQ_CALLBACK(WRITELINE(mbee_state, fdc_intrq_w)) |
| 817 | 796 | MCFG_WD_FDC_DRQ_CALLBACK(WRITELINE(mbee_state, fdc_drq_w)) |
| r243505 | r243506 | |
| 824 | 803 | MCFG_CPU_PROGRAM_MAP(mbee256_mem) |
| 825 | 804 | MCFG_CPU_IO_MAP(mbee256_io) |
| 826 | 805 | MCFG_MACHINE_RESET_OVERRIDE(mbee_state, mbee256) |
| 827 | | MCFG_MC146818_ADD( "rtc", XTAL_32_768kHz ) |
| 828 | 806 | |
| 829 | | MCFG_DEVICE_REMOVE("crtc") |
| 830 | | MCFG_MC6845_ADD("crtc", SY6545_1, "screen", XTAL_13_5MHz / 8) |
| 831 | | MCFG_MC6845_SHOW_BORDER_AREA(false) |
| 832 | | MCFG_MC6845_CHAR_WIDTH(8) |
| 833 | | MCFG_MC6845_UPDATE_ROW_CB(mbee_state, mbeeppc_update_row) |
| 834 | | MCFG_MC6845_ADDR_CHANGED_CB(mbee_state, mbee256_update_addr) |
| 835 | 807 | MCFG_DEVICE_REMOVE("fdc:0") |
| 836 | 808 | MCFG_DEVICE_REMOVE("fdc:1") |
| 837 | 809 | MCFG_FLOPPY_DRIVE_ADD("fdc:0", mbee_floppies, "drive3a", floppy_image_device::default_floppy_formats) |
| r243505 | r243506 | |
| 842 | 814 | MCFG_CPU_MODIFY( "maincpu" ) |
| 843 | 815 | MCFG_CPU_PROGRAM_MAP(mbeett_mem) |
| 844 | 816 | MCFG_CPU_IO_MAP(mbeett_io) |
| 845 | | MCFG_MACHINE_RESET_OVERRIDE(mbee_state, mbeett ) |
| 817 | MCFG_MACHINE_RESET_OVERRIDE(mbee_state, mbeett) |
| 846 | 818 | MCFG_MC146818_ADD( "rtc", XTAL_32_768kHz ) |
| 847 | | |
| 848 | | MCFG_DEVICE_REMOVE("crtc") |
| 849 | | MCFG_MC6845_ADD("crtc", SY6545_1, "screen", XTAL_13_5MHz / 8) |
| 850 | | MCFG_MC6845_SHOW_BORDER_AREA(false) |
| 851 | | MCFG_MC6845_CHAR_WIDTH(8) |
| 852 | | MCFG_MC6845_UPDATE_ROW_CB(mbee_state, mbeeppc_update_row) |
| 853 | | MCFG_MC6845_ADDR_CHANGED_CB(mbee_state, mbee256_update_addr) |
| 854 | 819 | MACHINE_CONFIG_END |
| 855 | 820 | |
| 856 | 821 | /* Unused roms: |
trunk/src/mess/video/mbee.c
| r243505 | r243506 | |
| 4 | 4 | video hardware |
| 5 | 5 | Juergen Buchmueller <pullmoll@t-online.de>, Dec 1999 |
| 6 | 6 | |
| 7 | | Tests of keyboard. Start mbeeic. |
| 7 | Rewritten by Robbbert |
| 8 | 8 | |
| 9 | | 1. Load ASTEROIDS PLUS, stay in attract mode, hold down spacebar, |
| 10 | | it should only fire bullets. If it sometimes starts turning, |
| 11 | | thrusting or using the shield, then there is a problem. |
| 12 | | |
| 13 | | 2. Load SCAVENGER and make sure it doesn't go to the next level |
| 14 | | until you find the Exit. |
| 15 | | |
| 16 | | 3. At the Basic prompt, type in EDASM press enter. At the memory size |
| 17 | | prompt press enter. Now, make sure the keyboard works properly. |
| 18 | | |
| 19 | | |
| 20 | | |
| 21 | | TODO: |
| 22 | | |
| 23 | | 1. mbeeppc keyboard response is quite slow. You need to hold each |
| 24 | | key until it responds. It works much better if you overclock the cpu. |
| 25 | | |
| 26 | 9 | ****************************************************************************/ |
| 27 | 10 | |
| 28 | 11 | |
| r243505 | r243506 | |
| 214 | 197 | ************************************************************/ |
| 215 | 198 | |
| 216 | 199 | |
| 217 | | /* The direction keys are used by the pc85 menu. Do not know what uses the "insert" key. */ |
| 218 | 200 | void mbee_state::keyboard_matrix_r(int offs) |
| 219 | 201 | { |
| 220 | 202 | UINT8 port = (offs >> 7) & 7; |
| 221 | 203 | UINT8 bit = (offs >> 4) & 7; |
| 222 | | UINT8 data = 0; |
| 204 | UINT8 data = m_io_oldkb[port]->read(); |
| 205 | bool keydown = ( data >> bit ) & 1; |
| 223 | 206 | |
| 224 | | switch ( port ) |
| 207 | // This adds premium-style cursor keys to the old keyboard |
| 208 | // They are used by the pc85 & ppc menu, and the 128k shell. |
| 209 | if (!keydown) |
| 225 | 210 | { |
| 226 | | case 0: data = m_io_x0->read(); break; |
| 227 | | case 1: data = m_io_x1->read(); break; |
| 228 | | case 2: data = m_io_x2->read(); break; |
| 229 | | case 3: data = m_io_x3->read(); break; |
| 230 | | case 4: data = m_io_x4->read(); break; |
| 231 | | case 5: data = m_io_x5->read(); break; |
| 232 | | case 6: data = m_io_x6->read(); break; |
| 233 | | case 7: data = m_io_x7->read(); break; |
| 234 | | } |
| 235 | | data = ( data >> bit ) & 1; |
| 236 | | |
| 237 | | if ((data | m_is_premium) == 0) |
| 238 | | { |
| 239 | 211 | UINT8 extra = m_io_extra->read(); |
| 240 | 212 | |
| 241 | | if( extra & 0x01 ) /* extra: cursor up */ |
| 242 | | { |
| 243 | | if( port == 7 && bit == 1 ) data = 1; /* Control */ |
| 244 | | if( port == 0 && bit == 5 ) data = 1; /* E */ |
| 245 | | } |
| 213 | if (extra && port == 7 && bit == 1) keydown = 1; /* Control */ |
| 214 | |
| 215 | if (BIT(extra, 0) && ( port == 0 && bit == 5 )) keydown = 1; // cursor up = ^E |
| 246 | 216 | else |
| 247 | | if( extra & 0x02 ) /* extra: cursor down */ |
| 248 | | { |
| 249 | | if( port == 7 && bit == 1 ) data = 1; /* Control */ |
| 250 | | if( port == 3 && bit == 0 ) data = 1; /* X */ |
| 251 | | } |
| 217 | if (BIT(extra, 1) && ( port == 3 && bit == 0 )) keydown = 1; // cursor down = ^X |
| 252 | 218 | else |
| 253 | | if( extra & 0x04 ) /* extra: cursor left */ |
| 254 | | { |
| 255 | | if( port == 7 && bit == 1 ) data = 1; /* Control */ |
| 256 | | if( port == 2 && bit == 3 ) data = 1; /* S */ |
| 257 | | } |
| 219 | if (BIT(extra, 2) && ( port == 2 && bit == 3 )) keydown = 1; // cursor left = ^S |
| 258 | 220 | else |
| 259 | | if( extra & 0x08 ) /* extra: cursor right */ |
| 260 | | { |
| 261 | | if( port == 7 && bit == 1 ) data = 1; /* Control */ |
| 262 | | if( port == 0 && bit == 4 ) data = 1; /* D */ |
| 263 | | } |
| 221 | if (BIT(extra, 3) && ( port == 0 && bit == 4 )) keydown = 1; // cursor right = ^D |
| 264 | 222 | #if 0 |
| 265 | | // this key doesn't appear on any keyboard afaik |
| 223 | // this key doesn't appear on any keyboard afaik. It is a Wordbee function. |
| 266 | 224 | else |
| 267 | | if( extra & 0x10 ) /* extra: insert */ |
| 268 | | { |
| 269 | | if( port == 7 && bit == 1 ) data = 1; /* Control */ |
| 270 | | if( port == 2 && bit == 6 ) data = 1; /* V */ |
| 271 | | } |
| 225 | if (BIT(extra, 4) && ( port == 2 && bit == 6 )) keydown = 1; // insert = ^V |
| 272 | 226 | #endif |
| 273 | 227 | } |
| 274 | 228 | |
| 275 | | if( data ) |
| 229 | if( keydown ) |
| 276 | 230 | { |
| 277 | 231 | m_sy6545_reg[17] = offs; |
| 278 | 232 | m_sy6545_reg[16] = (offs >> 8) & 0x3f; |
| r243505 | r243506 | |
| 283 | 237 | |
| 284 | 238 | void mbee_state::mbee_video_kbd_scan( int param ) |
| 285 | 239 | { |
| 286 | | if (m_0b) return; |
| 287 | | |
| 240 | if (m_0b) return; // can't remember why this is here |
| 241 | if (param & 15) return; // only scan once per row instead of 16 times |
| 288 | 242 | keyboard_matrix_r(param); |
| 289 | 243 | } |
| 290 | 244 | |
| r243505 | r243506 | |
| 375 | 329 | |
| 376 | 330 | ************************************************************/ |
| 377 | 331 | |
| 378 | | VIDEO_START_MEMBER( mbee_state, mbee ) |
| 332 | VIDEO_START_MEMBER( mbee_state, mono ) |
| 379 | 333 | { |
| 380 | 334 | m_p_videoram = memregion("videoram")->base(); |
| 381 | 335 | m_p_gfxram = memregion("gfx")->base()+0x1000; |
| 382 | 336 | m_is_premium = 0; |
| 383 | 337 | } |
| 384 | 338 | |
| 385 | | VIDEO_START_MEMBER( mbee_state, mbeeic ) |
| 339 | VIDEO_START_MEMBER( mbee_state, standard ) |
| 386 | 340 | { |
| 387 | 341 | m_p_videoram = memregion("videoram")->base(); |
| 388 | 342 | m_p_colorram = memregion("colorram")->base(); |
| r243505 | r243506 | |
| 390 | 344 | m_is_premium = 0; |
| 391 | 345 | } |
| 392 | 346 | |
| 393 | | VIDEO_START_MEMBER( mbee_state, mbeeppc ) |
| 347 | VIDEO_START_MEMBER( mbee_state, premium ) |
| 394 | 348 | { |
| 395 | 349 | m_p_videoram = memregion("videoram")->base(); |
| 396 | 350 | m_p_colorram = memregion("colorram")->base(); |
| r243505 | r243506 | |
| 407 | 361 | } |
| 408 | 362 | |
| 409 | 363 | |
| 410 | | MC6845_ON_UPDATE_ADDR_CHANGED( mbee_state::mbee_update_addr ) |
| 364 | MC6845_ON_UPDATE_ADDR_CHANGED( mbee_state::crtc_update_addr ) |
| 411 | 365 | { |
| 412 | | /* not sure what goes in here - parameters passed are device, address, strobe */ |
| 366 | // not sure what goes in here - parameters passed are device, address, strobe |
| 367 | // not used on 256TC |
| 413 | 368 | } |
| 414 | 369 | |
| 415 | | MC6845_ON_UPDATE_ADDR_CHANGED( mbee_state::mbee256_update_addr ) |
| 416 | | { |
| 417 | | /* not used on 256TC */ |
| 418 | | } |
| 419 | 370 | |
| 420 | | |
| 421 | 371 | /* monochrome bee */ |
| 422 | | MC6845_UPDATE_ROW( mbee_state::mbee_update_row ) |
| 372 | MC6845_UPDATE_ROW( mbee_state::mono_update_row ) |
| 423 | 373 | { |
| 424 | 374 | const rgb_t *palette = m_palette->palette()->entry_list_raw(); |
| 425 | 375 | UINT8 chr,gfx; |
| r243505 | r243506 | |
| 453 | 403 | } |
| 454 | 404 | } |
| 455 | 405 | |
| 456 | | /* prom-based colours */ |
| 457 | | MC6845_UPDATE_ROW( mbee_state::mbeeic_update_row ) |
| 406 | /* colour bee */ |
| 407 | MC6845_UPDATE_ROW( mbee_state::colour_update_row ) |
| 458 | 408 | { |
| 459 | 409 | const rgb_t *palette = m_palette->palette()->entry_list_raw(); |
| 460 | | UINT8 chr,gfx,fg,bg; |
| 461 | | UINT16 mem,x,col; |
| 410 | UINT8 inv,attr,gfx,fg,bg; |
| 411 | UINT16 mem,x,col,chr; |
| 462 | 412 | UINT16 colourm = (m_08 & 0x0e) << 7; |
| 463 | 413 | UINT32 *p = &bitmap.pix32(y); |
| 464 | 414 | |
| 465 | 415 | for (x = 0; x < x_count; x++) // for each character |
| 466 | 416 | { |
| 467 | | UINT8 inv=0; |
| 417 | inv = 0; |
| 468 | 418 | mem = (ma + x) & 0x7ff; |
| 469 | 419 | chr = m_p_videoram[mem]; |
| 470 | | col = m_p_colorram[mem] | colourm; // read a byte of colour |
| 471 | | |
| 472 | | mbee_video_kbd_scan(x+ma); |
| 473 | | |
| 474 | | /* process cursor */ |
| 475 | | if (x == cursor_x) |
| 476 | | inv ^= m_sy6545_cursor[ra]; // cursor scan row |
| 477 | | |
| 478 | | /* get pattern of pixels for that character scanline */ |
| 479 | | gfx = m_p_gfxram[(chr<<4) | ra] ^ inv; |
| 480 | | fg = (col & 0x001f) | 64; // map to foreground palette |
| 481 | | bg = (col & 0x07e0) >> 5; // and background palette |
| 482 | | |
| 483 | | /* Display a scanline of a character (8 pixels) */ |
| 484 | | *p++ = palette[BIT(gfx, 7) ? fg : bg]; |
| 485 | | *p++ = palette[BIT(gfx, 6) ? fg : bg]; |
| 486 | | *p++ = palette[BIT(gfx, 5) ? fg : bg]; |
| 487 | | *p++ = palette[BIT(gfx, 4) ? fg : bg]; |
| 488 | | *p++ = palette[BIT(gfx, 3) ? fg : bg]; |
| 489 | | *p++ = palette[BIT(gfx, 2) ? fg : bg]; |
| 490 | | *p++ = palette[BIT(gfx, 1) ? fg : bg]; |
| 491 | | *p++ = palette[BIT(gfx, 0) ? fg : bg]; |
| 492 | | } |
| 493 | | } |
| 494 | | |
| 495 | | |
| 496 | | /* new colours & hires2 */ |
| 497 | | MC6845_UPDATE_ROW( mbee_state::mbeeppc_update_row ) |
| 498 | | { |
| 499 | | const rgb_t *palette = m_palette->palette()->entry_list_raw(); |
| 500 | | UINT8 gfx,fg,bg; |
| 501 | | UINT16 mem,x,col,chr; |
| 502 | | UINT32 *p = &bitmap.pix32(y); |
| 503 | | |
| 504 | | for (x = 0; x < x_count; x++) // for each character |
| 505 | | { |
| 506 | | UINT8 inv=0; |
| 507 | | mem = (ma + x) & 0x7ff; |
| 508 | | chr = m_p_videoram[mem]; |
| 509 | 420 | col = m_p_colorram[mem]; // read a byte of colour |
| 510 | 421 | |
| 511 | | if (m_1c & 0x80) // are extended features enabled? |
| 422 | if (m_is_premium) |
| 512 | 423 | { |
| 513 | | UINT8 attr = m_p_attribram[mem]; |
| 424 | if (m_1c & 0x80) // are extended features enabled? |
| 425 | { |
| 426 | attr = m_p_attribram[mem]; |
| 514 | 427 | |
| 515 | | if (chr & 0x80) |
| 516 | | chr += ((attr & 15) << 7); // bump chr to its particular pcg definition |
| 428 | if (chr & 0x80) |
| 429 | chr += ((attr & 15) << 7); // bump chr to its particular pcg definition |
| 517 | 430 | |
| 518 | | if (attr & 0x40) |
| 519 | | inv ^= 0xff; // inverse attribute |
| 431 | if (attr & 0x40) |
| 432 | inv ^= 0xff; // inverse attribute |
| 520 | 433 | |
| 521 | | if ((attr & 0x80) && (m_framecnt & 0x10)) // flashing attribute |
| 522 | | chr = 0x20; |
| 434 | if ((attr & 0x80) && (m_framecnt & 0x10)) // flashing attribute |
| 435 | chr = 0x20; |
| 436 | } |
| 523 | 437 | } |
| 438 | else |
| 439 | col |= colourm; |
| 524 | 440 | |
| 525 | | mbee_video_kbd_scan(x+ma); |
| 441 | if (m_has_oldkb) |
| 442 | mbee_video_kbd_scan(x+ma); |
| 526 | 443 | |
| 527 | 444 | /* process cursor */ |
| 528 | 445 | if (x == cursor_x) |
| r243505 | r243506 | |
| 530 | 447 | |
| 531 | 448 | /* get pattern of pixels for that character scanline */ |
| 532 | 449 | gfx = m_p_gfxram[(chr<<4) | ra] ^ inv; |
| 533 | | fg = col & 15; // map to foreground palette |
| 534 | | bg = (col & 0xf0) >> 4; // and background palette |
| 535 | 450 | |
| 451 | // get colours |
| 452 | if (m_is_premium) |
| 453 | { |
| 454 | fg = col & 15; |
| 455 | bg = (col & 0xf0) >> 4; |
| 456 | } |
| 457 | else |
| 458 | { |
| 459 | fg = (col & 0x001f) | 64; |
| 460 | bg = (col & 0x07e0) >> 5; |
| 461 | } |
| 462 | |
| 536 | 463 | /* Display a scanline of a character (8 pixels) */ |
| 537 | 464 | *p++ = palette[BIT(gfx, 7) ? fg : bg]; |
| 538 | 465 | *p++ = palette[BIT(gfx, 6) ? fg : bg]; |
| r243505 | r243506 | |
| 552 | 479 | |
| 553 | 480 | ************************************************************/ |
| 554 | 481 | |
| 555 | | PALETTE_INIT_MEMBER( mbee_state, mbeeic ) |
| 482 | PALETTE_INIT_MEMBER( mbee_state, standard ) |
| 556 | 483 | { |
| 557 | 484 | const UINT8 *color_prom = memregion("proms")->base(); |
| 558 | 485 | UINT16 i; |
| r243505 | r243506 | |
| 610 | 537 | } |
| 611 | 538 | |
| 612 | 539 | |
| 613 | | PALETTE_INIT_MEMBER( mbee_state, mbeeppc ) |
| 540 | PALETTE_INIT_MEMBER( mbee_state, premium ) |
| 614 | 541 | { |
| 615 | 542 | UINT16 i; |
| 616 | 543 | UINT8 r, b, g; |