trunk/src/mess/drivers/esq5505.c
| r19134 | r19135 | |
| 29 | 29 | |
| 30 | 30 | 68681 GPIO lines (from VFX schematics): |
| 31 | 31 | I0: CARTIN (if cartridge is present) |
| 32 | | |
| 32 | |
| 33 | 33 | O0: "AN0" |
| 34 | 34 | O1: "AN1" |
| 35 | 35 | O2: "AN2" (disk side select on EPS/EPS-16) |
| 36 | 36 | O6: To ESPHALT pin on ES5510 |
| 37 | 37 | O7: "SACK" |
| 38 | 38 | |
| 39 | | VFX-SD / SD-1 / SD-1 32 panel button codes: |
| 39 | VFX / VFX-SD / SD-1 / SD-1 32 panel button codes: |
| 40 | 40 | 2 = PROG-CNTL |
| 41 | 41 | 3 = WRITE EDIT PROGRAM |
| 42 | 42 | 4 = WAVE |
| r19134 | r19135 | |
| 51 | 51 | 14 = ENV2 |
| 52 | 52 | 15 = FILTER |
| 53 | 53 | 16 = ENV3 |
| 54 | | 17 = OUTPUT |
| 55 | | 20 = MASTER |
| 54 | 17 = OUTPUT |
| 55 | 18 = ERROR 20 (VFX) / SEQUENCER MUST BE LOADED (VFX-SD/SD-1) |
| 56 | 19 = ? |
| 57 | 20 = MASTER |
| 58 | 21 = STORAGE |
| 59 | 22 = ? |
| 60 | 23 = ? |
| 56 | 61 | 24 = MIDI |
| 57 | 62 | 25 = INT9 |
| 58 | 63 | 26 = PSEL |
| r19134 | r19135 | |
| 60 | 65 | 28 = EFFECT |
| 61 | 66 | 29 = INT9 |
| 62 | 67 | 30 = TRAX |
| 63 | | 31 = TRAX (page 2) |
| 68 | 31 = TRAX (page 2) |
| 69 | 32 = ERROR 20 (VFX) / CLICK-REC |
| 70 | 33 = ERROR 20 (VFX) / LOCATE |
| 64 | 71 | 34 = INT8 |
| 65 | 72 | 35 = INT7 |
| 66 | 73 | 36 = VOL |
| r19134 | r19135 | |
| 68 | 75 | 38 = TIMB |
| 69 | 76 | 39 = ZONE |
| 70 | 77 | 40 = XPOS |
| 71 | | 41 = RELS |
| 78 | 41 = RELS |
| 79 | 42 = SOFT TOP CENTER |
| 80 | 43 = SOFT TOP RIGHT |
| 81 | 44 = SOFT BOTTOM CENTER |
| 82 | 45 = SOFT BOTTOM RIGHT |
| 83 | 46 = INT3 |
| 84 | 47 = INT4 |
| 85 | 48 = INT5 |
| 86 | 49 = INT6 |
| 87 | 50 = SOFT BOTTOM LEFT |
| 88 | 51 = ERROR 20 (VFX) / SEQ0 $SONG-00 |
| 89 | 52 = BANK? (toggles INTx, RM0x, RM1x) |
| 90 | 53 = INT0 |
| 91 | 54 = PSET |
| 92 | 55 = RM10 |
| 93 | 56 = RM11 |
| 94 | 57 = RM12 |
| 95 | 58 = SOFT TOP LEFT |
| 96 | 59 = ERROR 20 (VFX) / EDIT SEQUENCE |
| 97 | 60 = ERROR 20 (VFX) / SONG NOT SELECTED |
| 98 | 61 = ERROR 20 (VFX) / EDIT TRACK |
| 99 | 62 = DATA INCREMENT |
| 100 | 63 = DATA DECREMENT |
| 72 | 101 | |
| 73 | 102 | ***************************************************************************/ |
| 74 | 103 | |
| r19134 | r19135 | |
| 90 | 119 | #define SQ1 (2) |
| 91 | 120 | |
| 92 | 121 | #define KEYBOARD_HACK (1) // turn on to play the SQ-1, SD-1, and SD-1 32-voice: Z and X are program up/down, A/S/D/F/G/H/J/K/L and Q/W/E/R/T/Y/U play notes |
| 122 | #define HACK_VIA_MIDI (1) |
| 93 | 123 | |
| 94 | 124 | #if KEYBOARD_HACK |
| 125 | #if HACK_VIA_MIDI |
| 95 | 126 | static int program = 0; |
| 96 | 127 | #endif |
| 128 | #endif |
| 97 | 129 | |
| 98 | 130 | class esq5505_state : public driver_device |
| 99 | 131 | { |
| r19134 | r19135 | |
| 274 | 306 | AM_RANGE(0x260000, 0x2601ff) AM_READWRITE(es5510_dsp_r, es5510_dsp_w) |
| 275 | 307 | AM_RANGE(0x280000, 0x28001f) AM_DEVREADWRITE8_LEGACY("duart", duart68681_r, duart68681_w, 0x00ff) |
| 276 | 308 | AM_RANGE(0x2c0000, 0x2c0007) AM_DEVREADWRITE8("wd1772", wd1772_t, read, write, 0x00ff) |
| 277 | | AM_RANGE(0x340000, 0x3bffff) AM_RAM // sequencer memory? |
| 309 | AM_RANGE(0x330000, 0x3bffff) AM_RAM // sequencer memory? |
| 278 | 310 | AM_RANGE(0xc00000, 0xc3ffff) AM_ROM AM_REGION("osrom", 0) |
| 279 | 311 | AM_RANGE(0xff0000, 0xffffff) AM_RAM AM_SHARE("osram") |
| 280 | 312 | ADDRESS_MAP_END |
| r19134 | r19135 | |
| 290 | 322 | AM_RANGE(0xff0000, 0xffffff) AM_RAM AM_SHARE("osram") |
| 291 | 323 | ADDRESS_MAP_END |
| 292 | 324 | |
| 325 | static void esq5505_otis_irq(device_t *device, int state) |
| 326 | { |
| 327 | #if 0 // 5505/06 IRQ generation needs (more) work |
| 328 | esq5505_state *esq5505 = device->machine().driver_data<esq5505_state>(); |
| 329 | esq5505->m_maincpu->set_input_line(1, state); |
| 330 | #endif |
| 331 | } |
| 332 | |
| 293 | 333 | static UINT16 esq5505_read_adc(device_t *device) |
| 294 | 334 | { |
| 295 | 335 | esq5505_state *state = device->machine().driver_data<esq5505_state>(); |
| 296 | 336 | |
| 297 | 337 | // bit 0 controls reading the battery; other bits likely |
| 298 | 338 | // control other analog sources |
| 339 | // VFX & SD-1 32 voice schematics agree: |
| 340 | // bit 0: reference |
| 341 | // bit 1: battery |
| 342 | // bit 2: vol |
| 343 | // bit 3: pedal |
| 344 | // bit 4: val |
| 345 | // bit 5: mod wheel |
| 346 | // bit 6: psel |
| 347 | // bit 7: pitch wheel |
| 348 | switch ((state->m_duart_io & 7) ^ 7) |
| 349 | { |
| 350 | case 0: // vRef to check battery |
| 351 | return 0x5b00; |
| 352 | |
| 353 | case 1: // battery voltage |
| 354 | return 0x7f00; |
| 355 | |
| 356 | return 0x7f00; |
| 357 | |
| 358 | case 3: // pedal |
| 359 | case 5: // mod wheel |
| 360 | return 0; |
| 361 | |
| 362 | case 7: // pitch wheel |
| 363 | return 0x3f00; |
| 364 | |
| 365 | case 2: // volume control |
| 366 | case 4: // val (?) |
| 367 | case 6: // psel |
| 368 | return 0x7f00; |
| 369 | } |
| 370 | |
| 299 | 371 | if (state->m_duart_io & 1) |
| 300 | 372 | { |
| 301 | 373 | return 0x5b00; // vRef |
| r19134 | r19135 | |
| 313 | 385 | // printf("\nDUART IRQ: state %d vector %d\n", state, vector); |
| 314 | 386 | if (state == ASSERT_LINE) |
| 315 | 387 | { |
| 316 | | esq5505->m_maincpu->set_input_line_vector(1, vector); |
| 317 | | esq5505->m_maincpu->set_input_line(1, ASSERT_LINE); |
| 388 | esq5505->m_maincpu->set_input_line_vector(2, vector); |
| 389 | esq5505->m_maincpu->set_input_line(2, ASSERT_LINE); |
| 318 | 390 | } |
| 319 | 391 | else |
| 320 | 392 | { |
| 321 | | esq5505->m_maincpu->set_input_line(1, CLEAR_LINE); |
| 393 | esq5505->m_maincpu->set_input_line(2, CLEAR_LINE); |
| 322 | 394 | } |
| 323 | 395 | }; |
| 324 | 396 | |
| r19134 | r19135 | |
| 332 | 404 | static void duart_output(device_t *device, UINT8 data) |
| 333 | 405 | { |
| 334 | 406 | esq5505_state *state = device->machine().driver_data<esq5505_state>(); |
| 335 | | floppy_connector *con = device->machine().device<floppy_connector>("fd0"); |
| 407 | floppy_connector *con = device->machine().device<floppy_connector>("wd1772:0"); |
| 336 | 408 | floppy_image_device *floppy = con ? con->get_device() : 0; |
| 337 | 409 | |
| 338 | 410 | state->m_duart_io = data; |
| 339 | 411 | |
| 412 | /* |
| 413 | ESP: |
| 414 | |
| 415 | VFX: |
| 416 | bits 0/1/2 = analog sel |
| 417 | bit 6 = ESPHALT |
| 418 | bit 7 = SACK (?) |
| 419 | |
| 420 | SD-1 32: |
| 421 | bits 0/1/2 = analog sel |
| 422 | bit 3 = SSEL (disk side) |
| 423 | bit 4 = DSEL (drive select?) |
| 424 | bit 6 = ESPHALT |
| 425 | bit 7 = SACK (?) |
| 426 | */ |
| 427 | |
| 340 | 428 | if (floppy) |
| 341 | 429 | { |
| 342 | | floppy->ss_w((data & 2)>>1); |
| 430 | if (state->m_system_type == EPS) |
| 431 | { |
| 432 | floppy->ss_w((data & 2)>>1); |
| 433 | } |
| 434 | else |
| 435 | { |
| 436 | floppy->ss_w(((data & 8)>>3)^1); |
| 437 | } |
| 343 | 438 | } |
| 344 | 439 | |
| 345 | 440 | // printf("DUART output: %02x (PC=%x)\n", data, state->m_maincpu->pc()); |
| r19134 | r19135 | |
| 439 | 534 | #if KEYBOARD_HACK |
| 440 | 535 | INPUT_CHANGED_MEMBER(esq5505_state::key_stroke) |
| 441 | 536 | { |
| 442 | | #if 1 // MIDI |
| 537 | #if HACK_VIA_MIDI |
| 443 | 538 | // send a MIDI Note On |
| 444 | 539 | if (oldval == 0 && newval == 1) |
| 445 | 540 | { |
| r19134 | r19135 | |
| 487 | 582 | } |
| 488 | 583 | #else |
| 489 | 584 | int val = (UINT8)(FPTR)param; |
| 490 | | val += 50; |
| 491 | | if (oldval == 0 && newval == 1) |
| 585 | val += 32; |
| 586 | if (oldval == 0 && newval == 1) |
| 492 | 587 | { |
| 493 | | printf("key on %d\n", val&0x7f); |
| 588 | printf("key pressed %d\n", val&0x7f); |
| 494 | 589 | duart68681_rx_data(m_duart, 1, val); |
| 495 | 590 | duart68681_rx_data(m_duart, 1, 0x00); |
| 496 | 591 | } |
| r19134 | r19135 | |
| 519 | 614 | { |
| 520 | 615 | "waverom", /* Bank 0 */ |
| 521 | 616 | "waverom2", /* Bank 1 */ |
| 522 | | NULL, /* irq */ |
| 617 | esq5505_otis_irq, /* irq */ |
| 523 | 618 | esq5505_read_adc |
| 524 | 619 | }; |
| 525 | 620 | |
| r19134 | r19135 | |
| 585 | 680 | |
| 586 | 681 | static INPUT_PORTS_START( vfx ) |
| 587 | 682 | #if KEYBOARD_HACK |
| 683 | #if HACK_VIA_MIDI |
| 588 | 684 | PORT_START("KEY0") |
| 589 | 685 | PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_A) PORT_CHAR('a') PORT_CHAR('A') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x40) |
| 590 | 686 | PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_S) PORT_CHAR('s') PORT_CHAR('S') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x41) |
| r19134 | r19135 | |
| 606 | 702 | PORT_START("KEY1") |
| 607 | 703 | PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Z) PORT_CHAR('z') PORT_CHAR('Z') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x0) |
| 608 | 704 | PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_X) PORT_CHAR('x') PORT_CHAR('X') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x1) |
| 705 | #else |
| 706 | PORT_START("KEY0") |
| 707 | PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_A) PORT_CHAR('a') PORT_CHAR('A') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x80) |
| 708 | PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_S) PORT_CHAR('s') PORT_CHAR('S') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x81) |
| 709 | PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_D) PORT_CHAR('d') PORT_CHAR('D') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x82) |
| 710 | PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_F) PORT_CHAR('f') PORT_CHAR('F') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x83) |
| 711 | PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_G) PORT_CHAR('g') PORT_CHAR('G') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x84) |
| 712 | PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_H) PORT_CHAR('h') PORT_CHAR('H') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x85) |
| 713 | PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_J) PORT_CHAR('j') PORT_CHAR('J') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x86) |
| 714 | PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_K) PORT_CHAR('k') PORT_CHAR('K') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x87) |
| 715 | PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_L) PORT_CHAR('l') PORT_CHAR('L') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x88) |
| 716 | PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Q) PORT_CHAR('q') PORT_CHAR('Q') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x89) |
| 717 | PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_W) PORT_CHAR('w') PORT_CHAR('W') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x8a) |
| 718 | PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_E) PORT_CHAR('e') PORT_CHAR('E') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x8b) |
| 719 | PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_R) PORT_CHAR('r') PORT_CHAR('R') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x8c) |
| 720 | PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_T) PORT_CHAR('t') PORT_CHAR('T') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x8d) |
| 721 | PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Y) PORT_CHAR('y') PORT_CHAR('Y') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x8e) |
| 722 | PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_U) PORT_CHAR('u') PORT_CHAR('U') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x8f) |
| 723 | |
| 724 | PORT_START("KEY1") |
| 725 | PORT_BIT(0x0001, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_I) PORT_CHAR('i') PORT_CHAR('I') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x90) |
| 726 | PORT_BIT(0x0002, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_O) PORT_CHAR('o') PORT_CHAR('O') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x91) |
| 727 | PORT_BIT(0x0004, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_P) PORT_CHAR('p') PORT_CHAR('P') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x92) |
| 728 | PORT_BIT(0x0008, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_Z) PORT_CHAR('z') PORT_CHAR('Z') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x93) |
| 729 | PORT_BIT(0x0010, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_X) PORT_CHAR('x') PORT_CHAR('X') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x94) |
| 730 | PORT_BIT(0x0020, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_C) PORT_CHAR('c') PORT_CHAR('C') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x95) |
| 731 | PORT_BIT(0x0040, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_V) PORT_CHAR('v') PORT_CHAR('V') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x96) |
| 732 | PORT_BIT(0x0080, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_B) PORT_CHAR('b') PORT_CHAR('B') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x97) |
| 733 | PORT_BIT(0x0100, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_N) PORT_CHAR('n') PORT_CHAR('N') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x98) |
| 734 | PORT_BIT(0x0200, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_M) PORT_CHAR('m') PORT_CHAR('M') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x99) |
| 735 | PORT_BIT(0x0400, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x9a) |
| 736 | PORT_BIT(0x0800, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x9b) |
| 737 | PORT_BIT(0x1000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x9c) |
| 738 | PORT_BIT(0x2000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x9d) |
| 739 | PORT_BIT(0x4000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x9e) |
| 740 | PORT_BIT(0x8000, IP_ACTIVE_HIGH, IPT_KEYBOARD) PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CHANGED_MEMBER(DEVICE_SELF, esq5505_state, key_stroke, 0x9f) |
| 609 | 741 | #endif |
| 742 | #endif |
| 610 | 743 | INPUT_PORTS_END |
| 611 | 744 | |
| 612 | 745 | ROM_START( vfx ) |
| r19134 | r19135 | |
| 687 | 820 | |
| 688 | 821 | ROM_REGION(0x200000, "waverom", ROMREGION_ERASE00) // EPS-16 has no ROM sounds |
| 689 | 822 | |
| 690 | | ROM_REGION(0x80000, "nibbles", ROMREGION_ERASE00) |
| 823 | ROM_REGION(0x200000, "waverom2", ROMREGION_ERASE00) |
| 691 | 824 | ROM_END |
| 692 | 825 | |
| 693 | 826 | DRIVER_INIT_MEMBER(esq5505_state,common) |
| 694 | 827 | { |
| 695 | | |
| 696 | 828 | m_system_type = GENERIC; |
| 697 | 829 | m_duart_io = 0; |
| 698 | 830 | |