branches/kale/src/emu/cpu/i386/i386ops.h
| r244561 | r244562 | |
| 14 | 14 | #define OP_3BYTE66 0x40000000 |
| 15 | 15 | #define OP_3BYTEF2 0x20000000 |
| 16 | 16 | #define OP_3BYTEF3 0x10000000 |
| 17 | | #define OP_3BYTE38 0x08000000 |
| 18 | | #define OP_3BYTE3A 0x04000000 |
| 19 | | #define OP_4BYTE3866 0x02000000 |
| 20 | | #define OP_4BYTE3A66 0x01000000 |
| 21 | | #define OP_4BYTE38F2 0x00800000 |
| 22 | | #define OP_4BYTE3AF2 0x00400000 |
| 23 | | #define OP_4BYTE38F3 0x00200000 |
| 24 | 17 | |
| 25 | 18 | const i386_device::X86_OPCODE i386_device::s_x86_opcode_table[] = |
| 26 | 19 | { |
| r244561 | r244562 | |
| 327 | 320 | { 0x30, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_wrmsr, &i386_device::pentium_wrmsr, false}, |
| 328 | 321 | { 0x31, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_rdtsc, &i386_device::pentium_rdtsc, false}, |
| 329 | 322 | { 0x32, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_rdmsr, &i386_device::pentium_rdmsr, false}, |
| 330 | | { 0x38, OP_2BYTE|OP_PENTIUM, &i386_device::i386_decode_three_byte38, &i386_device::i386_decode_three_byte38,false}, |
| 331 | | { 0x3A, OP_2BYTE|OP_PENTIUM, &i386_device::i386_decode_three_byte3a, &i386_device::i386_decode_three_byte3a,false}, |
| 332 | | { 0x40, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_cmovo_r16_rm16, &i386_device::pentium_cmovo_r32_rm32, false}, |
| 323 | { 0x40, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_cmovo_r16_rm16, &i386_device::pentium_cmovo_r32_rm32, false}, |
| 333 | 324 | { 0x41, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_cmovno_r16_rm16, &i386_device::pentium_cmovno_r32_rm32, false}, |
| 334 | 325 | { 0x42, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_cmovb_r16_rm16, &i386_device::pentium_cmovb_r32_rm32, false}, |
| 335 | 326 | { 0x43, OP_2BYTE|OP_PENTIUM, &i386_device::pentium_cmovae_r16_rm16, &i386_device::pentium_cmovae_r32_rm32, false}, |
| r244561 | r244562 | |
| 430 | 421 | { 0xAB, OP_2BYTE|OP_I386, &i386_device::i386_bts_rm16_r16, &i386_device::i386_bts_rm32_r32, true }, |
| 431 | 422 | { 0xAC, OP_2BYTE|OP_I386, &i386_device::i386_shrd16_i8, &i386_device::i386_shrd32_i8, false}, |
| 432 | 423 | { 0xAD, OP_2BYTE|OP_I386, &i386_device::i386_shrd16_cl, &i386_device::i386_shrd32_cl, false}, |
| 433 | | { 0xAE, OP_2BYTE|OP_SSE, &i386_device::sse_group_0fae, &i386_device::sse_group_0fae, false}, |
| 424 | { 0xAE, OP_2BYTE|OP_SSE, &i386_device::sse_sse_group0fae, &i386_device::sse_sse_group0fae, false}, |
| 434 | 425 | { 0xAF, OP_2BYTE|OP_I386, &i386_device::i386_imul_r16_rm16, &i386_device::i386_imul_r32_rm32, false}, |
| 435 | 426 | { 0xB0, OP_2BYTE|OP_I486, &i386_device::i486_cmpxchg_rm8_r8, &i386_device::i486_cmpxchg_rm8_r8, true }, |
| 436 | 427 | { 0xB1, OP_2BYTE|OP_I486, &i386_device::i486_cmpxchg_rm16_r16, &i386_device::i486_cmpxchg_rm32_r32, true }, |
| r244561 | r244562 | |
| 528 | 519 | { 0x70, OP_3BYTEF3|OP_SSE, &i386_device::sse_pshufhw_r128_rm128_i8, &i386_device::sse_pshufhw_r128_rm128_i8,false}, |
| 529 | 520 | { 0x7E, OP_3BYTEF3|OP_SSE, &i386_device::sse_movq_r128_r128m64, &i386_device::sse_movq_r128_r128m64, false}, |
| 530 | 521 | { 0x7F, OP_3BYTEF3|OP_SSE, &i386_device::sse_movdqu_rm128_r128, &i386_device::sse_movdqu_rm128_r128, false}, |
| 531 | | { 0xAE, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 532 | 522 | { 0xB8, OP_3BYTEF3|OP_PENTIUM, &i386_device::pentium_popcnt_r16_rm16, &i386_device::pentium_popcnt_r32_rm32, false}, |
| 533 | | { 0xBC, OP_3BYTEF3|OP_PENTIUM, &i386_device::pentium_tzcnt_r16_rm16, &i386_device::pentium_tzcnt_r32_rm32, false}, |
| 523 | { 0xBC, OP_3BYTEF3|OP_PENTIUM, &i386_device::pentium_tzcnt_r16_rm16, &i386_device::pentium_tzcnt_r32_rm32, false}, |
| 534 | 524 | { 0xC2, OP_3BYTEF3|OP_SSE, &i386_device::sse_cmpss_r128_r128m32_i8, &i386_device::sse_cmpss_r128_r128m32_i8,false}, |
| 535 | | { 0xC7, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 536 | 525 | { 0xD6, OP_3BYTEF3|OP_SSE, &i386_device::sse_movq2dq_r128_r64, &i386_device::sse_movq2dq_r128_r64, false}, |
| 537 | | { 0xE6, OP_3BYTEF3|OP_SSE, &i386_device::sse_cvtdq2pd_r128_r128m64, &i386_device::sse_cvtdq2pd_r128_r128m64,false}, |
| 538 | | /* F2 0F ?? */ |
| 539 | | { 0x10, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 540 | | { 0x11, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 541 | | { 0x12, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 542 | | { 0x2A, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 543 | | { 0x2C, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 544 | | { 0x2D, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 545 | | { 0x51, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 546 | | { 0x58, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 547 | | { 0x59, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 548 | | { 0x5A, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 549 | | { 0x5C, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 550 | | { 0x5D, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 551 | | { 0x5E, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 552 | | { 0x5F, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 553 | | { 0x70, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 554 | | { 0x7C, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 555 | | { 0x7D, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 556 | | { 0xC2, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 557 | | { 0xD0, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 558 | | { 0xD6, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 559 | | { 0xE6, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 560 | | { 0xF0, OP_3BYTEF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 561 | | /* 66 0F ?? */ |
| 562 | | { 0x10, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 563 | | { 0x11, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 564 | | { 0x12, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 565 | | { 0x13, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 566 | | { 0x14, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 567 | | { 0x15, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 568 | | { 0x16, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 569 | | { 0x17, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 570 | | { 0x28, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 571 | | { 0x29, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 572 | | { 0x2A, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 573 | | { 0x2B, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 574 | | { 0x2C, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 575 | | { 0x2D, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 576 | | { 0x2E, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 577 | | { 0x2F, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 578 | | { 0x50, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 579 | | { 0x51, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 580 | | { 0x54, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 581 | | { 0x55, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 582 | | { 0x56, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 583 | | { 0x57, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 584 | | { 0x58, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 585 | | { 0x59, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 586 | | { 0x5A, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 587 | | { 0x5B, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 588 | | { 0x5C, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 589 | | { 0x5D, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 590 | | { 0x5E, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 591 | | { 0x5F, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 592 | | { 0x60, OP_3BYTE66|OP_SSE, &i386_device::sse_punpcklbw_r128_rm128, &i386_device::sse_punpcklbw_r128_rm128,false}, |
| 593 | | { 0x61, OP_3BYTE66|OP_SSE, &i386_device::sse_punpcklwd_r128_rm128, &i386_device::sse_punpcklwd_r128_rm128,false}, |
| 594 | | { 0x62, OP_3BYTE66|OP_SSE, &i386_device::sse_punpckldq_r128_rm128, &i386_device::sse_punpckldq_r128_rm128,false}, |
| 595 | | { 0x63, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 596 | | { 0x64, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 597 | | { 0x65, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 598 | | { 0x66, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 599 | | { 0x67, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 600 | | { 0x68, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 601 | | { 0x69, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 602 | | { 0x6A, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 603 | | { 0x6B, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 604 | | { 0x6C, OP_3BYTE66|OP_SSE, &i386_device::sse_punpcklqdq_r128_rm128, &i386_device::sse_punpcklqdq_r128_rm128,false}, |
| 605 | | { 0x6D, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 606 | | { 0x6E, OP_3BYTE66|OP_SSE, &i386_device::sse_movd_m128_rm32, &i386_device::sse_movd_m128_rm32, false}, |
| 607 | | { 0x6F, OP_3BYTE66|OP_SSE, &i386_device::sse_movdqa_m128_rm128, &i386_device::sse_movdqa_m128_rm128, false}, |
| 608 | | { 0x70, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 609 | | { 0x71, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 610 | | { 0x72, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 611 | | { 0x73, OP_3BYTE66|OP_SSE, &i386_device::sse_group_660f73, &i386_device::sse_group_660f73, false}, |
| 612 | | { 0x74, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 613 | | { 0x76, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 614 | | { 0x7C, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 615 | | { 0x7D, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 616 | | { 0x7E, OP_3BYTE66|OP_SSE, &i386_device::sse_movd_rm32_r128, &i386_device::sse_movd_rm32_r128, false}, |
| 617 | | { 0x7F, OP_3BYTE66|OP_SSE, &i386_device::sse_movdqa_rm128_r128, &i386_device::sse_movdqa_rm128_r128, false}, |
| 618 | | { 0xC2, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 619 | | { 0xC4, OP_3BYTE66|OP_SSE, &i386_device::sse_pinsrw_r128_r32m16_i8, &i386_device::sse_pinsrw_r128_r32m16_i8,false}, |
| 620 | | { 0xC5, OP_3BYTE66|OP_SSE, &i386_device::sse_pextrw_reg_r128_i8, &i386_device::sse_pextrw_reg_r128_i8, false}, |
| 621 | | { 0xC6, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 622 | | { 0xC7, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 623 | | { 0xD0, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 624 | | { 0xD1, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 625 | | { 0xD2, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 626 | | { 0xD3, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 627 | | { 0xD4, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 628 | | { 0xD5, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 629 | | { 0xD6, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 630 | | { 0xD7, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 631 | | { 0xD8, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 632 | | { 0xD9, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 633 | | { 0xDA, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 634 | | { 0xDB, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 635 | | { 0xDC, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 636 | | { 0xDD, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 637 | | { 0xDE, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 638 | | { 0xDF, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 639 | | { 0xE0, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 640 | | { 0xE1, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 641 | | { 0xE2, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 642 | | { 0xE3, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 643 | | { 0xE4, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 644 | | { 0xE5, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 645 | | { 0xE6, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 646 | | { 0xE7, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 647 | | { 0xE8, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 648 | | { 0xE9, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 649 | | { 0xEA, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 650 | | { 0xEB, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 651 | | { 0xEC, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 652 | | { 0xED, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 653 | | { 0xEE, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 654 | | { 0xEF, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 655 | | { 0xF1, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 656 | | { 0xF2, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 657 | | { 0xF3, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 658 | | { 0xF4, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 659 | | { 0xF5, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 660 | | { 0xF6, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 661 | | { 0xF7, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 662 | | { 0xF8, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 663 | | { 0xF9, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 664 | | { 0xFA, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 665 | | { 0xFB, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 666 | | { 0xFC, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 667 | | { 0xFD, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 668 | | { 0xFE, OP_3BYTE66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 669 | | /* 0F 38 ?? */ |
| 670 | | { 0x00, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 671 | | { 0x01, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 672 | | { 0x02, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 673 | | { 0x03, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 674 | | { 0x04, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 675 | | { 0x05, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 676 | | { 0x06, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 677 | | { 0x07, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 678 | | { 0x08, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 679 | | { 0x09, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 680 | | { 0x0A, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 681 | | { 0x0B, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 682 | | { 0x1C, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 683 | | { 0x1D, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 684 | | { 0x1E, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 685 | | { 0xF0, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 686 | | { 0xF1, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 687 | | { 0xF2, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 688 | | { 0xF3, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 689 | | { 0xF5, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 690 | | { 0xF7, OP_3BYTE38|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 691 | | /* 0F 3A ?? */ |
| 692 | | { 0x0F, OP_3BYTE3A|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 693 | | /* 66 0F 38 ?? */ |
| 694 | | { 0x00, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 695 | | { 0x01, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 696 | | { 0x02, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 697 | | { 0x03, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 698 | | { 0x04, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 699 | | { 0x05, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 700 | | { 0x06, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 701 | | { 0x07, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 702 | | { 0x08, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 703 | | { 0x09, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 704 | | { 0x0A, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 705 | | { 0x0B, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 706 | | { 0x0C, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 707 | | { 0x0D, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 708 | | { 0x0E, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 709 | | { 0x0F, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 710 | | { 0x10, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 711 | | { 0x13, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 712 | | { 0x14, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 713 | | { 0x15, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 714 | | { 0x16, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 715 | | { 0x17, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 716 | | { 0x18, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 717 | | { 0x19, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 718 | | { 0x1A, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 719 | | { 0x1C, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 720 | | { 0x1D, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 721 | | { 0x1E, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 722 | | { 0x20, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 723 | | { 0x21, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 724 | | { 0x22, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 725 | | { 0x23, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 726 | | { 0x24, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 727 | | { 0x25, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 728 | | { 0x28, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 729 | | { 0x29, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 730 | | { 0x2A, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 731 | | { 0x2B, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 732 | | { 0x2C, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 733 | | { 0x2D, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 734 | | { 0x2E, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 735 | | { 0x2F, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 736 | | { 0x30, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 737 | | { 0x31, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 738 | | { 0x32, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 739 | | { 0x33, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 740 | | { 0x34, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 741 | | { 0x35, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 742 | | { 0x36, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 743 | | { 0x37, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 744 | | { 0x38, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 745 | | { 0x39, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 746 | | { 0x3A, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 747 | | { 0x3B, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 748 | | { 0x3C, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 749 | | { 0x3D, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 750 | | { 0x3E, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 751 | | { 0x3F, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 752 | | { 0x40, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 753 | | { 0x41, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 754 | | { 0x45, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 755 | | { 0x46, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 756 | | { 0x47, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 757 | | { 0x58, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 758 | | { 0x59, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 759 | | { 0x5A, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 760 | | { 0x78, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 761 | | { 0x79, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 762 | | { 0x80, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 763 | | { 0x81, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 764 | | { 0x82, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 765 | | { 0x8C, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 766 | | { 0x8E, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 767 | | { 0x90, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 768 | | { 0x91, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 769 | | { 0x92, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 770 | | { 0x93, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 771 | | { 0x96, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 772 | | { 0x97, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 773 | | { 0x98, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 774 | | { 0x99, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 775 | | { 0x9A, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 776 | | { 0x9B, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 777 | | { 0x9C, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 778 | | { 0x9D, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 779 | | { 0x9E, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 780 | | { 0x9F, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 781 | | { 0xA6, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 782 | | { 0xA7, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 783 | | { 0xA8, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 784 | | { 0xA9, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 785 | | { 0xAA, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 786 | | { 0xAB, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 787 | | { 0xAC, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 788 | | { 0xAD, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 789 | | { 0xAE, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 790 | | { 0xAF, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 791 | | { 0xB6, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 792 | | { 0xB7, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 793 | | { 0xB8, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 794 | | { 0xB9, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 795 | | { 0xBA, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 796 | | { 0xBB, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 797 | | { 0xBC, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 798 | | { 0xBD, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 799 | | { 0xBE, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 800 | | { 0xBF, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 801 | | { 0xDB, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 802 | | { 0xDC, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 803 | | { 0xDD, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 804 | | { 0xDE, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 805 | | { 0xDF, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 806 | | { 0xF0, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 807 | | { 0xF1, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 808 | | { 0xF3, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 809 | | { 0xF6, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 810 | | { 0xF7, OP_4BYTE3866|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 811 | | /* F2 0F 38 ?? */ |
| 812 | | { 0xF0, OP_4BYTE38F2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 813 | | { 0xF1, OP_4BYTE38F2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 814 | | { 0xF3, OP_4BYTE38F2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 815 | | { 0xF5, OP_4BYTE38F2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 816 | | { 0xF6, OP_4BYTE38F2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 817 | | { 0xF7, OP_4BYTE38F2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 818 | | /* F3 0F 38 ?? */ |
| 819 | | { 0xF3, OP_4BYTE38F3|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 820 | | { 0xF5, OP_4BYTE38F3|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 821 | | { 0xF6, OP_4BYTE38F3|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 822 | | { 0xF7, OP_4BYTE38F3|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 823 | | /* 66 0F 3A ?? */ |
| 824 | | { 0x00, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 825 | | { 0x01, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 826 | | { 0x02, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 827 | | { 0x04, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 828 | | { 0x05, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 829 | | { 0x06, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 830 | | { 0x08, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 831 | | { 0x09, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 832 | | { 0x0A, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 833 | | { 0x0B, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 834 | | { 0x0C, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 835 | | { 0x0D, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 836 | | { 0x0E, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 837 | | { 0x0F, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 838 | | { 0x14, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 839 | | { 0x15, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 840 | | { 0x16, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 841 | | { 0x17, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 842 | | { 0x18, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 843 | | { 0x19, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 844 | | { 0x1D, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 845 | | { 0x20, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 846 | | { 0x21, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 847 | | { 0x22, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 848 | | { 0x38, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 849 | | { 0x39, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 850 | | { 0x40, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 851 | | { 0x41, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 852 | | { 0x42, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 853 | | { 0x44, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 854 | | { 0x46, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 855 | | { 0x4A, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 856 | | { 0x4B, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 857 | | { 0x4C, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 858 | | { 0x60, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 859 | | { 0x61, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 860 | | { 0x62, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 861 | | { 0x63, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 862 | | { 0xDF, OP_4BYTE3A66|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false}, |
| 863 | | /* F2 0F 3A ?? */ |
| 864 | | { 0xF0, OP_4BYTE3AF2|OP_SSE, &i386_device::i386_invalid, &i386_device::i386_invalid, false} |
| 526 | { 0xE6, OP_3BYTEF3|OP_SSE, &i386_device::sse_cvtdq2pd_r128_r128m64, &i386_device::sse_cvtdq2pd_r128_r128m64,false} |
| 865 | 527 | }; |
branches/kale/src/mess/drivers/gamate.c
| r244561 | r244562 | |
| 10 | 10 | #include "bus/generic/slot.h" |
| 11 | 11 | #include "bus/generic/carts.h" |
| 12 | 12 | #include "rendlay.h" |
| 13 | #include "includes/gamate.h" |
| 14 | #include "ui/ui.h" |
| 13 | 15 | |
| 14 | | //#define USE_GFX |
| 15 | | |
| 16 | 16 | class gamate_state : public driver_device |
| 17 | 17 | { |
| 18 | 18 | public: |
| 19 | 19 | gamate_state(const machine_config &mconfig, device_type type, const char *tag) |
| 20 | 20 | : driver_device(mconfig, type, tag) |
| 21 | 21 | , m_maincpu(*this, "maincpu") |
| 22 | , m_sound(*this, "custom") |
| 22 | 23 | , m_cart(*this, "cartslot") |
| 23 | | #ifdef USE_GFX |
| 24 | | , m_gfxdecode(*this, "gfxdecode") |
| 25 | | #endif |
| 26 | 24 | , m_io_joy(*this, "JOY") |
| 27 | 25 | , m_palette(*this, "palette") |
| 28 | 26 | , m_bios(*this, "bios") |
| r244561 | r244562 | |
| 53 | 51 | |
| 54 | 52 | struct |
| 55 | 53 | { |
| 56 | | UINT8 reg[8]; |
| 57 | | struct { |
| 58 | | bool write; |
| 59 | | bool page2; // else page1 |
| 54 | UINT8 reg[8]; |
| 55 | struct { |
| 56 | bool write; |
| 57 | bool page2; // else page1 |
| 60 | 58 | UINT8 ypos, xpos/*tennis*/; |
| 61 | | UINT8 data[2][0x100][0x20]; |
| 62 | | } bitmap; |
| 63 | | UINT8 x, y; |
| 59 | UINT8 data[2][0x100][0x20]; |
| 60 | } bitmap; |
| 61 | UINT8 x, y; |
| 64 | 62 | bool y_increment; |
| 65 | 63 | } video; |
| 66 | 64 | |
| 67 | 65 | struct { |
| 68 | | bool set; |
| 66 | bool set; |
| 69 | 67 | int bit_shifter; |
| 70 | 68 | UINT8 cartridge_byte; |
| 71 | 69 | UINT16 address; // in reality something more like short local cartridge address offset |
| 72 | 70 | bool unprotected; |
| 73 | 71 | bool failed; |
| 74 | | |
| 72 | |
| 75 | 73 | } card_protection; |
| 76 | 74 | |
| 77 | 75 | required_device<cpu_device> m_maincpu; |
| 76 | required_device<gamate_sound_device> m_sound; |
| 78 | 77 | required_device<generic_slot_device> m_cart; |
| 79 | | #ifdef USE_GFX |
| 80 | | required_device<gfxdecode_device> m_gfxdecode; |
| 81 | | #endif |
| 82 | 78 | required_ioport m_io_joy; |
| 83 | 79 | required_device<palette_device> m_palette; |
| 84 | 80 | required_shared_ptr<UINT8> m_bios; |
| 85 | 81 | emu_timer *timer1; |
| 86 | 82 | emu_timer *timer2; |
| 87 | | UINT8 bank_multi; |
| 88 | | UINT8 *m_cart_ptr; |
| 83 | UINT8 bank_multi; |
| 89 | 84 | }; |
| 90 | 85 | |
| 91 | 86 | WRITE8_MEMBER( gamate_state::gamate_cart_protection_w ) |
| 92 | 87 | { |
| 93 | | logerror("%.6f protection write %x %x address:%x data:%x shift:%d\n",machine().time().as_double(), offset, data, card_protection.address, card_protection.cartridge_byte, card_protection.bit_shifter); |
| 94 | | |
| 88 | logerror("%.6f protection write %x %x address:%x data:%x shift:%d\n",machine().time().as_double(), offset, data, card_protection.address, card_protection.cartridge_byte, card_protection.bit_shifter); |
| 89 | |
| 95 | 90 | switch (offset) { |
| 96 | 91 | case 0: |
| 97 | 92 | card_protection.failed= card_protection.failed || ((card_protection.cartridge_byte&0x80)!=0) != ((data&4)!=0); |
| 98 | 93 | card_protection.bit_shifter++; |
| 99 | 94 | if (card_protection.bit_shifter>=8) { |
| 100 | | card_protection.cartridge_byte=m_cart_ptr[card_protection.address++]; |
| 95 | card_protection.cartridge_byte=m_cart->get_rom_base()[card_protection.address++]; |
| 101 | 96 | card_protection.bit_shifter=0; |
| 102 | 97 | } |
| 103 | 98 | break; |
| r244561 | r244562 | |
| 107 | 102 | { |
| 108 | 103 | UINT8 ret=1; |
| 109 | 104 | if (card_protection.bit_shifter==7 && card_protection.unprotected) { |
| 110 | | ret=m_cart_ptr[bank_multi*0x4000]; |
| 105 | ret=m_cart->get_rom_base()[bank_multi*0x4000]; |
| 111 | 106 | } else { |
| 112 | 107 | card_protection.bit_shifter++; |
| 113 | 108 | if (card_protection.bit_shifter==8) { |
| r244561 | r244562 | |
| 117 | 112 | } |
| 118 | 113 | ret=(card_protection.cartridge_byte&0x80)?2:0; |
| 119 | 114 | if (card_protection.bit_shifter==7 && !card_protection.failed) { // now protection chip on cartridge activates cartridge chip select on cpu accesses |
| 120 | | // m_maincpu->space(AS_PROGRAM).install_read_handler(0x6000, 0x6000, READ8_DELEGATE(gamate_state, gamate_cart_protection_r)); // next time I will try to get this working |
| 115 | // m_maincpu->space(AS_PROGRAM).install_read_handler(0x6000, 0x6000, READ8_DELEGATE(gamate_state, gamate_cart_protection_r)); // next time I will try to get this working |
| 121 | 116 | } |
| 122 | 117 | card_protection.cartridge_byte<<=1; |
| 123 | 118 | } |
| r244561 | r244562 | |
| 132 | 127 | // writes 0x20 |
| 133 | 128 | card_protection.address=0x6005-0x6001; |
| 134 | 129 | card_protection.bit_shifter=0; |
| 135 | | card_protection.cartridge_byte=m_cart_ptr[card_protection.address++];//m_cart_rom[card_protection.address++]; |
| 130 | card_protection.cartridge_byte=m_cart->get_rom_base()[card_protection.address++];//m_cart_rom[card_protection.address++]; |
| 136 | 131 | card_protection.failed=false; |
| 137 | 132 | card_protection.unprotected=false; |
| 138 | 133 | } |
| r244561 | r244562 | |
| 148 | 143 | { |
| 149 | 144 | video.reg[offset]=data; |
| 150 | 145 | switch (offset) { |
| 151 | | case 1: video.bitmap.write=data&0xc0; // more addressing mode |
| 146 | case 1: |
| 147 | if (data&0xf) printf("lcd mode %x\n", data); |
| 148 | video.bitmap.write=data&0xc0; // more addressing mode |
| 152 | 149 | video.y_increment=data&0x40; |
| 153 | 150 | break; |
| 154 | | case 2: video.bitmap.xpos=data;break; // at least 7 bits |
| 155 | | case 3: video.bitmap.ypos=data;break; // at least 7 bits |
| 151 | case 2: video.bitmap.xpos=data;break; |
| 152 | case 3: |
| 153 | if (data>=200) printf("lcd ypos: %x\n", data); |
| 154 | video.bitmap.ypos=data; |
| 155 | break; |
| 156 | 156 | case 4: video.bitmap.page2=data&0x80;video.x=data&0x7f;break; |
| 157 | 157 | case 5: video.y=data;break; |
| 158 | 158 | case 7: |
| 159 | if (video.y>=200) |
| 160 | machine().ui().popup_time(2, "bitmap write to x:%x y:%x mode:%x data:%x\n", video.x, video.y, video.reg[1], data); |
| 159 | 161 | if (video.bitmap.write) { |
| 160 | | if (video.x<ARRAY_LENGTH(video.bitmap.data[0][0]) /*&& video.y<ARRAY_LENGTH(video.bitmap.data[0])*/) |
| 161 | 162 | video.bitmap.data[video.bitmap.page2][video.y][video.x]=data; |
| 162 | | else |
| 163 | | logerror("%.6f %04x video bitmap x %x invalid\n",machine().time().as_double(), m_maincpu->pc(), video.x); |
| 164 | 163 | } else { |
| 165 | 164 | video.bitmap.data[0][video.y][video.x&(ARRAY_LENGTH(video.bitmap.data[0][0])-1)]=data; |
| 166 | 165 | } |
| r244561 | r244562 | |
| 172 | 171 | WRITE8_MEMBER( gamate_state::cart_bankswitchmulti_w ) |
| 173 | 172 | { |
| 174 | 173 | bank_multi=data; |
| 175 | | membank("bankmulti")->set_base(m_cart_ptr+0x4000*data+1); |
| 174 | membank("bankmulti")->set_base(m_cart->get_rom_base()+0x4000*data+1); |
| 176 | 175 | } |
| 177 | 176 | |
| 178 | 177 | WRITE8_MEMBER( gamate_state::cart_bankswitch_w ) |
| 179 | 178 | { |
| 180 | | membank("bank")->set_base(m_cart_ptr+0x4000*data); |
| 179 | membank("bank")->set_base(m_cart->get_rom_base()+0x4000*data); |
| 181 | 180 | } |
| 182 | 181 | |
| 183 | 182 | READ8_MEMBER( gamate_state::gamate_video_r ) |
| 184 | 183 | { |
| 185 | | if (offset!=6) return 0; |
| 186 | | UINT8 data=0; |
| 187 | | if (video.bitmap.write) { |
| 188 | | if (video.x<ARRAY_LENGTH(video.bitmap.data[0][0]) /*&& video.y<ARRAY_LENGTH(video.bitmap.data[0])*/) |
| 189 | | data=video.bitmap.data[video.bitmap.page2][video.y][video.x]; |
| 190 | | else |
| 191 | | logerror("%.6f video bitmap x %x invalid\n",machine().time().as_double(),video.x); |
| 192 | | } else { |
| 193 | | data=video.bitmap.data[0][video.y][video.x&(ARRAY_LENGTH(video.bitmap.data[0][0])-1)]; |
| 194 | | } |
| 195 | | if (m_maincpu->pc()<0xf000) |
| 196 | | logerror("%.6f video read %04x %02x\n",machine().time().as_double(),offset, data); |
| 197 | | return data; |
| 184 | if (offset!=6) return 0; |
| 185 | UINT8 data=0; |
| 186 | if (video.bitmap.write) { |
| 187 | data=video.bitmap.data[video.bitmap.page2][video.y][video.x]; |
| 188 | } else { |
| 189 | data=video.bitmap.data[0][video.y][video.x&(ARRAY_LENGTH(video.bitmap.data[0][0])-1)]; |
| 190 | } |
| 191 | // if (m_maincpu->pc()<0xf000) |
| 192 | // machine().ui().popup_time(2, "lcd read x:%x y:%x mode:%x data:%x\n", video.x, video.y, video.reg[1], data); |
| 193 | return data; |
| 198 | 194 | } |
| 199 | 195 | |
| 200 | 196 | WRITE8_MEMBER( gamate_state::gamate_audio_w ) |
| 201 | 197 | { |
| 202 | | logerror("%.6f %04x audio write %04x %02x\n",machine().time().as_double(),m_maincpu->pc(),offset,data); |
| 198 | // printf("audio write %x:%x\n", offset, data);//logerror("%.6f %04x audio write %04x %02x\n",machine().time().as_double(),m_maincpu->pc(),offset,data); |
| 199 | m_sound->device_w(space, offset, data); |
| 203 | 200 | } |
| 204 | 201 | |
| 205 | 202 | READ8_MEMBER( gamate_state::gamate_audio_r ) |
| 206 | 203 | { |
| 207 | | logerror("%.6f %04x audio read %04x \n",machine().time().as_double(),m_maincpu->pc(),offset); |
| 208 | | return 0; |
| 204 | // legend of dragon knight |
| 205 | // machine().ui().popup_time(2, "%.6f %04x audio read %04x \n",machine().time().as_double(),m_maincpu->pc(),offset); |
| 206 | return 0; |
| 209 | 207 | } |
| 210 | 208 | |
| 211 | 209 | |
| 212 | 210 | READ8_MEMBER( gamate_state::gamate_pad_r ) |
| 213 | 211 | { |
| 214 | | UINT8 data=m_io_joy->read(); |
| 215 | | return data; |
| 212 | UINT8 data=m_io_joy->read(); |
| 213 | return data; |
| 216 | 214 | } |
| 217 | 215 | |
| 218 | 216 | static ADDRESS_MAP_START( gamate_mem, AS_PROGRAM, 8, gamate_state ) |
| 219 | | AM_RANGE(0x0000, 0x03ff) AM_RAM |
| 220 | | AM_RANGE(0x4000, 0x400d) AM_READWRITE(gamate_audio_r, gamate_audio_w) |
| 221 | | AM_RANGE(0x4400, 0x4400) AM_READ(gamate_pad_r) |
| 222 | | AM_RANGE(0x5000, 0x5007) AM_READWRITE(gamate_video_r, gamate_video_w) |
| 223 | | AM_RANGE(0x5800, 0x5800) AM_READ(newer_protection_set) |
| 224 | | AM_RANGE(0x5900, 0x5900) AM_WRITE(protection_reset) |
| 225 | | AM_RANGE(0x5a00, 0x5a00) AM_READ(protection_r) |
| 217 | AM_RANGE(0x0000, 0x03ff) AM_RAM |
| 218 | AM_RANGE(0x4000, 0x400d) AM_READWRITE(gamate_audio_r, gamate_audio_w) |
| 219 | AM_RANGE(0x4400, 0x4400) AM_READ(gamate_pad_r) |
| 220 | AM_RANGE(0x5000, 0x5007) AM_READWRITE(gamate_video_r, gamate_video_w) |
| 221 | AM_RANGE(0x5800, 0x5800) AM_READ(newer_protection_set) |
| 222 | AM_RANGE(0x5900, 0x5900) AM_WRITE(protection_reset) |
| 223 | AM_RANGE(0x5a00, 0x5a00) AM_READ(protection_r) |
| 226 | 224 | |
| 227 | | AM_RANGE(0x6001, 0x9fff) AM_READ_BANK("bankmulti") |
| 228 | | AM_RANGE(0xa000, 0xdfff) AM_READ_BANK("bank") |
| 225 | AM_RANGE(0x6001, 0x9fff) AM_READ_BANK("bankmulti") |
| 226 | AM_RANGE(0xa000, 0xdfff) AM_READ_BANK("bank") |
| 229 | 227 | |
| 230 | 228 | AM_RANGE(0x6000, 0x6000) AM_READWRITE(gamate_cart_protection_r, gamate_cart_protection_w) |
| 231 | 229 | AM_RANGE(0x8000, 0x8000) AM_WRITE(cart_bankswitchmulti_w) |
| 232 | 230 | AM_RANGE(0xc000, 0xc000) AM_WRITE(cart_bankswitch_w) |
| 233 | 231 | |
| 234 | | AM_RANGE(0xf000, 0xffff) AM_ROM AM_SHARE("bios") |
| 232 | AM_RANGE(0xf000, 0xffff) AM_ROM AM_SHARE("bios") |
| 235 | 233 | ADDRESS_MAP_END |
| 236 | 234 | |
| 237 | 235 | |
| r244561 | r244562 | |
| 247 | 245 | PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_SELECT) PORT_NAME("Select") |
| 248 | 246 | INPUT_PORTS_END |
| 249 | 247 | |
| 250 | | #ifdef USE_GFX |
| 251 | | static const struct gfx_layout gamate_charlayout = |
| 248 | static const unsigned short gamate_palette[4] = |
| 252 | 249 | { |
| 253 | | 4, /* width of object */ |
| 254 | | 1, /* height of object */ |
| 255 | | 256,/* 256 characters */ |
| 256 | | 2, /* bits per pixel */ |
| 257 | | { 0,4 }, /* no bitplanes */ |
| 258 | | /* x offsets */ |
| 259 | | { 0,1,2,3 }, |
| 260 | | /* y offsets */ |
| 261 | | { 0 }, |
| 262 | | 8*1 /* size of 1 object in bits */ |
| 250 | 0,1,2,3 |
| 263 | 251 | }; |
| 264 | 252 | |
| 265 | | static GFXDECODE_START( gamate ) |
| 266 | | GFXDECODE_ENTRY( "gfx1", 0x0000, gamate_charlayout, 0, 0x100 ) |
| 267 | | GFXDECODE_END |
| 268 | | #endif |
| 269 | 253 | |
| 270 | 254 | /* palette in red, green, blue tribles */ |
| 271 | 255 | static const unsigned char gamate_colors[4][3] = |
| 272 | 256 | { |
| 273 | | { 255,255,255 }, |
| 274 | | { 0xa0, 0xa0, 0xa0 }, |
| 275 | | { 0x60, 0x60, 0x60 }, |
| 276 | | { 0, 0, 0 } |
| 257 | { 255,255,255 }, |
| 258 | { 0xa0, 0xa0, 0xa0 }, |
| 259 | { 0x60, 0x60, 0x60 }, |
| 260 | { 0, 0, 0 } |
| 277 | 261 | }; |
| 278 | 262 | |
| 279 | 263 | PALETTE_INIT_MEMBER(gamate_state, gamate) |
| r244561 | r244562 | |
| 286 | 270 | } |
| 287 | 271 | } |
| 288 | 272 | |
| 289 | | #ifndef USE_GFX |
| 290 | 273 | static void BlitPlane(UINT16* line, UINT8 plane1, UINT8 plane2) |
| 291 | 274 | { |
| 292 | 275 | line[3]=(plane1&1)|((plane2<<1)&2); |
| r244561 | r244562 | |
| 294 | 277 | line[1]=((plane1>>2)&1)|((plane2>>1)&2); |
| 295 | 278 | line[0]=((plane1>>3)&1)|((plane2>>2)&2); |
| 296 | 279 | } |
| 297 | | #endif |
| 298 | 280 | |
| 299 | 281 | UINT32 gamate_state::screen_update_gamate(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 300 | 282 | { |
| 301 | | int x, y, j; |
| 302 | | for (y=0;y<152;y++) { |
| 303 | | for (x=-(video.bitmap.xpos&7), j=0;x<160;x+=8, j++) { |
| 304 | | UINT8 d1=video.bitmap.data[0][(y+video.bitmap.ypos)&0xff][(j+video.bitmap.xpos/8)&0x1f]; |
| 305 | | UINT8 d2=video.bitmap.data[1][(y+video.bitmap.ypos)&0xff][(j+video.bitmap.xpos/8)&0x1f]; |
| 306 | | #ifdef USE_GFX |
| 307 | | m_gfxdecode->gfx(0)->opaque(bitmap,cliprect, (d1&0xf)|((d2&0xf)<<4), 0,0,0,x+4,y); |
| 308 | | m_gfxdecode->gfx(0)->opaque(bitmap,cliprect, (d1>>4)|(d2&0xf0),0,0,0,x,y); |
| 309 | | #else |
| 310 | | BlitPlane(&bitmap.pix16(y, x+4), d1, d2); |
| 311 | | BlitPlane(&bitmap.pix16(y, x), d1>>4, d2>>4); |
| 312 | | #endif |
| 313 | | } |
| 314 | | } |
| 315 | | return 0; |
| 283 | int x, y, j; |
| 284 | for (y=0;y<152;y++) { |
| 285 | for (x=-(video.bitmap.xpos&7), j=0;x<160;x+=8, j++) { |
| 286 | UINT8 d1, d2; |
| 287 | if (video.bitmap.ypos<200) { |
| 288 | d1=video.bitmap.data[0][(y+video.bitmap.ypos)%200][(j+video.bitmap.xpos/8)&0x1f]; |
| 289 | d2=video.bitmap.data[1][(y+video.bitmap.ypos)%200][(j+video.bitmap.xpos/8)&0x1f]; |
| 290 | } else if ((video.bitmap.ypos&0xf)<8) { // lcdtest, of course still some registers not known, my gamate doesn't display bottom lines |
| 291 | int yi=(y+(video.bitmap.ypos&0xf)-8); |
| 292 | if (yi<0) yi=video.bitmap.ypos+y; // in this case only 2nd plane used!?, source of first plane? |
| 293 | d1=video.bitmap.data[0][yi][(j+video.bitmap.xpos/8)&0x1f]; // value of lines bevor 0 chaos |
| 294 | d2=video.bitmap.data[1][yi][(j+video.bitmap.xpos/8)&0x1f]; |
| 295 | } else { |
| 296 | d1=video.bitmap.data[0][y][(j+video.bitmap.xpos/8)&0x1f]; |
| 297 | d2=video.bitmap.data[1][y][(j+video.bitmap.xpos/8)&0x1f]; |
| 298 | } |
| 299 | BlitPlane(&bitmap.pix16(y, x+4), d1, d2); |
| 300 | BlitPlane(&bitmap.pix16(y, x), d1>>4, d2>>4); |
| 301 | } |
| 302 | } |
| 303 | return 0; |
| 316 | 304 | } |
| 317 | 305 | |
| 318 | 306 | DRIVER_INIT_MEMBER(gamate_state,gamate) |
| 319 | 307 | { |
| 320 | 308 | memset(&video, 0, sizeof(video));/* memset(m_ram, 0, sizeof(m_ram));*/ |
| 321 | | #ifdef USE_GFX |
| 322 | | UINT8 *gfx=memregion("gfx1")->base(); |
| 323 | | for (int i=0; i<256; i++) gfx[i]=i; |
| 324 | | #endif |
| 325 | 309 | timer1 = machine().scheduler().timer_alloc(timer_expired_delegate(FUNC(gamate_state::gamate_timer),this)); |
| 326 | 310 | timer2 = machine().scheduler().timer_alloc(timer_expired_delegate(FUNC(gamate_state::gamate_timer2),this)); |
| 327 | 311 | } |
| r244561 | r244562 | |
| 329 | 313 | |
| 330 | 314 | void gamate_state::machine_start() |
| 331 | 315 | { |
| 332 | | m_cart_ptr = memregion("maincpu")->base() + 0x6000; |
| 333 | 316 | if (m_cart->exists()) { |
| 334 | | // m_maincpu->space(AS_PROGRAM).install_read_handler(0x6000, 0x6000, READ8_DELEGATE(gamate_state, gamate_cart_protection_r)); |
| 335 | | m_cart_ptr = m_cart->get_rom_base(); |
| 317 | // m_maincpu->space(AS_PROGRAM).install_read_handler(0x6000, 0x6000, READ8_DELEGATE(gamate_state, gamate_cart_protection_r)); |
| 336 | 318 | membank("bankmulti")->set_base(m_cart->get_rom_base()+1); |
| 337 | 319 | membank("bank")->set_base(m_cart->get_rom_base()+0x4000); // bankswitched games in reality no offset |
| 338 | 320 | } |
| 339 | | // m_bios[0xdf1]=0xea; m_bios[0xdf2]=0xea; // default bios: $47 protection readback |
| 321 | // m_bios[0xdf1]=0xea; m_bios[0xdf2]=0xea; // default bios: $47 protection readback |
| 340 | 322 | card_protection.set=false; |
| 341 | 323 | bank_multi=0; |
| 342 | 324 | card_protection.unprotected=false; |
| r244561 | r244562 | |
| 367 | 349 | timer1->enable(TRUE); |
| 368 | 350 | timer1->reset(m_maincpu->cycles_to_attotime(10/* cycles short enought to clear irq line early enough*/)); |
| 369 | 351 | timer2->enable(TRUE); |
| 370 | | timer2->reset(m_maincpu->cycles_to_attotime(40000)); |
| 352 | timer2->reset(m_maincpu->cycles_to_attotime(32768/2)); |
| 371 | 353 | } |
| 372 | 354 | |
| 373 | 355 | |
| r244561 | r244562 | |
| 376 | 358 | } |
| 377 | 359 | |
| 378 | 360 | static MACHINE_CONFIG_START( gamate, gamate_state ) |
| 379 | | MCFG_CPU_ADD("maincpu", M6502, 4433000) |
| 361 | MCFG_CPU_ADD("maincpu", M6502, 4433000/2) |
| 380 | 362 | MCFG_CPU_PROGRAM_MAP(gamate_mem) |
| 381 | 363 | MCFG_CPU_VBLANK_INT_DRIVER("screen", gamate_state, gamate_interrupt) |
| 382 | 364 | |
| r244561 | r244562 | |
| 387 | 369 | MCFG_SCREEN_UPDATE_DRIVER(gamate_state, screen_update_gamate) |
| 388 | 370 | MCFG_SCREEN_PALETTE("palette") |
| 389 | 371 | |
| 390 | | #ifdef USE_GFX |
| 391 | | MCFG_GFXDECODE_ADD("gfxdecode", "palette", gamate ) |
| 392 | | #endif |
| 393 | 372 | MCFG_PALETTE_ADD("palette", ARRAY_LENGTH(gamate_colors)) |
| 394 | 373 | MCFG_PALETTE_INIT_OWNER(gamate_state, gamate) |
| 395 | 374 | MCFG_DEFAULT_LAYOUT(layout_lcd) |
| 396 | 375 | |
| 376 | /* sound hardware */ |
| 377 | MCFG_SPEAKER_STANDARD_STEREO("lspeaker", "rspeaker") |
| 378 | MCFG_SOUND_ADD("custom", GAMATE_SND, 0) |
| 379 | MCFG_SOUND_ROUTE(0, "lspeaker", 0.50) |
| 380 | MCFG_SOUND_ROUTE(1, "rspeaker", 0.50) |
| 381 | |
| 397 | 382 | MCFG_GENERIC_CARTSLOT_ADD("cartslot", generic_linear_slot, "gamate_cart") |
| 398 | 383 | MCFG_GENERIC_MANDATORY |
| 399 | 384 | |
| r244561 | r244562 | |
| 407 | 392 | ROMX_LOAD("gamate_bios_umc.bin", 0xf000, 0x1000, CRC(07090415) SHA1(ea449dc607601f9a68d855ad6ab53800d2e99297), ROM_BIOS(1) ) |
| 408 | 393 | ROM_SYSTEM_BIOS(1, "newer", "NEWER") |
| 409 | 394 | ROMX_LOAD("gamate_bios_9130__unknown__bit_icasc00001_9130-bs_r32261.bin", 0xf000, 0x1000, CRC(03a5f3a7) SHA1(4e9dfbfe916ca485530ef4221593ab68738e2217), ROM_BIOS(2) ) |
| 410 | | #ifdef USE_GFX |
| 411 | | ROM_REGION(0x100,"gfx1", ROMREGION_ERASEFF) |
| 412 | | #endif |
| 413 | 395 | ROM_END |
| 414 | 396 | |
| 415 | 397 | |
| 416 | 398 | /* YEAR NAME PARENT COMPAT MACHINE INPUT CLASS INIT COMPANY FULLNAME */ |
| 417 | | CONS( 19??, gamate, 0, 0, gamate, gamate, gamate_state, gamate, "Bit Corp", "Gamate", GAME_NO_SOUND) |
| 399 | CONS( 19??, gamate, 0, 0, gamate, gamate, gamate_state, gamate, "Bit Corp", "Gamate", GAME_IMPERFECT_SOUND) |
| 400 | |
| 401 | |