trunk/src/mess/drivers/timex.c
| r32395 | r32396 | |
| 157 | 157 | #include "machine/beta.h" |
| 158 | 158 | #include "machine/ram.h" |
| 159 | 159 | |
| 160 | | enum |
| 161 | | { |
| 162 | | TIMEX_CART_NONE, |
| 163 | | TIMEX_CART_DOCK, |
| 164 | | TIMEX_CART_EXROM, |
| 165 | | TIMEX_CART_HOME |
| 166 | | }; |
| 167 | | |
| 168 | | struct timex_cart_t |
| 169 | | { |
| 170 | | int type; |
| 171 | | UINT8 chunks; |
| 172 | | UINT8 *data; |
| 173 | | }; |
| 174 | | |
| 175 | | static timex_cart_t timex_cart; |
| 176 | | |
| 177 | | const timex_cart_t *timex_cart_data(void) |
| 178 | | { |
| 179 | | return &timex_cart; |
| 180 | | } |
| 181 | | |
| 182 | 160 | /****************************************************************************************************/ |
| 183 | 161 | /* TS2048 specific functions */ |
| 184 | 162 | |
| r32395 | r32396 | |
| 234 | 212 | { |
| 235 | 213 | UINT8 *messram = m_ram->pointer(); |
| 236 | 214 | address_space &space = m_maincpu->space(AS_PROGRAM); |
| 237 | | unsigned char *ChosenROM, *ExROM; |
| 238 | | const timex_cart_t *timex_cart = timex_cart_data(); |
| 239 | | int timex_cart_type = timex_cart->type; |
| 240 | | UINT8 timex_cart_chunks = timex_cart->chunks; |
| 241 | | UINT8 *DOCK = timex_cart->data; |
| 215 | UINT8 *DOCK = m_dock_crt->base(); |
| 216 | UINT8 *ExROM = memregion("maincpu")->base() + 0x014000; |
| 217 | UINT8 *ChosenROM; |
| 242 | 218 | |
| 243 | | ExROM = memregion("maincpu")->base() + 0x014000; |
| 244 | | |
| 245 | 219 | if (m_port_f4_data & 0x01) |
| 246 | 220 | { |
| 247 | 221 | if (m_port_ff_data & 0x80) |
| r32395 | r32396 | |
| 253 | 227 | } |
| 254 | 228 | else |
| 255 | 229 | { |
| 256 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 230 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 257 | 231 | { |
| 258 | 232 | membank("bank1")->set_base(DOCK); |
| 259 | 233 | space.install_read_bank(0x0000, 0x1fff, "bank1"); |
| 260 | | if (timex_cart_chunks&0x01) |
| 234 | if (m_ram_chunks & 0x01) |
| 261 | 235 | space.install_write_bank(0x0000, 0x1fff, "bank9"); |
| 262 | 236 | else |
| 263 | 237 | space.unmap_write(0x0000, 0x1fff); |
| r32395 | r32396 | |
| 292 | 266 | } |
| 293 | 267 | else |
| 294 | 268 | { |
| 295 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 269 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 296 | 270 | { |
| 297 | 271 | membank("bank2")->set_base(DOCK+0x2000); |
| 298 | 272 | space.install_read_bank(0x2000, 0x3fff, "bank2"); |
| 299 | | if (timex_cart_chunks&0x02) |
| 273 | if (m_ram_chunks & 0x02) |
| 300 | 274 | space.install_write_bank(0x2000, 0x3fff, "bank10"); |
| 301 | 275 | else |
| 302 | 276 | space.unmap_write(0x2000, 0x3fff); |
| r32395 | r32396 | |
| 330 | 304 | } |
| 331 | 305 | else |
| 332 | 306 | { |
| 333 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 307 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 334 | 308 | { |
| 335 | 309 | membank("bank3")->set_base(DOCK+0x4000); |
| 336 | 310 | space.install_read_bank(0x4000, 0x5fff, "bank3"); |
| 337 | | if (timex_cart_chunks&0x04) |
| 311 | if (m_ram_chunks & 0x04) |
| 338 | 312 | space.install_write_bank(0x4000, 0x5fff, "bank11"); |
| 339 | 313 | else |
| 340 | 314 | space.unmap_write(0x4000, 0x5fff); |
| r32395 | r32396 | |
| 367 | 341 | } |
| 368 | 342 | else |
| 369 | 343 | { |
| 370 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 344 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 371 | 345 | { |
| 372 | 346 | membank("bank4")->set_base(DOCK+0x6000); |
| 373 | 347 | space.install_read_bank(0x6000, 0x7fff, "bank4"); |
| 374 | | if (timex_cart_chunks&0x08) |
| 348 | if (m_ram_chunks & 0x08) |
| 375 | 349 | space.install_write_bank(0x6000, 0x7fff, "bank12"); |
| 376 | 350 | else |
| 377 | 351 | space.unmap_write(0x6000, 0x7fff); |
| r32395 | r32396 | |
| 404 | 378 | } |
| 405 | 379 | else |
| 406 | 380 | { |
| 407 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 381 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 408 | 382 | { |
| 409 | 383 | membank("bank5")->set_base(DOCK+0x8000); |
| 410 | 384 | space.install_read_bank(0x8000, 0x9fff,"bank5"); |
| 411 | | if (timex_cart_chunks&0x10) |
| 385 | if (m_ram_chunks & 0x10) |
| 412 | 386 | space.install_write_bank(0x8000, 0x9fff,"bank13"); |
| 413 | 387 | else |
| 414 | 388 | space.unmap_write(0x8000, 0x9fff); |
| r32395 | r32396 | |
| 441 | 415 | } |
| 442 | 416 | else |
| 443 | 417 | { |
| 444 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 418 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 445 | 419 | { |
| 446 | 420 | membank("bank6")->set_base(DOCK+0xa000); |
| 447 | 421 | space.install_read_bank(0xa000, 0xbfff, "bank6"); |
| 448 | | if (timex_cart_chunks&0x20) |
| 422 | if (m_ram_chunks & 0x20) |
| 449 | 423 | space.install_write_bank(0xa000, 0xbfff, "bank14"); |
| 450 | 424 | else |
| 451 | 425 | space.unmap_write(0xa000, 0xbfff); |
| r32395 | r32396 | |
| 479 | 453 | } |
| 480 | 454 | else |
| 481 | 455 | { |
| 482 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 456 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 483 | 457 | { |
| 484 | 458 | membank("bank7")->set_base(DOCK+0xc000); |
| 485 | 459 | space.install_read_bank(0xc000, 0xdfff, "bank7"); |
| 486 | | if (timex_cart_chunks&0x40) |
| 460 | if (m_ram_chunks & 0x40) |
| 487 | 461 | space.install_write_bank(0xc000, 0xdfff, "bank15"); |
| 488 | 462 | else |
| 489 | 463 | space.unmap_write(0xc000, 0xdfff); |
| r32395 | r32396 | |
| 516 | 490 | } |
| 517 | 491 | else |
| 518 | 492 | { |
| 519 | | if (timex_cart_type == TIMEX_CART_DOCK) |
| 493 | if (m_dock_cart_type == TIMEX_CART_DOCK) |
| 520 | 494 | { |
| 521 | 495 | membank("bank8")->set_base(DOCK+0xe000); |
| 522 | 496 | space.install_read_bank(0xe000, 0xffff, "bank8"); |
| 523 | | if (timex_cart_chunks&0x80) |
| 497 | if (m_ram_chunks & 0x80) |
| 524 | 498 | space.install_write_bank(0xe000, 0xffff, "bank16"); |
| 525 | 499 | else |
| 526 | 500 | space.unmap_write(0xe000, 0xffff); |
| r32395 | r32396 | |
| 570 | 544 | { |
| 571 | 545 | m_port_ff_data = 0; |
| 572 | 546 | m_port_f4_data = 0; |
| 547 | |
| 548 | astring region_tag; |
| 549 | m_dock_crt = memregion(region_tag.cpy(m_dock->tag()).cat(GENERIC_ROM_REGION_TAG)); |
| 550 | m_dock_cart_type = (m_dock->exists()) ? TIMEX_CART_DOCK : TIMEX_CART_NONE; |
| 551 | |
| 573 | 552 | ts2068_update_memory(); |
| 574 | 553 | MACHINE_RESET_CALL_MEMBER(spectrum); |
| 575 | | |
| 576 | 554 | } |
| 577 | 555 | |
| 578 | 556 | |
| r32395 | r32396 | |
| 613 | 591 | |
| 614 | 592 | DEVICE_IMAGE_LOAD_MEMBER( spectrum_state, timex_cart ) |
| 615 | 593 | { |
| 616 | | int file_size; |
| 617 | | dynamic_buffer file_data; |
| 618 | | |
| 594 | UINT32 size = m_dock->common_get_size("rom"); |
| 595 | UINT8 *DOCK; |
| 619 | 596 | int chunks_in_file = 0; |
| 597 | dynamic_buffer header; |
| 598 | header.resize(9); |
| 620 | 599 | |
| 621 | | int i; |
| 622 | | |
| 623 | | logerror ("Trying to load cart\n"); |
| 624 | | |
| 625 | | file_size = image.length(); |
| 626 | | |
| 627 | | if (file_size < 0x09) |
| 600 | if (size % 0x2000 != 9) |
| 628 | 601 | { |
| 629 | | logerror ("Bad file size\n"); |
| 602 | image.seterror(IMAGE_ERROR_UNSPECIFIED, "File corrupted"); |
| 630 | 603 | return IMAGE_INIT_FAIL; |
| 631 | 604 | } |
| 632 | | |
| 633 | | file_data.resize(file_size); |
| 634 | | |
| 635 | | image.fread(file_data, file_size); |
| 636 | | |
| 637 | | for (i=0; i<8; i++) |
| 638 | | if(file_data[i+1]&0x02) chunks_in_file++; |
| 639 | | |
| 640 | | if (chunks_in_file*0x2000+0x09 != file_size) |
| 605 | if (image.software_entry() != NULL) |
| 641 | 606 | { |
| 642 | | logerror ("File corrupted\n"); |
| 607 | image.seterror(IMAGE_ERROR_UNSPECIFIED, "Loading from softlist is not supported yet"); |
| 643 | 608 | return IMAGE_INIT_FAIL; |
| 644 | 609 | } |
| 610 | |
| 611 | m_dock->rom_alloc(0x10000, GENERIC_ROM8_WIDTH, ENDIANNESS_LITTLE); |
| 612 | DOCK = m_dock->get_rom_base(); |
| 645 | 613 | |
| 646 | | switch (file_data[0x00]) |
| 614 | // check header |
| 615 | image.fread(header, 9); |
| 616 | |
| 617 | for (int i = 0; i < 8; i++) |
| 618 | if (header[i + 1] & 0x02) chunks_in_file++; |
| 619 | |
| 620 | if (chunks_in_file * 0x2000 + 0x09 != size) |
| 647 | 621 | { |
| 622 | image.seterror(IMAGE_ERROR_UNSPECIFIED, "File corrupted"); |
| 623 | return IMAGE_INIT_FAIL; |
| 624 | } |
| 625 | |
| 626 | switch (header[0]) |
| 627 | { |
| 648 | 628 | case 0x00: logerror ("DOCK cart\n"); |
| 649 | | timex_cart.type = TIMEX_CART_DOCK; |
| 650 | | timex_cart.data = global_alloc_array(UINT8, 0x10000); |
| 651 | | if (!timex_cart.data) |
| 629 | m_ram_chunks = 0; |
| 630 | for (int i = 0; i < 8; i++) |
| 631 | { |
| 632 | m_ram_chunks = m_ram_chunks | ((header[i + 1] & 0x01) << i); |
| 633 | if (header[i + 1] & 0x02) |
| 634 | image.fread(DOCK + i * 0x2000, 0x2000); |
| 635 | else |
| 652 | 636 | { |
| 653 | | logerror ("Memory allocate error\n"); |
| 654 | | return IMAGE_INIT_FAIL; |
| 655 | | } |
| 656 | | chunks_in_file = 0; |
| 657 | | for (i=0; i<8; i++) |
| 658 | | { |
| 659 | | timex_cart.chunks = timex_cart.chunks | ((file_data[i+1]&0x01)<<i); |
| 660 | | if (file_data[i+1]&0x02) |
| 661 | | { |
| 662 | | memcpy (timex_cart.data+i*0x2000, file_data+0x09+chunks_in_file*0x2000, 0x2000); |
| 663 | | chunks_in_file++; |
| 664 | | } |
| 637 | if (header[i + 1] & 0x01) |
| 638 | memset(DOCK + i * 0x2000, 0x00, 0x2000); |
| 665 | 639 | else |
| 666 | | { |
| 667 | | if (file_data[i+1]&0x01) |
| 668 | | memset (timex_cart.data+i*0x2000, 0x00, 0x2000); |
| 669 | | else |
| 670 | | memset (timex_cart.data+i*0x2000, 0xff, 0x2000); |
| 671 | | } |
| 640 | memset(DOCK + i * 0x2000, 0xff, 0x2000); |
| 672 | 641 | } |
| 673 | | break; |
| 674 | | |
| 675 | | default: logerror ("Cart type not supported\n"); |
| 676 | | timex_cart.type = TIMEX_CART_NONE; |
| 677 | | return IMAGE_INIT_FAIL; |
| 642 | } |
| 643 | break; |
| 644 | |
| 645 | default: |
| 646 | image.seterror(IMAGE_ERROR_UNSPECIFIED, "Cart type not supported"); |
| 647 | return IMAGE_INIT_FAIL; |
| 678 | 648 | } |
| 649 | |
| 650 | logerror ("Cart loaded [Chunks %02x]\n", m_ram_chunks); |
| 679 | 651 | |
| 680 | | logerror ("Cart loaded\n"); |
| 681 | | logerror ("Chunks %02x\n", timex_cart.chunks); |
| 682 | 652 | return IMAGE_INIT_PASS; |
| 683 | 653 | } |
| 684 | 654 | |
| 685 | 655 | |
| 686 | | DEVICE_IMAGE_UNLOAD_MEMBER( spectrum_state, timex_cart ) |
| 687 | | { |
| 688 | | if (timex_cart.data) |
| 689 | | { |
| 690 | | global_free_array(timex_cart.data); |
| 691 | | timex_cart.data = NULL; |
| 692 | | } |
| 693 | | timex_cart.type = TIMEX_CART_NONE; |
| 694 | | timex_cart.chunks = 0x00; |
| 695 | | } |
| 696 | | |
| 697 | | |
| 698 | 656 | /* F4 Character Displayer - tc2048 code is inherited from the spectrum */ |
| 699 | 657 | static const gfx_layout ts2068_charlayout = |
| 700 | 658 | { |
| r32395 | r32396 | |
| 737 | 695 | |
| 738 | 696 | /* cartridge */ |
| 739 | 697 | MCFG_DEVICE_REMOVE("cartslot") |
| 698 | MCFG_GENERIC_CARTSLOT_ADD("dockslot", generic_plain_slot, NULL) |
| 699 | MCFG_GENERIC_EXTENSIONS("dck") |
| 700 | MCFG_GENERIC_LOAD(spectrum_state, timex_cart) |
| 740 | 701 | |
| 741 | | MCFG_CARTSLOT_ADD("cart") |
| 742 | | MCFG_CARTSLOT_EXTENSION_LIST("dck") |
| 743 | | MCFG_CARTSLOT_NOT_MANDATORY |
| 744 | | MCFG_CARTSLOT_LOAD(spectrum_state,timex_cart) |
| 745 | | MCFG_CARTSLOT_UNLOAD(spectrum_state,timex_cart) |
| 746 | | |
| 747 | 702 | /* internal ram */ |
| 748 | 703 | MCFG_RAM_MODIFY(RAM_TAG) |
| 749 | 704 | MCFG_RAM_DEFAULT_SIZE("48K") |
| r32395 | r32396 | |
| 788 | 743 | ROM_START(tc2048) |
| 789 | 744 | ROM_REGION(0x10000,"maincpu",0) |
| 790 | 745 | ROM_LOAD("tc2048.rom",0x0000,0x4000, CRC(f1b5fa67) SHA1(febb2d495b6eda7cdcb4074935d6e9d9f328972d)) |
| 791 | | ROM_CART_LOAD("cart", 0x0000, 0x4000, ROM_NOCLEAR | ROM_NOMIRROR | ROM_OPTIONAL) |
| 792 | 746 | ROM_END |
| 793 | 747 | |
| 794 | 748 | ROM_START(ts2068) |
trunk/src/mess/drivers/radio86.c
| r32395 | r32396 | |
| 12 | 12 | #include "sound/wave.h" |
| 13 | 13 | #include "machine/i8255.h" |
| 14 | 14 | #include "imagedev/cassette.h" |
| 15 | | #include "imagedev/cartslot.h" |
| 16 | 15 | #include "formats/rk_cas.h" |
| 17 | 16 | #include "includes/radio86.h" |
| 18 | 17 | |
| r32395 | r32396 | |
| 379 | 378 | MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_STOPPED | CASSETTE_SPEAKER_ENABLED | CASSETTE_MOTOR_ENABLED) |
| 380 | 379 | MCFG_CASSETTE_INTERFACE("radio86_cass") |
| 381 | 380 | |
| 382 | | MCFG_SOFTWARE_LIST_ADD("cass_list","radio86") |
| 381 | MCFG_SOFTWARE_LIST_ADD("cass_list", "radio86_cass") |
| 383 | 382 | MACHINE_CONFIG_END |
| 384 | 383 | |
| 385 | 384 | |
| r32395 | r32396 | |
| 395 | 394 | MCFG_CPU_PROGRAM_MAP(radio86rom_mem) |
| 396 | 395 | |
| 397 | 396 | MCFG_DEVICE_ADD("ppi8255_2", I8255, 0) |
| 398 | | MCFG_I8255_IN_PORTA_CB(READ8(radio86_state, radio86_romdisk_porta_r)) |
| 397 | MCFG_I8255_IN_PORTA_CB(READ8(radio86_state, radio86rom_romdisk_porta_r)) |
| 399 | 398 | MCFG_I8255_OUT_PORTB_CB(WRITE8(radio86_state, radio86_romdisk_portb_w)) |
| 400 | 399 | MCFG_I8255_OUT_PORTC_CB(WRITE8(radio86_state, radio86_romdisk_portc_w)) |
| 401 | 400 | |
| 402 | | MCFG_CARTSLOT_ADD("cart") |
| 403 | | MCFG_CARTSLOT_EXTENSION_LIST("bin,rom") |
| 404 | | MCFG_CARTSLOT_NOT_MANDATORY |
| 401 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_plain_slot, "radio86_cart") |
| 402 | MCFG_GENERIC_EXTENSIONS("bin,rom") |
| 403 | |
| 404 | MCFG_SOFTWARE_LIST_ADD("cart_list", "radio86_cart") |
| 405 | 405 | MACHINE_CONFIG_END |
| 406 | 406 | |
| 407 | 407 | static MACHINE_CONFIG_DERIVED( radioram, radio86 ) |
| r32395 | r32396 | |
| 410 | 410 | MCFG_CPU_PROGRAM_MAP(radio86ram_mem) |
| 411 | 411 | |
| 412 | 412 | MCFG_DEVICE_ADD("ppi8255_2", I8255, 0) |
| 413 | | MCFG_I8255_IN_PORTA_CB(READ8(radio86_state, radio86_romdisk_porta_r)) |
| 413 | MCFG_I8255_IN_PORTA_CB(READ8(radio86_state, radio86ram_romdisk_porta_r)) |
| 414 | 414 | MCFG_I8255_OUT_PORTB_CB(WRITE8(radio86_state, radio86_romdisk_portb_w)) |
| 415 | 415 | MCFG_I8255_OUT_PORTC_CB(WRITE8(radio86_state, radio86_romdisk_portc_w)) |
| 416 | 416 | MACHINE_CONFIG_END |
| r32395 | r32396 | |
| 486 | 486 | ROM_START( radiorom ) |
| 487 | 487 | ROM_REGION( 0x20000, "maincpu", ROMREGION_ERASEFF ) |
| 488 | 488 | ROM_SYSTEM_BIOS(0, "32k", "32 KB rom disk") |
| 489 | | ROMX_LOAD( "radiorom.rom", 0xf800, 0x0800, CRC(B5CDEAB7) SHA1(1c80d72082f2fb2190b575726cb82d86ae0ee7d8), ROM_BIOS(1)) |
| 489 | ROMX_LOAD( "radiorom.rom", 0xf800, 0x0800, CRC(b5cdeab7) SHA1(1c80d72082f2fb2190b575726cb82d86ae0ee7d8), ROM_BIOS(1)) |
| 490 | 490 | ROM_SYSTEM_BIOS(1, "64k", "64 KB rom disk") |
| 491 | 491 | ROMX_LOAD( "radiorom.64", 0xf800, 0x0800, CRC(5250b927) SHA1(e885e0f5b2325190b38a4c92b20a8b4fa78fbd8f), ROM_BIOS(2)) |
| 492 | 492 | ROM_COPY( "maincpu", 0xf800, 0xf000, 0x0800 ) |
| 493 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_NOMIRROR | ROM_OPTIONAL) |
| 494 | 493 | ROM_REGION(0x0800, "gfx1",0) |
| 495 | 494 | ROM_LOAD ("radio86.fnt", 0x0000, 0x0400, CRC(7666bd5e) SHA1(8652787603bee9b4da204745e3b2aa07a4783dfc)) |
| 496 | 495 | ROM_END |
| 497 | 496 | |
| 498 | 497 | ROM_START( radioram ) |
| 499 | 498 | ROM_REGION( 0x20000, "maincpu", ROMREGION_ERASEFF ) |
| 500 | | ROM_LOAD( "r86-1.bin", 0xf800, 0x0800, CRC(7E7AB7CB) SHA1(fedb00b6b8fbe1167faba3e4611b483f800e6934)) |
| 499 | ROM_LOAD( "r86-1.bin", 0xf800, 0x0800, CRC(7e7ab7cb) SHA1(fedb00b6b8fbe1167faba3e4611b483f800e6934)) |
| 501 | 500 | ROM_LOAD( "r86-2.bin", 0xe000, 0x0800, CRC(955F0616) SHA1(d2b9f960558bdcb60074091fc79d1ad56c313586)) |
| 502 | | ROM_LOAD( "romdisk.bin", 0x10000, 0x10000, CRC(43C0279B) SHA1(bc1dfd9bdbce39460616e2158f5d96279d0af3cf)) |
| 501 | ROM_LOAD( "romdisk.bin", 0x10000, 0x10000, CRC(43c0279b) SHA1(bc1dfd9bdbce39460616e2158f5d96279d0af3cf)) |
| 503 | 502 | ROM_REGION(0x0800, "gfx1",0) |
| 504 | 503 | ROM_LOAD ("radio86.fnt", 0x0000, 0x0400, CRC(7666bd5e) SHA1(8652787603bee9b4da204745e3b2aa07a4783dfc)) |
| 505 | 504 | ROM_END |
| 506 | 505 | |
| 507 | 506 | ROM_START( rk7007 ) |
| 508 | 507 | ROM_REGION( 0x10000, "maincpu", ROMREGION_ERASEFF ) |
| 509 | | ROM_LOAD( "ms7007.rom", 0xf800, 0x0800, CRC(002811DC) SHA1(4529eb72198c49af77fbcd7833bcd06a1cf9b1ac)) |
| 508 | ROM_LOAD( "ms7007.rom", 0xf800, 0x0800, CRC(002811dc) SHA1(4529eb72198c49af77fbcd7833bcd06a1cf9b1ac)) |
| 510 | 509 | ROM_COPY( "maincpu", 0xf800, 0xf000, 0x0800 ) |
| 511 | 510 | ROM_REGION(0x0800, "gfx1",0) |
| 512 | 511 | ROM_LOAD ("radio86.fnt", 0x0000, 0x0400, CRC(7666bd5e) SHA1(8652787603bee9b4da204745e3b2aa07a4783dfc)) |
| r32395 | r32396 | |
| 514 | 513 | |
| 515 | 514 | ROM_START( rk700716 ) |
| 516 | 515 | ROM_REGION( 0x10000, "maincpu", ROMREGION_ERASEFF ) |
| 517 | | ROM_LOAD( "ms7007.16k", 0xf800, 0x0800, CRC(5268D7B6) SHA1(efd69d8456b8cf8b37f33237153c659725608528)) |
| 516 | ROM_LOAD( "ms7007.16k", 0xf800, 0x0800, CRC(5268d7b6) SHA1(efd69d8456b8cf8b37f33237153c659725608528)) |
| 518 | 517 | ROM_COPY( "maincpu", 0xf800, 0xf000, 0x0800 ) |
| 519 | 518 | ROM_REGION(0x0800, "gfx1",0) |
| 520 | 519 | ROM_LOAD ("radio86.fnt", 0x0000, 0x0400, CRC(7666bd5e) SHA1(8652787603bee9b4da204745e3b2aa07a4783dfc)) |
| r32395 | r32396 | |
| 530 | 529 | |
| 531 | 530 | ROM_START( kr03 ) |
| 532 | 531 | ROM_REGION( 0x10000, "maincpu", ROMREGION_ERASEFF ) |
| 533 | | ROM_LOAD( "kr03-dd17.rf2", 0xf800, 0x0800, CRC(AC2E24D5) SHA1(a1317a261bfd55b3b37109b14d1391308dee04de)) |
| 532 | ROM_LOAD( "kr03-dd17.rf2", 0xf800, 0x0800, CRC(ac2e24d5) SHA1(a1317a261bfd55b3b37109b14d1391308dee04de)) |
| 534 | 533 | ROM_COPY( "maincpu", 0xf800, 0xf000, 0x0800 ) |
| 535 | 534 | ROM_REGION(0x0800, "gfx1",0) |
| 536 | 535 | ROM_LOAD ("kr03-dd12.rf2", 0x0000, 0x0800, CRC(085F4259) SHA1(11c5829b072a00961ad936c26559fb63bf2dc896)) |
trunk/src/mess/drivers/orion.c
| r32395 | r32396 | |
| 9 | 9 | |
| 10 | 10 | |
| 11 | 11 | #include "emu.h" |
| 12 | | #include "cpu/z80/z80.h" |
| 13 | | #include "cpu/i8085/i8085.h" |
| 14 | | #include "sound/ay8910.h" |
| 15 | | #include "sound/wave.h" |
| 12 | #include "includes/orion.h" |
| 16 | 13 | #include "imagedev/cassette.h" |
| 17 | | #include "imagedev/cartslot.h" |
| 18 | 14 | #include "formats/smx_dsk.h" |
| 19 | 15 | #include "formats/rk_cas.h" |
| 20 | | #include "includes/orion.h" |
| 21 | 16 | |
| 22 | 17 | /* Address maps */ |
| 23 | 18 | |
| r32395 | r32396 | |
| 124 | 119 | MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_STOPPED | CASSETTE_SPEAKER_ENABLED | CASSETTE_MOTOR_ENABLED) |
| 125 | 120 | MCFG_CASSETTE_INTERFACE("orion_cass") |
| 126 | 121 | |
| 127 | | MCFG_SOFTWARE_LIST_ADD("cass_list","orion_cass") |
| 122 | MCFG_SOFTWARE_LIST_ADD("cass_list", "orion_cass") |
| 128 | 123 | |
| 129 | 124 | MCFG_FD1793x_ADD("fd1793", XTAL_8MHz / 8) |
| 130 | 125 | |
| r32395 | r32396 | |
| 134 | 129 | MCFG_FLOPPY_DRIVE_ADD("fd3", orion_floppies, "525qd", orion_state::orion_floppy_formats) |
| 135 | 130 | MCFG_SOFTWARE_LIST_ADD("flop_list","orion_flop") |
| 136 | 131 | |
| 137 | | MCFG_CARTSLOT_ADD("cart") |
| 138 | | MCFG_CARTSLOT_INTERFACE("orion_cart") |
| 139 | | MCFG_SOFTWARE_LIST_ADD("cart_list","orion_cart") |
| 132 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_plain_slot, "orion_cart") |
| 140 | 133 | |
| 134 | MCFG_SOFTWARE_LIST_ADD("cart_list", "orion_cart") |
| 135 | |
| 141 | 136 | /* internal ram */ |
| 142 | 137 | MCFG_RAM_ADD(RAM_TAG) |
| 143 | 138 | MCFG_RAM_DEFAULT_SIZE("256K") |
| r32395 | r32396 | |
| 203 | 198 | MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_STOPPED | CASSETTE_SPEAKER_ENABLED | CASSETTE_MOTOR_ENABLED) |
| 204 | 199 | MCFG_CASSETTE_INTERFACE("orion_cass") |
| 205 | 200 | |
| 206 | | MCFG_SOFTWARE_LIST_ADD("cass_list","orion_cass") |
| 201 | MCFG_SOFTWARE_LIST_ADD("cass_list", "orion_cass") |
| 207 | 202 | |
| 208 | 203 | MCFG_FD1793x_ADD("fd1793", XTAL_8MHz / 8) |
| 209 | 204 | |
| r32395 | r32396 | |
| 213 | 208 | MCFG_FLOPPY_DRIVE_ADD("fd3", orion_floppies, "525qd", orion_state::orion_floppy_formats) |
| 214 | 209 | MCFG_SOFTWARE_LIST_ADD("flop_list","orion_flop") |
| 215 | 210 | |
| 216 | | MCFG_CARTSLOT_ADD("cart") |
| 217 | | MCFG_CARTSLOT_INTERFACE("orion_cart") |
| 218 | | MCFG_SOFTWARE_LIST_ADD("cart_list","orion_cart") |
| 211 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_plain_slot, "orion_cart") |
| 219 | 212 | |
| 213 | MCFG_SOFTWARE_LIST_ADD("cart_list", "orion_cart") |
| 214 | |
| 220 | 215 | /* internal ram */ |
| 221 | 216 | MCFG_RAM_ADD(RAM_TAG) |
| 222 | 217 | MCFG_RAM_DEFAULT_SIZE("512K") |
| r32395 | r32396 | |
| 278 | 273 | MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_STOPPED | CASSETTE_SPEAKER_ENABLED | CASSETTE_MOTOR_ENABLED) |
| 279 | 274 | MCFG_CASSETTE_INTERFACE("orion_cass") |
| 280 | 275 | |
| 281 | | MCFG_SOFTWARE_LIST_ADD("cass_list","orion_cass") |
| 276 | MCFG_SOFTWARE_LIST_ADD("cass_list", "orion_cass") |
| 282 | 277 | |
| 283 | 278 | MCFG_FD1793x_ADD("fd1793", XTAL_8MHz / 8) |
| 284 | 279 | |
| r32395 | r32396 | |
| 289 | 284 | MCFG_SOFTWARE_LIST_ADD("flop_list","orionpro_flop") |
| 290 | 285 | MCFG_SOFTWARE_LIST_COMPATIBLE_ADD("flop128_list","orion_flop") |
| 291 | 286 | |
| 292 | | MCFG_CARTSLOT_ADD("cart") |
| 293 | | MCFG_CARTSLOT_INTERFACE("orion_cart") |
| 294 | | MCFG_SOFTWARE_LIST_ADD("cart_list","orion_cart") |
| 287 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_plain_slot, "orion_cart") |
| 295 | 288 | |
| 289 | MCFG_SOFTWARE_LIST_ADD("cart_list", "orion_cart") |
| 290 | |
| 296 | 291 | /* internal ram */ |
| 297 | 292 | MCFG_RAM_ADD(RAM_TAG) |
| 298 | 293 | MCFG_RAM_DEFAULT_SIZE("512K") |
| r32395 | r32396 | |
| 307 | 302 | ROMX_LOAD( "m2rk.bin", 0x0f800, 0x0800, CRC(2025c234) SHA1(caf86918629be951fe698cddcdf4589f07e2fb96), ROM_BIOS(1) ) |
| 308 | 303 | ROM_SYSTEM_BIOS( 1, "m2_2rk", "Version 3.2.2 rk" ) |
| 309 | 304 | ROMX_LOAD( "m2_2rk.bin", 0x0f800, 0x0800, CRC(fc662351) SHA1(7c6de67127fae5869281449de1c503597c0c058e), ROM_BIOS(2) ) |
| 310 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_OPTIONAL) |
| 311 | 305 | ROM_END |
| 312 | 306 | |
| 313 | 307 | ROM_START( orionms ) |
| 314 | 308 | ROM_REGION( 0x30000, "maincpu", ROMREGION_ERASEFF ) |
| 315 | 309 | ROM_LOAD( "ms7007.bin", 0x0f800, 0x0800, CRC(c6174ba3) SHA1(8f9a42c3e09684718fe4121a8408e7860129d26f) ) |
| 316 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_OPTIONAL) |
| 317 | 310 | ROM_END |
| 318 | 311 | |
| 319 | 312 | ROM_START( orionz80 ) |
| r32395 | r32396 | |
| 330 | 323 | ROMX_LOAD( "m35zrkd.bin", 0x0f800, 0x0800, CRC(9368b38f) SHA1(64a77f22119d40c9b18b64d78ad12acc6fff9efb), ROM_BIOS(5) ) |
| 331 | 324 | ROM_SYSTEM_BIOS( 5, "peter", "Peterburg '91" ) |
| 332 | 325 | ROMX_LOAD( "peter.bin", 0x0f800, 0x0800, CRC(df9b1d8c) SHA1(c7f1e074e58ad1c1799cf522161b4f4cffa5aefa), ROM_BIOS(6) ) |
| 333 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_OPTIONAL) |
| 334 | 326 | ROM_END |
| 335 | 327 | |
| 336 | 328 | ROM_START( orionide ) |
| 337 | 329 | ROM_REGION( 0x30000, "maincpu", ROMREGION_ERASEFF ) |
| 338 | 330 | ROM_LOAD( "m35zrkh.bin", 0x0f800, 0x0800, CRC(b7745f28) SHA1(c3bd3e662db7ec56ecbab54bf6b3a4c26200d0bb) ) |
| 339 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_OPTIONAL) |
| 340 | 331 | ROM_END |
| 341 | 332 | |
| 342 | 333 | ROM_START( orionzms ) |
| r32395 | r32396 | |
| 347 | 338 | ROMX_LOAD( "m34zms.bin", 0x0f800, 0x0800, CRC(0f87a80b) SHA1(ab1121092e61268d8162ed8a7d4fd081016a409a), ROM_BIOS(2) ) |
| 348 | 339 | ROM_SYSTEM_BIOS( 2, "m35zmsd", "Version 3.5 zmsd" ) |
| 349 | 340 | ROMX_LOAD( "m35zmsd.bin", 0x0f800, 0x0800, CRC(f714ff37) SHA1(fbe9514adb3384aff146cbedd4fede37ce9591e1), ROM_BIOS(3) ) |
| 350 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_OPTIONAL) |
| 351 | 341 | ROM_END |
| 352 | 342 | |
| 353 | 343 | ROM_START( orionidm ) |
| 354 | 344 | ROM_REGION( 0x30000, "maincpu", ROMREGION_ERASEFF ) |
| 355 | 345 | ROM_LOAD( "m35zmsh.bin", 0x0f800, 0x0800, CRC(01e66df4) SHA1(8c785a3c32fe3eacda73ec79157b41a6e4b63ba8) ) |
| 356 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_OPTIONAL) |
| 357 | 346 | ROM_END |
| 358 | 347 | |
| 359 | 348 | ROM_START( orionpro ) |
| 360 | 349 | ROM_REGION( 0x32000, "maincpu", ROMREGION_ERASEFF ) |
| 361 | | ROM_CART_LOAD("cart", 0x10000, 0x10000, ROM_OPTIONAL) |
| 362 | 350 | ROM_SYSTEM_BIOS( 0, "ver21", "Version 2.1" ) |
| 363 | 351 | ROMX_LOAD( "rom1-210.bin", 0x20000, 0x2000, CRC(8e1a0c78) SHA1(61c8a5ed596ce7e3fd32da920dcc80dc5375b421), ROM_BIOS(1) ) |
| 364 | 352 | ROMX_LOAD( "rom2-210.bin", 0x22000, 0x10000, CRC(7cb7a49b) SHA1(601f3dd61db323407c4874fd7f23c10dccac0209), ROM_BIOS(1) ) |
trunk/src/mess/drivers/pv1000.c
| r32395 | r32396 | |
| 6 | 6 | |
| 7 | 7 | #include "emu.h" |
| 8 | 8 | #include "cpu/z80/z80.h" |
| 9 | | #include "imagedev/cartslot.h" |
| 9 | #include "bus/generic/slot.h" |
| 10 | #include "bus/generic/carts.h" |
| 10 | 11 | |
| 11 | 12 | // PV-1000 Sound device |
| 12 | 13 | |
| r32395 | r32396 | |
| 143 | 144 | : driver_device(mconfig, type, tag), |
| 144 | 145 | m_maincpu(*this, "maincpu"), |
| 145 | 146 | m_sound(*this, "pv1000_sound"), |
| 147 | m_cart(*this, "cartslot"), |
| 146 | 148 | m_p_videoram(*this, "p_videoram"), |
| 147 | 149 | m_gfxdecode(*this, "gfxdecode"), |
| 148 | 150 | m_screen(*this, "screen"), |
| 149 | 151 | m_palette(*this, "palette") |
| 150 | 152 | { } |
| 151 | 153 | |
| 152 | | DECLARE_WRITE8_MEMBER(pv1000_io_w); |
| 153 | | DECLARE_READ8_MEMBER(pv1000_io_r); |
| 154 | | DECLARE_WRITE8_MEMBER(pv1000_gfxram_w); |
| 154 | DECLARE_WRITE8_MEMBER(io_w); |
| 155 | DECLARE_READ8_MEMBER(io_r); |
| 156 | DECLARE_WRITE8_MEMBER(gfxram_w); |
| 155 | 157 | UINT8 m_io_regs[8]; |
| 156 | 158 | UINT8 m_fd_data; |
| 157 | 159 | |
| r32395 | r32396 | |
| 167 | 169 | |
| 168 | 170 | required_device<cpu_device> m_maincpu; |
| 169 | 171 | required_device<pv1000_sound_device> m_sound; |
| 172 | required_device<generic_slot_device> m_cart; |
| 170 | 173 | required_shared_ptr<UINT8> m_p_videoram; |
| 171 | 174 | virtual void machine_start(); |
| 172 | 175 | virtual void machine_reset(); |
| r32395 | r32396 | |
| 182 | 185 | |
| 183 | 186 | |
| 184 | 187 | static ADDRESS_MAP_START( pv1000, AS_PROGRAM, 8, pv1000_state ) |
| 185 | | AM_RANGE( 0x0000, 0x3fff ) AM_MIRROR( 0x4000 ) AM_ROM AM_REGION( "cart", 0 ) |
| 186 | | AM_RANGE( 0xb800, 0xbbff ) AM_RAM AM_SHARE("p_videoram") |
| 187 | | AM_RANGE( 0xbc00, 0xbfff ) AM_RAM_WRITE( pv1000_gfxram_w ) AM_REGION( "gfxram", 0 ) |
| 188 | //AM_RANGE(0x0000, 0x7fff) // mapped by the cartslot |
| 189 | AM_RANGE(0xb800, 0xbbff) AM_RAM AM_SHARE("p_videoram") |
| 190 | AM_RANGE(0xbc00, 0xbfff) AM_RAM_WRITE(gfxram_w) AM_REGION("gfxram", 0) |
| 188 | 191 | ADDRESS_MAP_END |
| 189 | 192 | |
| 190 | 193 | |
| 191 | 194 | static ADDRESS_MAP_START( pv1000_io, AS_IO, 8, pv1000_state ) |
| 192 | | ADDRESS_MAP_GLOBAL_MASK( 0xff ) |
| 193 | | AM_RANGE( 0xf8, 0xff ) AM_READWRITE( pv1000_io_r, pv1000_io_w ) |
| 195 | ADDRESS_MAP_GLOBAL_MASK(0xff) |
| 196 | AM_RANGE(0xf8, 0xff) AM_READWRITE(io_r, io_w) |
| 194 | 197 | ADDRESS_MAP_END |
| 195 | 198 | |
| 196 | 199 | |
| 197 | | WRITE8_MEMBER( pv1000_state::pv1000_gfxram_w ) |
| 200 | WRITE8_MEMBER( pv1000_state::gfxram_w ) |
| 198 | 201 | { |
| 199 | 202 | UINT8 *gfxram = memregion( "gfxram" )->base(); |
| 200 | 203 | |
| r32395 | r32396 | |
| 203 | 206 | } |
| 204 | 207 | |
| 205 | 208 | |
| 206 | | WRITE8_MEMBER( pv1000_state::pv1000_io_w ) |
| 209 | WRITE8_MEMBER( pv1000_state::io_w ) |
| 207 | 210 | { |
| 208 | 211 | switch (offset) |
| 209 | 212 | { |
| 210 | 213 | case 0x00: |
| 211 | 214 | case 0x01: |
| 212 | 215 | case 0x02: |
| 213 | | //logerror("pv1000_io_w offset=%02x, data=%02x (%03d)\n", offset, data , data); |
| 216 | //logerror("io_w offset=%02x, data=%02x (%03d)\n", offset, data , data); |
| 214 | 217 | m_sound->voice_w(space, offset, data); |
| 215 | 218 | break; |
| 216 | 219 | |
| r32395 | r32396 | |
| 234 | 237 | } |
| 235 | 238 | |
| 236 | 239 | |
| 237 | | READ8_MEMBER( pv1000_state::pv1000_io_r ) |
| 240 | READ8_MEMBER( pv1000_state::io_r ) |
| 238 | 241 | { |
| 239 | 242 | UINT8 data = m_io_regs[offset]; |
| 240 | 243 | |
| 241 | | // logerror("pv1000_io_r offset=%02x\n", offset ); |
| 244 | // logerror("io_r offset=%02x\n", offset ); |
| 242 | 245 | |
| 243 | 246 | switch ( offset ) |
| 244 | 247 | { |
| r32395 | r32396 | |
| 308 | 311 | |
| 309 | 312 | DEVICE_IMAGE_LOAD_MEMBER( pv1000_state, pv1000_cart ) |
| 310 | 313 | { |
| 311 | | UINT8 *cart = memregion("cart")->base(); |
| 312 | | UINT32 size; |
| 313 | | |
| 314 | | if (image.software_entry() == NULL) |
| 315 | | size = image.length(); |
| 316 | | else |
| 317 | | size = image.get_software_region_length("rom"); |
| 318 | | |
| 319 | | |
| 314 | UINT32 size = m_cart->common_get_size("rom"); |
| 315 | |
| 320 | 316 | if (size != 0x2000 && size != 0x4000) |
| 321 | 317 | { |
| 322 | 318 | image.seterror(IMAGE_ERROR_UNSPECIFIED, "Unsupported cartridge size"); |
| 323 | 319 | return IMAGE_INIT_FAIL; |
| 324 | 320 | } |
| 325 | | |
| 326 | | if (image.software_entry() == NULL) |
| 327 | | { |
| 328 | | if (image.fread( cart, size) != size) |
| 329 | | { |
| 330 | | image.seterror(IMAGE_ERROR_UNSPECIFIED, "Unable to fully read from file"); |
| 331 | | return IMAGE_INIT_FAIL; |
| 332 | | } |
| 333 | | } |
| 334 | | else |
| 335 | | memcpy(cart, image.get_software_region("rom"), size); |
| 336 | | |
| 337 | | |
| 338 | | /* Mirror 8KB rom */ |
| 339 | | if (size == 0x2000) |
| 340 | | memcpy(cart + 0x2000, cart, 0x2000); |
| 341 | | |
| 321 | |
| 322 | m_cart->rom_alloc(size, GENERIC_ROM8_WIDTH, ENDIANNESS_LITTLE); |
| 323 | m_cart->common_load_rom(m_cart->get_rom_base(), size, "rom"); |
| 324 | |
| 342 | 325 | return IMAGE_INIT_PASS; |
| 343 | 326 | } |
| 344 | 327 | |
| r32395 | r32396 | |
| 406 | 389 | { |
| 407 | 390 | // restore GFX ram |
| 408 | 391 | for (int i = 0; i < 0x400; i++) |
| 409 | | pv1000_gfxram_w(m_maincpu->space(AS_PROGRAM), i, m_gfxram[i]); |
| 392 | gfxram_w(m_maincpu->space(AS_PROGRAM), i, m_gfxram[i]); |
| 410 | 393 | } |
| 411 | 394 | |
| 412 | 395 | void pv1000_state::machine_start() |
| r32395 | r32396 | |
| 417 | 400 | m_gfxram = memregion("gfxram")->base(); |
| 418 | 401 | save_pointer(NAME(m_gfxram), 0x400); |
| 419 | 402 | |
| 403 | if (m_cart->exists()) |
| 404 | { |
| 405 | m_maincpu->space(AS_PROGRAM).install_read_handler(0x0000, 0x7fff, read8_delegate(FUNC(generic_slot_device::read_rom),(generic_slot_device*)m_cart)); |
| 406 | |
| 407 | // FIXME: this is needed for gfx decoding, but there is probably a cleaner solution! |
| 408 | astring region_tag; |
| 409 | memcpy(memregion("gfxrom")->base(), memregion(region_tag.cpy(m_cart->tag()).cat(GENERIC_ROM_REGION_TAG))->base(), m_cart->get_rom_size()); |
| 410 | } |
| 411 | |
| 420 | 412 | save_item(NAME(m_io_regs)); |
| 421 | 413 | save_item(NAME(m_fd_data)); |
| 422 | 414 | save_item(NAME(m_pcg_bank)); |
| r32395 | r32396 | |
| 450 | 442 | |
| 451 | 443 | |
| 452 | 444 | static GFXDECODE_START( pv1000 ) |
| 453 | | GFXDECODE_ENTRY( "cart", 8, pv1000_3bpp_gfx, 0, 8 ) |
| 445 | GFXDECODE_ENTRY( "gfxrom", 8, pv1000_3bpp_gfx, 0, 8 ) |
| 454 | 446 | GFXDECODE_ENTRY( "gfxram", 8, pv1000_3bpp_gfx, 0, 8 ) |
| 455 | 447 | GFXDECODE_END |
| 456 | 448 | |
| r32395 | r32396 | |
| 478 | 470 | MCFG_SOUND_ROUTE( ALL_OUTPUTS, "mono", 1.00 ) |
| 479 | 471 | |
| 480 | 472 | /* Cartridge slot */ |
| 481 | | MCFG_CARTSLOT_ADD("cart") |
| 482 | | MCFG_CARTSLOT_EXTENSION_LIST("bin") |
| 483 | | MCFG_CARTSLOT_MANDATORY |
| 484 | | MCFG_CARTSLOT_INTERFACE("pv1000_cart") |
| 485 | | MCFG_CARTSLOT_LOAD(pv1000_state,pv1000_cart) |
| 473 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_linear_slot, "pv1000_cart") |
| 474 | MCFG_GENERIC_MANDATORY |
| 475 | MCFG_GENERIC_LOAD(pv1000_state, pv1000_cart) |
| 486 | 476 | |
| 487 | 477 | /* Software lists */ |
| 488 | 478 | MCFG_SOFTWARE_LIST_ADD("cart_list","pv1000") |
| r32395 | r32396 | |
| 490 | 480 | |
| 491 | 481 | |
| 492 | 482 | ROM_START( pv1000 ) |
| 493 | | ROM_REGION( 0x4000, "cart", ROMREGION_ERASE00 ) |
| 483 | ROM_REGION( 0x4000, "gfxrom", ROMREGION_ERASE00 ) |
| 494 | 484 | ROM_REGION( 0x400, "gfxram", ROMREGION_ERASE00 ) |
| 495 | 485 | ROM_END |
| 496 | 486 | |
trunk/src/mess/drivers/cgenie.c
| r32395 | r32396 | |
| 488 | 488 | NULL |
| 489 | 489 | }; |
| 490 | 490 | |
| 491 | |
| 492 | // TODO: investigate this! I think it is some sort of expansion of the DOS cart... |
| 493 | DEVICE_IMAGE_LOAD_MEMBER( cgenie_state, cgenie_cart ) |
| 494 | { |
| 495 | UINT32 size = m_cart->common_get_size("rom"); |
| 496 | |
| 497 | if (size > 0x1000) |
| 498 | { |
| 499 | image.seterror(IMAGE_ERROR_UNSPECIFIED, "Unsupported cartridge size"); |
| 500 | return IMAGE_INIT_FAIL; |
| 501 | } |
| 502 | |
| 503 | m_cart->rom_alloc(0x1000, GENERIC_ROM8_WIDTH, ENDIANNESS_LITTLE); |
| 504 | m_cart->common_load_rom(m_cart->get_rom_base(), size, "rom"); |
| 505 | |
| 506 | return IMAGE_INIT_PASS; |
| 507 | } |
| 508 | |
| 509 | |
| 491 | 510 | static MACHINE_CONFIG_START( cgenie_common, cgenie_state ) |
| 492 | 511 | /* basic machine hardware */ |
| 493 | 512 | MCFG_CPU_ADD("maincpu", Z80, XTAL_17_73447MHz/8) /* 2,2168 MHz */ |
| r32395 | r32396 | |
| 535 | 554 | MCFG_LEGACY_FLOPPY_4_DRIVES_ADD(cgenie_floppy_interface) |
| 536 | 555 | |
| 537 | 556 | /* cartridge */ |
| 538 | | MCFG_CARTSLOT_ADD("cart") |
| 539 | | MCFG_CARTSLOT_EXTENSION_LIST("rom") |
| 540 | | MCFG_CARTSLOT_NOT_MANDATORY |
| 557 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_plain_slot, "cgenie_cart") |
| 558 | MCFG_GENERIC_EXTENSIONS("bin,rom") |
| 559 | MCFG_GENERIC_LOAD(cgenie_state, cgenie_cart) |
| 541 | 560 | |
| 561 | MCFG_SOFTWARE_LIST_ADD("cart_list", "cgenie_cart") |
| 562 | |
| 542 | 563 | /* internal ram */ |
| 543 | 564 | MCFG_RAM_ADD(RAM_TAG) |
| 544 | 565 | MCFG_RAM_DEFAULT_SIZE("16K") |
| r32395 | r32396 | |
| 565 | 586 | ROM_REGION(0x13000,"maincpu",0) |
| 566 | 587 | ROM_LOAD ("cgenie.rom", 0x00000, 0x4000, CRC(d359ead7) SHA1(d8c2fc389ad38c45fba0ed556a7d91abac5463f4)) |
| 567 | 588 | ROM_LOAD ("cgdos.rom", 0x10000, 0x2000, CRC(2a96cf74) SHA1(6dcac110f87897e1ee7521aefbb3d77a14815893)) |
| 568 | | ROM_CART_LOAD("cart", 0x12000, 0x1000, ROM_NOMIRROR | ROM_OPTIONAL) |
| 569 | 589 | |
| 570 | 590 | ROM_REGION(0x0c00,"gfx1",0) |
| 571 | 591 | ROM_LOAD ("cgenie1.fnt", 0x0000, 0x0800, CRC(4fed774a) SHA1(d53df8212b521892cc56be690db0bb474627d2ff)) |
| r32395 | r32396 | |
| 582 | 602 | ROM_SYSTEM_BIOS(1, "new", "New ROM") |
| 583 | 603 | ROMX_LOAD( "cgromv2.rom", 0x0000, 0x4000, CRC(cfb84e09) SHA1(e199e4429bab6f9fca2bb05e71324538928a693a), ROM_BIOS(2) ) |
| 584 | 604 | ROM_LOAD ("cgdos.rom", 0x10000, 0x2000, CRC(2a96cf74) SHA1(6dcac110f87897e1ee7521aefbb3d77a14815893)) |
| 585 | | ROM_CART_LOAD("cart", 0x12000, 0x1000, ROM_NOMIRROR | ROM_OPTIONAL) |
| 586 | 605 | |
| 587 | 606 | ROM_REGION(0x0c00,"gfx1",0) |
| 588 | 607 | ROM_LOAD ("cgenie1.fnt", 0x0000, 0x0800, CRC(4fed774a) SHA1(d53df8212b521892cc56be690db0bb474627d2ff)) |
trunk/src/mess/drivers/vector06.c
| r32395 | r32396 | |
| 183 | 183 | MCFG_LEGACY_FLOPPY_2_DRIVES_ADD(vector_floppy_interface) |
| 184 | 184 | |
| 185 | 185 | /* cartridge */ |
| 186 | | MCFG_CARTSLOT_ADD("cart") |
| 187 | | MCFG_CARTSLOT_EXTENSION_LIST("emr") |
| 188 | | MCFG_CARTSLOT_NOT_MANDATORY |
| 186 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_plain_slot, "vector06_cart") |
| 187 | MCFG_GENERIC_EXTENSIONS("bin,emr") |
| 189 | 188 | |
| 189 | MCFG_SOFTWARE_LIST_ADD("cart_list", "vector06_cart") |
| 190 | |
| 190 | 191 | /* internal ram */ |
| 191 | 192 | MCFG_RAM_ADD(RAM_TAG) |
| 192 | 193 | MCFG_RAM_DEFAULT_SIZE("64K") |
| r32395 | r32396 | |
| 196 | 197 | /* ROM definition */ |
| 197 | 198 | |
| 198 | 199 | ROM_START( vector06 ) |
| 199 | | ROM_REGION( 0x20000, "maincpu", ROMREGION_ERASEFF ) |
| 200 | ROM_REGION( 0x18000, "maincpu", ROMREGION_ERASEFF ) |
| 200 | 201 | ROM_SYSTEM_BIOS(0, "unboot32k", "Universal Boot 32K") |
| 201 | 202 | ROMX_LOAD( "unboot32k.rt", 0x10000, 0x8000, CRC(28c9b5cd) SHA1(8cd7fb658896a7066ae93b10eaafa0f12139ad81), ROM_BIOS(1)) |
| 202 | 203 | ROM_SYSTEM_BIOS(1, "unboot2k", "Universal Boot 2K") |
| r32395 | r32396 | |
| 209 | 210 | ROMX_LOAD( "bootos.rt", 0x10000, 0x0200, CRC(46bef038) SHA1(6732f4a360cd38112c53c458842d31f5b035cf59), ROM_BIOS(5)) |
| 210 | 211 | ROM_SYSTEM_BIOS(5, "boot512", "Boot 512") |
| 211 | 212 | ROMX_LOAD( "boot512.rt", 0x10000, 0x0200, CRC(a0b1c6b2) SHA1(f6fe15cb0974aed30f9b7aa72133324a66d1ed3f), ROM_BIOS(6)) |
| 212 | | ROM_CART_LOAD("cart", 0x18000, 0x8000, ROM_OPTIONAL) |
| 213 | 213 | ROM_END |
| 214 | 214 | |
| 215 | 215 | ROM_START( vec1200 ) |
| 216 | | ROM_REGION( 0x20000, "maincpu", ROMREGION_ERASEFF ) |
| 216 | ROM_REGION( 0x18000, "maincpu", ROMREGION_ERASEFF ) |
| 217 | 217 | ROM_LOAD( "vec1200.bin", 0x10000, 0x2000, CRC(37349224) SHA1(060fbb2c1a89040c929521cfd58cb6f1431a8b75)) |
| 218 | | ROM_CART_LOAD("cart", 0x18000, 0x8000, ROM_OPTIONAL) |
| 219 | 218 | |
| 220 | 219 | ROM_REGION( 0x0200, "palette", 0 ) |
| 221 | 220 | ROM_LOAD( "palette.bin", 0x0000, 0x0200, CRC(74b7376b) SHA1(fb56b60babd7e6ed68e5f4e791ad2800d7ef6729)) |
| 222 | 221 | ROM_END |
| 223 | 222 | |
| 224 | 223 | ROM_START( pk6128c ) |
| 225 | | ROM_REGION( 0x20000, "maincpu", ROMREGION_ERASEFF ) |
| 224 | ROM_REGION( 0x18000, "maincpu", ROMREGION_ERASEFF ) |
| 226 | 225 | ROM_LOAD( "6128.bin", 0x10000, 0x4000, CRC(d4f68433) SHA1(ef5ac75f9240ca8996689c23642d4e47e5e774d8)) |
| 227 | | ROM_CART_LOAD("cart", 0x18000, 0x8000, ROM_OPTIONAL) |
| 228 | 226 | ROM_END |
| 229 | 227 | |
| 230 | 228 | ROM_START( krista2 ) |
| 231 | | ROM_REGION( 0x20000, "maincpu", ROMREGION_ERASEFF ) |
| 229 | ROM_REGION( 0x18000, "maincpu", ROMREGION_ERASEFF ) |
| 232 | 230 | ROM_LOAD( "krista2.epr", 0x10000, 0x0200, CRC(df5440b0) SHA1(bcbbb3cc10aeb17c1262b45111d20279266b9ba4)) |
| 233 | | ROM_CART_LOAD("cart", 0x18000, 0x8000, ROM_OPTIONAL) |
| 234 | 231 | ROM_LOAD( "krista2.pal", 0x0000, 0x0200, CRC(b243da33) SHA1(9af7873e6f8bf452c8d831833ffb02dce833c095)) |
| 235 | 232 | ROM_END |
| 236 | 233 | /* Driver */ |