Commit 5462327761e909bddb8b3a14051e415351781fe3
1 parent
e8eaa2c0
Concentrate most table entries to top
Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
Showing
1 changed file
with
291 additions
and
422 deletions
target-ppc/translate.c
| ... | ... | @@ -558,10 +558,246 @@ static always_inline void gen_store_spr(int reg, TCGv t) |
| 558 | 558 | |
| 559 | 559 | /* Start opcode list */ |
| 560 | 560 | GEN_OPCODE_MARK(start); |
| 561 | - | |
| 562 | -/* Invalid instruction */ | |
| 563 | 561 | GEN_HANDLER(invalid, 0x00, 0x00, 0x00, 0xFFFFFFFF, PPC_NONE); |
| 562 | +GEN_HANDLER(cmp, 0x1F, 0x00, 0x00, 0x00400000, PPC_INTEGER); | |
| 563 | +GEN_HANDLER(cmpi, 0x0B, 0xFF, 0xFF, 0x00400000, PPC_INTEGER); | |
| 564 | +GEN_HANDLER(cmpl, 0x1F, 0x00, 0x01, 0x00400000, PPC_INTEGER); | |
| 565 | +GEN_HANDLER(cmpli, 0x0A, 0xFF, 0xFF, 0x00400000, PPC_INTEGER); | |
| 566 | +GEN_HANDLER(isel, 0x1F, 0x0F, 0xFF, 0x00000001, PPC_ISEL); | |
| 567 | +GEN_HANDLER(addi, 0x0E, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 568 | +GEN_HANDLER(addic, 0x0C, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 569 | +GEN_HANDLER2(addic_, "addic.", 0x0D, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 570 | +GEN_HANDLER(addis, 0x0F, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 571 | +GEN_HANDLER(mulhw, 0x1F, 0x0B, 0x02, 0x00000400, PPC_INTEGER); | |
| 572 | +GEN_HANDLER(mulhwu, 0x1F, 0x0B, 0x00, 0x00000400, PPC_INTEGER); | |
| 573 | +GEN_HANDLER(mullw, 0x1F, 0x0B, 0x07, 0x00000000, PPC_INTEGER); | |
| 574 | +GEN_HANDLER(mullwo, 0x1F, 0x0B, 0x17, 0x00000000, PPC_INTEGER); | |
| 575 | +GEN_HANDLER(mulli, 0x07, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 576 | +#if defined(TARGET_PPC64) | |
| 577 | +GEN_HANDLER(mulld, 0x1F, 0x09, 0x07, 0x00000000, PPC_64B); | |
| 578 | +#endif | |
| 579 | +GEN_HANDLER(neg, 0x1F, 0x08, 0x03, 0x0000F800, PPC_INTEGER); | |
| 580 | +GEN_HANDLER(nego, 0x1F, 0x08, 0x13, 0x0000F800, PPC_INTEGER); | |
| 581 | +GEN_HANDLER(subfic, 0x08, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 582 | +GEN_HANDLER2(andi_, "andi.", 0x1C, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 583 | +GEN_HANDLER2(andis_, "andis.", 0x1D, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 584 | +GEN_HANDLER(cntlzw, 0x1F, 0x1A, 0x00, 0x00000000, PPC_INTEGER); | |
| 585 | +GEN_HANDLER(or, 0x1F, 0x1C, 0x0D, 0x00000000, PPC_INTEGER); | |
| 586 | +GEN_HANDLER(xor, 0x1F, 0x1C, 0x09, 0x00000000, PPC_INTEGER); | |
| 587 | +GEN_HANDLER(ori, 0x18, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 588 | +GEN_HANDLER(oris, 0x19, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 589 | +GEN_HANDLER(xori, 0x1A, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 590 | +GEN_HANDLER(xoris, 0x1B, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 591 | +GEN_HANDLER(popcntb, 0x1F, 0x03, 0x03, 0x0000F801, PPC_POPCNTB); | |
| 592 | +#if defined(TARGET_PPC64) | |
| 593 | +GEN_HANDLER(cntlzd, 0x1F, 0x1A, 0x01, 0x00000000, PPC_64B); | |
| 594 | +#endif | |
| 595 | +GEN_HANDLER(rlwimi, 0x14, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 596 | +GEN_HANDLER(rlwinm, 0x15, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 597 | +GEN_HANDLER(rlwnm, 0x17, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 598 | +GEN_HANDLER(slw, 0x1F, 0x18, 0x00, 0x00000000, PPC_INTEGER); | |
| 599 | +GEN_HANDLER(sraw, 0x1F, 0x18, 0x18, 0x00000000, PPC_INTEGER); | |
| 600 | +GEN_HANDLER(srawi, 0x1F, 0x18, 0x19, 0x00000000, PPC_INTEGER); | |
| 601 | +GEN_HANDLER(srw, 0x1F, 0x18, 0x10, 0x00000000, PPC_INTEGER); | |
| 602 | +#if defined(TARGET_PPC64) | |
| 603 | +GEN_HANDLER(sld, 0x1F, 0x1B, 0x00, 0x00000000, PPC_64B); | |
| 604 | +GEN_HANDLER(srad, 0x1F, 0x1A, 0x18, 0x00000000, PPC_64B); | |
| 605 | +GEN_HANDLER2(sradi0, "sradi", 0x1F, 0x1A, 0x19, 0x00000000, PPC_64B); | |
| 606 | +GEN_HANDLER2(sradi1, "sradi", 0x1F, 0x1B, 0x19, 0x00000000, PPC_64B); | |
| 607 | +GEN_HANDLER(srd, 0x1F, 0x1B, 0x10, 0x00000000, PPC_64B); | |
| 608 | +#endif | |
| 609 | +GEN_HANDLER(frsqrtes, 0x3B, 0x1A, 0xFF, 0x001F07C0, PPC_FLOAT_FRSQRTES); | |
| 610 | +GEN_HANDLER(fsqrt, 0x3F, 0x16, 0xFF, 0x001F07C0, PPC_FLOAT_FSQRT); | |
| 611 | +GEN_HANDLER(fsqrts, 0x3B, 0x16, 0xFF, 0x001F07C0, PPC_FLOAT_FSQRT); | |
| 612 | +GEN_HANDLER(fcmpo, 0x3F, 0x00, 0x01, 0x00600001, PPC_FLOAT); | |
| 613 | +GEN_HANDLER(fcmpu, 0x3F, 0x00, 0x00, 0x00600001, PPC_FLOAT); | |
| 614 | +GEN_HANDLER(fmr, 0x3F, 0x08, 0x02, 0x001F0000, PPC_FLOAT); | |
| 615 | +GEN_HANDLER(mcrfs, 0x3F, 0x00, 0x02, 0x0063F801, PPC_FLOAT); | |
| 616 | +GEN_HANDLER(mffs, 0x3F, 0x07, 0x12, 0x001FF800, PPC_FLOAT); | |
| 617 | +GEN_HANDLER(mtfsb0, 0x3F, 0x06, 0x02, 0x001FF800, PPC_FLOAT); | |
| 618 | +GEN_HANDLER(mtfsb1, 0x3F, 0x06, 0x01, 0x001FF800, PPC_FLOAT); | |
| 619 | +GEN_HANDLER(mtfsf, 0x3F, 0x07, 0x16, 0x00010000, PPC_FLOAT); | |
| 620 | +GEN_HANDLER(mtfsfi, 0x3F, 0x06, 0x04, 0x006f0800, PPC_FLOAT); | |
| 621 | +#if defined(TARGET_PPC64) | |
| 622 | +GEN_HANDLER(ld, 0x3A, 0xFF, 0xFF, 0x00000000, PPC_64B); | |
| 623 | +GEN_HANDLER(lq, 0x38, 0xFF, 0xFF, 0x00000000, PPC_64BX); | |
| 624 | +GEN_HANDLER(std, 0x3E, 0xFF, 0xFF, 0x00000000, PPC_64B); | |
| 625 | +#endif | |
| 626 | +GEN_HANDLER(lmw, 0x2E, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 627 | +GEN_HANDLER(stmw, 0x2F, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 628 | +GEN_HANDLER(lswi, 0x1F, 0x15, 0x12, 0x00000001, PPC_STRING); | |
| 629 | +GEN_HANDLER(lswx, 0x1F, 0x15, 0x10, 0x00000001, PPC_STRING); | |
| 630 | +GEN_HANDLER(stswi, 0x1F, 0x15, 0x16, 0x00000001, PPC_STRING); | |
| 631 | +GEN_HANDLER(stswx, 0x1F, 0x15, 0x14, 0x00000001, PPC_STRING); | |
| 632 | +GEN_HANDLER(eieio, 0x1F, 0x16, 0x1A, 0x03FFF801, PPC_MEM_EIEIO); | |
| 633 | +GEN_HANDLER(isync, 0x13, 0x16, 0x04, 0x03FFF801, PPC_MEM); | |
| 634 | +GEN_HANDLER(lwarx, 0x1F, 0x14, 0x00, 0x00000001, PPC_RES); | |
| 635 | +GEN_HANDLER2(stwcx_, "stwcx.", 0x1F, 0x16, 0x04, 0x00000000, PPC_RES); | |
| 636 | +#if defined(TARGET_PPC64) | |
| 637 | +GEN_HANDLER(ldarx, 0x1F, 0x14, 0x02, 0x00000001, PPC_64B); | |
| 638 | +GEN_HANDLER2(stdcx_, "stdcx.", 0x1F, 0x16, 0x06, 0x00000000, PPC_64B); | |
| 639 | +#endif | |
| 640 | +GEN_HANDLER(sync, 0x1F, 0x16, 0x12, 0x039FF801, PPC_MEM_SYNC); | |
| 641 | +GEN_HANDLER(wait, 0x1F, 0x1E, 0x01, 0x03FFF801, PPC_WAIT); | |
| 642 | +GEN_HANDLER(b, 0x12, 0xFF, 0xFF, 0x00000000, PPC_FLOW); | |
| 643 | +GEN_HANDLER(bc, 0x10, 0xFF, 0xFF, 0x00000000, PPC_FLOW); | |
| 644 | +GEN_HANDLER(bcctr, 0x13, 0x10, 0x10, 0x00000000, PPC_FLOW); | |
| 645 | +GEN_HANDLER(bclr, 0x13, 0x10, 0x00, 0x00000000, PPC_FLOW); | |
| 646 | +GEN_HANDLER(mcrf, 0x13, 0x00, 0xFF, 0x00000001, PPC_INTEGER); | |
| 647 | +GEN_HANDLER(rfi, 0x13, 0x12, 0x01, 0x03FF8001, PPC_FLOW); | |
| 648 | +#if defined(TARGET_PPC64) | |
| 649 | +GEN_HANDLER(rfid, 0x13, 0x12, 0x00, 0x03FF8001, PPC_64B); | |
| 650 | +GEN_HANDLER(hrfid, 0x13, 0x12, 0x08, 0x03FF8001, PPC_64H); | |
| 651 | +#endif | |
| 652 | +GEN_HANDLER(sc, 0x11, 0xFF, 0xFF, 0x03FFF01D, PPC_FLOW); | |
| 653 | +GEN_HANDLER(tw, 0x1F, 0x04, 0x00, 0x00000001, PPC_FLOW); | |
| 654 | +GEN_HANDLER(twi, 0x03, 0xFF, 0xFF, 0x00000000, PPC_FLOW); | |
| 655 | +#if defined(TARGET_PPC64) | |
| 656 | +GEN_HANDLER(td, 0x1F, 0x04, 0x02, 0x00000001, PPC_64B); | |
| 657 | +GEN_HANDLER(tdi, 0x02, 0xFF, 0xFF, 0x00000000, PPC_64B); | |
| 658 | +#endif | |
| 659 | +GEN_HANDLER(mcrxr, 0x1F, 0x00, 0x10, 0x007FF801, PPC_MISC); | |
| 660 | +GEN_HANDLER(mfcr, 0x1F, 0x13, 0x00, 0x00000801, PPC_MISC); | |
| 661 | +GEN_HANDLER(mfmsr, 0x1F, 0x13, 0x02, 0x001FF801, PPC_MISC); | |
| 662 | +GEN_HANDLER(mfspr, 0x1F, 0x13, 0x0A, 0x00000001, PPC_MISC); | |
| 663 | +GEN_HANDLER(mftb, 0x1F, 0x13, 0x0B, 0x00000001, PPC_MFTB); | |
| 664 | +GEN_HANDLER(mtcrf, 0x1F, 0x10, 0x04, 0x00000801, PPC_MISC); | |
| 665 | +#if defined(TARGET_PPC64) | |
| 666 | +GEN_HANDLER(mtmsrd, 0x1F, 0x12, 0x05, 0x001EF801, PPC_64B); | |
| 667 | +#endif | |
| 668 | +GEN_HANDLER(mtmsr, 0x1F, 0x12, 0x04, 0x001FF801, PPC_MISC); | |
| 669 | +GEN_HANDLER(mtspr, 0x1F, 0x13, 0x0E, 0x00000001, PPC_MISC); | |
| 670 | +GEN_HANDLER(dcbf, 0x1F, 0x16, 0x02, 0x03C00001, PPC_CACHE); | |
| 671 | +GEN_HANDLER(dcbi, 0x1F, 0x16, 0x0E, 0x03E00001, PPC_CACHE); | |
| 672 | +GEN_HANDLER(dcbst, 0x1F, 0x16, 0x01, 0x03E00001, PPC_CACHE); | |
| 673 | +GEN_HANDLER(dcbt, 0x1F, 0x16, 0x08, 0x02000001, PPC_CACHE); | |
| 674 | +GEN_HANDLER(dcbtst, 0x1F, 0x16, 0x07, 0x02000001, PPC_CACHE); | |
| 675 | +GEN_HANDLER(dcbz, 0x1F, 0x16, 0x1F, 0x03E00001, PPC_CACHE_DCBZ); | |
| 676 | +GEN_HANDLER2(dcbz_970, "dcbz", 0x1F, 0x16, 0x1F, 0x03C00001, PPC_CACHE_DCBZT); | |
| 677 | +GEN_HANDLER(dst, 0x1F, 0x16, 0x0A, 0x01800001, PPC_ALTIVEC); | |
| 678 | +GEN_HANDLER(dstst, 0x1F, 0x16, 0x0B, 0x02000001, PPC_ALTIVEC); | |
| 679 | +GEN_HANDLER(dss, 0x1F, 0x16, 0x19, 0x019FF801, PPC_ALTIVEC); | |
| 680 | +GEN_HANDLER(icbi, 0x1F, 0x16, 0x1E, 0x03E00001, PPC_CACHE_ICBI); | |
| 681 | +GEN_HANDLER(dcba, 0x1F, 0x16, 0x17, 0x03E00001, PPC_CACHE_DCBA); | |
| 682 | +GEN_HANDLER(mfsr, 0x1F, 0x13, 0x12, 0x0010F801, PPC_SEGMENT); | |
| 683 | +GEN_HANDLER(mfsrin, 0x1F, 0x13, 0x14, 0x001F0001, PPC_SEGMENT); | |
| 684 | +GEN_HANDLER(mtsr, 0x1F, 0x12, 0x06, 0x0010F801, PPC_SEGMENT); | |
| 685 | +GEN_HANDLER(mtsrin, 0x1F, 0x12, 0x07, 0x001F0001, PPC_SEGMENT); | |
| 686 | +#if defined(TARGET_PPC64) | |
| 687 | +GEN_HANDLER2(mfsr_64b, "mfsr", 0x1F, 0x13, 0x12, 0x0010F801, PPC_SEGMENT_64B); | |
| 688 | +GEN_HANDLER2(mfsrin_64b, "mfsrin", 0x1F, 0x13, 0x14, 0x001F0001, | |
| 689 | + PPC_SEGMENT_64B); | |
| 690 | +GEN_HANDLER2(mtsr_64b, "mtsr", 0x1F, 0x12, 0x06, 0x0010F801, PPC_SEGMENT_64B); | |
| 691 | +GEN_HANDLER2(mtsrin_64b, "mtsrin", 0x1F, 0x12, 0x07, 0x001F0001, | |
| 692 | + PPC_SEGMENT_64B); | |
| 693 | +GEN_HANDLER2(slbmte, "slbmte", 0x1F, 0x12, 0x0C, 0x00000000, PPC_SEGMENT_64B); | |
| 694 | +#endif | |
| 695 | +GEN_HANDLER(tlbia, 0x1F, 0x12, 0x0B, 0x03FFFC01, PPC_MEM_TLBIA); | |
| 696 | +GEN_HANDLER(tlbiel, 0x1F, 0x12, 0x08, 0x03FF0001, PPC_MEM_TLBIE); | |
| 697 | +GEN_HANDLER(tlbie, 0x1F, 0x12, 0x09, 0x03FF0001, PPC_MEM_TLBIE); | |
| 698 | +GEN_HANDLER(tlbsync, 0x1F, 0x16, 0x11, 0x03FFF801, PPC_MEM_TLBSYNC); | |
| 699 | +#if defined(TARGET_PPC64) | |
| 700 | +GEN_HANDLER(slbia, 0x1F, 0x12, 0x0F, 0x03FFFC01, PPC_SLBI); | |
| 701 | +GEN_HANDLER(slbie, 0x1F, 0x12, 0x0D, 0x03FF0001, PPC_SLBI); | |
| 702 | +#endif | |
| 703 | +GEN_HANDLER(eciwx, 0x1F, 0x16, 0x0D, 0x00000001, PPC_EXTERN); | |
| 704 | +GEN_HANDLER(ecowx, 0x1F, 0x16, 0x09, 0x00000001, PPC_EXTERN); | |
| 705 | +GEN_HANDLER(abs, 0x1F, 0x08, 0x0B, 0x0000F800, PPC_POWER_BR); | |
| 706 | +GEN_HANDLER(abso, 0x1F, 0x08, 0x1B, 0x0000F800, PPC_POWER_BR); | |
| 707 | +GEN_HANDLER(clcs, 0x1F, 0x10, 0x13, 0x0000F800, PPC_POWER_BR); | |
| 708 | +GEN_HANDLER(div, 0x1F, 0x0B, 0x0A, 0x00000000, PPC_POWER_BR); | |
| 709 | +GEN_HANDLER(divo, 0x1F, 0x0B, 0x1A, 0x00000000, PPC_POWER_BR); | |
| 710 | +GEN_HANDLER(divs, 0x1F, 0x0B, 0x0B, 0x00000000, PPC_POWER_BR); | |
| 711 | +GEN_HANDLER(divso, 0x1F, 0x0B, 0x1B, 0x00000000, PPC_POWER_BR); | |
| 712 | +GEN_HANDLER(doz, 0x1F, 0x08, 0x08, 0x00000000, PPC_POWER_BR); | |
| 713 | +GEN_HANDLER(dozo, 0x1F, 0x08, 0x18, 0x00000000, PPC_POWER_BR); | |
| 714 | +GEN_HANDLER(dozi, 0x09, 0xFF, 0xFF, 0x00000000, PPC_POWER_BR); | |
| 715 | +GEN_HANDLER(lscbx, 0x1F, 0x15, 0x08, 0x00000000, PPC_POWER_BR); | |
| 716 | +GEN_HANDLER(maskg, 0x1F, 0x1D, 0x00, 0x00000000, PPC_POWER_BR); | |
| 717 | +GEN_HANDLER(maskir, 0x1F, 0x1D, 0x10, 0x00000000, PPC_POWER_BR); | |
| 718 | +GEN_HANDLER(mul, 0x1F, 0x0B, 0x03, 0x00000000, PPC_POWER_BR); | |
| 719 | +GEN_HANDLER(mulo, 0x1F, 0x0B, 0x13, 0x00000000, PPC_POWER_BR); | |
| 720 | +GEN_HANDLER(nabs, 0x1F, 0x08, 0x0F, 0x00000000, PPC_POWER_BR); | |
| 721 | +GEN_HANDLER(nabso, 0x1F, 0x08, 0x1F, 0x00000000, PPC_POWER_BR); | |
| 722 | +GEN_HANDLER(rlmi, 0x16, 0xFF, 0xFF, 0x00000000, PPC_POWER_BR); | |
| 723 | +GEN_HANDLER(rrib, 0x1F, 0x19, 0x10, 0x00000000, PPC_POWER_BR); | |
| 724 | +GEN_HANDLER(sle, 0x1F, 0x19, 0x04, 0x00000000, PPC_POWER_BR); | |
| 725 | +GEN_HANDLER(sleq, 0x1F, 0x19, 0x06, 0x00000000, PPC_POWER_BR); | |
| 726 | +GEN_HANDLER(sliq, 0x1F, 0x18, 0x05, 0x00000000, PPC_POWER_BR); | |
| 727 | +GEN_HANDLER(slliq, 0x1F, 0x18, 0x07, 0x00000000, PPC_POWER_BR); | |
| 728 | +GEN_HANDLER(sllq, 0x1F, 0x18, 0x06, 0x00000000, PPC_POWER_BR); | |
| 729 | +GEN_HANDLER(slq, 0x1F, 0x18, 0x04, 0x00000000, PPC_POWER_BR); | |
| 730 | +GEN_HANDLER(sraiq, 0x1F, 0x18, 0x1D, 0x00000000, PPC_POWER_BR); | |
| 731 | +GEN_HANDLER(sraq, 0x1F, 0x18, 0x1C, 0x00000000, PPC_POWER_BR); | |
| 732 | +GEN_HANDLER(sre, 0x1F, 0x19, 0x14, 0x00000000, PPC_POWER_BR); | |
| 733 | +GEN_HANDLER(srea, 0x1F, 0x19, 0x1C, 0x00000000, PPC_POWER_BR); | |
| 734 | +GEN_HANDLER(sreq, 0x1F, 0x19, 0x16, 0x00000000, PPC_POWER_BR); | |
| 735 | +GEN_HANDLER(sriq, 0x1F, 0x18, 0x15, 0x00000000, PPC_POWER_BR); | |
| 736 | +GEN_HANDLER(srliq, 0x1F, 0x18, 0x17, 0x00000000, PPC_POWER_BR); | |
| 737 | +GEN_HANDLER(srlq, 0x1F, 0x18, 0x16, 0x00000000, PPC_POWER_BR); | |
| 738 | +GEN_HANDLER(srq, 0x1F, 0x18, 0x14, 0x00000000, PPC_POWER_BR); | |
| 739 | +GEN_HANDLER(dsa, 0x1F, 0x14, 0x13, 0x03FFF801, PPC_602_SPEC); | |
| 740 | +GEN_HANDLER(esa, 0x1F, 0x14, 0x12, 0x03FFF801, PPC_602_SPEC); | |
| 741 | +GEN_HANDLER(mfrom, 0x1F, 0x09, 0x08, 0x03E0F801, PPC_602_SPEC); | |
| 742 | +GEN_HANDLER2(tlbld_6xx, "tlbld", 0x1F, 0x12, 0x1E, 0x03FF0001, PPC_6xx_TLB); | |
| 743 | +GEN_HANDLER2(tlbli_6xx, "tlbli", 0x1F, 0x12, 0x1F, 0x03FF0001, PPC_6xx_TLB); | |
| 744 | +GEN_HANDLER2(tlbld_74xx, "tlbld", 0x1F, 0x12, 0x1E, 0x03FF0001, PPC_74xx_TLB); | |
| 745 | +GEN_HANDLER2(tlbli_74xx, "tlbli", 0x1F, 0x12, 0x1F, 0x03FF0001, PPC_74xx_TLB); | |
| 746 | +GEN_HANDLER(clf, 0x1F, 0x16, 0x03, 0x03E00000, PPC_POWER); | |
| 747 | +GEN_HANDLER(cli, 0x1F, 0x16, 0x0F, 0x03E00000, PPC_POWER); | |
| 748 | +GEN_HANDLER(dclst, 0x1F, 0x16, 0x13, 0x03E00000, PPC_POWER); | |
| 749 | +GEN_HANDLER(mfsri, 0x1F, 0x13, 0x13, 0x00000001, PPC_POWER); | |
| 750 | +GEN_HANDLER(rac, 0x1F, 0x12, 0x19, 0x00000001, PPC_POWER); | |
| 751 | +GEN_HANDLER(rfsvc, 0x13, 0x12, 0x02, 0x03FFF0001, PPC_POWER); | |
| 752 | +GEN_HANDLER(lfq, 0x38, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 753 | +GEN_HANDLER(lfqu, 0x39, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 754 | +GEN_HANDLER(lfqux, 0x1F, 0x17, 0x19, 0x00000001, PPC_POWER2); | |
| 755 | +GEN_HANDLER(lfqx, 0x1F, 0x17, 0x18, 0x00000001, PPC_POWER2); | |
| 756 | +GEN_HANDLER(stfq, 0x3C, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 757 | +GEN_HANDLER(stfqu, 0x3D, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 758 | +GEN_HANDLER(stfqux, 0x1F, 0x17, 0x1D, 0x00000001, PPC_POWER2); | |
| 759 | +GEN_HANDLER(stfqx, 0x1F, 0x17, 0x1C, 0x00000001, PPC_POWER2); | |
| 760 | +GEN_HANDLER(mfapidi, 0x1F, 0x13, 0x08, 0x0000F801, PPC_MFAPIDI); | |
| 761 | +GEN_HANDLER(tlbiva, 0x1F, 0x12, 0x18, 0x03FFF801, PPC_TLBIVA); | |
| 762 | +GEN_HANDLER(mfdcr, 0x1F, 0x03, 0x0A, 0x00000001, PPC_DCR); | |
| 763 | +GEN_HANDLER(mtdcr, 0x1F, 0x03, 0x0E, 0x00000001, PPC_DCR); | |
| 764 | +GEN_HANDLER(mfdcrx, 0x1F, 0x03, 0x08, 0x00000000, PPC_DCRX); | |
| 765 | +GEN_HANDLER(mtdcrx, 0x1F, 0x03, 0x0C, 0x00000000, PPC_DCRX); | |
| 766 | +GEN_HANDLER(mfdcrux, 0x1F, 0x03, 0x09, 0x00000000, PPC_DCRUX); | |
| 767 | +GEN_HANDLER(mtdcrux, 0x1F, 0x03, 0x0D, 0x00000000, PPC_DCRUX); | |
| 768 | +GEN_HANDLER(dccci, 0x1F, 0x06, 0x0E, 0x03E00001, PPC_4xx_COMMON); | |
| 769 | +GEN_HANDLER(dcread, 0x1F, 0x06, 0x0F, 0x00000001, PPC_4xx_COMMON); | |
| 770 | +GEN_HANDLER2(icbt_40x, "icbt", 0x1F, 0x06, 0x08, 0x03E00001, PPC_40x_ICBT); | |
| 771 | +GEN_HANDLER(iccci, 0x1F, 0x06, 0x1E, 0x00000001, PPC_4xx_COMMON); | |
| 772 | +GEN_HANDLER(icread, 0x1F, 0x06, 0x1F, 0x03E00001, PPC_4xx_COMMON); | |
| 773 | +GEN_HANDLER2(rfci_40x, "rfci", 0x13, 0x13, 0x01, 0x03FF8001, PPC_40x_EXCP); | |
| 774 | +GEN_HANDLER(rfci, 0x13, 0x13, 0x01, 0x03FF8001, PPC_BOOKE); | |
| 775 | +GEN_HANDLER(rfdi, 0x13, 0x07, 0x01, 0x03FF8001, PPC_RFDI); | |
| 776 | +GEN_HANDLER(rfmci, 0x13, 0x06, 0x01, 0x03FF8001, PPC_RFMCI); | |
| 777 | +GEN_HANDLER2(tlbre_40x, "tlbre", 0x1F, 0x12, 0x1D, 0x00000001, PPC_40x_TLB); | |
| 778 | +GEN_HANDLER2(tlbsx_40x, "tlbsx", 0x1F, 0x12, 0x1C, 0x00000000, PPC_40x_TLB); | |
| 779 | +GEN_HANDLER2(tlbwe_40x, "tlbwe", 0x1F, 0x12, 0x1E, 0x00000001, PPC_40x_TLB); | |
| 780 | +GEN_HANDLER2(tlbre_440, "tlbre", 0x1F, 0x12, 0x1D, 0x00000001, PPC_BOOKE); | |
| 781 | +GEN_HANDLER2(tlbsx_440, "tlbsx", 0x1F, 0x12, 0x1C, 0x00000000, PPC_BOOKE); | |
| 782 | +GEN_HANDLER2(tlbwe_440, "tlbwe", 0x1F, 0x12, 0x1E, 0x00000001, PPC_BOOKE); | |
| 783 | +GEN_HANDLER(wrtee, 0x1F, 0x03, 0x04, 0x000FFC01, PPC_WRTEE); | |
| 784 | +GEN_HANDLER(wrteei, 0x1F, 0x03, 0x05, 0x000EFC01, PPC_WRTEE); | |
| 785 | +GEN_HANDLER(dlmzb, 0x1F, 0x0E, 0x02, 0x00000000, PPC_440_SPEC); | |
| 786 | +GEN_HANDLER(mbar, 0x1F, 0x16, 0x1a, 0x001FF801, PPC_BOOKE); | |
| 787 | +GEN_HANDLER(msync, 0x1F, 0x16, 0x12, 0x03FFF801, PPC_BOOKE); | |
| 788 | +GEN_HANDLER2(icbt_440, "icbt", 0x1F, 0x16, 0x00, 0x03E00001, PPC_BOOKE); | |
| 789 | +GEN_HANDLER(lvsl, 0x1f, 0x06, 0x00, 0x00000001, PPC_ALTIVEC); | |
| 790 | +GEN_HANDLER(lvsr, 0x1f, 0x06, 0x01, 0x00000001, PPC_ALTIVEC); | |
| 791 | +GEN_HANDLER(mfvscr, 0x04, 0x2, 0x18, 0x001ff800, PPC_ALTIVEC); | |
| 792 | +GEN_HANDLER(mtvscr, 0x04, 0x2, 0x19, 0x03ff0000, PPC_ALTIVEC); | |
| 793 | +GEN_HANDLER(vsldoi, 0x04, 0x16, 0xFF, 0x00000400, PPC_ALTIVEC); | |
| 794 | +GEN_HANDLER(vmladduhm, 0x04, 0x11, 0xFF, 0x00000000, PPC_ALTIVEC); | |
| 795 | +GEN_HANDLER2(evsel0, "evsel", 0x04, 0x1c, 0x09, 0x00000000, PPC_SPE); | |
| 796 | +GEN_HANDLER2(evsel1, "evsel", 0x04, 0x1d, 0x09, 0x00000000, PPC_SPE); | |
| 797 | +GEN_HANDLER2(evsel2, "evsel", 0x04, 0x1e, 0x09, 0x00000000, PPC_SPE); | |
| 798 | +GEN_HANDLER2(evsel3, "evsel", 0x04, 0x1f, 0x09, 0x00000000, PPC_SPE); | |
| 564 | 799 | |
| 800 | +/* Invalid instruction */ | |
| 565 | 801 | static void gen_invalid(DisasContext *ctx) |
| 566 | 802 | { |
| 567 | 803 | gen_inval_exception(ctx, POWERPC_EXCP_INVAL_INVAL); |
| ... | ... | @@ -647,8 +883,6 @@ static always_inline void gen_set_Rc0 (DisasContext *ctx, TCGv reg) |
| 647 | 883 | } |
| 648 | 884 | |
| 649 | 885 | /* cmp */ |
| 650 | -GEN_HANDLER(cmp, 0x1F, 0x00, 0x00, 0x00400000, PPC_INTEGER); | |
| 651 | - | |
| 652 | 886 | static void gen_cmp(DisasContext *ctx) |
| 653 | 887 | { |
| 654 | 888 | #if defined(TARGET_PPC64) |
| ... | ... | @@ -662,8 +896,6 @@ static void gen_cmp(DisasContext *ctx) |
| 662 | 896 | } |
| 663 | 897 | |
| 664 | 898 | /* cmpi */ |
| 665 | -GEN_HANDLER(cmpi, 0x0B, 0xFF, 0xFF, 0x00400000, PPC_INTEGER); | |
| 666 | - | |
| 667 | 899 | static void gen_cmpi(DisasContext *ctx) |
| 668 | 900 | { |
| 669 | 901 | #if defined(TARGET_PPC64) |
| ... | ... | @@ -677,8 +909,6 @@ static void gen_cmpi(DisasContext *ctx) |
| 677 | 909 | } |
| 678 | 910 | |
| 679 | 911 | /* cmpl */ |
| 680 | -GEN_HANDLER(cmpl, 0x1F, 0x00, 0x01, 0x00400000, PPC_INTEGER); | |
| 681 | - | |
| 682 | 912 | static void gen_cmpl(DisasContext *ctx) |
| 683 | 913 | { |
| 684 | 914 | #if defined(TARGET_PPC64) |
| ... | ... | @@ -692,8 +922,6 @@ static void gen_cmpl(DisasContext *ctx) |
| 692 | 922 | } |
| 693 | 923 | |
| 694 | 924 | /* cmpli */ |
| 695 | -GEN_HANDLER(cmpli, 0x0A, 0xFF, 0xFF, 0x00400000, PPC_INTEGER); | |
| 696 | - | |
| 697 | 925 | static void gen_cmpli(DisasContext *ctx) |
| 698 | 926 | { |
| 699 | 927 | #if defined(TARGET_PPC64) |
| ... | ... | @@ -707,8 +935,6 @@ static void gen_cmpli(DisasContext *ctx) |
| 707 | 935 | } |
| 708 | 936 | |
| 709 | 937 | /* isel (PowerPC 2.03 specification) */ |
| 710 | -GEN_HANDLER(isel, 0x1F, 0x0F, 0xFF, 0x00000001, PPC_ISEL); | |
| 711 | - | |
| 712 | 938 | static void gen_isel(DisasContext *ctx) |
| 713 | 939 | { |
| 714 | 940 | int l1, l2; |
| ... | ... | @@ -894,8 +1120,6 @@ GEN_INT_ARITH_ADD_CONST(addmeo, 0x17, -1LL, 1, 1, 1) |
| 894 | 1120 | GEN_INT_ARITH_ADD_CONST(addze, 0x06, 0, 1, 1, 0) |
| 895 | 1121 | GEN_INT_ARITH_ADD_CONST(addzeo, 0x16, 0, 1, 1, 1) |
| 896 | 1122 | /* addi */ |
| 897 | -GEN_HANDLER(addi, 0x0E, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 898 | - | |
| 899 | 1123 | static void gen_addi(DisasContext *ctx) |
| 900 | 1124 | { |
| 901 | 1125 | target_long simm = SIMM(ctx->opcode); |
| ... | ... | @@ -929,21 +1153,18 @@ static always_inline void gen_op_addic (DisasContext *ctx, TCGv ret, TCGv arg1, |
| 929 | 1153 | gen_set_Rc0(ctx, ret); |
| 930 | 1154 | } |
| 931 | 1155 | } |
| 932 | -GEN_HANDLER(addic, 0x0C, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 933 | 1156 | |
| 934 | 1157 | static void gen_addic(DisasContext *ctx) |
| 935 | 1158 | { |
| 936 | 1159 | gen_op_addic(ctx, cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], 0); |
| 937 | 1160 | } |
| 938 | -GEN_HANDLER2(addic_, "addic.", 0x0D, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 939 | 1161 | |
| 940 | 1162 | static void gen_addic_(DisasContext *ctx) |
| 941 | 1163 | { |
| 942 | 1164 | gen_op_addic(ctx, cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], 1); |
| 943 | 1165 | } |
| 944 | -/* addis */ | |
| 945 | -GEN_HANDLER(addis, 0x0F, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 946 | 1166 | |
| 1167 | +/* addis */ | |
| 947 | 1168 | static void gen_addis(DisasContext *ctx) |
| 948 | 1169 | { |
| 949 | 1170 | target_long simm = SIMM(ctx->opcode); |
| ... | ... | @@ -1064,8 +1285,6 @@ GEN_INT_ARITH_DIVD(divdo, 0x1F, 1, 1); |
| 1064 | 1285 | #endif |
| 1065 | 1286 | |
| 1066 | 1287 | /* mulhw mulhw. */ |
| 1067 | -GEN_HANDLER(mulhw, 0x1F, 0x0B, 0x02, 0x00000400, PPC_INTEGER); | |
| 1068 | - | |
| 1069 | 1288 | static void gen_mulhw(DisasContext *ctx) |
| 1070 | 1289 | { |
| 1071 | 1290 | TCGv_i64 t0, t1; |
| ... | ... | @@ -1089,9 +1308,8 @@ static void gen_mulhw(DisasContext *ctx) |
| 1089 | 1308 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1090 | 1309 | gen_set_Rc0(ctx, cpu_gpr[rD(ctx->opcode)]); |
| 1091 | 1310 | } |
| 1092 | -/* mulhwu mulhwu. */ | |
| 1093 | -GEN_HANDLER(mulhwu, 0x1F, 0x0B, 0x00, 0x00000400, PPC_INTEGER); | |
| 1094 | 1311 | |
| 1312 | +/* mulhwu mulhwu. */ | |
| 1095 | 1313 | static void gen_mulhwu(DisasContext *ctx) |
| 1096 | 1314 | { |
| 1097 | 1315 | TCGv_i64 t0, t1; |
| ... | ... | @@ -1115,9 +1333,8 @@ static void gen_mulhwu(DisasContext *ctx) |
| 1115 | 1333 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1116 | 1334 | gen_set_Rc0(ctx, cpu_gpr[rD(ctx->opcode)]); |
| 1117 | 1335 | } |
| 1118 | -/* mullw mullw. */ | |
| 1119 | -GEN_HANDLER(mullw, 0x1F, 0x0B, 0x07, 0x00000000, PPC_INTEGER); | |
| 1120 | 1336 | |
| 1337 | +/* mullw mullw. */ | |
| 1121 | 1338 | static void gen_mullw(DisasContext *ctx) |
| 1122 | 1339 | { |
| 1123 | 1340 | tcg_gen_mul_tl(cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], |
| ... | ... | @@ -1126,9 +1343,8 @@ static void gen_mullw(DisasContext *ctx) |
| 1126 | 1343 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1127 | 1344 | gen_set_Rc0(ctx, cpu_gpr[rD(ctx->opcode)]); |
| 1128 | 1345 | } |
| 1129 | -/* mullwo mullwo. */ | |
| 1130 | -GEN_HANDLER(mullwo, 0x1F, 0x0B, 0x17, 0x00000000, PPC_INTEGER); | |
| 1131 | 1346 | |
| 1347 | +/* mullwo mullwo. */ | |
| 1132 | 1348 | static void gen_mullwo(DisasContext *ctx) |
| 1133 | 1349 | { |
| 1134 | 1350 | int l1; |
| ... | ... | @@ -1162,9 +1378,8 @@ static void gen_mullwo(DisasContext *ctx) |
| 1162 | 1378 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1163 | 1379 | gen_set_Rc0(ctx, cpu_gpr[rD(ctx->opcode)]); |
| 1164 | 1380 | } |
| 1165 | -/* mulli */ | |
| 1166 | -GEN_HANDLER(mulli, 0x07, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1167 | 1381 | |
| 1382 | +/* mulli */ | |
| 1168 | 1383 | static void gen_mulli(DisasContext *ctx) |
| 1169 | 1384 | { |
| 1170 | 1385 | tcg_gen_muli_tl(cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], |
| ... | ... | @@ -1185,9 +1400,8 @@ static void glue(gen_, name)(DisasContext *ctx) |
| 1185 | 1400 | GEN_INT_ARITH_MUL_HELPER(mulhdu, 0x00); |
| 1186 | 1401 | /* mulhdu mulhdu. */ |
| 1187 | 1402 | GEN_INT_ARITH_MUL_HELPER(mulhd, 0x02); |
| 1188 | -/* mulld mulld. */ | |
| 1189 | -GEN_HANDLER(mulld, 0x1F, 0x09, 0x07, 0x00000000, PPC_64B); | |
| 1190 | 1403 | |
| 1404 | +/* mulld mulld. */ | |
| 1191 | 1405 | static void gen_mulld(DisasContext *ctx) |
| 1192 | 1406 | { |
| 1193 | 1407 | tcg_gen_mul_tl(cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], |
| ... | ... | @@ -1230,13 +1444,11 @@ static always_inline void gen_op_arith_neg (DisasContext *ctx, TCGv ret, TCGv ar |
| 1230 | 1444 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1231 | 1445 | gen_set_Rc0(ctx, ret); |
| 1232 | 1446 | } |
| 1233 | -GEN_HANDLER(neg, 0x1F, 0x08, 0x03, 0x0000F800, PPC_INTEGER); | |
| 1234 | 1447 | |
| 1235 | 1448 | static void gen_neg(DisasContext *ctx) |
| 1236 | 1449 | { |
| 1237 | 1450 | gen_op_arith_neg(ctx, cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], 0); |
| 1238 | 1451 | } |
| 1239 | -GEN_HANDLER(nego, 0x1F, 0x08, 0x13, 0x0000F800, PPC_INTEGER); | |
| 1240 | 1452 | |
| 1241 | 1453 | static void gen_nego(DisasContext *ctx) |
| 1242 | 1454 | { |
| ... | ... | @@ -1336,9 +1548,8 @@ GEN_INT_ARITH_SUBF_CONST(subfmeo, 0x17, -1LL, 1, 1, 1) |
| 1336 | 1548 | /* subfze subfze. subfzeo subfzeo.*/ |
| 1337 | 1549 | GEN_INT_ARITH_SUBF_CONST(subfze, 0x06, 0, 1, 1, 0) |
| 1338 | 1550 | GEN_INT_ARITH_SUBF_CONST(subfzeo, 0x16, 0, 1, 1, 1) |
| 1339 | -/* subfic */ | |
| 1340 | -GEN_HANDLER(subfic, 0x08, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1341 | 1551 | |
| 1552 | +/* subfic */ | |
| 1342 | 1553 | static void gen_subfic(DisasContext *ctx) |
| 1343 | 1554 | { |
| 1344 | 1555 | /* Start with XER CA and OV disabled, the most likely case */ |
| ... | ... | @@ -1378,25 +1589,22 @@ static void glue(gen_, name)(DisasContext *ctx) |
| 1378 | 1589 | GEN_LOGICAL2(and, tcg_gen_and_tl, 0x00, PPC_INTEGER); |
| 1379 | 1590 | /* andc & andc. */ |
| 1380 | 1591 | GEN_LOGICAL2(andc, tcg_gen_andc_tl, 0x01, PPC_INTEGER); |
| 1381 | -/* andi. */ | |
| 1382 | -GEN_HANDLER2(andi_, "andi.", 0x1C, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1383 | 1592 | |
| 1593 | +/* andi. */ | |
| 1384 | 1594 | static void gen_andi_(DisasContext *ctx) |
| 1385 | 1595 | { |
| 1386 | 1596 | tcg_gen_andi_tl(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)], UIMM(ctx->opcode)); |
| 1387 | 1597 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1388 | 1598 | } |
| 1389 | -/* andis. */ | |
| 1390 | -GEN_HANDLER2(andis_, "andis.", 0x1D, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1391 | 1599 | |
| 1600 | +/* andis. */ | |
| 1392 | 1601 | static void gen_andis_(DisasContext *ctx) |
| 1393 | 1602 | { |
| 1394 | 1603 | tcg_gen_andi_tl(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)], UIMM(ctx->opcode) << 16); |
| 1395 | 1604 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1396 | 1605 | } |
| 1397 | -/* cntlzw */ | |
| 1398 | -GEN_HANDLER(cntlzw, 0x1F, 0x1A, 0x00, 0x00000000, PPC_INTEGER); | |
| 1399 | 1606 | |
| 1607 | +/* cntlzw */ | |
| 1400 | 1608 | static void gen_cntlzw(DisasContext *ctx) |
| 1401 | 1609 | { |
| 1402 | 1610 | gen_helper_cntlzw(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)]); |
| ... | ... | @@ -1413,9 +1621,8 @@ GEN_LOGICAL1(extsh, tcg_gen_ext16s_tl, 0x1C, PPC_INTEGER); |
| 1413 | 1621 | GEN_LOGICAL2(nand, tcg_gen_nand_tl, 0x0E, PPC_INTEGER); |
| 1414 | 1622 | /* nor & nor. */ |
| 1415 | 1623 | GEN_LOGICAL2(nor, tcg_gen_nor_tl, 0x03, PPC_INTEGER); |
| 1416 | -/* or & or. */ | |
| 1417 | -GEN_HANDLER(or, 0x1F, 0x1C, 0x0D, 0x00000000, PPC_INTEGER); | |
| 1418 | 1624 | |
| 1625 | +/* or & or. */ | |
| 1419 | 1626 | static void gen_or(DisasContext *ctx) |
| 1420 | 1627 | { |
| 1421 | 1628 | int rs, ra, rb; |
| ... | ... | @@ -1493,9 +1700,8 @@ static void gen_or(DisasContext *ctx) |
| 1493 | 1700 | } |
| 1494 | 1701 | /* orc & orc. */ |
| 1495 | 1702 | GEN_LOGICAL2(orc, tcg_gen_orc_tl, 0x0C, PPC_INTEGER); |
| 1496 | -/* xor & xor. */ | |
| 1497 | -GEN_HANDLER(xor, 0x1F, 0x1C, 0x09, 0x00000000, PPC_INTEGER); | |
| 1498 | 1703 | |
| 1704 | +/* xor & xor. */ | |
| 1499 | 1705 | static void gen_xor(DisasContext *ctx) |
| 1500 | 1706 | { |
| 1501 | 1707 | /* Optimisation for "set to zero" case */ |
| ... | ... | @@ -1506,9 +1712,8 @@ static void gen_xor(DisasContext *ctx) |
| 1506 | 1712 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1507 | 1713 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1508 | 1714 | } |
| 1509 | -/* ori */ | |
| 1510 | -GEN_HANDLER(ori, 0x18, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1511 | 1715 | |
| 1716 | +/* ori */ | |
| 1512 | 1717 | static void gen_ori(DisasContext *ctx) |
| 1513 | 1718 | { |
| 1514 | 1719 | target_ulong uimm = UIMM(ctx->opcode); |
| ... | ... | @@ -1520,9 +1725,8 @@ static void gen_ori(DisasContext *ctx) |
| 1520 | 1725 | } |
| 1521 | 1726 | tcg_gen_ori_tl(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)], uimm); |
| 1522 | 1727 | } |
| 1523 | -/* oris */ | |
| 1524 | -GEN_HANDLER(oris, 0x19, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1525 | 1728 | |
| 1729 | +/* oris */ | |
| 1526 | 1730 | static void gen_oris(DisasContext *ctx) |
| 1527 | 1731 | { |
| 1528 | 1732 | target_ulong uimm = UIMM(ctx->opcode); |
| ... | ... | @@ -1533,9 +1737,8 @@ static void gen_oris(DisasContext *ctx) |
| 1533 | 1737 | } |
| 1534 | 1738 | tcg_gen_ori_tl(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)], uimm << 16); |
| 1535 | 1739 | } |
| 1536 | -/* xori */ | |
| 1537 | -GEN_HANDLER(xori, 0x1A, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1538 | 1740 | |
| 1741 | +/* xori */ | |
| 1539 | 1742 | static void gen_xori(DisasContext *ctx) |
| 1540 | 1743 | { |
| 1541 | 1744 | target_ulong uimm = UIMM(ctx->opcode); |
| ... | ... | @@ -1546,9 +1749,8 @@ static void gen_xori(DisasContext *ctx) |
| 1546 | 1749 | } |
| 1547 | 1750 | tcg_gen_xori_tl(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)], uimm); |
| 1548 | 1751 | } |
| 1549 | -/* xoris */ | |
| 1550 | -GEN_HANDLER(xoris, 0x1B, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1551 | 1752 | |
| 1753 | +/* xoris */ | |
| 1552 | 1754 | static void gen_xoris(DisasContext *ctx) |
| 1553 | 1755 | { |
| 1554 | 1756 | target_ulong uimm = UIMM(ctx->opcode); |
| ... | ... | @@ -1559,9 +1761,8 @@ static void gen_xoris(DisasContext *ctx) |
| 1559 | 1761 | } |
| 1560 | 1762 | tcg_gen_xori_tl(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)], uimm << 16); |
| 1561 | 1763 | } |
| 1562 | -/* popcntb : PowerPC 2.03 specification */ | |
| 1563 | -GEN_HANDLER(popcntb, 0x1F, 0x03, 0x03, 0x0000F801, PPC_POPCNTB); | |
| 1564 | 1764 | |
| 1765 | +/* popcntb : PowerPC 2.03 specification */ | |
| 1565 | 1766 | static void gen_popcntb(DisasContext *ctx) |
| 1566 | 1767 | { |
| 1567 | 1768 | #if defined(TARGET_PPC64) |
| ... | ... | @@ -1575,9 +1776,8 @@ static void gen_popcntb(DisasContext *ctx) |
| 1575 | 1776 | #if defined(TARGET_PPC64) |
| 1576 | 1777 | /* extsw & extsw. */ |
| 1577 | 1778 | GEN_LOGICAL1(extsw, tcg_gen_ext32s_tl, 0x1E, PPC_64B); |
| 1578 | -/* cntlzd */ | |
| 1579 | -GEN_HANDLER(cntlzd, 0x1F, 0x1A, 0x01, 0x00000000, PPC_64B); | |
| 1580 | 1779 | |
| 1780 | +/* cntlzd */ | |
| 1581 | 1781 | static void gen_cntlzd(DisasContext *ctx) |
| 1582 | 1782 | { |
| 1583 | 1783 | gen_helper_cntlzd(cpu_gpr[rA(ctx->opcode)], cpu_gpr[rS(ctx->opcode)]); |
| ... | ... | @@ -1587,9 +1787,8 @@ static void gen_cntlzd(DisasContext *ctx) |
| 1587 | 1787 | #endif |
| 1588 | 1788 | |
| 1589 | 1789 | /*** Integer rotate ***/ |
| 1590 | -/* rlwimi & rlwimi. */ | |
| 1591 | -GEN_HANDLER(rlwimi, 0x14, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1592 | 1790 | |
| 1791 | +/* rlwimi & rlwimi. */ | |
| 1593 | 1792 | static void gen_rlwimi(DisasContext *ctx) |
| 1594 | 1793 | { |
| 1595 | 1794 | uint32_t mb, me, sh; |
| ... | ... | @@ -1627,9 +1826,8 @@ static void gen_rlwimi(DisasContext *ctx) |
| 1627 | 1826 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1628 | 1827 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1629 | 1828 | } |
| 1630 | -/* rlwinm & rlwinm. */ | |
| 1631 | -GEN_HANDLER(rlwinm, 0x15, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1632 | 1829 | |
| 1830 | +/* rlwinm & rlwinm. */ | |
| 1633 | 1831 | static void gen_rlwinm(DisasContext *ctx) |
| 1634 | 1832 | { |
| 1635 | 1833 | uint32_t mb, me, sh; |
| ... | ... | @@ -1675,9 +1873,8 @@ static void gen_rlwinm(DisasContext *ctx) |
| 1675 | 1873 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1676 | 1874 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1677 | 1875 | } |
| 1678 | -/* rlwnm & rlwnm. */ | |
| 1679 | -GEN_HANDLER(rlwnm, 0x17, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 1680 | 1876 | |
| 1877 | +/* rlwnm & rlwnm. */ | |
| 1681 | 1878 | static void gen_rlwnm(DisasContext *ctx) |
| 1682 | 1879 | { |
| 1683 | 1880 | uint32_t mb, me; |
| ... | ... | @@ -1880,9 +2077,8 @@ GEN_PPC64_R4(rldimi, 0x1E, 0x06); |
| 1880 | 2077 | #endif |
| 1881 | 2078 | |
| 1882 | 2079 | /*** Integer shift ***/ |
| 1883 | -/* slw & slw. */ | |
| 1884 | -GEN_HANDLER(slw, 0x1F, 0x18, 0x00, 0x00000000, PPC_INTEGER); | |
| 1885 | 2080 | |
| 2081 | +/* slw & slw. */ | |
| 1886 | 2082 | static void gen_slw(DisasContext *ctx) |
| 1887 | 2083 | { |
| 1888 | 2084 | TCGv t0; |
| ... | ... | @@ -1903,9 +2099,8 @@ static void gen_slw(DisasContext *ctx) |
| 1903 | 2099 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1904 | 2100 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1905 | 2101 | } |
| 1906 | -/* sraw & sraw. */ | |
| 1907 | -GEN_HANDLER(sraw, 0x1F, 0x18, 0x18, 0x00000000, PPC_INTEGER); | |
| 1908 | 2102 | |
| 2103 | +/* sraw & sraw. */ | |
| 1909 | 2104 | static void gen_sraw(DisasContext *ctx) |
| 1910 | 2105 | { |
| 1911 | 2106 | gen_helper_sraw(cpu_gpr[rA(ctx->opcode)], |
| ... | ... | @@ -1913,9 +2108,8 @@ static void gen_sraw(DisasContext *ctx) |
| 1913 | 2108 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1914 | 2109 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1915 | 2110 | } |
| 1916 | -/* srawi & srawi. */ | |
| 1917 | -GEN_HANDLER(srawi, 0x1F, 0x18, 0x19, 0x00000000, PPC_INTEGER); | |
| 1918 | 2111 | |
| 2112 | +/* srawi & srawi. */ | |
| 1919 | 2113 | static void gen_srawi(DisasContext *ctx) |
| 1920 | 2114 | { |
| 1921 | 2115 | int sh = SH(ctx->opcode); |
| ... | ... | @@ -1944,9 +2138,8 @@ static void gen_srawi(DisasContext *ctx) |
| 1944 | 2138 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1945 | 2139 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1946 | 2140 | } |
| 1947 | -/* srw & srw. */ | |
| 1948 | -GEN_HANDLER(srw, 0x1F, 0x18, 0x10, 0x00000000, PPC_INTEGER); | |
| 1949 | 2141 | |
| 2142 | +/* srw & srw. */ | |
| 1950 | 2143 | static void gen_srw(DisasContext *ctx) |
| 1951 | 2144 | { |
| 1952 | 2145 | TCGv t0, t1; |
| ... | ... | @@ -1969,10 +2162,9 @@ static void gen_srw(DisasContext *ctx) |
| 1969 | 2162 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1970 | 2163 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1971 | 2164 | } |
| 2165 | + | |
| 1972 | 2166 | #if defined(TARGET_PPC64) |
| 1973 | 2167 | /* sld & sld. */ |
| 1974 | -GEN_HANDLER(sld, 0x1F, 0x1B, 0x00, 0x00000000, PPC_64B); | |
| 1975 | - | |
| 1976 | 2168 | static void gen_sld(DisasContext *ctx) |
| 1977 | 2169 | { |
| 1978 | 2170 | TCGv t0; |
| ... | ... | @@ -1992,9 +2184,8 @@ static void gen_sld(DisasContext *ctx) |
| 1992 | 2184 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 1993 | 2185 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 1994 | 2186 | } |
| 1995 | -/* srad & srad. */ | |
| 1996 | -GEN_HANDLER(srad, 0x1F, 0x1A, 0x18, 0x00000000, PPC_64B); | |
| 1997 | 2187 | |
| 2188 | +/* srad & srad. */ | |
| 1998 | 2189 | static void gen_srad(DisasContext *ctx) |
| 1999 | 2190 | { |
| 2000 | 2191 | gen_helper_srad(cpu_gpr[rA(ctx->opcode)], |
| ... | ... | @@ -2029,21 +2220,18 @@ static always_inline void gen_sradi (DisasContext *ctx, int n) |
| 2029 | 2220 | if (unlikely(Rc(ctx->opcode) != 0)) |
| 2030 | 2221 | gen_set_Rc0(ctx, cpu_gpr[rA(ctx->opcode)]); |
| 2031 | 2222 | } |
| 2032 | -GEN_HANDLER2(sradi0, "sradi", 0x1F, 0x1A, 0x19, 0x00000000, PPC_64B); | |
| 2033 | 2223 | |
| 2034 | 2224 | static void gen_sradi0(DisasContext *ctx) |
| 2035 | 2225 | { |
| 2036 | 2226 | gen_sradi(ctx, 0); |
| 2037 | 2227 | } |
| 2038 | -GEN_HANDLER2(sradi1, "sradi", 0x1F, 0x1B, 0x19, 0x00000000, PPC_64B); | |
| 2039 | 2228 | |
| 2040 | 2229 | static void gen_sradi1(DisasContext *ctx) |
| 2041 | 2230 | { |
| 2042 | 2231 | gen_sradi(ctx, 1); |
| 2043 | 2232 | } |
| 2044 | -/* srd & srd. */ | |
| 2045 | -GEN_HANDLER(srd, 0x1F, 0x1B, 0x10, 0x00000000, PPC_64B); | |
| 2046 | 2233 | |
| 2234 | +/* srd & srd. */ | |
| 2047 | 2235 | static void gen_srd(DisasContext *ctx) |
| 2048 | 2236 | { |
| 2049 | 2237 | TCGv t0; |
| ... | ... | @@ -2190,8 +2378,6 @@ GEN_FLOAT_BS(res, 0x3B, 0x18, 1, PPC_FLOAT_FRES); |
| 2190 | 2378 | GEN_FLOAT_BS(rsqrte, 0x3F, 0x1A, 1, PPC_FLOAT_FRSQRTE); |
| 2191 | 2379 | |
| 2192 | 2380 | /* frsqrtes */ |
| 2193 | -GEN_HANDLER(frsqrtes, 0x3B, 0x1A, 0xFF, 0x001F07C0, PPC_FLOAT_FRSQRTES); | |
| 2194 | - | |
| 2195 | 2381 | static void gen_frsqrtes(DisasContext *ctx) |
| 2196 | 2382 | { |
| 2197 | 2383 | if (unlikely(!ctx->fpu_enabled)) { |
| ... | ... | @@ -2211,9 +2397,8 @@ _GEN_FLOAT_ACB(sel, sel, 0x3F, 0x17, 0, 0, PPC_FLOAT_FSEL); |
| 2211 | 2397 | /* fsub - fsubs */ |
| 2212 | 2398 | GEN_FLOAT_AB(sub, 0x14, 0x000007C0, 1, PPC_FLOAT); |
| 2213 | 2399 | /* Optional: */ |
| 2214 | -/* fsqrt */ | |
| 2215 | -GEN_HANDLER(fsqrt, 0x3F, 0x16, 0xFF, 0x001F07C0, PPC_FLOAT_FSQRT); | |
| 2216 | 2400 | |
| 2401 | +/* fsqrt */ | |
| 2217 | 2402 | static void gen_fsqrt(DisasContext *ctx) |
| 2218 | 2403 | { |
| 2219 | 2404 | if (unlikely(!ctx->fpu_enabled)) { |
| ... | ... | @@ -2227,8 +2412,6 @@ static void gen_fsqrt(DisasContext *ctx) |
| 2227 | 2412 | gen_compute_fprf(cpu_fpr[rD(ctx->opcode)], 1, Rc(ctx->opcode) != 0); |
| 2228 | 2413 | } |
| 2229 | 2414 | |
| 2230 | -GEN_HANDLER(fsqrts, 0x3B, 0x16, 0xFF, 0x001F07C0, PPC_FLOAT_FSQRT); | |
| 2231 | - | |
| 2232 | 2415 | static void gen_fsqrts(DisasContext *ctx) |
| 2233 | 2416 | { |
| 2234 | 2417 | if (unlikely(!ctx->fpu_enabled)) { |
| ... | ... | @@ -2279,9 +2462,8 @@ GEN_FLOAT_B(rip, 0x08, 0x0E, 1, PPC_FLOAT_EXT); |
| 2279 | 2462 | GEN_FLOAT_B(rim, 0x08, 0x0F, 1, PPC_FLOAT_EXT); |
| 2280 | 2463 | |
| 2281 | 2464 | /*** Floating-Point compare ***/ |
| 2282 | -/* fcmpo */ | |
| 2283 | -GEN_HANDLER(fcmpo, 0x3F, 0x00, 0x01, 0x00600001, PPC_FLOAT); | |
| 2284 | 2465 | |
| 2466 | +/* fcmpo */ | |
| 2285 | 2467 | static void gen_fcmpo(DisasContext *ctx) |
| 2286 | 2468 | { |
| 2287 | 2469 | TCGv_i32 crf; |
| ... | ... | @@ -2299,8 +2481,6 @@ static void gen_fcmpo(DisasContext *ctx) |
| 2299 | 2481 | } |
| 2300 | 2482 | |
| 2301 | 2483 | /* fcmpu */ |
| 2302 | -GEN_HANDLER(fcmpu, 0x3F, 0x00, 0x00, 0x00600001, PPC_FLOAT); | |
| 2303 | - | |
| 2304 | 2484 | static void gen_fcmpu(DisasContext *ctx) |
| 2305 | 2485 | { |
| 2306 | 2486 | TCGv_i32 crf; |
| ... | ... | @@ -2324,8 +2504,6 @@ GEN_FLOAT_B(abs, 0x08, 0x08, 0, PPC_FLOAT); |
| 2324 | 2504 | |
| 2325 | 2505 | /* fmr - fmr. */ |
| 2326 | 2506 | /* XXX: beware that fmr never checks for NaNs nor update FPSCR */ |
| 2327 | -GEN_HANDLER(fmr, 0x3F, 0x08, 0x02, 0x001F0000, PPC_FLOAT); | |
| 2328 | - | |
| 2329 | 2507 | static void gen_fmr(DisasContext *ctx) |
| 2330 | 2508 | { |
| 2331 | 2509 | if (unlikely(!ctx->fpu_enabled)) { |
| ... | ... | @@ -2344,9 +2522,8 @@ GEN_FLOAT_B(nabs, 0x08, 0x04, 0, PPC_FLOAT); |
| 2344 | 2522 | GEN_FLOAT_B(neg, 0x08, 0x01, 0, PPC_FLOAT); |
| 2345 | 2523 | |
| 2346 | 2524 | /*** Floating-Point status & ctrl register ***/ |
| 2347 | -/* mcrfs */ | |
| 2348 | -GEN_HANDLER(mcrfs, 0x3F, 0x00, 0x02, 0x0063F801, PPC_FLOAT); | |
| 2349 | 2525 | |
| 2526 | +/* mcrfs */ | |
| 2350 | 2527 | static void gen_mcrfs(DisasContext *ctx) |
| 2351 | 2528 | { |
| 2352 | 2529 | int bfa; |
| ... | ... | @@ -2362,8 +2539,6 @@ static void gen_mcrfs(DisasContext *ctx) |
| 2362 | 2539 | } |
| 2363 | 2540 | |
| 2364 | 2541 | /* mffs */ |
| 2365 | -GEN_HANDLER(mffs, 0x3F, 0x07, 0x12, 0x001FF800, PPC_FLOAT); | |
| 2366 | - | |
| 2367 | 2542 | static void gen_mffs(DisasContext *ctx) |
| 2368 | 2543 | { |
| 2369 | 2544 | if (unlikely(!ctx->fpu_enabled)) { |
| ... | ... | @@ -2376,8 +2551,6 @@ static void gen_mffs(DisasContext *ctx) |
| 2376 | 2551 | } |
| 2377 | 2552 | |
| 2378 | 2553 | /* mtfsb0 */ |
| 2379 | -GEN_HANDLER(mtfsb0, 0x3F, 0x06, 0x02, 0x001FF800, PPC_FLOAT); | |
| 2380 | - | |
| 2381 | 2554 | static void gen_mtfsb0(DisasContext *ctx) |
| 2382 | 2555 | { |
| 2383 | 2556 | uint8_t crb; |
| ... | ... | @@ -2402,8 +2575,6 @@ static void gen_mtfsb0(DisasContext *ctx) |
| 2402 | 2575 | } |
| 2403 | 2576 | |
| 2404 | 2577 | /* mtfsb1 */ |
| 2405 | -GEN_HANDLER(mtfsb1, 0x3F, 0x06, 0x01, 0x001FF800, PPC_FLOAT); | |
| 2406 | - | |
| 2407 | 2578 | static void gen_mtfsb1(DisasContext *ctx) |
| 2408 | 2579 | { |
| 2409 | 2580 | uint8_t crb; |
| ... | ... | @@ -2431,8 +2602,6 @@ static void gen_mtfsb1(DisasContext *ctx) |
| 2431 | 2602 | } |
| 2432 | 2603 | |
| 2433 | 2604 | /* mtfsf */ |
| 2434 | -GEN_HANDLER(mtfsf, 0x3F, 0x07, 0x16, 0x00010000, PPC_FLOAT); | |
| 2435 | - | |
| 2436 | 2605 | static void gen_mtfsf(DisasContext *ctx) |
| 2437 | 2606 | { |
| 2438 | 2607 | TCGv_i32 t0; |
| ... | ... | @@ -2459,8 +2628,6 @@ static void gen_mtfsf(DisasContext *ctx) |
| 2459 | 2628 | } |
| 2460 | 2629 | |
| 2461 | 2630 | /* mtfsfi */ |
| 2462 | -GEN_HANDLER(mtfsfi, 0x3F, 0x06, 0x04, 0x006f0800, PPC_FLOAT); | |
| 2463 | - | |
| 2464 | 2631 | static void gen_mtfsfi(DisasContext *ctx) |
| 2465 | 2632 | { |
| 2466 | 2633 | int bf, sh; |
| ... | ... | @@ -2770,7 +2937,6 @@ GEN_LDX(lwa, ld32s, 0x15, 0x0A, PPC_64B); |
| 2770 | 2937 | GEN_LDUX(ld, ld64, 0x15, 0x01, PPC_64B); |
| 2771 | 2938 | /* ldx */ |
| 2772 | 2939 | GEN_LDX(ld, ld64, 0x15, 0x00, PPC_64B); |
| 2773 | -GEN_HANDLER(ld, 0x3A, 0xFF, 0xFF, 0x00000000, PPC_64B); | |
| 2774 | 2940 | |
| 2775 | 2941 | static void gen_ld(DisasContext *ctx) |
| 2776 | 2942 | { |
| ... | ... | @@ -2796,9 +2962,8 @@ static void gen_ld(DisasContext *ctx) |
| 2796 | 2962 | tcg_gen_mov_tl(cpu_gpr[rA(ctx->opcode)], EA); |
| 2797 | 2963 | tcg_temp_free(EA); |
| 2798 | 2964 | } |
| 2799 | -/* lq */ | |
| 2800 | -GEN_HANDLER(lq, 0x38, 0xFF, 0xFF, 0x00000000, PPC_64BX); | |
| 2801 | 2965 | |
| 2966 | +/* lq */ | |
| 2802 | 2967 | static void gen_lq(DisasContext *ctx) |
| 2803 | 2968 | { |
| 2804 | 2969 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -2915,7 +3080,6 @@ GEN_STS(stw, st32, 0x04, PPC_INTEGER); |
| 2915 | 3080 | #if defined(TARGET_PPC64) |
| 2916 | 3081 | GEN_STUX(std, st64, 0x15, 0x05, PPC_64B); |
| 2917 | 3082 | GEN_STX(std, st64, 0x15, 0x04, PPC_64B); |
| 2918 | -GEN_HANDLER(std, 0x3E, 0xFF, 0xFF, 0x00000000, PPC_64B); | |
| 2919 | 3083 | |
| 2920 | 3084 | static void gen_std(DisasContext *ctx) |
| 2921 | 3085 | { |
| ... | ... | @@ -3019,9 +3183,8 @@ static void always_inline gen_qemu_st32r(DisasContext *ctx, TCGv arg1, TCGv arg2 |
| 3019 | 3183 | GEN_STX(stwbr, st32r, 0x16, 0x14, PPC_INTEGER); |
| 3020 | 3184 | |
| 3021 | 3185 | /*** Integer load and store multiple ***/ |
| 3022 | -/* lmw */ | |
| 3023 | -GEN_HANDLER(lmw, 0x2E, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 3024 | 3186 | |
| 3187 | +/* lmw */ | |
| 3025 | 3188 | static void gen_lmw(DisasContext *ctx) |
| 3026 | 3189 | { |
| 3027 | 3190 | TCGv t0; |
| ... | ... | @@ -3038,8 +3201,6 @@ static void gen_lmw(DisasContext *ctx) |
| 3038 | 3201 | } |
| 3039 | 3202 | |
| 3040 | 3203 | /* stmw */ |
| 3041 | -GEN_HANDLER(stmw, 0x2F, 0xFF, 0xFF, 0x00000000, PPC_INTEGER); | |
| 3042 | - | |
| 3043 | 3204 | static void gen_stmw(DisasContext *ctx) |
| 3044 | 3205 | { |
| 3045 | 3206 | TCGv t0; |
| ... | ... | @@ -3056,14 +3217,13 @@ static void gen_stmw(DisasContext *ctx) |
| 3056 | 3217 | } |
| 3057 | 3218 | |
| 3058 | 3219 | /*** Integer load and store strings ***/ |
| 3220 | + | |
| 3059 | 3221 | /* lswi */ |
| 3060 | 3222 | /* PowerPC32 specification says we must generate an exception if |
| 3061 | 3223 | * rA is in the range of registers to be loaded. |
| 3062 | 3224 | * In an other hand, IBM says this is valid, but rA won't be loaded. |
| 3063 | 3225 | * For now, I'll follow the spec... |
| 3064 | 3226 | */ |
| 3065 | -GEN_HANDLER(lswi, 0x1F, 0x15, 0x12, 0x00000001, PPC_STRING); | |
| 3066 | - | |
| 3067 | 3227 | static void gen_lswi(DisasContext *ctx) |
| 3068 | 3228 | { |
| 3069 | 3229 | TCGv t0; |
| ... | ... | @@ -3096,8 +3256,6 @@ static void gen_lswi(DisasContext *ctx) |
| 3096 | 3256 | } |
| 3097 | 3257 | |
| 3098 | 3258 | /* lswx */ |
| 3099 | -GEN_HANDLER(lswx, 0x1F, 0x15, 0x10, 0x00000001, PPC_STRING); | |
| 3100 | - | |
| 3101 | 3259 | static void gen_lswx(DisasContext *ctx) |
| 3102 | 3260 | { |
| 3103 | 3261 | TCGv t0; |
| ... | ... | @@ -3118,8 +3276,6 @@ static void gen_lswx(DisasContext *ctx) |
| 3118 | 3276 | } |
| 3119 | 3277 | |
| 3120 | 3278 | /* stswi */ |
| 3121 | -GEN_HANDLER(stswi, 0x1F, 0x15, 0x16, 0x00000001, PPC_STRING); | |
| 3122 | - | |
| 3123 | 3279 | static void gen_stswi(DisasContext *ctx) |
| 3124 | 3280 | { |
| 3125 | 3281 | TCGv t0; |
| ... | ... | @@ -3141,8 +3297,6 @@ static void gen_stswi(DisasContext *ctx) |
| 3141 | 3297 | } |
| 3142 | 3298 | |
| 3143 | 3299 | /* stswx */ |
| 3144 | -GEN_HANDLER(stswx, 0x1F, 0x15, 0x14, 0x00000001, PPC_STRING); | |
| 3145 | - | |
| 3146 | 3300 | static void gen_stswx(DisasContext *ctx) |
| 3147 | 3301 | { |
| 3148 | 3302 | TCGv t0; |
| ... | ... | @@ -3164,23 +3318,17 @@ static void gen_stswx(DisasContext *ctx) |
| 3164 | 3318 | |
| 3165 | 3319 | /*** Memory synchronisation ***/ |
| 3166 | 3320 | /* eieio */ |
| 3167 | -GEN_HANDLER(eieio, 0x1F, 0x16, 0x1A, 0x03FFF801, PPC_MEM_EIEIO); | |
| 3168 | - | |
| 3169 | 3321 | static void gen_eieio(DisasContext *ctx) |
| 3170 | 3322 | { |
| 3171 | 3323 | } |
| 3172 | 3324 | |
| 3173 | 3325 | /* isync */ |
| 3174 | -GEN_HANDLER(isync, 0x13, 0x16, 0x04, 0x03FFF801, PPC_MEM); | |
| 3175 | - | |
| 3176 | 3326 | static void gen_isync(DisasContext *ctx) |
| 3177 | 3327 | { |
| 3178 | 3328 | gen_stop_exception(ctx); |
| 3179 | 3329 | } |
| 3180 | 3330 | |
| 3181 | 3331 | /* lwarx */ |
| 3182 | -GEN_HANDLER(lwarx, 0x1F, 0x14, 0x00, 0x00000001, PPC_RES); | |
| 3183 | - | |
| 3184 | 3332 | static void gen_lwarx(DisasContext *ctx) |
| 3185 | 3333 | { |
| 3186 | 3334 | TCGv t0; |
| ... | ... | @@ -3194,8 +3342,6 @@ static void gen_lwarx(DisasContext *ctx) |
| 3194 | 3342 | } |
| 3195 | 3343 | |
| 3196 | 3344 | /* stwcx. */ |
| 3197 | -GEN_HANDLER2(stwcx_, "stwcx.", 0x1F, 0x16, 0x04, 0x00000000, PPC_RES); | |
| 3198 | - | |
| 3199 | 3345 | static void gen_stwcx_(DisasContext *ctx) |
| 3200 | 3346 | { |
| 3201 | 3347 | int l1; |
| ... | ... | @@ -3218,8 +3364,6 @@ static void gen_stwcx_(DisasContext *ctx) |
| 3218 | 3364 | |
| 3219 | 3365 | #if defined(TARGET_PPC64) |
| 3220 | 3366 | /* ldarx */ |
| 3221 | -GEN_HANDLER(ldarx, 0x1F, 0x14, 0x02, 0x00000001, PPC_64B); | |
| 3222 | - | |
| 3223 | 3367 | static void gen_ldarx(DisasContext *ctx) |
| 3224 | 3368 | { |
| 3225 | 3369 | TCGv t0; |
| ... | ... | @@ -3233,8 +3377,6 @@ static void gen_ldarx(DisasContext *ctx) |
| 3233 | 3377 | } |
| 3234 | 3378 | |
| 3235 | 3379 | /* stdcx. */ |
| 3236 | -GEN_HANDLER2(stdcx_, "stdcx.", 0x1F, 0x16, 0x06, 0x00000000, PPC_64B); | |
| 3237 | - | |
| 3238 | 3380 | static void gen_stdcx_(DisasContext *ctx) |
| 3239 | 3381 | { |
| 3240 | 3382 | int l1; |
| ... | ... | @@ -3257,15 +3399,11 @@ static void gen_stdcx_(DisasContext *ctx) |
| 3257 | 3399 | #endif /* defined(TARGET_PPC64) */ |
| 3258 | 3400 | |
| 3259 | 3401 | /* sync */ |
| 3260 | -GEN_HANDLER(sync, 0x1F, 0x16, 0x12, 0x039FF801, PPC_MEM_SYNC); | |
| 3261 | - | |
| 3262 | 3402 | static void gen_sync(DisasContext *ctx) |
| 3263 | 3403 | { |
| 3264 | 3404 | } |
| 3265 | 3405 | |
| 3266 | 3406 | /* wait */ |
| 3267 | -GEN_HANDLER(wait, 0x1F, 0x1E, 0x01, 0x03FFF801, PPC_WAIT); | |
| 3268 | - | |
| 3269 | 3407 | static void gen_wait(DisasContext *ctx) |
| 3270 | 3408 | { |
| 3271 | 3409 | TCGv_i32 t0 = tcg_temp_new_i32(); |
| ... | ... | @@ -3533,8 +3671,6 @@ static always_inline void gen_setlr (DisasContext *ctx, target_ulong nip) |
| 3533 | 3671 | } |
| 3534 | 3672 | |
| 3535 | 3673 | /* b ba bl bla */ |
| 3536 | -GEN_HANDLER(b, 0x12, 0xFF, 0xFF, 0x00000000, PPC_FLOW); | |
| 3537 | - | |
| 3538 | 3674 | static void gen_b(DisasContext *ctx) |
| 3539 | 3675 | { |
| 3540 | 3676 | target_ulong li, target; |
| ... | ... | @@ -3641,22 +3777,16 @@ static always_inline void gen_bcond (DisasContext *ctx, int type) |
| 3641 | 3777 | } |
| 3642 | 3778 | } |
| 3643 | 3779 | |
| 3644 | -GEN_HANDLER(bc, 0x10, 0xFF, 0xFF, 0x00000000, PPC_FLOW); | |
| 3645 | - | |
| 3646 | 3780 | static void gen_bc(DisasContext *ctx) |
| 3647 | 3781 | { |
| 3648 | 3782 | gen_bcond(ctx, BCOND_IM); |
| 3649 | 3783 | } |
| 3650 | 3784 | |
| 3651 | -GEN_HANDLER(bcctr, 0x13, 0x10, 0x10, 0x00000000, PPC_FLOW); | |
| 3652 | - | |
| 3653 | 3785 | static void gen_bcctr(DisasContext *ctx) |
| 3654 | 3786 | { |
| 3655 | 3787 | gen_bcond(ctx, BCOND_CTR); |
| 3656 | 3788 | } |
| 3657 | 3789 | |
| 3658 | -GEN_HANDLER(bclr, 0x13, 0x10, 0x00, 0x00000000, PPC_FLOW); | |
| 3659 | - | |
| 3660 | 3790 | static void gen_bclr(DisasContext *ctx) |
| 3661 | 3791 | { |
| 3662 | 3792 | gen_bcond(ctx, BCOND_LR); |
| ... | ... | @@ -3712,18 +3842,16 @@ GEN_CRLOGIC(cror, tcg_gen_or_i32, 0x0E); |
| 3712 | 3842 | GEN_CRLOGIC(crorc, tcg_gen_orc_i32, 0x0D); |
| 3713 | 3843 | /* crxor */ |
| 3714 | 3844 | GEN_CRLOGIC(crxor, tcg_gen_xor_i32, 0x06); |
| 3715 | -/* mcrf */ | |
| 3716 | -GEN_HANDLER(mcrf, 0x13, 0x00, 0xFF, 0x00000001, PPC_INTEGER); | |
| 3717 | 3845 | |
| 3846 | +/* mcrf */ | |
| 3718 | 3847 | static void gen_mcrf(DisasContext *ctx) |
| 3719 | 3848 | { |
| 3720 | 3849 | tcg_gen_mov_i32(cpu_crf[crfD(ctx->opcode)], cpu_crf[crfS(ctx->opcode)]); |
| 3721 | 3850 | } |
| 3722 | 3851 | |
| 3723 | 3852 | /*** System linkage ***/ |
| 3724 | -/* rfi (mem_idx only) */ | |
| 3725 | -GEN_HANDLER(rfi, 0x13, 0x12, 0x01, 0x03FF8001, PPC_FLOW); | |
| 3726 | 3853 | |
| 3854 | +/* rfi (mem_idx only) */ | |
| 3727 | 3855 | static void gen_rfi(DisasContext *ctx) |
| 3728 | 3856 | { |
| 3729 | 3857 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -3740,8 +3868,6 @@ static void gen_rfi(DisasContext *ctx) |
| 3740 | 3868 | } |
| 3741 | 3869 | |
| 3742 | 3870 | #if defined(TARGET_PPC64) |
| 3743 | -GEN_HANDLER(rfid, 0x13, 0x12, 0x00, 0x03FF8001, PPC_64B); | |
| 3744 | - | |
| 3745 | 3871 | static void gen_rfid(DisasContext *ctx) |
| 3746 | 3872 | { |
| 3747 | 3873 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -3757,8 +3883,6 @@ static void gen_rfid(DisasContext *ctx) |
| 3757 | 3883 | #endif |
| 3758 | 3884 | } |
| 3759 | 3885 | |
| 3760 | -GEN_HANDLER(hrfid, 0x13, 0x12, 0x08, 0x03FF8001, PPC_64H); | |
| 3761 | - | |
| 3762 | 3886 | static void gen_hrfid(DisasContext *ctx) |
| 3763 | 3887 | { |
| 3764 | 3888 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -3781,8 +3905,6 @@ static void gen_hrfid(DisasContext *ctx) |
| 3781 | 3905 | #else |
| 3782 | 3906 | #define POWERPC_SYSCALL POWERPC_EXCP_SYSCALL |
| 3783 | 3907 | #endif |
| 3784 | -GEN_HANDLER(sc, 0x11, 0xFF, 0xFF, 0x03FFF01D, PPC_FLOW); | |
| 3785 | - | |
| 3786 | 3908 | static void gen_sc(DisasContext *ctx) |
| 3787 | 3909 | { |
| 3788 | 3910 | uint32_t lev; |
| ... | ... | @@ -3792,9 +3914,8 @@ static void gen_sc(DisasContext *ctx) |
| 3792 | 3914 | } |
| 3793 | 3915 | |
| 3794 | 3916 | /*** Trap ***/ |
| 3795 | -/* tw */ | |
| 3796 | -GEN_HANDLER(tw, 0x1F, 0x04, 0x00, 0x00000001, PPC_FLOW); | |
| 3797 | 3917 | |
| 3918 | +/* tw */ | |
| 3798 | 3919 | static void gen_tw(DisasContext *ctx) |
| 3799 | 3920 | { |
| 3800 | 3921 | TCGv_i32 t0 = tcg_const_i32(TO(ctx->opcode)); |
| ... | ... | @@ -3805,8 +3926,6 @@ static void gen_tw(DisasContext *ctx) |
| 3805 | 3926 | } |
| 3806 | 3927 | |
| 3807 | 3928 | /* twi */ |
| 3808 | -GEN_HANDLER(twi, 0x03, 0xFF, 0xFF, 0x00000000, PPC_FLOW); | |
| 3809 | - | |
| 3810 | 3929 | static void gen_twi(DisasContext *ctx) |
| 3811 | 3930 | { |
| 3812 | 3931 | TCGv t0 = tcg_const_tl(SIMM(ctx->opcode)); |
| ... | ... | @@ -3820,8 +3939,6 @@ static void gen_twi(DisasContext *ctx) |
| 3820 | 3939 | |
| 3821 | 3940 | #if defined(TARGET_PPC64) |
| 3822 | 3941 | /* td */ |
| 3823 | -GEN_HANDLER(td, 0x1F, 0x04, 0x02, 0x00000001, PPC_64B); | |
| 3824 | - | |
| 3825 | 3942 | static void gen_td(DisasContext *ctx) |
| 3826 | 3943 | { |
| 3827 | 3944 | TCGv_i32 t0 = tcg_const_i32(TO(ctx->opcode)); |
| ... | ... | @@ -3832,8 +3949,6 @@ static void gen_td(DisasContext *ctx) |
| 3832 | 3949 | } |
| 3833 | 3950 | |
| 3834 | 3951 | /* tdi */ |
| 3835 | -GEN_HANDLER(tdi, 0x02, 0xFF, 0xFF, 0x00000000, PPC_64B); | |
| 3836 | - | |
| 3837 | 3952 | static void gen_tdi(DisasContext *ctx) |
| 3838 | 3953 | { |
| 3839 | 3954 | TCGv t0 = tcg_const_tl(SIMM(ctx->opcode)); |
| ... | ... | @@ -3847,9 +3962,8 @@ static void gen_tdi(DisasContext *ctx) |
| 3847 | 3962 | #endif |
| 3848 | 3963 | |
| 3849 | 3964 | /*** Processor control ***/ |
| 3850 | -/* mcrxr */ | |
| 3851 | -GEN_HANDLER(mcrxr, 0x1F, 0x00, 0x10, 0x007FF801, PPC_MISC); | |
| 3852 | 3965 | |
| 3966 | +/* mcrxr */ | |
| 3853 | 3967 | static void gen_mcrxr(DisasContext *ctx) |
| 3854 | 3968 | { |
| 3855 | 3969 | tcg_gen_trunc_tl_i32(cpu_crf[crfD(ctx->opcode)], cpu_xer); |
| ... | ... | @@ -3858,8 +3972,6 @@ static void gen_mcrxr(DisasContext *ctx) |
| 3858 | 3972 | } |
| 3859 | 3973 | |
| 3860 | 3974 | /* mfcr mfocrf */ |
| 3861 | -GEN_HANDLER(mfcr, 0x1F, 0x13, 0x00, 0x00000801, PPC_MISC); | |
| 3862 | - | |
| 3863 | 3975 | static void gen_mfcr(DisasContext *ctx) |
| 3864 | 3976 | { |
| 3865 | 3977 | uint32_t crm, crn; |
| ... | ... | @@ -3895,8 +4007,6 @@ static void gen_mfcr(DisasContext *ctx) |
| 3895 | 4007 | } |
| 3896 | 4008 | |
| 3897 | 4009 | /* mfmsr */ |
| 3898 | -GEN_HANDLER(mfmsr, 0x1F, 0x13, 0x02, 0x001FF801, PPC_MISC); | |
| 3899 | - | |
| 3900 | 4010 | static void gen_mfmsr(DisasContext *ctx) |
| 3901 | 4011 | { |
| 3902 | 4012 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -3962,24 +4072,18 @@ static always_inline void gen_op_mfspr (DisasContext *ctx) |
| 3962 | 4072 | } |
| 3963 | 4073 | } |
| 3964 | 4074 | |
| 3965 | -GEN_HANDLER(mfspr, 0x1F, 0x13, 0x0A, 0x00000001, PPC_MISC); | |
| 3966 | - | |
| 3967 | 4075 | static void gen_mfspr(DisasContext *ctx) |
| 3968 | 4076 | { |
| 3969 | 4077 | gen_op_mfspr(ctx); |
| 3970 | 4078 | } |
| 3971 | 4079 | |
| 3972 | 4080 | /* mftb */ |
| 3973 | -GEN_HANDLER(mftb, 0x1F, 0x13, 0x0B, 0x00000001, PPC_MFTB); | |
| 3974 | - | |
| 3975 | 4081 | static void gen_mftb(DisasContext *ctx) |
| 3976 | 4082 | { |
| 3977 | 4083 | gen_op_mfspr(ctx); |
| 3978 | 4084 | } |
| 3979 | 4085 | |
| 3980 | 4086 | /* mtcrf mtocrf*/ |
| 3981 | -GEN_HANDLER(mtcrf, 0x1F, 0x10, 0x04, 0x00000801, PPC_MISC); | |
| 3982 | - | |
| 3983 | 4087 | static void gen_mtcrf(DisasContext *ctx) |
| 3984 | 4088 | { |
| 3985 | 4089 | uint32_t crm, crn; |
| ... | ... | @@ -4009,8 +4113,6 @@ static void gen_mtcrf(DisasContext *ctx) |
| 4009 | 4113 | |
| 4010 | 4114 | /* mtmsr */ |
| 4011 | 4115 | #if defined(TARGET_PPC64) |
| 4012 | -GEN_HANDLER(mtmsrd, 0x1F, 0x12, 0x05, 0x001EF801, PPC_64B); | |
| 4013 | - | |
| 4014 | 4116 | static void gen_mtmsrd(DisasContext *ctx) |
| 4015 | 4117 | { |
| 4016 | 4118 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4042,8 +4144,6 @@ static void gen_mtmsrd(DisasContext *ctx) |
| 4042 | 4144 | } |
| 4043 | 4145 | #endif |
| 4044 | 4146 | |
| 4045 | -GEN_HANDLER(mtmsr, 0x1F, 0x12, 0x04, 0x001FF801, PPC_MISC); | |
| 4046 | - | |
| 4047 | 4147 | static void gen_mtmsr(DisasContext *ctx) |
| 4048 | 4148 | { |
| 4049 | 4149 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4087,8 +4187,6 @@ static void gen_mtmsr(DisasContext *ctx) |
| 4087 | 4187 | } |
| 4088 | 4188 | |
| 4089 | 4189 | /* mtspr */ |
| 4090 | -GEN_HANDLER(mtspr, 0x1F, 0x13, 0x0E, 0x00000001, PPC_MISC); | |
| 4091 | - | |
| 4092 | 4190 | static void gen_mtspr(DisasContext *ctx) |
| 4093 | 4191 | { |
| 4094 | 4192 | void (*write_cb)(void *opaque, int sprn, int gprn); |
| ... | ... | @@ -4124,9 +4222,8 @@ static void gen_mtspr(DisasContext *ctx) |
| 4124 | 4222 | } |
| 4125 | 4223 | |
| 4126 | 4224 | /*** Cache management ***/ |
| 4127 | -/* dcbf */ | |
| 4128 | -GEN_HANDLER(dcbf, 0x1F, 0x16, 0x02, 0x03C00001, PPC_CACHE); | |
| 4129 | 4225 | |
| 4226 | +/* dcbf */ | |
| 4130 | 4227 | static void gen_dcbf(DisasContext *ctx) |
| 4131 | 4228 | { |
| 4132 | 4229 | /* XXX: specification says this is treated as a load by the MMU */ |
| ... | ... | @@ -4139,8 +4236,6 @@ static void gen_dcbf(DisasContext *ctx) |
| 4139 | 4236 | } |
| 4140 | 4237 | |
| 4141 | 4238 | /* dcbi (Supervisor only) */ |
| 4142 | -GEN_HANDLER(dcbi, 0x1F, 0x16, 0x0E, 0x03E00001, PPC_CACHE); | |
| 4143 | - | |
| 4144 | 4239 | static void gen_dcbi(DisasContext *ctx) |
| 4145 | 4240 | { |
| 4146 | 4241 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4164,8 +4259,6 @@ static void gen_dcbi(DisasContext *ctx) |
| 4164 | 4259 | } |
| 4165 | 4260 | |
| 4166 | 4261 | /* dcdst */ |
| 4167 | -GEN_HANDLER(dcbst, 0x1F, 0x16, 0x01, 0x03E00001, PPC_CACHE); | |
| 4168 | - | |
| 4169 | 4262 | static void gen_dcbst(DisasContext *ctx) |
| 4170 | 4263 | { |
| 4171 | 4264 | /* XXX: specification say this is treated as a load by the MMU */ |
| ... | ... | @@ -4178,8 +4271,6 @@ static void gen_dcbst(DisasContext *ctx) |
| 4178 | 4271 | } |
| 4179 | 4272 | |
| 4180 | 4273 | /* dcbt */ |
| 4181 | -GEN_HANDLER(dcbt, 0x1F, 0x16, 0x08, 0x02000001, PPC_CACHE); | |
| 4182 | - | |
| 4183 | 4274 | static void gen_dcbt(DisasContext *ctx) |
| 4184 | 4275 | { |
| 4185 | 4276 | /* interpreted as no-op */ |
| ... | ... | @@ -4189,8 +4280,6 @@ static void gen_dcbt(DisasContext *ctx) |
| 4189 | 4280 | } |
| 4190 | 4281 | |
| 4191 | 4282 | /* dcbtst */ |
| 4192 | -GEN_HANDLER(dcbtst, 0x1F, 0x16, 0x07, 0x02000001, PPC_CACHE); | |
| 4193 | - | |
| 4194 | 4283 | static void gen_dcbtst(DisasContext *ctx) |
| 4195 | 4284 | { |
| 4196 | 4285 | /* interpreted as no-op */ |
| ... | ... | @@ -4200,8 +4289,6 @@ static void gen_dcbtst(DisasContext *ctx) |
| 4200 | 4289 | } |
| 4201 | 4290 | |
| 4202 | 4291 | /* dcbz */ |
| 4203 | -GEN_HANDLER(dcbz, 0x1F, 0x16, 0x1F, 0x03E00001, PPC_CACHE_DCBZ); | |
| 4204 | - | |
| 4205 | 4292 | static void gen_dcbz(DisasContext *ctx) |
| 4206 | 4293 | { |
| 4207 | 4294 | TCGv t0; |
| ... | ... | @@ -4214,8 +4301,6 @@ static void gen_dcbz(DisasContext *ctx) |
| 4214 | 4301 | tcg_temp_free(t0); |
| 4215 | 4302 | } |
| 4216 | 4303 | |
| 4217 | -GEN_HANDLER2(dcbz_970, "dcbz", 0x1F, 0x16, 0x1F, 0x03C00001, PPC_CACHE_DCBZT); | |
| 4218 | - | |
| 4219 | 4304 | static void gen_dcbz_970(DisasContext *ctx) |
| 4220 | 4305 | { |
| 4221 | 4306 | TCGv t0; |
| ... | ... | @@ -4232,8 +4317,6 @@ static void gen_dcbz_970(DisasContext *ctx) |
| 4232 | 4317 | } |
| 4233 | 4318 | |
| 4234 | 4319 | /* dst / dstt */ |
| 4235 | -GEN_HANDLER(dst, 0x1F, 0x16, 0x0A, 0x01800001, PPC_ALTIVEC); | |
| 4236 | - | |
| 4237 | 4320 | static void gen_dst(DisasContext *ctx) |
| 4238 | 4321 | { |
| 4239 | 4322 | if (rA(ctx->opcode) == 0) { |
| ... | ... | @@ -4244,8 +4327,6 @@ static void gen_dst(DisasContext *ctx) |
| 4244 | 4327 | } |
| 4245 | 4328 | |
| 4246 | 4329 | /* dstst /dststt */ |
| 4247 | -GEN_HANDLER(dstst, 0x1F, 0x16, 0x0B, 0x02000001, PPC_ALTIVEC); | |
| 4248 | - | |
| 4249 | 4330 | static void gen_dstst(DisasContext *ctx) |
| 4250 | 4331 | { |
| 4251 | 4332 | if (rA(ctx->opcode) == 0) { |
| ... | ... | @@ -4257,16 +4338,12 @@ static void gen_dstst(DisasContext *ctx) |
| 4257 | 4338 | } |
| 4258 | 4339 | |
| 4259 | 4340 | /* dss / dssall */ |
| 4260 | -GEN_HANDLER(dss, 0x1F, 0x16, 0x19, 0x019FF801, PPC_ALTIVEC); | |
| 4261 | - | |
| 4262 | 4341 | static void gen_dss(DisasContext *ctx) |
| 4263 | 4342 | { |
| 4264 | 4343 | /* interpreted as no-op */ |
| 4265 | 4344 | } |
| 4266 | 4345 | |
| 4267 | 4346 | /* icbi */ |
| 4268 | -GEN_HANDLER(icbi, 0x1F, 0x16, 0x1E, 0x03E00001, PPC_CACHE_ICBI); | |
| 4269 | - | |
| 4270 | 4347 | static void gen_icbi(DisasContext *ctx) |
| 4271 | 4348 | { |
| 4272 | 4349 | TCGv t0; |
| ... | ... | @@ -4281,8 +4358,6 @@ static void gen_icbi(DisasContext *ctx) |
| 4281 | 4358 | |
| 4282 | 4359 | /* Optional: */ |
| 4283 | 4360 | /* dcba */ |
| 4284 | -GEN_HANDLER(dcba, 0x1F, 0x16, 0x17, 0x03E00001, PPC_CACHE_DCBA); | |
| 4285 | - | |
| 4286 | 4361 | static void gen_dcba(DisasContext *ctx) |
| 4287 | 4362 | { |
| 4288 | 4363 | /* interpreted as no-op */ |
| ... | ... | @@ -4293,9 +4368,8 @@ static void gen_dcba(DisasContext *ctx) |
| 4293 | 4368 | |
| 4294 | 4369 | /*** Segment register manipulation ***/ |
| 4295 | 4370 | /* Supervisor only: */ |
| 4296 | -/* mfsr */ | |
| 4297 | -GEN_HANDLER(mfsr, 0x1F, 0x13, 0x12, 0x0010F801, PPC_SEGMENT); | |
| 4298 | 4371 | |
| 4372 | +/* mfsr */ | |
| 4299 | 4373 | static void gen_mfsr(DisasContext *ctx) |
| 4300 | 4374 | { |
| 4301 | 4375 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4313,8 +4387,6 @@ static void gen_mfsr(DisasContext *ctx) |
| 4313 | 4387 | } |
| 4314 | 4388 | |
| 4315 | 4389 | /* mfsrin */ |
| 4316 | -GEN_HANDLER(mfsrin, 0x1F, 0x13, 0x14, 0x001F0001, PPC_SEGMENT); | |
| 4317 | - | |
| 4318 | 4390 | static void gen_mfsrin(DisasContext *ctx) |
| 4319 | 4391 | { |
| 4320 | 4392 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4334,8 +4406,6 @@ static void gen_mfsrin(DisasContext *ctx) |
| 4334 | 4406 | } |
| 4335 | 4407 | |
| 4336 | 4408 | /* mtsr */ |
| 4337 | -GEN_HANDLER(mtsr, 0x1F, 0x12, 0x06, 0x0010F801, PPC_SEGMENT); | |
| 4338 | - | |
| 4339 | 4409 | static void gen_mtsr(DisasContext *ctx) |
| 4340 | 4410 | { |
| 4341 | 4411 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4353,8 +4423,6 @@ static void gen_mtsr(DisasContext *ctx) |
| 4353 | 4423 | } |
| 4354 | 4424 | |
| 4355 | 4425 | /* mtsrin */ |
| 4356 | -GEN_HANDLER(mtsrin, 0x1F, 0x12, 0x07, 0x001F0001, PPC_SEGMENT); | |
| 4357 | - | |
| 4358 | 4426 | static void gen_mtsrin(DisasContext *ctx) |
| 4359 | 4427 | { |
| 4360 | 4428 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4375,9 +4443,8 @@ static void gen_mtsrin(DisasContext *ctx) |
| 4375 | 4443 | |
| 4376 | 4444 | #if defined(TARGET_PPC64) |
| 4377 | 4445 | /* Specific implementation for PowerPC 64 "bridge" emulation using SLB */ |
| 4378 | -/* mfsr */ | |
| 4379 | -GEN_HANDLER2(mfsr_64b, "mfsr", 0x1F, 0x13, 0x12, 0x0010F801, PPC_SEGMENT_64B); | |
| 4380 | 4446 | |
| 4447 | +/* mfsr */ | |
| 4381 | 4448 | static void gen_mfsr_64b(DisasContext *ctx) |
| 4382 | 4449 | { |
| 4383 | 4450 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4395,9 +4462,6 @@ static void gen_mfsr_64b(DisasContext *ctx) |
| 4395 | 4462 | } |
| 4396 | 4463 | |
| 4397 | 4464 | /* mfsrin */ |
| 4398 | -GEN_HANDLER2(mfsrin_64b, "mfsrin", 0x1F, 0x13, 0x14, 0x001F0001, | |
| 4399 | - PPC_SEGMENT_64B); | |
| 4400 | - | |
| 4401 | 4465 | static void gen_mfsrin_64b(DisasContext *ctx) |
| 4402 | 4466 | { |
| 4403 | 4467 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4417,8 +4481,6 @@ static void gen_mfsrin_64b(DisasContext *ctx) |
| 4417 | 4481 | } |
| 4418 | 4482 | |
| 4419 | 4483 | /* mtsr */ |
| 4420 | -GEN_HANDLER2(mtsr_64b, "mtsr", 0x1F, 0x12, 0x06, 0x0010F801, PPC_SEGMENT_64B); | |
| 4421 | - | |
| 4422 | 4484 | static void gen_mtsr_64b(DisasContext *ctx) |
| 4423 | 4485 | { |
| 4424 | 4486 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4436,9 +4498,6 @@ static void gen_mtsr_64b(DisasContext *ctx) |
| 4436 | 4498 | } |
| 4437 | 4499 | |
| 4438 | 4500 | /* mtsrin */ |
| 4439 | -GEN_HANDLER2(mtsrin_64b, "mtsrin", 0x1F, 0x12, 0x07, 0x001F0001, | |
| 4440 | - PPC_SEGMENT_64B); | |
| 4441 | - | |
| 4442 | 4501 | static void gen_mtsrin_64b(DisasContext *ctx) |
| 4443 | 4502 | { |
| 4444 | 4503 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4458,8 +4517,6 @@ static void gen_mtsrin_64b(DisasContext *ctx) |
| 4458 | 4517 | } |
| 4459 | 4518 | |
| 4460 | 4519 | /* slbmte */ |
| 4461 | -GEN_HANDLER2(slbmte, "slbmte", 0x1F, 0x12, 0x0C, 0x00000000, PPC_SEGMENT_64B); | |
| 4462 | - | |
| 4463 | 4520 | static void gen_slbmte(DisasContext *ctx) |
| 4464 | 4521 | { |
| 4465 | 4522 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4477,9 +4534,8 @@ static void gen_slbmte(DisasContext *ctx) |
| 4477 | 4534 | |
| 4478 | 4535 | /*** Lookaside buffer management ***/ |
| 4479 | 4536 | /* Optional & mem_idx only: */ |
| 4480 | -/* tlbia */ | |
| 4481 | -GEN_HANDLER(tlbia, 0x1F, 0x12, 0x0B, 0x03FFFC01, PPC_MEM_TLBIA); | |
| 4482 | 4537 | |
| 4538 | +/* tlbia */ | |
| 4483 | 4539 | static void gen_tlbia(DisasContext *ctx) |
| 4484 | 4540 | { |
| 4485 | 4541 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4494,8 +4550,6 @@ static void gen_tlbia(DisasContext *ctx) |
| 4494 | 4550 | } |
| 4495 | 4551 | |
| 4496 | 4552 | /* tlbiel */ |
| 4497 | -GEN_HANDLER(tlbiel, 0x1F, 0x12, 0x08, 0x03FF0001, PPC_MEM_TLBIE); | |
| 4498 | - | |
| 4499 | 4553 | static void gen_tlbiel(DisasContext *ctx) |
| 4500 | 4554 | { |
| 4501 | 4555 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4510,8 +4564,6 @@ static void gen_tlbiel(DisasContext *ctx) |
| 4510 | 4564 | } |
| 4511 | 4565 | |
| 4512 | 4566 | /* tlbie */ |
| 4513 | -GEN_HANDLER(tlbie, 0x1F, 0x12, 0x09, 0x03FF0001, PPC_MEM_TLBIE); | |
| 4514 | - | |
| 4515 | 4567 | static void gen_tlbie(DisasContext *ctx) |
| 4516 | 4568 | { |
| 4517 | 4569 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4534,8 +4586,6 @@ static void gen_tlbie(DisasContext *ctx) |
| 4534 | 4586 | } |
| 4535 | 4587 | |
| 4536 | 4588 | /* tlbsync */ |
| 4537 | -GEN_HANDLER(tlbsync, 0x1F, 0x16, 0x11, 0x03FFF801, PPC_MEM_TLBSYNC); | |
| 4538 | - | |
| 4539 | 4589 | static void gen_tlbsync(DisasContext *ctx) |
| 4540 | 4590 | { |
| 4541 | 4591 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4554,8 +4604,6 @@ static void gen_tlbsync(DisasContext *ctx) |
| 4554 | 4604 | |
| 4555 | 4605 | #if defined(TARGET_PPC64) |
| 4556 | 4606 | /* slbia */ |
| 4557 | -GEN_HANDLER(slbia, 0x1F, 0x12, 0x0F, 0x03FFFC01, PPC_SLBI); | |
| 4558 | - | |
| 4559 | 4607 | static void gen_slbia(DisasContext *ctx) |
| 4560 | 4608 | { |
| 4561 | 4609 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4570,8 +4618,6 @@ static void gen_slbia(DisasContext *ctx) |
| 4570 | 4618 | } |
| 4571 | 4619 | |
| 4572 | 4620 | /* slbie */ |
| 4573 | -GEN_HANDLER(slbie, 0x1F, 0x12, 0x0D, 0x03FF0001, PPC_SLBI); | |
| 4574 | - | |
| 4575 | 4621 | static void gen_slbie(DisasContext *ctx) |
| 4576 | 4622 | { |
| 4577 | 4623 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -4588,9 +4634,8 @@ static void gen_slbie(DisasContext *ctx) |
| 4588 | 4634 | |
| 4589 | 4635 | /*** External control ***/ |
| 4590 | 4636 | /* Optional: */ |
| 4591 | -/* eciwx */ | |
| 4592 | -GEN_HANDLER(eciwx, 0x1F, 0x16, 0x0D, 0x00000001, PPC_EXTERN); | |
| 4593 | 4637 | |
| 4638 | +/* eciwx */ | |
| 4594 | 4639 | static void gen_eciwx(DisasContext *ctx) |
| 4595 | 4640 | { |
| 4596 | 4641 | TCGv t0; |
| ... | ... | @@ -4604,8 +4649,6 @@ static void gen_eciwx(DisasContext *ctx) |
| 4604 | 4649 | } |
| 4605 | 4650 | |
| 4606 | 4651 | /* ecowx */ |
| 4607 | -GEN_HANDLER(ecowx, 0x1F, 0x16, 0x09, 0x00000001, PPC_EXTERN); | |
| 4608 | - | |
| 4609 | 4652 | static void gen_ecowx(DisasContext *ctx) |
| 4610 | 4653 | { |
| 4611 | 4654 | TCGv t0; |
| ... | ... | @@ -4619,9 +4662,8 @@ static void gen_ecowx(DisasContext *ctx) |
| 4619 | 4662 | } |
| 4620 | 4663 | |
| 4621 | 4664 | /* PowerPC 601 specific instructions */ |
| 4622 | -/* abs - abs. */ | |
| 4623 | -GEN_HANDLER(abs, 0x1F, 0x08, 0x0B, 0x0000F800, PPC_POWER_BR); | |
| 4624 | 4665 | |
| 4666 | +/* abs - abs. */ | |
| 4625 | 4667 | static void gen_abs(DisasContext *ctx) |
| 4626 | 4668 | { |
| 4627 | 4669 | int l1 = gen_new_label(); |
| ... | ... | @@ -4637,8 +4679,6 @@ static void gen_abs(DisasContext *ctx) |
| 4637 | 4679 | } |
| 4638 | 4680 | |
| 4639 | 4681 | /* abso - abso. */ |
| 4640 | -GEN_HANDLER(abso, 0x1F, 0x08, 0x1B, 0x0000F800, PPC_POWER_BR); | |
| 4641 | - | |
| 4642 | 4682 | static void gen_abso(DisasContext *ctx) |
| 4643 | 4683 | { |
| 4644 | 4684 | int l1 = gen_new_label(); |
| ... | ... | @@ -4661,8 +4701,6 @@ static void gen_abso(DisasContext *ctx) |
| 4661 | 4701 | } |
| 4662 | 4702 | |
| 4663 | 4703 | /* clcs */ |
| 4664 | -GEN_HANDLER(clcs, 0x1F, 0x10, 0x13, 0x0000F800, PPC_POWER_BR); | |
| 4665 | - | |
| 4666 | 4704 | static void gen_clcs(DisasContext *ctx) |
| 4667 | 4705 | { |
| 4668 | 4706 | TCGv_i32 t0 = tcg_const_i32(rA(ctx->opcode)); |
| ... | ... | @@ -4672,8 +4710,6 @@ static void gen_clcs(DisasContext *ctx) |
| 4672 | 4710 | } |
| 4673 | 4711 | |
| 4674 | 4712 | /* div - div. */ |
| 4675 | -GEN_HANDLER(div, 0x1F, 0x0B, 0x0A, 0x00000000, PPC_POWER_BR); | |
| 4676 | - | |
| 4677 | 4713 | static void gen_div(DisasContext *ctx) |
| 4678 | 4714 | { |
| 4679 | 4715 | gen_helper_div(cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], cpu_gpr[rB(ctx->opcode)]); |
| ... | ... | @@ -4682,8 +4718,6 @@ static void gen_div(DisasContext *ctx) |
| 4682 | 4718 | } |
| 4683 | 4719 | |
| 4684 | 4720 | /* divo - divo. */ |
| 4685 | -GEN_HANDLER(divo, 0x1F, 0x0B, 0x1A, 0x00000000, PPC_POWER_BR); | |
| 4686 | - | |
| 4687 | 4721 | static void gen_divo(DisasContext *ctx) |
| 4688 | 4722 | { |
| 4689 | 4723 | gen_helper_divo(cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], cpu_gpr[rB(ctx->opcode)]); |
| ... | ... | @@ -4692,8 +4726,6 @@ static void gen_divo(DisasContext *ctx) |
| 4692 | 4726 | } |
| 4693 | 4727 | |
| 4694 | 4728 | /* divs - divs. */ |
| 4695 | -GEN_HANDLER(divs, 0x1F, 0x0B, 0x0B, 0x00000000, PPC_POWER_BR); | |
| 4696 | - | |
| 4697 | 4729 | static void gen_divs(DisasContext *ctx) |
| 4698 | 4730 | { |
| 4699 | 4731 | gen_helper_divs(cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], cpu_gpr[rB(ctx->opcode)]); |
| ... | ... | @@ -4702,8 +4734,6 @@ static void gen_divs(DisasContext *ctx) |
| 4702 | 4734 | } |
| 4703 | 4735 | |
| 4704 | 4736 | /* divso - divso. */ |
| 4705 | -GEN_HANDLER(divso, 0x1F, 0x0B, 0x1B, 0x00000000, PPC_POWER_BR); | |
| 4706 | - | |
| 4707 | 4737 | static void gen_divso(DisasContext *ctx) |
| 4708 | 4738 | { |
| 4709 | 4739 | gen_helper_divso(cpu_gpr[rD(ctx->opcode)], cpu_gpr[rA(ctx->opcode)], cpu_gpr[rB(ctx->opcode)]); |
| ... | ... | @@ -4712,8 +4742,6 @@ static void gen_divso(DisasContext *ctx) |
| 4712 | 4742 | } |
| 4713 | 4743 | |
| 4714 | 4744 | /* doz - doz. */ |
| 4715 | -GEN_HANDLER(doz, 0x1F, 0x08, 0x08, 0x00000000, PPC_POWER_BR); | |
| 4716 | - | |
| 4717 | 4745 | static void gen_doz(DisasContext *ctx) |
| 4718 | 4746 | { |
| 4719 | 4747 | int l1 = gen_new_label(); |
| ... | ... | @@ -4729,8 +4757,6 @@ static void gen_doz(DisasContext *ctx) |
| 4729 | 4757 | } |
| 4730 | 4758 | |
| 4731 | 4759 | /* dozo - dozo. */ |
| 4732 | -GEN_HANDLER(dozo, 0x1F, 0x08, 0x18, 0x00000000, PPC_POWER_BR); | |
| 4733 | - | |
| 4734 | 4760 | static void gen_dozo(DisasContext *ctx) |
| 4735 | 4761 | { |
| 4736 | 4762 | int l1 = gen_new_label(); |
| ... | ... | @@ -4760,8 +4786,6 @@ static void gen_dozo(DisasContext *ctx) |
| 4760 | 4786 | } |
| 4761 | 4787 | |
| 4762 | 4788 | /* dozi */ |
| 4763 | -GEN_HANDLER(dozi, 0x09, 0xFF, 0xFF, 0x00000000, PPC_POWER_BR); | |
| 4764 | - | |
| 4765 | 4789 | static void gen_dozi(DisasContext *ctx) |
| 4766 | 4790 | { |
| 4767 | 4791 | target_long simm = SIMM(ctx->opcode); |
| ... | ... | @@ -4778,8 +4802,6 @@ static void gen_dozi(DisasContext *ctx) |
| 4778 | 4802 | } |
| 4779 | 4803 | |
| 4780 | 4804 | /* lscbx - lscbx. */ |
| 4781 | -GEN_HANDLER(lscbx, 0x1F, 0x15, 0x08, 0x00000000, PPC_POWER_BR); | |
| 4782 | - | |
| 4783 | 4805 | static void gen_lscbx(DisasContext *ctx) |
| 4784 | 4806 | { |
| 4785 | 4807 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -4802,8 +4824,6 @@ static void gen_lscbx(DisasContext *ctx) |
| 4802 | 4824 | } |
| 4803 | 4825 | |
| 4804 | 4826 | /* maskg - maskg. */ |
| 4805 | -GEN_HANDLER(maskg, 0x1F, 0x1D, 0x00, 0x00000000, PPC_POWER_BR); | |
| 4806 | - | |
| 4807 | 4827 | static void gen_maskg(DisasContext *ctx) |
| 4808 | 4828 | { |
| 4809 | 4829 | int l1 = gen_new_label(); |
| ... | ... | @@ -4830,8 +4850,6 @@ static void gen_maskg(DisasContext *ctx) |
| 4830 | 4850 | } |
| 4831 | 4851 | |
| 4832 | 4852 | /* maskir - maskir. */ |
| 4833 | -GEN_HANDLER(maskir, 0x1F, 0x1D, 0x10, 0x00000000, PPC_POWER_BR); | |
| 4834 | - | |
| 4835 | 4853 | static void gen_maskir(DisasContext *ctx) |
| 4836 | 4854 | { |
| 4837 | 4855 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -4846,8 +4864,6 @@ static void gen_maskir(DisasContext *ctx) |
| 4846 | 4864 | } |
| 4847 | 4865 | |
| 4848 | 4866 | /* mul - mul. */ |
| 4849 | -GEN_HANDLER(mul, 0x1F, 0x0B, 0x03, 0x00000000, PPC_POWER_BR); | |
| 4850 | - | |
| 4851 | 4867 | static void gen_mul(DisasContext *ctx) |
| 4852 | 4868 | { |
| 4853 | 4869 | TCGv_i64 t0 = tcg_temp_new_i64(); |
| ... | ... | @@ -4868,8 +4884,6 @@ static void gen_mul(DisasContext *ctx) |
| 4868 | 4884 | } |
| 4869 | 4885 | |
| 4870 | 4886 | /* mulo - mulo. */ |
| 4871 | -GEN_HANDLER(mulo, 0x1F, 0x0B, 0x13, 0x00000000, PPC_POWER_BR); | |
| 4872 | - | |
| 4873 | 4887 | static void gen_mulo(DisasContext *ctx) |
| 4874 | 4888 | { |
| 4875 | 4889 | int l1 = gen_new_label(); |
| ... | ... | @@ -4897,8 +4911,6 @@ static void gen_mulo(DisasContext *ctx) |
| 4897 | 4911 | } |
| 4898 | 4912 | |
| 4899 | 4913 | /* nabs - nabs. */ |
| 4900 | -GEN_HANDLER(nabs, 0x1F, 0x08, 0x0F, 0x00000000, PPC_POWER_BR); | |
| 4901 | - | |
| 4902 | 4914 | static void gen_nabs(DisasContext *ctx) |
| 4903 | 4915 | { |
| 4904 | 4916 | int l1 = gen_new_label(); |
| ... | ... | @@ -4914,8 +4926,6 @@ static void gen_nabs(DisasContext *ctx) |
| 4914 | 4926 | } |
| 4915 | 4927 | |
| 4916 | 4928 | /* nabso - nabso. */ |
| 4917 | -GEN_HANDLER(nabso, 0x1F, 0x08, 0x1F, 0x00000000, PPC_POWER_BR); | |
| 4918 | - | |
| 4919 | 4929 | static void gen_nabso(DisasContext *ctx) |
| 4920 | 4930 | { |
| 4921 | 4931 | int l1 = gen_new_label(); |
| ... | ... | @@ -4933,8 +4943,6 @@ static void gen_nabso(DisasContext *ctx) |
| 4933 | 4943 | } |
| 4934 | 4944 | |
| 4935 | 4945 | /* rlmi - rlmi. */ |
| 4936 | -GEN_HANDLER(rlmi, 0x16, 0xFF, 0xFF, 0x00000000, PPC_POWER_BR); | |
| 4937 | - | |
| 4938 | 4946 | static void gen_rlmi(DisasContext *ctx) |
| 4939 | 4947 | { |
| 4940 | 4948 | uint32_t mb = MB(ctx->opcode); |
| ... | ... | @@ -4951,8 +4959,6 @@ static void gen_rlmi(DisasContext *ctx) |
| 4951 | 4959 | } |
| 4952 | 4960 | |
| 4953 | 4961 | /* rrib - rrib. */ |
| 4954 | -GEN_HANDLER(rrib, 0x1F, 0x19, 0x10, 0x00000000, PPC_POWER_BR); | |
| 4955 | - | |
| 4956 | 4962 | static void gen_rrib(DisasContext *ctx) |
| 4957 | 4963 | { |
| 4958 | 4964 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -4971,8 +4977,6 @@ static void gen_rrib(DisasContext *ctx) |
| 4971 | 4977 | } |
| 4972 | 4978 | |
| 4973 | 4979 | /* sle - sle. */ |
| 4974 | -GEN_HANDLER(sle, 0x1F, 0x19, 0x04, 0x00000000, PPC_POWER_BR); | |
| 4975 | - | |
| 4976 | 4980 | static void gen_sle(DisasContext *ctx) |
| 4977 | 4981 | { |
| 4978 | 4982 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -4991,8 +4995,6 @@ static void gen_sle(DisasContext *ctx) |
| 4991 | 4995 | } |
| 4992 | 4996 | |
| 4993 | 4997 | /* sleq - sleq. */ |
| 4994 | -GEN_HANDLER(sleq, 0x1F, 0x19, 0x06, 0x00000000, PPC_POWER_BR); | |
| 4995 | - | |
| 4996 | 4998 | static void gen_sleq(DisasContext *ctx) |
| 4997 | 4999 | { |
| 4998 | 5000 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -5015,8 +5017,6 @@ static void gen_sleq(DisasContext *ctx) |
| 5015 | 5017 | } |
| 5016 | 5018 | |
| 5017 | 5019 | /* sliq - sliq. */ |
| 5018 | -GEN_HANDLER(sliq, 0x1F, 0x18, 0x05, 0x00000000, PPC_POWER_BR); | |
| 5019 | - | |
| 5020 | 5020 | static void gen_sliq(DisasContext *ctx) |
| 5021 | 5021 | { |
| 5022 | 5022 | int sh = SH(ctx->opcode); |
| ... | ... | @@ -5034,8 +5034,6 @@ static void gen_sliq(DisasContext *ctx) |
| 5034 | 5034 | } |
| 5035 | 5035 | |
| 5036 | 5036 | /* slliq - slliq. */ |
| 5037 | -GEN_HANDLER(slliq, 0x1F, 0x18, 0x07, 0x00000000, PPC_POWER_BR); | |
| 5038 | - | |
| 5039 | 5037 | static void gen_slliq(DisasContext *ctx) |
| 5040 | 5038 | { |
| 5041 | 5039 | int sh = SH(ctx->opcode); |
| ... | ... | @@ -5054,8 +5052,6 @@ static void gen_slliq(DisasContext *ctx) |
| 5054 | 5052 | } |
| 5055 | 5053 | |
| 5056 | 5054 | /* sllq - sllq. */ |
| 5057 | -GEN_HANDLER(sllq, 0x1F, 0x18, 0x06, 0x00000000, PPC_POWER_BR); | |
| 5058 | - | |
| 5059 | 5055 | static void gen_sllq(DisasContext *ctx) |
| 5060 | 5056 | { |
| 5061 | 5057 | int l1 = gen_new_label(); |
| ... | ... | @@ -5085,8 +5081,6 @@ static void gen_sllq(DisasContext *ctx) |
| 5085 | 5081 | } |
| 5086 | 5082 | |
| 5087 | 5083 | /* slq - slq. */ |
| 5088 | -GEN_HANDLER(slq, 0x1F, 0x18, 0x04, 0x00000000, PPC_POWER_BR); | |
| 5089 | - | |
| 5090 | 5084 | static void gen_slq(DisasContext *ctx) |
| 5091 | 5085 | { |
| 5092 | 5086 | int l1 = gen_new_label(); |
| ... | ... | @@ -5110,8 +5104,6 @@ static void gen_slq(DisasContext *ctx) |
| 5110 | 5104 | } |
| 5111 | 5105 | |
| 5112 | 5106 | /* sraiq - sraiq. */ |
| 5113 | -GEN_HANDLER(sraiq, 0x1F, 0x18, 0x1D, 0x00000000, PPC_POWER_BR); | |
| 5114 | - | |
| 5115 | 5107 | static void gen_sraiq(DisasContext *ctx) |
| 5116 | 5108 | { |
| 5117 | 5109 | int sh = SH(ctx->opcode); |
| ... | ... | @@ -5135,8 +5127,6 @@ static void gen_sraiq(DisasContext *ctx) |
| 5135 | 5127 | } |
| 5136 | 5128 | |
| 5137 | 5129 | /* sraq - sraq. */ |
| 5138 | -GEN_HANDLER(sraq, 0x1F, 0x18, 0x1C, 0x00000000, PPC_POWER_BR); | |
| 5139 | - | |
| 5140 | 5130 | static void gen_sraq(DisasContext *ctx) |
| 5141 | 5131 | { |
| 5142 | 5132 | int l1 = gen_new_label(); |
| ... | ... | @@ -5170,8 +5160,6 @@ static void gen_sraq(DisasContext *ctx) |
| 5170 | 5160 | } |
| 5171 | 5161 | |
| 5172 | 5162 | /* sre - sre. */ |
| 5173 | -GEN_HANDLER(sre, 0x1F, 0x19, 0x14, 0x00000000, PPC_POWER_BR); | |
| 5174 | - | |
| 5175 | 5163 | static void gen_sre(DisasContext *ctx) |
| 5176 | 5164 | { |
| 5177 | 5165 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -5190,8 +5178,6 @@ static void gen_sre(DisasContext *ctx) |
| 5190 | 5178 | } |
| 5191 | 5179 | |
| 5192 | 5180 | /* srea - srea. */ |
| 5193 | -GEN_HANDLER(srea, 0x1F, 0x19, 0x1C, 0x00000000, PPC_POWER_BR); | |
| 5194 | - | |
| 5195 | 5181 | static void gen_srea(DisasContext *ctx) |
| 5196 | 5182 | { |
| 5197 | 5183 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -5207,8 +5193,6 @@ static void gen_srea(DisasContext *ctx) |
| 5207 | 5193 | } |
| 5208 | 5194 | |
| 5209 | 5195 | /* sreq */ |
| 5210 | -GEN_HANDLER(sreq, 0x1F, 0x19, 0x16, 0x00000000, PPC_POWER_BR); | |
| 5211 | - | |
| 5212 | 5196 | static void gen_sreq(DisasContext *ctx) |
| 5213 | 5197 | { |
| 5214 | 5198 | TCGv t0 = tcg_temp_new(); |
| ... | ... | @@ -5231,8 +5215,6 @@ static void gen_sreq(DisasContext *ctx) |
| 5231 | 5215 | } |
| 5232 | 5216 | |
| 5233 | 5217 | /* sriq */ |
| 5234 | -GEN_HANDLER(sriq, 0x1F, 0x18, 0x15, 0x00000000, PPC_POWER_BR); | |
| 5235 | - | |
| 5236 | 5218 | static void gen_sriq(DisasContext *ctx) |
| 5237 | 5219 | { |
| 5238 | 5220 | int sh = SH(ctx->opcode); |
| ... | ... | @@ -5250,8 +5232,6 @@ static void gen_sriq(DisasContext *ctx) |
| 5250 | 5232 | } |
| 5251 | 5233 | |
| 5252 | 5234 | /* srliq */ |
| 5253 | -GEN_HANDLER(srliq, 0x1F, 0x18, 0x17, 0x00000000, PPC_POWER_BR); | |
| 5254 | - | |
| 5255 | 5235 | static void gen_srliq(DisasContext *ctx) |
| 5256 | 5236 | { |
| 5257 | 5237 | int sh = SH(ctx->opcode); |
| ... | ... | @@ -5270,8 +5250,6 @@ static void gen_srliq(DisasContext *ctx) |
| 5270 | 5250 | } |
| 5271 | 5251 | |
| 5272 | 5252 | /* srlq */ |
| 5273 | -GEN_HANDLER(srlq, 0x1F, 0x18, 0x16, 0x00000000, PPC_POWER_BR); | |
| 5274 | - | |
| 5275 | 5253 | static void gen_srlq(DisasContext *ctx) |
| 5276 | 5254 | { |
| 5277 | 5255 | int l1 = gen_new_label(); |
| ... | ... | @@ -5302,8 +5280,6 @@ static void gen_srlq(DisasContext *ctx) |
| 5302 | 5280 | } |
| 5303 | 5281 | |
| 5304 | 5282 | /* srq */ |
| 5305 | -GEN_HANDLER(srq, 0x1F, 0x18, 0x14, 0x00000000, PPC_POWER_BR); | |
| 5306 | - | |
| 5307 | 5283 | static void gen_srq(DisasContext *ctx) |
| 5308 | 5284 | { |
| 5309 | 5285 | int l1 = gen_new_label(); |
| ... | ... | @@ -5327,9 +5303,8 @@ static void gen_srq(DisasContext *ctx) |
| 5327 | 5303 | } |
| 5328 | 5304 | |
| 5329 | 5305 | /* PowerPC 602 specific instructions */ |
| 5330 | -/* dsa */ | |
| 5331 | -GEN_HANDLER(dsa, 0x1F, 0x14, 0x13, 0x03FFF801, PPC_602_SPEC); | |
| 5332 | 5306 | |
| 5307 | +/* dsa */ | |
| 5333 | 5308 | static void gen_dsa(DisasContext *ctx) |
| 5334 | 5309 | { |
| 5335 | 5310 | /* XXX: TODO */ |
| ... | ... | @@ -5337,8 +5312,6 @@ static void gen_dsa(DisasContext *ctx) |
| 5337 | 5312 | } |
| 5338 | 5313 | |
| 5339 | 5314 | /* esa */ |
| 5340 | -GEN_HANDLER(esa, 0x1F, 0x14, 0x12, 0x03FFF801, PPC_602_SPEC); | |
| 5341 | - | |
| 5342 | 5315 | static void gen_esa(DisasContext *ctx) |
| 5343 | 5316 | { |
| 5344 | 5317 | /* XXX: TODO */ |
| ... | ... | @@ -5346,8 +5319,6 @@ static void gen_esa(DisasContext *ctx) |
| 5346 | 5319 | } |
| 5347 | 5320 | |
| 5348 | 5321 | /* mfrom */ |
| 5349 | -GEN_HANDLER(mfrom, 0x1F, 0x09, 0x08, 0x03E0F801, PPC_602_SPEC); | |
| 5350 | - | |
| 5351 | 5322 | static void gen_mfrom(DisasContext *ctx) |
| 5352 | 5323 | { |
| 5353 | 5324 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5362,9 +5333,8 @@ static void gen_mfrom(DisasContext *ctx) |
| 5362 | 5333 | } |
| 5363 | 5334 | |
| 5364 | 5335 | /* 602 - 603 - G2 TLB management */ |
| 5365 | -/* tlbld */ | |
| 5366 | -GEN_HANDLER2(tlbld_6xx, "tlbld", 0x1F, 0x12, 0x1E, 0x03FF0001, PPC_6xx_TLB); | |
| 5367 | 5336 | |
| 5337 | +/* tlbld */ | |
| 5368 | 5338 | static void gen_tlbld_6xx(DisasContext *ctx) |
| 5369 | 5339 | { |
| 5370 | 5340 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5379,8 +5349,6 @@ static void gen_tlbld_6xx(DisasContext *ctx) |
| 5379 | 5349 | } |
| 5380 | 5350 | |
| 5381 | 5351 | /* tlbli */ |
| 5382 | -GEN_HANDLER2(tlbli_6xx, "tlbli", 0x1F, 0x12, 0x1F, 0x03FF0001, PPC_6xx_TLB); | |
| 5383 | - | |
| 5384 | 5352 | static void gen_tlbli_6xx(DisasContext *ctx) |
| 5385 | 5353 | { |
| 5386 | 5354 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5395,9 +5363,8 @@ static void gen_tlbli_6xx(DisasContext *ctx) |
| 5395 | 5363 | } |
| 5396 | 5364 | |
| 5397 | 5365 | /* 74xx TLB management */ |
| 5398 | -/* tlbld */ | |
| 5399 | -GEN_HANDLER2(tlbld_74xx, "tlbld", 0x1F, 0x12, 0x1E, 0x03FF0001, PPC_74xx_TLB); | |
| 5400 | 5366 | |
| 5367 | +/* tlbld */ | |
| 5401 | 5368 | static void gen_tlbld_74xx(DisasContext *ctx) |
| 5402 | 5369 | { |
| 5403 | 5370 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5412,8 +5379,6 @@ static void gen_tlbld_74xx(DisasContext *ctx) |
| 5412 | 5379 | } |
| 5413 | 5380 | |
| 5414 | 5381 | /* tlbli */ |
| 5415 | -GEN_HANDLER2(tlbli_74xx, "tlbli", 0x1F, 0x12, 0x1F, 0x03FF0001, PPC_74xx_TLB); | |
| 5416 | - | |
| 5417 | 5382 | static void gen_tlbli_74xx(DisasContext *ctx) |
| 5418 | 5383 | { |
| 5419 | 5384 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5428,17 +5393,14 @@ static void gen_tlbli_74xx(DisasContext *ctx) |
| 5428 | 5393 | } |
| 5429 | 5394 | |
| 5430 | 5395 | /* POWER instructions not in PowerPC 601 */ |
| 5431 | -/* clf */ | |
| 5432 | -GEN_HANDLER(clf, 0x1F, 0x16, 0x03, 0x03E00000, PPC_POWER); | |
| 5433 | 5396 | |
| 5397 | +/* clf */ | |
| 5434 | 5398 | static void gen_clf(DisasContext *ctx) |
| 5435 | 5399 | { |
| 5436 | 5400 | /* Cache line flush: implemented as no-op */ |
| 5437 | 5401 | } |
| 5438 | 5402 | |
| 5439 | 5403 | /* cli */ |
| 5440 | -GEN_HANDLER(cli, 0x1F, 0x16, 0x0F, 0x03E00000, PPC_POWER); | |
| 5441 | - | |
| 5442 | 5404 | static void gen_cli(DisasContext *ctx) |
| 5443 | 5405 | { |
| 5444 | 5406 | /* Cache line invalidate: privileged and treated as no-op */ |
| ... | ... | @@ -5453,15 +5415,11 @@ static void gen_cli(DisasContext *ctx) |
| 5453 | 5415 | } |
| 5454 | 5416 | |
| 5455 | 5417 | /* dclst */ |
| 5456 | -GEN_HANDLER(dclst, 0x1F, 0x16, 0x13, 0x03E00000, PPC_POWER); | |
| 5457 | - | |
| 5458 | 5418 | static void gen_dclst(DisasContext *ctx) |
| 5459 | 5419 | { |
| 5460 | 5420 | /* Data cache line store: treated as no-op */ |
| 5461 | 5421 | } |
| 5462 | 5422 | |
| 5463 | -GEN_HANDLER(mfsri, 0x1F, 0x13, 0x13, 0x00000001, PPC_POWER); | |
| 5464 | - | |
| 5465 | 5423 | static void gen_mfsri(DisasContext *ctx) |
| 5466 | 5424 | { |
| 5467 | 5425 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5485,8 +5443,6 @@ static void gen_mfsri(DisasContext *ctx) |
| 5485 | 5443 | #endif |
| 5486 | 5444 | } |
| 5487 | 5445 | |
| 5488 | -GEN_HANDLER(rac, 0x1F, 0x12, 0x19, 0x00000001, PPC_POWER); | |
| 5489 | - | |
| 5490 | 5446 | static void gen_rac(DisasContext *ctx) |
| 5491 | 5447 | { |
| 5492 | 5448 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5504,8 +5460,6 @@ static void gen_rac(DisasContext *ctx) |
| 5504 | 5460 | #endif |
| 5505 | 5461 | } |
| 5506 | 5462 | |
| 5507 | -GEN_HANDLER(rfsvc, 0x13, 0x12, 0x02, 0x03FFF0001, PPC_POWER); | |
| 5508 | - | |
| 5509 | 5463 | static void gen_rfsvc(DisasContext *ctx) |
| 5510 | 5464 | { |
| 5511 | 5465 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5526,8 +5480,6 @@ static void gen_rfsvc(DisasContext *ctx) |
| 5526 | 5480 | /* Quad manipulation (load/store two floats at a time) */ |
| 5527 | 5481 | |
| 5528 | 5482 | /* lfq */ |
| 5529 | -GEN_HANDLER(lfq, 0x38, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 5530 | - | |
| 5531 | 5483 | static void gen_lfq(DisasContext *ctx) |
| 5532 | 5484 | { |
| 5533 | 5485 | int rd = rD(ctx->opcode); |
| ... | ... | @@ -5542,8 +5494,6 @@ static void gen_lfq(DisasContext *ctx) |
| 5542 | 5494 | } |
| 5543 | 5495 | |
| 5544 | 5496 | /* lfqu */ |
| 5545 | -GEN_HANDLER(lfqu, 0x39, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 5546 | - | |
| 5547 | 5497 | static void gen_lfqu(DisasContext *ctx) |
| 5548 | 5498 | { |
| 5549 | 5499 | int ra = rA(ctx->opcode); |
| ... | ... | @@ -5563,8 +5513,6 @@ static void gen_lfqu(DisasContext *ctx) |
| 5563 | 5513 | } |
| 5564 | 5514 | |
| 5565 | 5515 | /* lfqux */ |
| 5566 | -GEN_HANDLER(lfqux, 0x1F, 0x17, 0x19, 0x00000001, PPC_POWER2); | |
| 5567 | - | |
| 5568 | 5516 | static void gen_lfqux(DisasContext *ctx) |
| 5569 | 5517 | { |
| 5570 | 5518 | int ra = rA(ctx->opcode); |
| ... | ... | @@ -5584,8 +5532,6 @@ static void gen_lfqux(DisasContext *ctx) |
| 5584 | 5532 | } |
| 5585 | 5533 | |
| 5586 | 5534 | /* lfqx */ |
| 5587 | -GEN_HANDLER(lfqx, 0x1F, 0x17, 0x18, 0x00000001, PPC_POWER2); | |
| 5588 | - | |
| 5589 | 5535 | static void gen_lfqx(DisasContext *ctx) |
| 5590 | 5536 | { |
| 5591 | 5537 | int rd = rD(ctx->opcode); |
| ... | ... | @@ -5600,8 +5546,6 @@ static void gen_lfqx(DisasContext *ctx) |
| 5600 | 5546 | } |
| 5601 | 5547 | |
| 5602 | 5548 | /* stfq */ |
| 5603 | -GEN_HANDLER(stfq, 0x3C, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 5604 | - | |
| 5605 | 5549 | static void gen_stfq(DisasContext *ctx) |
| 5606 | 5550 | { |
| 5607 | 5551 | int rd = rD(ctx->opcode); |
| ... | ... | @@ -5616,8 +5560,6 @@ static void gen_stfq(DisasContext *ctx) |
| 5616 | 5560 | } |
| 5617 | 5561 | |
| 5618 | 5562 | /* stfqu */ |
| 5619 | -GEN_HANDLER(stfqu, 0x3D, 0xFF, 0xFF, 0x00000003, PPC_POWER2); | |
| 5620 | - | |
| 5621 | 5563 | static void gen_stfqu(DisasContext *ctx) |
| 5622 | 5564 | { |
| 5623 | 5565 | int ra = rA(ctx->opcode); |
| ... | ... | @@ -5637,8 +5579,6 @@ static void gen_stfqu(DisasContext *ctx) |
| 5637 | 5579 | } |
| 5638 | 5580 | |
| 5639 | 5581 | /* stfqux */ |
| 5640 | -GEN_HANDLER(stfqux, 0x1F, 0x17, 0x1D, 0x00000001, PPC_POWER2); | |
| 5641 | - | |
| 5642 | 5582 | static void gen_stfqux(DisasContext *ctx) |
| 5643 | 5583 | { |
| 5644 | 5584 | int ra = rA(ctx->opcode); |
| ... | ... | @@ -5658,8 +5598,6 @@ static void gen_stfqux(DisasContext *ctx) |
| 5658 | 5598 | } |
| 5659 | 5599 | |
| 5660 | 5600 | /* stfqx */ |
| 5661 | -GEN_HANDLER(stfqx, 0x1F, 0x17, 0x1C, 0x00000001, PPC_POWER2); | |
| 5662 | - | |
| 5663 | 5601 | static void gen_stfqx(DisasContext *ctx) |
| 5664 | 5602 | { |
| 5665 | 5603 | int rd = rD(ctx->opcode); |
| ... | ... | @@ -5674,9 +5612,8 @@ static void gen_stfqx(DisasContext *ctx) |
| 5674 | 5612 | } |
| 5675 | 5613 | |
| 5676 | 5614 | /* BookE specific instructions */ |
| 5677 | -/* XXX: not implemented on 440 ? */ | |
| 5678 | -GEN_HANDLER(mfapidi, 0x1F, 0x13, 0x08, 0x0000F801, PPC_MFAPIDI); | |
| 5679 | 5615 | |
| 5616 | +/* XXX: not implemented on 440 ? */ | |
| 5680 | 5617 | static void gen_mfapidi(DisasContext *ctx) |
| 5681 | 5618 | { |
| 5682 | 5619 | /* XXX: TODO */ |
| ... | ... | @@ -5684,8 +5621,6 @@ static void gen_mfapidi(DisasContext *ctx) |
| 5684 | 5621 | } |
| 5685 | 5622 | |
| 5686 | 5623 | /* XXX: not implemented on 440 ? */ |
| 5687 | -GEN_HANDLER(tlbiva, 0x1F, 0x12, 0x18, 0x03FFF801, PPC_TLBIVA); | |
| 5688 | - | |
| 5689 | 5624 | static void gen_tlbiva(DisasContext *ctx) |
| 5690 | 5625 | { |
| 5691 | 5626 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5921,8 +5856,6 @@ GEN_MAC_HANDLER(mullhw, 0x08, 0x0D); |
| 5921 | 5856 | GEN_MAC_HANDLER(mullhwu, 0x08, 0x0C); |
| 5922 | 5857 | |
| 5923 | 5858 | /* mfdcr */ |
| 5924 | -GEN_HANDLER(mfdcr, 0x1F, 0x03, 0x0A, 0x00000001, PPC_DCR); | |
| 5925 | - | |
| 5926 | 5859 | static void gen_mfdcr(DisasContext *ctx) |
| 5927 | 5860 | { |
| 5928 | 5861 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5942,8 +5875,6 @@ static void gen_mfdcr(DisasContext *ctx) |
| 5942 | 5875 | } |
| 5943 | 5876 | |
| 5944 | 5877 | /* mtdcr */ |
| 5945 | -GEN_HANDLER(mtdcr, 0x1F, 0x03, 0x0E, 0x00000001, PPC_DCR); | |
| 5946 | - | |
| 5947 | 5878 | static void gen_mtdcr(DisasContext *ctx) |
| 5948 | 5879 | { |
| 5949 | 5880 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5964,8 +5895,6 @@ static void gen_mtdcr(DisasContext *ctx) |
| 5964 | 5895 | |
| 5965 | 5896 | /* mfdcrx */ |
| 5966 | 5897 | /* XXX: not implemented on 440 ? */ |
| 5967 | -GEN_HANDLER(mfdcrx, 0x1F, 0x03, 0x08, 0x00000000, PPC_DCRX); | |
| 5968 | - | |
| 5969 | 5898 | static void gen_mfdcrx(DisasContext *ctx) |
| 5970 | 5899 | { |
| 5971 | 5900 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -5984,8 +5913,6 @@ static void gen_mfdcrx(DisasContext *ctx) |
| 5984 | 5913 | |
| 5985 | 5914 | /* mtdcrx */ |
| 5986 | 5915 | /* XXX: not implemented on 440 ? */ |
| 5987 | -GEN_HANDLER(mtdcrx, 0x1F, 0x03, 0x0C, 0x00000000, PPC_DCRX); | |
| 5988 | - | |
| 5989 | 5916 | static void gen_mtdcrx(DisasContext *ctx) |
| 5990 | 5917 | { |
| 5991 | 5918 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6003,8 +5930,6 @@ static void gen_mtdcrx(DisasContext *ctx) |
| 6003 | 5930 | } |
| 6004 | 5931 | |
| 6005 | 5932 | /* mfdcrux (PPC 460) : user-mode access to DCR */ |
| 6006 | -GEN_HANDLER(mfdcrux, 0x1F, 0x03, 0x09, 0x00000000, PPC_DCRUX); | |
| 6007 | - | |
| 6008 | 5933 | static void gen_mfdcrux(DisasContext *ctx) |
| 6009 | 5934 | { |
| 6010 | 5935 | /* NIP cannot be restored if the memory exception comes from an helper */ |
| ... | ... | @@ -6014,8 +5939,6 @@ static void gen_mfdcrux(DisasContext *ctx) |
| 6014 | 5939 | } |
| 6015 | 5940 | |
| 6016 | 5941 | /* mtdcrux (PPC 460) : user-mode access to DCR */ |
| 6017 | -GEN_HANDLER(mtdcrux, 0x1F, 0x03, 0x0D, 0x00000000, PPC_DCRUX); | |
| 6018 | - | |
| 6019 | 5942 | static void gen_mtdcrux(DisasContext *ctx) |
| 6020 | 5943 | { |
| 6021 | 5944 | /* NIP cannot be restored if the memory exception comes from an helper */ |
| ... | ... | @@ -6025,8 +5948,6 @@ static void gen_mtdcrux(DisasContext *ctx) |
| 6025 | 5948 | } |
| 6026 | 5949 | |
| 6027 | 5950 | /* dccci */ |
| 6028 | -GEN_HANDLER(dccci, 0x1F, 0x06, 0x0E, 0x03E00001, PPC_4xx_COMMON); | |
| 6029 | - | |
| 6030 | 5951 | static void gen_dccci(DisasContext *ctx) |
| 6031 | 5952 | { |
| 6032 | 5953 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6041,8 +5962,6 @@ static void gen_dccci(DisasContext *ctx) |
| 6041 | 5962 | } |
| 6042 | 5963 | |
| 6043 | 5964 | /* dcread */ |
| 6044 | -GEN_HANDLER(dcread, 0x1F, 0x06, 0x0F, 0x00000001, PPC_4xx_COMMON); | |
| 6045 | - | |
| 6046 | 5965 | static void gen_dcread(DisasContext *ctx) |
| 6047 | 5966 | { |
| 6048 | 5967 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6065,8 +5984,6 @@ static void gen_dcread(DisasContext *ctx) |
| 6065 | 5984 | } |
| 6066 | 5985 | |
| 6067 | 5986 | /* icbt */ |
| 6068 | -GEN_HANDLER2(icbt_40x, "icbt", 0x1F, 0x06, 0x08, 0x03E00001, PPC_40x_ICBT); | |
| 6069 | - | |
| 6070 | 5987 | static void gen_icbt_40x(DisasContext *ctx) |
| 6071 | 5988 | { |
| 6072 | 5989 | /* interpreted as no-op */ |
| ... | ... | @@ -6076,8 +5993,6 @@ static void gen_icbt_40x(DisasContext *ctx) |
| 6076 | 5993 | } |
| 6077 | 5994 | |
| 6078 | 5995 | /* iccci */ |
| 6079 | -GEN_HANDLER(iccci, 0x1F, 0x06, 0x1E, 0x00000001, PPC_4xx_COMMON); | |
| 6080 | - | |
| 6081 | 5996 | static void gen_iccci(DisasContext *ctx) |
| 6082 | 5997 | { |
| 6083 | 5998 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6092,8 +6007,6 @@ static void gen_iccci(DisasContext *ctx) |
| 6092 | 6007 | } |
| 6093 | 6008 | |
| 6094 | 6009 | /* icread */ |
| 6095 | -GEN_HANDLER(icread, 0x1F, 0x06, 0x1F, 0x03E00001, PPC_4xx_COMMON); | |
| 6096 | - | |
| 6097 | 6010 | static void gen_icread(DisasContext *ctx) |
| 6098 | 6011 | { |
| 6099 | 6012 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6108,8 +6021,6 @@ static void gen_icread(DisasContext *ctx) |
| 6108 | 6021 | } |
| 6109 | 6022 | |
| 6110 | 6023 | /* rfci (mem_idx only) */ |
| 6111 | -GEN_HANDLER2(rfci_40x, "rfci", 0x13, 0x13, 0x01, 0x03FF8001, PPC_40x_EXCP); | |
| 6112 | - | |
| 6113 | 6024 | static void gen_rfci_40x(DisasContext *ctx) |
| 6114 | 6025 | { |
| 6115 | 6026 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6125,8 +6036,6 @@ static void gen_rfci_40x(DisasContext *ctx) |
| 6125 | 6036 | #endif |
| 6126 | 6037 | } |
| 6127 | 6038 | |
| 6128 | -GEN_HANDLER(rfci, 0x13, 0x13, 0x01, 0x03FF8001, PPC_BOOKE); | |
| 6129 | - | |
| 6130 | 6039 | static void gen_rfci(DisasContext *ctx) |
| 6131 | 6040 | { |
| 6132 | 6041 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6143,9 +6052,8 @@ static void gen_rfci(DisasContext *ctx) |
| 6143 | 6052 | } |
| 6144 | 6053 | |
| 6145 | 6054 | /* BookE specific */ |
| 6146 | -/* XXX: not implemented on 440 ? */ | |
| 6147 | -GEN_HANDLER(rfdi, 0x13, 0x07, 0x01, 0x03FF8001, PPC_RFDI); | |
| 6148 | 6055 | |
| 6056 | +/* XXX: not implemented on 440 ? */ | |
| 6149 | 6057 | static void gen_rfdi(DisasContext *ctx) |
| 6150 | 6058 | { |
| 6151 | 6059 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6162,8 +6070,6 @@ static void gen_rfdi(DisasContext *ctx) |
| 6162 | 6070 | } |
| 6163 | 6071 | |
| 6164 | 6072 | /* XXX: not implemented on 440 ? */ |
| 6165 | -GEN_HANDLER(rfmci, 0x13, 0x06, 0x01, 0x03FF8001, PPC_RFMCI); | |
| 6166 | - | |
| 6167 | 6073 | static void gen_rfmci(DisasContext *ctx) |
| 6168 | 6074 | { |
| 6169 | 6075 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6180,9 +6086,8 @@ static void gen_rfmci(DisasContext *ctx) |
| 6180 | 6086 | } |
| 6181 | 6087 | |
| 6182 | 6088 | /* TLB management - PowerPC 405 implementation */ |
| 6183 | -/* tlbre */ | |
| 6184 | -GEN_HANDLER2(tlbre_40x, "tlbre", 0x1F, 0x12, 0x1D, 0x00000001, PPC_40x_TLB); | |
| 6185 | 6089 | |
| 6090 | +/* tlbre */ | |
| 6186 | 6091 | static void gen_tlbre_40x(DisasContext *ctx) |
| 6187 | 6092 | { |
| 6188 | 6093 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6207,8 +6112,6 @@ static void gen_tlbre_40x(DisasContext *ctx) |
| 6207 | 6112 | } |
| 6208 | 6113 | |
| 6209 | 6114 | /* tlbsx - tlbsx. */ |
| 6210 | -GEN_HANDLER2(tlbsx_40x, "tlbsx", 0x1F, 0x12, 0x1C, 0x00000000, PPC_40x_TLB); | |
| 6211 | - | |
| 6212 | 6115 | static void gen_tlbsx_40x(DisasContext *ctx) |
| 6213 | 6116 | { |
| 6214 | 6117 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6236,8 +6139,6 @@ static void gen_tlbsx_40x(DisasContext *ctx) |
| 6236 | 6139 | } |
| 6237 | 6140 | |
| 6238 | 6141 | /* tlbwe */ |
| 6239 | -GEN_HANDLER2(tlbwe_40x, "tlbwe", 0x1F, 0x12, 0x1E, 0x00000001, PPC_40x_TLB); | |
| 6240 | - | |
| 6241 | 6142 | static void gen_tlbwe_40x(DisasContext *ctx) |
| 6242 | 6143 | { |
| 6243 | 6144 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6262,9 +6163,8 @@ static void gen_tlbwe_40x(DisasContext *ctx) |
| 6262 | 6163 | } |
| 6263 | 6164 | |
| 6264 | 6165 | /* TLB management - PowerPC 440 implementation */ |
| 6265 | -/* tlbre */ | |
| 6266 | -GEN_HANDLER2(tlbre_440, "tlbre", 0x1F, 0x12, 0x1D, 0x00000001, PPC_BOOKE); | |
| 6267 | 6166 | |
| 6167 | +/* tlbre */ | |
| 6268 | 6168 | static void gen_tlbre_440(DisasContext *ctx) |
| 6269 | 6169 | { |
| 6270 | 6170 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6292,8 +6192,6 @@ static void gen_tlbre_440(DisasContext *ctx) |
| 6292 | 6192 | } |
| 6293 | 6193 | |
| 6294 | 6194 | /* tlbsx - tlbsx. */ |
| 6295 | -GEN_HANDLER2(tlbsx_440, "tlbsx", 0x1F, 0x12, 0x1C, 0x00000000, PPC_BOOKE); | |
| 6296 | - | |
| 6297 | 6195 | static void gen_tlbsx_440(DisasContext *ctx) |
| 6298 | 6196 | { |
| 6299 | 6197 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6321,8 +6219,6 @@ static void gen_tlbsx_440(DisasContext *ctx) |
| 6321 | 6219 | } |
| 6322 | 6220 | |
| 6323 | 6221 | /* tlbwe */ |
| 6324 | -GEN_HANDLER2(tlbwe_440, "tlbwe", 0x1F, 0x12, 0x1E, 0x00000001, PPC_BOOKE); | |
| 6325 | - | |
| 6326 | 6222 | static void gen_tlbwe_440(DisasContext *ctx) |
| 6327 | 6223 | { |
| 6328 | 6224 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6350,8 +6246,6 @@ static void gen_tlbwe_440(DisasContext *ctx) |
| 6350 | 6246 | } |
| 6351 | 6247 | |
| 6352 | 6248 | /* wrtee */ |
| 6353 | -GEN_HANDLER(wrtee, 0x1F, 0x03, 0x04, 0x000FFC01, PPC_WRTEE); | |
| 6354 | - | |
| 6355 | 6249 | static void gen_wrtee(DisasContext *ctx) |
| 6356 | 6250 | { |
| 6357 | 6251 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6375,8 +6269,6 @@ static void gen_wrtee(DisasContext *ctx) |
| 6375 | 6269 | } |
| 6376 | 6270 | |
| 6377 | 6271 | /* wrteei */ |
| 6378 | -GEN_HANDLER(wrteei, 0x1F, 0x03, 0x05, 0x000EFC01, PPC_WRTEE); | |
| 6379 | - | |
| 6380 | 6272 | static void gen_wrteei(DisasContext *ctx) |
| 6381 | 6273 | { |
| 6382 | 6274 | #if defined(CONFIG_USER_ONLY) |
| ... | ... | @@ -6397,9 +6289,8 @@ static void gen_wrteei(DisasContext *ctx) |
| 6397 | 6289 | } |
| 6398 | 6290 | |
| 6399 | 6291 | /* PowerPC 440 specific instructions */ |
| 6400 | -/* dlmzb */ | |
| 6401 | -GEN_HANDLER(dlmzb, 0x1F, 0x0E, 0x02, 0x00000000, PPC_440_SPEC); | |
| 6402 | 6292 | |
| 6293 | +/* dlmzb */ | |
| 6403 | 6294 | static void gen_dlmzb(DisasContext *ctx) |
| 6404 | 6295 | { |
| 6405 | 6296 | TCGv_i32 t0 = tcg_const_i32(Rc(ctx->opcode)); |
| ... | ... | @@ -6409,24 +6300,18 @@ static void gen_dlmzb(DisasContext *ctx) |
| 6409 | 6300 | } |
| 6410 | 6301 | |
| 6411 | 6302 | /* mbar replaces eieio on 440 */ |
| 6412 | -GEN_HANDLER(mbar, 0x1F, 0x16, 0x1a, 0x001FF801, PPC_BOOKE); | |
| 6413 | - | |
| 6414 | 6303 | static void gen_mbar(DisasContext *ctx) |
| 6415 | 6304 | { |
| 6416 | 6305 | /* interpreted as no-op */ |
| 6417 | 6306 | } |
| 6418 | 6307 | |
| 6419 | 6308 | /* msync replaces sync on 440 */ |
| 6420 | -GEN_HANDLER(msync, 0x1F, 0x16, 0x12, 0x03FFF801, PPC_BOOKE); | |
| 6421 | - | |
| 6422 | 6309 | static void gen_msync(DisasContext *ctx) |
| 6423 | 6310 | { |
| 6424 | 6311 | /* interpreted as no-op */ |
| 6425 | 6312 | } |
| 6426 | 6313 | |
| 6427 | 6314 | /* icbt */ |
| 6428 | -GEN_HANDLER2(icbt_440, "icbt", 0x1F, 0x16, 0x00, 0x03E00001, PPC_BOOKE); | |
| 6429 | - | |
| 6430 | 6315 | static void gen_icbt_440(DisasContext *ctx) |
| 6431 | 6316 | { |
| 6432 | 6317 | /* interpreted as no-op */ |
| ... | ... | @@ -6553,8 +6438,6 @@ GEN_VR_STVE(bx, 0x07, 0x04); |
| 6553 | 6438 | GEN_VR_STVE(hx, 0x07, 0x05); |
| 6554 | 6439 | GEN_VR_STVE(wx, 0x07, 0x06); |
| 6555 | 6440 | |
| 6556 | -GEN_HANDLER(lvsl, 0x1f, 0x06, 0x00, 0x00000001, PPC_ALTIVEC); | |
| 6557 | - | |
| 6558 | 6441 | static void gen_lvsl(DisasContext *ctx) |
| 6559 | 6442 | { |
| 6560 | 6443 | TCGv_ptr rd; |
| ... | ... | @@ -6571,8 +6454,6 @@ static void gen_lvsl(DisasContext *ctx) |
| 6571 | 6454 | tcg_temp_free_ptr(rd); |
| 6572 | 6455 | } |
| 6573 | 6456 | |
| 6574 | -GEN_HANDLER(lvsr, 0x1f, 0x06, 0x01, 0x00000001, PPC_ALTIVEC); | |
| 6575 | - | |
| 6576 | 6457 | static void gen_lvsr(DisasContext *ctx) |
| 6577 | 6458 | { |
| 6578 | 6459 | TCGv_ptr rd; |
| ... | ... | @@ -6589,8 +6470,6 @@ static void gen_lvsr(DisasContext *ctx) |
| 6589 | 6470 | tcg_temp_free_ptr(rd); |
| 6590 | 6471 | } |
| 6591 | 6472 | |
| 6592 | -GEN_HANDLER(mfvscr, 0x04, 0x2, 0x18, 0x001ff800, PPC_ALTIVEC); | |
| 6593 | - | |
| 6594 | 6473 | static void gen_mfvscr(DisasContext *ctx) |
| 6595 | 6474 | { |
| 6596 | 6475 | TCGv_i32 t; |
| ... | ... | @@ -6605,8 +6484,6 @@ static void gen_mfvscr(DisasContext *ctx) |
| 6605 | 6484 | tcg_temp_free_i32(t); |
| 6606 | 6485 | } |
| 6607 | 6486 | |
| 6608 | -GEN_HANDLER(mtvscr, 0x04, 0x2, 0x19, 0x03ff0000, PPC_ALTIVEC); | |
| 6609 | - | |
| 6610 | 6487 | static void gen_mtvscr(DisasContext *ctx) |
| 6611 | 6488 | { |
| 6612 | 6489 | TCGv_ptr p; |
| ... | ... | @@ -6881,8 +6758,6 @@ GEN_VXFORM_UIMM(vcfsx, 5, 13); |
| 6881 | 6758 | GEN_VXFORM_UIMM(vctuxs, 5, 14); |
| 6882 | 6759 | GEN_VXFORM_UIMM(vctsxs, 5, 15); |
| 6883 | 6760 | |
| 6884 | -GEN_HANDLER(vsldoi, 0x04, 0x16, 0xFF, 0x00000400, PPC_ALTIVEC); | |
| 6885 | - | |
| 6886 | 6761 | static void gen_vsldoi(DisasContext *ctx) |
| 6887 | 6762 | { |
| 6888 | 6763 | TCGv_ptr ra, rb, rd; |
| ... | ... | @@ -6929,8 +6804,6 @@ static void glue(gen_, name0##_##name1)(DisasContext *ctx) |
| 6929 | 6804 | |
| 6930 | 6805 | GEN_VAFORM_PAIRED(vmhaddshs, vmhraddshs, 16) |
| 6931 | 6806 | |
| 6932 | -GEN_HANDLER(vmladduhm, 0x04, 0x11, 0xFF, 0x00000000, PPC_ALTIVEC); | |
| 6933 | - | |
| 6934 | 6807 | static void gen_vmladduhm(DisasContext *ctx) |
| 6935 | 6808 | { |
| 6936 | 6809 | TCGv_ptr ra, rb, rc, rd; |
| ... | ... | @@ -7517,25 +7390,21 @@ static always_inline void gen_evsel (DisasContext *ctx) |
| 7517 | 7390 | tcg_temp_free(t2); |
| 7518 | 7391 | #endif |
| 7519 | 7392 | } |
| 7520 | -GEN_HANDLER2(evsel0, "evsel", 0x04, 0x1c, 0x09, 0x00000000, PPC_SPE); | |
| 7521 | 7393 | |
| 7522 | 7394 | static void gen_evsel0(DisasContext *ctx) |
| 7523 | 7395 | { |
| 7524 | 7396 | gen_evsel(ctx); |
| 7525 | 7397 | } |
| 7526 | -GEN_HANDLER2(evsel1, "evsel", 0x04, 0x1d, 0x09, 0x00000000, PPC_SPE); | |
| 7527 | 7398 | |
| 7528 | 7399 | static void gen_evsel1(DisasContext *ctx) |
| 7529 | 7400 | { |
| 7530 | 7401 | gen_evsel(ctx); |
| 7531 | 7402 | } |
| 7532 | -GEN_HANDLER2(evsel2, "evsel", 0x04, 0x1e, 0x09, 0x00000000, PPC_SPE); | |
| 7533 | 7403 | |
| 7534 | 7404 | static void gen_evsel2(DisasContext *ctx) |
| 7535 | 7405 | { |
| 7536 | 7406 | gen_evsel(ctx); |
| 7537 | 7407 | } |
| 7538 | -GEN_HANDLER2(evsel3, "evsel", 0x04, 0x1f, 0x09, 0x00000000, PPC_SPE); | |
| 7539 | 7408 | |
| 7540 | 7409 | static void gen_evsel3(DisasContext *ctx) |
| 7541 | 7410 | { | ... | ... |