OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/disassembler.h" | 5 #include "vm/disassembler.h" |
6 | 6 |
7 #include "vm/globals.h" // Needed here to get TARGET_ARCH_IA32. | 7 #include "vm/globals.h" // Needed here to get TARGET_ARCH_IA32. |
8 #if defined(TARGET_ARCH_IA32) | 8 #if defined(TARGET_ARCH_IA32) |
9 #include "platform/utils.h" | 9 #include "platform/utils.h" |
10 #include "vm/allocation.h" | 10 #include "vm/allocation.h" |
(...skipping 742 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
753 uint8_t cond = *(data + 1) & 0x0F; | 753 uint8_t cond = *(data + 1) & 0x0F; |
754 const char* mnem = conditional_move_mnem[cond]; | 754 const char* mnem = conditional_move_mnem[cond]; |
755 int op_size = PrintOperands(mnem, REG_OPER_OP_ORDER, data + 2); | 755 int op_size = PrintOperands(mnem, REG_OPER_OP_ORDER, data + 2); |
756 return 2 + op_size; // includes 0x0F | 756 return 2 + op_size; // includes 0x0F |
757 } | 757 } |
758 | 758 |
759 | 759 |
760 int X86Decoder::D1D3C1Instruction(uint8_t* data) { | 760 int X86Decoder::D1D3C1Instruction(uint8_t* data) { |
761 uint8_t op = *data; | 761 uint8_t op = *data; |
762 ASSERT(op == 0xD1 || op == 0xD3 || op == 0xC1); | 762 ASSERT(op == 0xD1 || op == 0xD3 || op == 0xC1); |
763 uint8_t modrm = *(data+1); | |
764 int mod, regop, rm; | 763 int mod, regop, rm; |
765 GetModRm(modrm, &mod, ®op, &rm); | 764 GetModRm(*(data+1), &mod, ®op, &rm); |
766 int imm8 = -1; | 765 int num_bytes = 1; |
767 int num_bytes = 2; | 766 const char* mnem = NULL; |
768 if (mod == 3) { | 767 switch (regop) { |
769 const char* mnem = NULL; | 768 case 2: mnem = "rcl"; break; |
770 if (op == 0xD1) { | 769 case 4: mnem = "shl"; break; |
771 imm8 = 1; | 770 case 5: mnem = "shr"; break; |
772 switch (regop) { | 771 case 7: mnem = "sar"; break; |
773 case edx: mnem = "rcl"; break; | 772 default: UNIMPLEMENTED(); |
774 case edi: mnem = "sar"; break; | 773 } |
775 case esp: mnem = "shl"; break; | 774 ASSERT(mnem != NULL); |
776 case ebp: mnem = "shr"; break; | 775 Print(mnem); |
777 default: UNIMPLEMENTED(); | 776 Print(" "); |
778 } | 777 |
779 } else if (op == 0xC1) { | 778 if (op == 0xD1) { |
780 imm8 = *(data+2); | 779 num_bytes += PrintRightOperand(data+1); |
781 num_bytes = 3; | 780 Print(", 1"); |
782 switch (regop) { | 781 } else if (op == 0xC1) { |
783 case edx: mnem = "rcl"; break; | 782 num_bytes += PrintRightOperand(data+1); |
784 case esp: mnem = "shl"; break; | 783 Print(", "); |
785 case ebp: mnem = "shr"; break; | 784 PrintInt(*(data+2)); |
786 case edi: mnem = "sar"; break; | 785 num_bytes++; |
787 default: UNIMPLEMENTED(); | |
788 } | |
789 } else if (op == 0xD3) { | |
790 switch (regop) { | |
791 case esp: mnem = "shl"; break; | |
792 case ebp: mnem = "shr"; break; | |
793 case edi: mnem = "sar"; break; | |
794 default: UNIMPLEMENTED(); | |
795 } | |
796 } | |
797 ASSERT(mnem != NULL); | |
798 Print(mnem); | |
799 Print(" "); | |
800 PrintCPURegister(rm); | |
801 Print(","); | |
802 if (imm8 > 0) { | |
803 PrintInt(imm8); | |
804 } else { | |
805 Print("cl"); | |
806 } | |
807 } else { | 786 } else { |
808 UNIMPLEMENTED(); | 787 ASSERT(op == 0xD3); |
| 788 num_bytes += PrintRightOperand(data+1); |
| 789 Print(", cl"); |
809 } | 790 } |
810 return num_bytes; | 791 return num_bytes; |
811 } | 792 } |
812 | 793 |
813 | 794 |
814 uint8_t* X86Decoder::F3Instruction(uint8_t* data) { | 795 uint8_t* X86Decoder::F3Instruction(uint8_t* data) { |
815 if (*(data+1) == 0x0F) { | 796 if (*(data+1) == 0x0F) { |
816 uint8_t b2 = *(data+2); | 797 uint8_t b2 = *(data+2); |
817 switch (b2) { | 798 switch (b2) { |
818 case 0x2C: { | 799 case 0x2C: { |
(...skipping 510 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1329 } else { | 1310 } else { |
1330 UNIMPLEMENTED(); | 1311 UNIMPLEMENTED(); |
1331 } | 1312 } |
1332 } else { | 1313 } else { |
1333 data += 2; | 1314 data += 2; |
1334 if (f0byte == 0xAB || f0byte == 0xA5 || f0byte == 0xAD) { | 1315 if (f0byte == 0xAB || f0byte == 0xA5 || f0byte == 0xAD) { |
1335 // shrd, shld, bts | 1316 // shrd, shld, bts |
1336 Print(f0mnem); | 1317 Print(f0mnem); |
1337 int mod, regop, rm; | 1318 int mod, regop, rm; |
1338 GetModRm(*data, &mod, ®op, &rm); | 1319 GetModRm(*data, &mod, ®op, &rm); |
| 1320 Print(" "); |
1339 data += PrintRightOperand(data); | 1321 data += PrintRightOperand(data); |
1340 if (f0byte == 0xAB) { | 1322 if (f0byte == 0xAB) { |
1341 Print(","); | 1323 Print(","); |
1342 PrintCPURegister(regop); | 1324 PrintCPURegister(regop); |
1343 } else { | 1325 } else { |
1344 Print(","); | 1326 Print(","); |
1345 PrintCPURegister(regop); | 1327 PrintCPURegister(regop); |
1346 Print(",cl"); | 1328 Print(",cl"); |
1347 } | 1329 } |
1348 } else if (f0byte == 0x28) { | 1330 } else if (f0byte == 0x28) { |
(...skipping 369 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1718 human_buffer, | 1700 human_buffer, |
1719 sizeof(human_buffer), | 1701 sizeof(human_buffer), |
1720 pc); | 1702 pc); |
1721 pc += instruction_length; | 1703 pc += instruction_length; |
1722 } | 1704 } |
1723 } | 1705 } |
1724 | 1706 |
1725 } // namespace dart | 1707 } // namespace dart |
1726 | 1708 |
1727 #endif // defined TARGET_ARCH_IA32 | 1709 #endif // defined TARGET_ARCH_IA32 |
OLD | NEW |