trunk/src/mess/drivers/victor9k.c
| r242306 | r242307 | |
| 13 | 13 | |
| 14 | 14 | TODO: |
| 15 | 15 | |
| 16 | | - centronics |
| 16 | - keyboard |
| 17 | 17 | - expansion bus |
| 18 | 18 | - Z80 card |
| 19 | 19 | - Winchester DMA card (Xebec S1410 + Tandon TM502/TM603SE) |
| 20 | 20 | - RAM cards |
| 21 | 21 | - clock cards |
| 22 | 22 | - floppy 8048 |
| 23 | | - keyboard |
| 24 | 23 | - hires graphics |
| 25 | 24 | - brightness/contrast |
| 26 | 25 | - MC6852 |
| r242306 | r242307 | |
| 41 | 40 | //------------------------------------------------- |
| 42 | 41 | |
| 43 | 42 | static ADDRESS_MAP_START( victor9k_mem, AS_PROGRAM, 8, victor9k_state ) |
| 44 | | // AM_RANGE(0x00000, 0xdffff) AM_RAM |
| 43 | AM_RANGE(0x00000, 0x1ffff) AM_RAM |
| 45 | 44 | AM_RANGE(0x20000, 0xdffff) AM_NOP |
| 46 | | AM_RANGE(0xe0000, 0xe0001) AM_DEVREADWRITE(I8259A_TAG, pic8259_device, read, write) |
| 47 | | AM_RANGE(0xe0020, 0xe0023) AM_DEVREADWRITE(I8253_TAG, pit8253_device, read, write) |
| 48 | | AM_RANGE(0xe0040, 0xe0043) AM_DEVREADWRITE(UPD7201_TAG, upd7201_device, cd_ba_r, cd_ba_w) |
| 45 | AM_RANGE(0xe0000, 0xe0001) AM_MIRROR(0x7f00) AM_DEVREADWRITE(I8259A_TAG, pic8259_device, read, write) |
| 46 | AM_RANGE(0xe0020, 0xe0023) AM_MIRROR(0x7f00) AM_DEVREADWRITE(I8253_TAG, pit8253_device, read, write) |
| 47 | AM_RANGE(0xe0040, 0xe0043) AM_MIRROR(0x7f00) AM_DEVREADWRITE(UPD7201_TAG, upd7201_device, cd_ba_r, cd_ba_w) |
| 49 | 48 | AM_RANGE(0xe8000, 0xe8000) AM_MIRROR(0x7f00) AM_DEVREADWRITE(HD46505S_TAG, mc6845_device, status_r, address_w) |
| 50 | 49 | AM_RANGE(0xe8001, 0xe8001) AM_MIRROR(0x7f00) AM_DEVREADWRITE(HD46505S_TAG, mc6845_device, register_r, register_w) |
| 51 | 50 | AM_RANGE(0xe8020, 0xe802f) AM_MIRROR(0x7f00) AM_DEVREADWRITE(M6522_1_TAG, via6522_device, read, write) |
| r242306 | r242307 | |
| 56 | 55 | AM_RANGE(0xe80c0, 0xe80cf) AM_MIRROR(0x7f00) AM_DEVREADWRITE(FDC_TAG, victor_9000_fdc_t, cs6_r, cs6_w) |
| 57 | 56 | AM_RANGE(0xe80e0, 0xe80ef) AM_MIRROR(0x7f00) AM_DEVREADWRITE(FDC_TAG, victor_9000_fdc_t, cs7_r, cs7_w) |
| 58 | 57 | AM_RANGE(0xf0000, 0xf0fff) AM_MIRROR(0x1000) AM_RAM AM_SHARE("video_ram") |
| 59 | | AM_RANGE(0xfe000, 0xfffff) AM_ROM AM_REGION(I8088_TAG, 0) |
| 58 | AM_RANGE(0xf8000, 0xf9fff) AM_MIRROR(0x6000) AM_ROM AM_REGION(I8088_TAG, 0) |
| 60 | 59 | ADDRESS_MAP_END |
| 61 | 60 | |
| 62 | 61 | |
| r242306 | r242307 | |
| 169 | 168 | { |
| 170 | 169 | m_ssda_irq = state; |
| 171 | 170 | |
| 172 | | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via2_irq || m_via3_irq || m_fdc_irq); |
| 171 | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via3_irq || m_fdc_irq); |
| 173 | 172 | } |
| 174 | 173 | |
| 175 | 174 | |
| r242306 | r242307 | |
| 190 | 189 | |
| 191 | 190 | */ |
| 192 | 191 | |
| 192 | // centronics |
| 193 | m_centronics->write_data0(BIT(data, 0)); |
| 194 | m_centronics->write_data1(BIT(data, 1)); |
| 195 | m_centronics->write_data2(BIT(data, 2)); |
| 196 | m_centronics->write_data3(BIT(data, 3)); |
| 197 | m_centronics->write_data4(BIT(data, 4)); |
| 198 | m_centronics->write_data5(BIT(data, 5)); |
| 199 | m_centronics->write_data6(BIT(data, 6)); |
| 200 | m_centronics->write_data7(BIT(data, 7)); |
| 201 | |
| 202 | // IEEE-488 |
| 193 | 203 | m_ieee488->dio_w(data); |
| 194 | 204 | } |
| 195 | 205 | |
| r242306 | r242307 | |
| 211 | 221 | |
| 212 | 222 | bit description |
| 213 | 223 | |
| 214 | | PB0 DAV |
| 215 | | PB1 EOI |
| 224 | PB0 DAV / DATA STROBE |
| 225 | PB1 EOI / VFU? |
| 216 | 226 | PB2 REN |
| 217 | 227 | PB3 ATN |
| 218 | 228 | PB4 IFC |
| r242306 | r242307 | |
| 222 | 232 | |
| 223 | 233 | */ |
| 224 | 234 | |
| 235 | // centronics |
| 236 | m_centronics->write_strobe(BIT(data, 0)); |
| 237 | |
| 225 | 238 | // IEEE-488 |
| 226 | 239 | m_ieee488->dav_w(BIT(data, 0)); |
| 227 | 240 | m_ieee488->eoi_w(BIT(data, 1)); |
| r242306 | r242307 | |
| 241 | 254 | { |
| 242 | 255 | m_via1_irq = state; |
| 243 | 256 | |
| 244 | | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via2_irq || m_via3_irq || m_fdc_irq); |
| 257 | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via3_irq || m_fdc_irq); |
| 245 | 258 | } |
| 246 | 259 | |
| 247 | 260 | WRITE8_MEMBER( victor9k_state::via2_pa_w ) |
| r242306 | r242307 | |
| 304 | 317 | } |
| 305 | 318 | |
| 306 | 319 | |
| 307 | | WRITE_LINE_MEMBER( victor9k_state::via2_irq_w ) |
| 308 | | { |
| 309 | | m_via2_irq = state; |
| 310 | | |
| 311 | | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via2_irq || m_via3_irq || m_fdc_irq); |
| 312 | | } |
| 313 | | |
| 314 | | |
| 315 | 320 | /* |
| 316 | 321 | bit description |
| 317 | 322 | |
| r242306 | r242307 | |
| 348 | 353 | { |
| 349 | 354 | m_via3_irq = state; |
| 350 | 355 | |
| 351 | | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via2_irq || m_via3_irq || m_fdc_irq); |
| 356 | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via3_irq || m_fdc_irq); |
| 352 | 357 | } |
| 353 | 358 | |
| 354 | 359 | |
| r242306 | r242307 | |
| 359 | 364 | WRITE_LINE_MEMBER( victor9k_state::kbrdy_w ) |
| 360 | 365 | { |
| 361 | 366 | //logerror("KBRDY %u\n", state); |
| 367 | |
| 362 | 368 | m_via2->write_cb1(state); |
| 363 | | |
| 364 | | m_pic->ir6_w(state ? CLEAR_LINE : ASSERT_LINE); |
| 365 | 369 | } |
| 366 | 370 | |
| 367 | 371 | WRITE_LINE_MEMBER( victor9k_state::kbdata_w ) |
| 368 | 372 | { |
| 369 | 373 | //logerror("KBDATA %u\n", state); |
| 374 | |
| 370 | 375 | m_via2->write_cb2(state); |
| 371 | 376 | m_via2->write_pa6(state); |
| 372 | 377 | } |
| r242306 | r242307 | |
| 376 | 381 | { |
| 377 | 382 | m_fdc_irq = state; |
| 378 | 383 | |
| 379 | | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via2_irq || m_via3_irq || m_fdc_irq); |
| 384 | m_pic->ir3_w(m_ssda_irq || m_via1_irq || m_via3_irq || m_fdc_irq); |
| 380 | 385 | } |
| 381 | 386 | |
| 382 | 387 | |
| r242306 | r242307 | |
| 390 | 395 | save_item(NAME(m_brt)); |
| 391 | 396 | save_item(NAME(m_cont)); |
| 392 | 397 | save_item(NAME(m_via1_irq)); |
| 393 | | save_item(NAME(m_via2_irq)); |
| 394 | 398 | save_item(NAME(m_via3_irq)); |
| 395 | 399 | save_item(NAME(m_fdc_irq)); |
| 396 | 400 | save_item(NAME(m_ssda_irq)); |
| 397 | 401 | |
| 398 | | // memory banking |
| 399 | | address_space &program = m_maincpu->space(AS_PROGRAM); |
| 400 | | program.install_ram(0x00000, m_ram->size() - 1, m_ram->pointer()); |
| 401 | | |
| 402 | 402 | // patch out SCP self test |
| 403 | 403 | m_rom->base()[0x11ab] = 0xc3; |
| 404 | 404 | |
| r242306 | r242307 | |
| 422 | 422 | } |
| 423 | 423 | |
| 424 | 424 | |
| 425 | |
| 425 | 426 | //************************************************************************** |
| 426 | 427 | // MACHINE CONFIGURATION |
| 427 | 428 | //************************************************************************** |
| r242306 | r242307 | |
| 446 | 447 | |
| 447 | 448 | MCFG_PALETTE_ADD_MONOCHROME_GREEN_HIGHLIGHT("palette") |
| 448 | 449 | |
| 449 | | MCFG_MC6845_ADD(HD46505S_TAG, HD6845, SCREEN_TAG, 1000000) // HD6845 == HD46505S |
| 450 | MCFG_MC6845_ADD(HD46505S_TAG, HD6845, SCREEN_TAG, XTAL_30MHz/11) // HD6845 == HD46505S |
| 450 | 451 | MCFG_MC6845_SHOW_BORDER_AREA(true) |
| 451 | 452 | MCFG_MC6845_CHAR_WIDTH(10) |
| 452 | 453 | MCFG_MC6845_UPDATE_ROW_CB(victor9k_state, crtc_update_row) |
| r242306 | r242307 | |
| 501 | 502 | MCFG_DEVICE_ADD(M6522_2_TAG, VIA6522, XTAL_30MHz/30) |
| 502 | 503 | MCFG_VIA6522_WRITEPA_HANDLER(WRITE8(victor9k_state, via2_pa_w)) |
| 503 | 504 | MCFG_VIA6522_WRITEPB_HANDLER(WRITE8(victor9k_state, via2_pb_w)) |
| 504 | | MCFG_VIA6522_IRQ_HANDLER(WRITELINE(victor9k_state, via2_irq_w)) |
| 505 | MCFG_VIA6522_IRQ_HANDLER(DEVWRITELINE(I8259A_TAG, pic8259_device, ir6_w)) |
| 505 | 506 | |
| 506 | 507 | MCFG_DEVICE_ADD(M6522_3_TAG, VIA6522, XTAL_30MHz/30) |
| 507 | 508 | MCFG_VIA6522_WRITEPB_HANDLER(WRITE8(victor9k_state, via3_pb_w)) |
| 508 | 509 | MCFG_VIA6522_IRQ_HANDLER(WRITELINE(victor9k_state, via3_irq_w)) |
| 509 | 510 | |
| 511 | MCFG_CENTRONICS_ADD(CENTRONICS_TAG, centronics_devices, "printer") |
| 512 | MCFG_CENTRONICS_BUSY_HANDLER(DEVWRITELINE(M6522_1_TAG, via6522_device, write_pb5)) |
| 513 | MCFG_CENTRONICS_ACK_HANDLER(DEVWRITELINE(M6522_1_TAG, via6522_device, write_pb6)) |
| 514 | MCFG_CENTRONICS_SELECT_HANDLER(DEVWRITELINE(M6522_1_TAG, via6522_device, write_pb7)) |
| 515 | |
| 510 | 516 | MCFG_RS232_PORT_ADD(RS232_A_TAG, default_rs232_devices, NULL) |
| 511 | 517 | MCFG_RS232_RXD_HANDLER(DEVWRITELINE(UPD7201_TAG, z80dart_device, rxa_w)) |
| 512 | 518 | MCFG_RS232_DCD_HANDLER(DEVWRITELINE(UPD7201_TAG, z80dart_device, dcda_w)) |
| r242306 | r242307 | |
| 521 | 527 | MCFG_RS232_CTS_HANDLER(DEVWRITELINE(UPD7201_TAG, z80dart_device, ctsb_w)) |
| 522 | 528 | MCFG_RS232_DSR_HANDLER(DEVWRITELINE(M6522_2_TAG, via6522_device, write_pa5)) |
| 523 | 529 | |
| 524 | | MCFG_DEVICE_ADD(VICTOR9K_KEYBOARD_TAG, VICTOR9K_KEYBOARD, 0) |
| 530 | MCFG_DEVICE_ADD(KB_TAG, VICTOR9K_KEYBOARD, 0) |
| 525 | 531 | MCFG_VICTOR9K_KBRDY_HANDLER(WRITELINE(victor9k_state, kbrdy_w)) |
| 526 | 532 | MCFG_VICTOR9K_KBDATA_HANDLER(WRITELINE(victor9k_state, kbdata_w)) |
| 527 | 533 | |
| r242306 | r242307 | |
| 533 | 539 | // internal ram |
| 534 | 540 | MCFG_RAM_ADD(RAM_TAG) |
| 535 | 541 | MCFG_RAM_DEFAULT_SIZE("128K") |
| 536 | | MCFG_RAM_EXTRA_OPTIONS("256K,384K,512K,640K,768K,896K") |
| 537 | 542 | |
| 538 | 543 | // software list |
| 539 | 544 | MCFG_SOFTWARE_LIST_ADD("flop_list", "victor9k_flop") |
trunk/src/mess/includes/victor9k.h
| r242306 | r242307 | |
| 15 | 15 | #define __VICTOR9K__ |
| 16 | 16 | |
| 17 | 17 | #include "bus/rs232/rs232.h" |
| 18 | #include "bus/centronics/ctronics.h" |
| 18 | 19 | #include "cpu/i86/i86.h" |
| 19 | 20 | #include "formats/victor9k_dsk.h" |
| 20 | 21 | #include "imagedev/floppy.h" |
| r242306 | r242307 | |
| 47 | 48 | #define RS232_A_TAG "rs232a" |
| 48 | 49 | #define RS232_B_TAG "rs232b" |
| 49 | 50 | #define SCREEN_TAG "screen" |
| 50 | | #define VICTOR9K_KEYBOARD_TAG "victor9kb" |
| 51 | #define KB_TAG "kb" |
| 51 | 52 | #define FDC_TAG "fdc" |
| 52 | 53 | |
| 53 | 54 | class victor9k_state : public driver_device |
| r242306 | r242307 | |
| 66 | 67 | m_cvsd(*this, HC55516_TAG), |
| 67 | 68 | m_crtc(*this, HD46505S_TAG), |
| 68 | 69 | m_ram(*this, RAM_TAG), |
| 69 | | m_kb(*this, VICTOR9K_KEYBOARD_TAG), |
| 70 | m_kb(*this, KB_TAG), |
| 70 | 71 | m_fdc(*this, FDC_TAG), |
| 72 | m_centronics(*this, CENTRONICS_TAG), |
| 71 | 73 | m_rs232a(*this, RS232_A_TAG), |
| 72 | 74 | m_rs232b(*this, RS232_B_TAG), |
| 73 | 75 | m_palette(*this, "palette"), |
| r242306 | r242307 | |
| 76 | 78 | m_brt(0), |
| 77 | 79 | m_cont(0), |
| 78 | 80 | m_via1_irq(CLEAR_LINE), |
| 79 | | m_via2_irq(CLEAR_LINE), |
| 80 | 81 | m_via3_irq(CLEAR_LINE), |
| 81 | 82 | m_fdc_irq(CLEAR_LINE), |
| 82 | 83 | m_ssda_irq(CLEAR_LINE) |
| r242306 | r242307 | |
| 95 | 96 | required_device<ram_device> m_ram; |
| 96 | 97 | required_device<victor9k_keyboard_device> m_kb; |
| 97 | 98 | required_device<victor_9000_fdc_t> m_fdc; |
| 99 | required_device<centronics_device> m_centronics; |
| 98 | 100 | required_device<rs232_port_device> m_rs232a; |
| 99 | 101 | required_device<rs232_port_device> m_rs232b; |
| 100 | 102 | required_device<palette_device> m_palette; |
| r242306 | r242307 | |
| 115 | 117 | DECLARE_WRITE8_MEMBER( via2_pb_w ); |
| 116 | 118 | DECLARE_WRITE_LINE_MEMBER( write_ria ); |
| 117 | 119 | DECLARE_WRITE_LINE_MEMBER( write_rib ); |
| 118 | | DECLARE_WRITE_LINE_MEMBER( via2_irq_w ); |
| 119 | 120 | |
| 120 | 121 | DECLARE_WRITE8_MEMBER( via3_pb_w ); |
| 121 | 122 | DECLARE_WRITE_LINE_MEMBER( via3_irq_w ); |
| r242306 | r242307 | |
| 136 | 137 | |
| 137 | 138 | /* interrupts */ |
| 138 | 139 | int m_via1_irq; |
| 139 | | int m_via2_irq; |
| 140 | 140 | int m_via3_irq; |
| 141 | 141 | int m_fdc_irq; |
| 142 | 142 | int m_ssda_irq; |
trunk/src/mess/machine/victor9kb.c
| r242306 | r242307 | |
| 177 | 177 | PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 178 | 178 | |
| 179 | 179 | PORT_START("Y6") |
| 180 | | PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 181 | | PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 182 | | PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 183 | | PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 184 | | PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 185 | | PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 186 | | PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 187 | | PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| 180 | PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Q) |
| 181 | PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_W) |
| 182 | PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_E) |
| 183 | PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_R) |
| 184 | PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_T) |
| 185 | PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Y) |
| 186 | PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_U) |
| 187 | PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_KEYBOARD ) PORT_CODE(KEYCODE_I) |
| 188 | 188 | |
| 189 | 189 | PORT_START("Y7") |
| 190 | 190 | PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_KEYBOARD ) |
| r242306 | r242307 | |
| 286 | 286 | m_kbrdy_handler(*this), |
| 287 | 287 | m_kbdata_handler(*this), |
| 288 | 288 | m_y(0), |
| 289 | | m_kbrdy(1), |
| 290 | | m_kbdata(1), |
| 289 | m_kbrdy(-1), |
| 290 | m_kbdata(-1), |
| 291 | 291 | m_kback(1) |
| 292 | 292 | { |
| 293 | 293 | } |
| r242306 | r242307 | |
| 371 | 371 | m_y = data & 0x0f; |
| 372 | 372 | } |
| 373 | 373 | |
| 374 | | //logerror("P1 %02x\n", data); |
| 374 | //logerror("%s P1 %02x\n", machine().describe_context(), data); |
| 375 | 375 | } |
| 376 | 376 | |
| 377 | 377 | |
| r242306 | r242307 | |
| 408 | 408 | m_kbdata_handler(m_kbdata); |
| 409 | 409 | } |
| 410 | 410 | |
| 411 | | //logerror("P2 %02x\n", data); |
| 411 | //logerror("%s P2 %01x\n", machine().describe_context(), data&0x0f); |
| 412 | 412 | } |
| 413 | 413 | |
| 414 | 414 | |