OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // A Disassembler object is used to disassemble a block of code instruction by | 5 // A Disassembler object is used to disassemble a block of code instruction by |
6 // instruction. The default implementation of the NameConverter object can be | 6 // instruction. The default implementation of the NameConverter object can be |
7 // overriden to modify register names or to do symbol lookup on addresses. | 7 // overriden to modify register names or to do symbol lookup on addresses. |
8 // | 8 // |
9 // The example below will disassemble a block of code and print it to stdout. | 9 // The example below will disassemble a block of code and print it to stdout. |
10 // | 10 // |
(...skipping 596 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
607 break; | 607 break; |
608 case FLOOR_L_D: | 608 case FLOOR_L_D: |
609 Format(instr, "floor.l.'t 'fd, 'fs"); | 609 Format(instr, "floor.l.'t 'fd, 'fs"); |
610 break; | 610 break; |
611 case CEIL_W_D: | 611 case CEIL_W_D: |
612 Format(instr, "ceil.w.'t 'fd, 'fs"); | 612 Format(instr, "ceil.w.'t 'fd, 'fs"); |
613 break; | 613 break; |
614 case CEIL_L_D: | 614 case CEIL_L_D: |
615 Format(instr, "ceil.l.'t 'fd, 'fs"); | 615 Format(instr, "ceil.l.'t 'fd, 'fs"); |
616 break; | 616 break; |
| 617 case CLASS_D: |
| 618 Format(instr, "class.'t 'fd, 'fs"); |
| 619 break; |
617 case CVT_S_D: | 620 case CVT_S_D: |
618 Format(instr, "cvt.s.'t 'fd, 'fs"); | 621 Format(instr, "cvt.s.'t 'fd, 'fs"); |
619 break; | 622 break; |
620 case C_F_D: | 623 case C_F_D: |
621 Format(instr, "c.f.'t 'fs, 'ft, 'Cc"); | 624 Format(instr, "c.f.'t 'fs, 'ft, 'Cc"); |
622 break; | 625 break; |
623 case C_UN_D: | 626 case C_UN_D: |
624 Format(instr, "c.un.'t 'fs, 'ft, 'Cc"); | 627 Format(instr, "c.un.'t 'fs, 'ft, 'Cc"); |
625 break; | 628 break; |
626 case C_EQ_D: | 629 case C_EQ_D: |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
670 | 673 |
671 | 674 |
672 void Decoder::DecodeTypeRegisterLRsType(Instruction* instr) { | 675 void Decoder::DecodeTypeRegisterLRsType(Instruction* instr) { |
673 switch (instr->FunctionFieldRaw()) { | 676 switch (instr->FunctionFieldRaw()) { |
674 case CVT_D_L: | 677 case CVT_D_L: |
675 Format(instr, "cvt.d.l 'fd, 'fs"); | 678 Format(instr, "cvt.d.l 'fd, 'fs"); |
676 break; | 679 break; |
677 case CVT_S_L: | 680 case CVT_S_L: |
678 Format(instr, "cvt.s.l 'fd, 'fs"); | 681 Format(instr, "cvt.s.l 'fd, 'fs"); |
679 break; | 682 break; |
| 683 case CMP_AF: |
| 684 Format(instr, "cmp.af.d 'fd, 'fs, 'ft"); |
| 685 break; |
680 case CMP_UN: | 686 case CMP_UN: |
681 Format(instr, "cmp.un.d 'fd, 'fs, 'ft"); | 687 Format(instr, "cmp.un.d 'fd, 'fs, 'ft"); |
682 break; | 688 break; |
683 case CMP_EQ: | 689 case CMP_EQ: |
684 Format(instr, "cmp.eq.d 'fd, 'fs, 'ft"); | 690 Format(instr, "cmp.eq.d 'fd, 'fs, 'ft"); |
685 break; | 691 break; |
686 case CMP_UEQ: | 692 case CMP_UEQ: |
687 Format(instr, "cmp.ueq.d 'fd, 'fs, 'ft"); | 693 Format(instr, "cmp.ueq.d 'fd, 'fs, 'ft"); |
688 break; | 694 break; |
689 case CMP_LT: | 695 case CMP_LT: |
(...skipping 432 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1122 break; | 1128 break; |
1123 } | 1129 } |
1124 case EXT: { | 1130 case EXT: { |
1125 Format(instr, "ext 'rt, 'rs, 'sa, 'ss1"); | 1131 Format(instr, "ext 'rt, 'rs, 'sa, 'ss1"); |
1126 break; | 1132 break; |
1127 } | 1133 } |
1128 case DEXT: { | 1134 case DEXT: { |
1129 Format(instr, "dext 'rt, 'rs, 'sa, 'ss1"); | 1135 Format(instr, "dext 'rt, 'rs, 'sa, 'ss1"); |
1130 break; | 1136 break; |
1131 } | 1137 } |
| 1138 case BITSWAP: { |
| 1139 Format(instr, "bitswap 'rd, 'rt"); |
| 1140 break; |
| 1141 } |
| 1142 case DBITSWAP: { |
| 1143 switch (instr->SaFieldRaw()) { |
| 1144 case DBITSWAP_SA: |
| 1145 Format(instr, "dbitswap 'rd, 'rt"); |
| 1146 break; |
| 1147 default: |
| 1148 UNREACHABLE(); |
| 1149 } |
| 1150 break; |
| 1151 } |
1132 default: | 1152 default: |
1133 UNREACHABLE(); | 1153 UNREACHABLE(); |
1134 } | 1154 } |
1135 } | 1155 } |
1136 | 1156 |
1137 | 1157 |
1138 int Decoder::DecodeTypeRegister(Instruction* instr) { | 1158 int Decoder::DecodeTypeRegister(Instruction* instr) { |
1139 switch (instr->OpcodeFieldRaw()) { | 1159 switch (instr->OpcodeFieldRaw()) { |
1140 case COP1: // Coprocessor instructions. | 1160 case COP1: // Coprocessor instructions. |
1141 DecodeTypeRegisterCOP1(instr); | 1161 DecodeTypeRegisterCOP1(instr); |
(...skipping 421 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1563 prev_pc, *reinterpret_cast<int32_t*>(prev_pc), buffer.start()); | 1583 prev_pc, *reinterpret_cast<int32_t*>(prev_pc), buffer.start()); |
1564 } | 1584 } |
1565 } | 1585 } |
1566 | 1586 |
1567 | 1587 |
1568 #undef UNSUPPORTED | 1588 #undef UNSUPPORTED |
1569 | 1589 |
1570 } // namespace disasm | 1590 } // namespace disasm |
1571 | 1591 |
1572 #endif // V8_TARGET_ARCH_MIPS64 | 1592 #endif // V8_TARGET_ARCH_MIPS64 |
OLD | NEW |