///////////////////////////////////////////////////////////////////////// // $Id$ ///////////////////////////////////////////////////////////////////////// // // Copyright (c) 2017-2023 Stanislav Shwartsman // Written by Stanislav Shwartsman [sshwarts at sourceforge net] // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA B 02110-1301 USA // ///////////////////////////////////////////////////////////////////////// #ifndef BX_FETCHDECODE_OPMAP_H #define BX_FETCHDECODE_OPMAP_H // opcode 00 static const Bit64u BxOpcodeTable00[] = { last_opcode_lockable(0, BX_IA_ADD_EbGb) }; // opcode 01 static const Bit64u BxOpcodeTable01[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_ADD_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_ADD_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_ADD_EwGw) }; // opcode 02 static const Bit64u BxOpcodeTable02[] = { last_opcode(0, BX_IA_ADD_GbEb) }; // opcode 03 static const Bit64u BxOpcodeTable03[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_ADD_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_ADD_GdEd), last_opcode(ATTR_OS16, BX_IA_ADD_GwEw) }; // opcode 04 static const Bit64u BxOpcodeTable04[] = { last_opcode(0, BX_IA_ADD_ALIb) }; // opcode 05 static const Bit64u BxOpcodeTable05[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_ADD_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_ADD_EAXId), last_opcode(ATTR_OS16, BX_IA_ADD_AXIw) }; // opcode 06 static const Bit64u BxOpcodeTable06[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSH_Op32_Sw), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_PUSH_Op16_Sw) }; // opcode 07 static const Bit64u BxOpcodeTable07[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_POP_Op32_Sw), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_POP_Op16_Sw) }; // opcode 08 static const Bit64u BxOpcodeTable08[] = { last_opcode_lockable(0, BX_IA_OR_EbGb) }; // opcode 09 static const Bit64u BxOpcodeTable09[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_OR_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_OR_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_OR_EwGw) }; // opcode 0A static const Bit64u BxOpcodeTable0A[] = { last_opcode(0, BX_IA_OR_GbEb) }; // opcode 0B static const Bit64u BxOpcodeTable0B[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_OR_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_OR_GdEd), last_opcode(ATTR_OS16, BX_IA_OR_GwEw) }; // opcode 0C static const Bit64u BxOpcodeTable0C[] = { last_opcode(0, BX_IA_OR_ALIb) }; // opcode 0D static const Bit64u BxOpcodeTable0D[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_OR_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_OR_EAXId), last_opcode(ATTR_OS16, BX_IA_OR_AXIw) }; // opcode 0E static const Bit64u BxOpcodeTable0E[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSH_Op32_Sw), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_PUSH_Op16_Sw) }; // opcode 10 static const Bit64u BxOpcodeTable10[] = { last_opcode_lockable(0, BX_IA_ADC_EbGb) }; // opcode 11 static const Bit64u BxOpcodeTable11[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_ADC_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_ADC_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_ADC_EwGw) }; // opcode 12 static const Bit64u BxOpcodeTable12[] = { last_opcode(0, BX_IA_ADC_GbEb) }; // opcode 13 static const Bit64u BxOpcodeTable13[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_ADC_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_ADC_GdEd), last_opcode(ATTR_OS16, BX_IA_ADC_GwEw) }; // opcode 14 static const Bit64u BxOpcodeTable14[] = { last_opcode(0, BX_IA_ADC_ALIb) }; // opcode 15 static const Bit64u BxOpcodeTable15[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_ADC_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_ADC_EAXId), last_opcode(ATTR_OS16, BX_IA_ADC_AXIw) }; // opcode 16 static const Bit64u BxOpcodeTable16[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSH_Op32_Sw), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_PUSH_Op16_Sw) }; // opcode 17 static const Bit64u BxOpcodeTable17[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_POP_Op32_Sw), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_POP_Op16_Sw) }; // opcode 18 static const Bit64u BxOpcodeTable18[] = { last_opcode_lockable(0, BX_IA_SBB_EbGb) }; // opcode 19 static const Bit64u BxOpcodeTable19[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_SBB_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_SBB_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_SBB_EwGw) }; // opcode 1A static const Bit64u BxOpcodeTable1A[] = { last_opcode(0, BX_IA_SBB_GbEb) }; // opcode 1B static const Bit64u BxOpcodeTable1B[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SBB_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_SBB_GdEd), last_opcode(ATTR_OS16, BX_IA_SBB_GwEw) }; // opcode 1C static const Bit64u BxOpcodeTable1C[] = { last_opcode(0, BX_IA_SBB_ALIb) }; // opcode 1D static const Bit64u BxOpcodeTable1D[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SBB_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_SBB_EAXId), last_opcode(ATTR_OS16, BX_IA_SBB_AXIw) }; // opcode 1E static const Bit64u BxOpcodeTable1E[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSH_Op32_Sw), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_PUSH_Op16_Sw) }; // opcode 1F static const Bit64u BxOpcodeTable1F[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_POP_Op32_Sw), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_POP_Op16_Sw) }; // opcode 20 static const Bit64u BxOpcodeTable20[] = { last_opcode_lockable(0, BX_IA_AND_EbGb) }; // opcode 21 static const Bit64u BxOpcodeTable21[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_AND_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_AND_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_AND_EwGw) }; // opcode 22 static const Bit64u BxOpcodeTable22[] = { last_opcode(0, BX_IA_AND_GbEb) }; // opcode 23 static const Bit64u BxOpcodeTable23[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_AND_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_AND_GdEd), last_opcode(ATTR_OS16, BX_IA_AND_GwEw) }; // opcode 24 static const Bit64u BxOpcodeTable24[] = { last_opcode(0, BX_IA_AND_ALIb) }; // opcode 25 static const Bit64u BxOpcodeTable25[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_AND_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_AND_EAXId), last_opcode(ATTR_OS16, BX_IA_AND_AXIw) }; // opcode 27 static const Bit64u BxOpcodeTable27[] = { last_opcode(0, BX_IA_DAA) }; // opcode 28 static const Bit64u BxOpcodeTable28[] = { last_opcode_lockable(0, BX_IA_SUB_EbGb) }; // opcode 29 static const Bit64u BxOpcodeTable29[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_SRC_EQ_DST, BX_IA_SUB_EqGq_ZERO_IDIOM), #endif form_opcode(ATTR_OS32 | ATTR_SRC_EQ_DST, BX_IA_SUB_EdGd_ZERO_IDIOM), form_opcode(ATTR_OS16 | ATTR_SRC_EQ_DST, BX_IA_SUB_EwGw_ZERO_IDIOM), #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_SUB_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_SUB_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_SUB_EwGw) }; // opcode 2A static const Bit64u BxOpcodeTable2A[] = { last_opcode(0, BX_IA_SUB_GbEb) }; // opcode 2B static const Bit64u BxOpcodeTable2B[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_SRC_EQ_DST, BX_IA_SUB_GqEq_ZERO_IDIOM), #endif form_opcode(ATTR_OS32 | ATTR_SRC_EQ_DST, BX_IA_SUB_GdEd_ZERO_IDIOM), form_opcode(ATTR_OS16 | ATTR_SRC_EQ_DST, BX_IA_SUB_GwEw_ZERO_IDIOM), #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SUB_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_SUB_GdEd), last_opcode(ATTR_OS16, BX_IA_SUB_GwEw) }; // opcode 2C static const Bit64u BxOpcodeTable2C[] = { last_opcode(0, BX_IA_SUB_ALIb) }; // opcode 2D static const Bit64u BxOpcodeTable2D[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SUB_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_SUB_EAXId), last_opcode(ATTR_OS16, BX_IA_SUB_AXIw) }; // opcode 2F static const Bit64u BxOpcodeTable2F[] = { last_opcode(0, BX_IA_DAS) }; // opcode 30 static const Bit64u BxOpcodeTable30[] = { last_opcode_lockable(0, BX_IA_XOR_EbGb) }; // opcode 31 static const Bit64u BxOpcodeTable31[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_SRC_EQ_DST, BX_IA_XOR_EqGq_ZERO_IDIOM), #endif form_opcode(ATTR_OS32 | ATTR_SRC_EQ_DST, BX_IA_XOR_EdGd_ZERO_IDIOM), form_opcode(ATTR_OS16 | ATTR_SRC_EQ_DST, BX_IA_XOR_EwGw_ZERO_IDIOM), #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_XOR_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_XOR_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_XOR_EwGw) }; // opcode 32 static const Bit64u BxOpcodeTable32[] = { last_opcode(0, BX_IA_XOR_GbEb) }; // opcode 33 static const Bit64u BxOpcodeTable33[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_SRC_EQ_DST, BX_IA_XOR_GqEq_ZERO_IDIOM), #endif form_opcode(ATTR_OS32 | ATTR_SRC_EQ_DST, BX_IA_XOR_GdEd_ZERO_IDIOM), form_opcode(ATTR_OS16 | ATTR_SRC_EQ_DST, BX_IA_XOR_GwEw_ZERO_IDIOM), #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_XOR_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_XOR_GdEd), last_opcode(ATTR_OS16, BX_IA_XOR_GwEw) }; // opcode 34 static const Bit64u BxOpcodeTable34[] = { last_opcode(0, BX_IA_XOR_ALIb) }; // opcode 35 static const Bit64u BxOpcodeTable35[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_XOR_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_XOR_EAXId), last_opcode(ATTR_OS16, BX_IA_XOR_AXIw) }; // opcode 37 static const Bit64u BxOpcodeTable37[] = { last_opcode(0, BX_IA_AAA) }; // opcode 38 static const Bit64u BxOpcodeTable38[] = { last_opcode(0, BX_IA_CMP_EbGb) }; // opcode 39 static const Bit64u BxOpcodeTable39[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMP_EqGq), #endif form_opcode(ATTR_OS32, BX_IA_CMP_EdGd), last_opcode(ATTR_OS16, BX_IA_CMP_EwGw) }; // opcode 3A static const Bit64u BxOpcodeTable3A[] = { last_opcode(0, BX_IA_CMP_GbEb) }; // opcode 3B static const Bit64u BxOpcodeTable3B[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMP_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMP_GdEd), last_opcode(ATTR_OS16, BX_IA_CMP_GwEw) }; // opcode 3C static const Bit64u BxOpcodeTable3C[] = { last_opcode(0, BX_IA_CMP_ALIb) }; // opcode 3D static const Bit64u BxOpcodeTable3D[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMP_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_CMP_EAXId), last_opcode(ATTR_OS16, BX_IA_CMP_AXIw) }; // opcode 3F static const Bit64u BxOpcodeTable3F[] = { last_opcode(0, BX_IA_AAS) }; // opcode 40 - 47 static const Bit64u BxOpcodeTable40x47[] = { form_opcode_lockable(ATTR_OS32 | ATTR_IS32, BX_IA_INC_Ed), last_opcode_lockable(ATTR_OS16 | ATTR_IS32, BX_IA_INC_Ew) }; // opcode 48 - 4F static const Bit64u BxOpcodeTable48x4F[] = { form_opcode_lockable(ATTR_OS32 | ATTR_IS32, BX_IA_DEC_Ed), last_opcode_lockable(ATTR_OS16 | ATTR_IS32, BX_IA_DEC_Ew) }; // opcode 50 - 57 static const Bit64u BxOpcodeTable50x57[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS32_64 | ATTR_IS64, BX_IA_PUSH_Eq), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSH_Ed), last_opcode(ATTR_OS16, BX_IA_PUSH_Ew) }; // opcode 58 - 5F static const Bit64u BxOpcodeTable58x5F[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS32_64 | ATTR_IS64, BX_IA_POP_Eq), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_POP_Ed), last_opcode(ATTR_OS16, BX_IA_POP_Ew) }; // opcode 60 static const Bit64u BxOpcodeTable60[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSHA_Op32), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_PUSHA_Op16) }; // opcode 61 static const Bit64u BxOpcodeTable61[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_POPA_Op32), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_POPA_Op16) }; // opcode 62 - EVEX prefix static const Bit64u BxOpcodeTable62[] = { form_opcode(ATTR_OS32 | ATTR_MOD_MEM | ATTR_IS32, BX_IA_BOUND_GdMa), last_opcode(ATTR_OS16 | ATTR_MOD_MEM | ATTR_IS32, BX_IA_BOUND_GwMa) }; // opcode 63 static const Bit64u BxOpcodeTable63_32[] = { last_opcode(ATTR_OS16_32, BX_IA_ARPL_EwGw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable63_64[] = { form_opcode(ATTR_OS64, BX_IA_MOVSXD_GqEd), form_opcode(ATTR_OS32, BX_IA_MOV_Op64_GdEd), // MOVSX_GdEd last_opcode(ATTR_OS16, BX_IA_MOV_GwEw) // MOVSX_GwEw }; #endif // opcode 68 static const Bit64u BxOpcodeTable68[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS32_64 | ATTR_IS64, BX_IA_PUSH_Op64_Id), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSH_Id), last_opcode(ATTR_OS16, BX_IA_PUSH_Iw) }; // opcode 69 static const Bit64u BxOpcodeTable69[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_IMUL_GqEqId), #endif form_opcode(ATTR_OS32, BX_IA_IMUL_GdEdId), last_opcode(ATTR_OS16, BX_IA_IMUL_GwEwIw) }; // opcode 6A static const Bit64u BxOpcodeTable6A[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS32_64 | ATTR_IS64, BX_IA_PUSH_Op64_sIb), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSH_sIb32), // imm8 sign extended to 32-bit last_opcode(ATTR_OS16, BX_IA_PUSH_sIb16) // imm8 sign extended to 16-bit }; // opcode 6B static const Bit64u BxOpcodeTable6B[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_IMUL_GqEqsIb), #endif form_opcode(ATTR_OS32, BX_IA_IMUL_GdEdsIb), last_opcode(ATTR_OS16, BX_IA_IMUL_GwEwsIb) }; // opcode 6C static const Bit64u BxOpcodeTable6C[] = { last_opcode(0, BX_IA_REP_INSB_YbDX) }; // opcode 6D static const Bit64u BxOpcodeTable6D[] = { form_opcode(ATTR_OS32_64, BX_IA_REP_INSD_YdDX), last_opcode(ATTR_OS16, BX_IA_REP_INSW_YwDX) }; // opcode 6E static const Bit64u BxOpcodeTable6E[] = { last_opcode(0, BX_IA_REP_OUTSB_DXXb) }; // opcode 6F static const Bit64u BxOpcodeTable6F[] = { form_opcode(ATTR_OS32_64, BX_IA_REP_OUTSD_DXXd), last_opcode(ATTR_OS16, BX_IA_REP_OUTSW_DXXw) }; // opcode 70 static const Bit64u BxOpcodeTable70_32[] = { form_opcode(ATTR_OS32, BX_IA_JO_Jbd), last_opcode(ATTR_OS16, BX_IA_JO_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable70_64[] = { last_opcode(0, BX_IA_JO_Jbq) }; #endif // opcode 71 static const Bit64u BxOpcodeTable71_32[] = { form_opcode(ATTR_OS32, BX_IA_JNO_Jbd), last_opcode(ATTR_OS16, BX_IA_JNO_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable71_64[] = { last_opcode(0, BX_IA_JNO_Jbq) }; #endif // opcode 72 static const Bit64u BxOpcodeTable72_32[] = { form_opcode(ATTR_OS32, BX_IA_JB_Jbd), last_opcode(ATTR_OS16, BX_IA_JB_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable72_64[] = { last_opcode(0, BX_IA_JB_Jbq) }; #endif // opcode 73 static const Bit64u BxOpcodeTable73_32[] = { form_opcode(ATTR_OS32, BX_IA_JNB_Jbd), last_opcode(ATTR_OS16, BX_IA_JNB_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable73_64[] = { last_opcode(0, BX_IA_JNB_Jbq) }; #endif // opcode 74 static const Bit64u BxOpcodeTable74_32[] = { form_opcode(ATTR_OS32, BX_IA_JZ_Jbd), last_opcode(ATTR_OS16, BX_IA_JZ_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable74_64[] = { last_opcode(0, BX_IA_JZ_Jbq) }; #endif // opcode 75 static const Bit64u BxOpcodeTable75_32[] = { form_opcode(ATTR_OS32, BX_IA_JNZ_Jbd), last_opcode(ATTR_OS16, BX_IA_JNZ_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable75_64[] = { last_opcode(0, BX_IA_JNZ_Jbq) }; #endif // opcode 76 static const Bit64u BxOpcodeTable76_32[] = { form_opcode(ATTR_OS32, BX_IA_JBE_Jbd), last_opcode(ATTR_OS16, BX_IA_JBE_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable76_64[] = { last_opcode(0, BX_IA_JBE_Jbq) }; #endif // opcode 77 static const Bit64u BxOpcodeTable77_32[] = { form_opcode(ATTR_OS32, BX_IA_JNBE_Jbd), last_opcode(ATTR_OS16, BX_IA_JNBE_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable77_64[] = { last_opcode(0, BX_IA_JNBE_Jbq) }; #endif // opcode 78 static const Bit64u BxOpcodeTable78_32[] = { form_opcode(ATTR_OS32, BX_IA_JS_Jbd), last_opcode(ATTR_OS16, BX_IA_JS_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable78_64[] = { last_opcode(0, BX_IA_JS_Jbq) }; #endif // opcode 79 static const Bit64u BxOpcodeTable79_32[] = { form_opcode(ATTR_OS32, BX_IA_JNS_Jbd), last_opcode(ATTR_OS16, BX_IA_JNS_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable79_64[] = { last_opcode(0, BX_IA_JNS_Jbq) }; #endif // opcode 7A static const Bit64u BxOpcodeTable7A_32[] = { form_opcode(ATTR_OS32, BX_IA_JP_Jbd), last_opcode(ATTR_OS16, BX_IA_JP_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable7A_64[] = { last_opcode(0, BX_IA_JP_Jbq) }; #endif // opcode 7B static const Bit64u BxOpcodeTable7B_32[] = { form_opcode(ATTR_OS32, BX_IA_JNP_Jbd), last_opcode(ATTR_OS16, BX_IA_JNP_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable7B_64[] = { last_opcode(0, BX_IA_JNP_Jbq) }; #endif // opcode 7C static const Bit64u BxOpcodeTable7C_32[] = { form_opcode(ATTR_OS32, BX_IA_JL_Jbd), last_opcode(ATTR_OS16, BX_IA_JL_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable7C_64[] = { last_opcode(0, BX_IA_JL_Jbq) }; #endif // opcode 7D static const Bit64u BxOpcodeTable7D_32[] = { form_opcode(ATTR_OS32, BX_IA_JNL_Jbd), last_opcode(ATTR_OS16, BX_IA_JNL_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable7D_64[] = { last_opcode(0, BX_IA_JNL_Jbq) }; #endif // opcode 7E static const Bit64u BxOpcodeTable7E_32[] = { form_opcode(ATTR_OS32, BX_IA_JLE_Jbd), last_opcode(ATTR_OS16, BX_IA_JLE_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable7E_64[] = { last_opcode(0, BX_IA_JLE_Jbq) }; #endif // opcode 7F static const Bit64u BxOpcodeTable7F_32[] = { form_opcode(ATTR_OS32, BX_IA_JNLE_Jbd), last_opcode(ATTR_OS16, BX_IA_JNLE_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable7F_64[] = { last_opcode(0, BX_IA_JNLE_Jbq) }; #endif // opcode 80 static const Bit64u BxOpcodeTable80[] = { form_opcode_lockable(ATTR_NNN0, BX_IA_ADD_EbIb), form_opcode_lockable(ATTR_NNN1, BX_IA_OR_EbIb), form_opcode_lockable(ATTR_NNN2, BX_IA_ADC_EbIb), form_opcode_lockable(ATTR_NNN3, BX_IA_SBB_EbIb), form_opcode_lockable(ATTR_NNN4, BX_IA_AND_EbIb), form_opcode_lockable(ATTR_NNN5, BX_IA_SUB_EbIb), form_opcode_lockable(ATTR_NNN6, BX_IA_XOR_EbIb), last_opcode(ATTR_NNN7, BX_IA_CMP_EbIb) }; // opcode 81 static const Bit64u BxOpcodeTable81[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_NNN0 | ATTR_OS64, BX_IA_ADD_EqId), form_opcode_lockable(ATTR_NNN1 | ATTR_OS64, BX_IA_OR_EqId), form_opcode_lockable(ATTR_NNN2 | ATTR_OS64, BX_IA_ADC_EqId), form_opcode_lockable(ATTR_NNN3 | ATTR_OS64, BX_IA_SBB_EqId), form_opcode_lockable(ATTR_NNN4 | ATTR_OS64, BX_IA_AND_EqId), form_opcode_lockable(ATTR_NNN5 | ATTR_OS64, BX_IA_SUB_EqId), form_opcode_lockable(ATTR_NNN6 | ATTR_OS64, BX_IA_XOR_EqId), form_opcode(ATTR_NNN7 | ATTR_OS64, BX_IA_CMP_EqId), #endif form_opcode_lockable(ATTR_NNN0 | ATTR_OS32, BX_IA_ADD_EdId), form_opcode_lockable(ATTR_NNN1 | ATTR_OS32, BX_IA_OR_EdId), form_opcode_lockable(ATTR_NNN2 | ATTR_OS32, BX_IA_ADC_EdId), form_opcode_lockable(ATTR_NNN3 | ATTR_OS32, BX_IA_SBB_EdId), form_opcode_lockable(ATTR_NNN4 | ATTR_OS32, BX_IA_AND_EdId), form_opcode_lockable(ATTR_NNN5 | ATTR_OS32, BX_IA_SUB_EdId), form_opcode_lockable(ATTR_NNN6 | ATTR_OS32, BX_IA_XOR_EdId), form_opcode(ATTR_NNN7 | ATTR_OS32, BX_IA_CMP_EdId), form_opcode_lockable(ATTR_NNN0 | ATTR_OS16, BX_IA_ADD_EwIw), form_opcode_lockable(ATTR_NNN1 | ATTR_OS16, BX_IA_OR_EwIw), form_opcode_lockable(ATTR_NNN2 | ATTR_OS16, BX_IA_ADC_EwIw), form_opcode_lockable(ATTR_NNN3 | ATTR_OS16, BX_IA_SBB_EwIw), form_opcode_lockable(ATTR_NNN4 | ATTR_OS16, BX_IA_AND_EwIw), form_opcode_lockable(ATTR_NNN5 | ATTR_OS16, BX_IA_SUB_EwIw), form_opcode_lockable(ATTR_NNN6 | ATTR_OS16, BX_IA_XOR_EwIw), last_opcode(ATTR_NNN7 | ATTR_OS16, BX_IA_CMP_EwIw) }; // opcode 83 static const Bit64u BxOpcodeTable83[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_NNN0 | ATTR_OS64, BX_IA_ADD_EqsIb), form_opcode_lockable(ATTR_NNN1 | ATTR_OS64, BX_IA_OR_EqsIb), form_opcode_lockable(ATTR_NNN2 | ATTR_OS64, BX_IA_ADC_EqsIb), form_opcode_lockable(ATTR_NNN3 | ATTR_OS64, BX_IA_SBB_EqsIb), form_opcode_lockable(ATTR_NNN4 | ATTR_OS64, BX_IA_AND_EqsIb), form_opcode_lockable(ATTR_NNN5 | ATTR_OS64, BX_IA_SUB_EqsIb), form_opcode_lockable(ATTR_NNN6 | ATTR_OS64, BX_IA_XOR_EqsIb), form_opcode(ATTR_NNN7 | ATTR_OS64, BX_IA_CMP_EqsIb), #endif form_opcode_lockable(ATTR_NNN0 | ATTR_OS32, BX_IA_ADD_EdsIb), form_opcode_lockable(ATTR_NNN1 | ATTR_OS32, BX_IA_OR_EdsIb), form_opcode_lockable(ATTR_NNN2 | ATTR_OS32, BX_IA_ADC_EdsIb), form_opcode_lockable(ATTR_NNN3 | ATTR_OS32, BX_IA_SBB_EdsIb), form_opcode_lockable(ATTR_NNN4 | ATTR_OS32, BX_IA_AND_EdsIb), form_opcode_lockable(ATTR_NNN5 | ATTR_OS32, BX_IA_SUB_EdsIb), form_opcode_lockable(ATTR_NNN6 | ATTR_OS32, BX_IA_XOR_EdsIb), form_opcode(ATTR_NNN7 | ATTR_OS32, BX_IA_CMP_EdsIb), form_opcode_lockable(ATTR_NNN0 | ATTR_OS16, BX_IA_ADD_EwsIb), form_opcode_lockable(ATTR_NNN1 | ATTR_OS16, BX_IA_OR_EwsIb), form_opcode_lockable(ATTR_NNN2 | ATTR_OS16, BX_IA_ADC_EwsIb), form_opcode_lockable(ATTR_NNN3 | ATTR_OS16, BX_IA_SBB_EwsIb), form_opcode_lockable(ATTR_NNN4 | ATTR_OS16, BX_IA_AND_EwsIb), form_opcode_lockable(ATTR_NNN5 | ATTR_OS16, BX_IA_SUB_EwsIb), form_opcode_lockable(ATTR_NNN6 | ATTR_OS16, BX_IA_XOR_EwsIb), last_opcode(ATTR_NNN7 | ATTR_OS16, BX_IA_CMP_EwsIb) }; // opcode 84 static const Bit64u BxOpcodeTable84[] = { last_opcode(0, BX_IA_TEST_EbGb) }; // opcode 85 static const Bit64u BxOpcodeTable85[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_TEST_EqGq), #endif form_opcode(ATTR_OS32, BX_IA_TEST_EdGd), last_opcode(ATTR_OS16, BX_IA_TEST_EwGw) }; // opcode 86 static const Bit64u BxOpcodeTable86[] = { last_opcode_lockable(0, BX_IA_XCHG_EbGb) }; // opcode 87 static const Bit64u BxOpcodeTable87[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_XCHG_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_XCHG_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_XCHG_EwGw) }; // opcode 88 static const Bit64u BxOpcodeTable88[] = { last_opcode(0, BX_IA_MOV_EbGb) }; // opcode 89 - split for better emulation performance static const Bit64u BxOpcodeTable89[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_MOV_EqGq), form_opcode(ATTR_OS32 | ATTR_IS64, BX_IA_MOV_Op64_EdGd), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_MOV_Op32_EdGd), last_opcode(ATTR_OS16, BX_IA_MOV_EwGw) }; // opcode 8A static const Bit64u BxOpcodeTable8A[] = { last_opcode(0, BX_IA_MOV_GbEb) }; // opcode 8B - split for better emulation performance static const Bit64u BxOpcodeTable8B[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_MOV_GqEq), form_opcode(ATTR_OS32 | ATTR_IS64, BX_IA_MOV_Op64_GdEd), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_MOV_Op32_GdEd), last_opcode(ATTR_OS16, BX_IA_MOV_GwEw) }; // opcode 8C static const Bit64u BxOpcodeTable8C[] = { last_opcode(0, BX_IA_MOV_EwSw) }; // opcode 8D static const Bit64u BxOpcodeTable8D[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_MOD_MEM, BX_IA_LEA_GqM), #endif form_opcode(ATTR_OS32 | ATTR_MOD_MEM, BX_IA_LEA_GdM), last_opcode(ATTR_OS16 | ATTR_MOD_MEM, BX_IA_LEA_GwM) }; // opcode 8E static const Bit64u BxOpcodeTable8E[] = { last_opcode(0, BX_IA_MOV_SwEw) }; // opcode 8F - XOP prefix static const Bit64u BxOpcodeTable8F[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_IS64 | ATTR_OS32_64 | ATTR_NNN0, BX_IA_POP_Eq), #endif form_opcode(ATTR_IS32 | ATTR_OS32 | ATTR_NNN0, BX_IA_POP_Ed), last_opcode(ATTR_OS16 | ATTR_NNN0, BX_IA_POP_Ew) }; // opcode 90 - 97 static const Bit64u BxOpcodeTable90x97[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_XCHG_RRXRAX), // handles also XCHG R8, RAX #endif form_opcode(ATTR_OS32, BX_IA_XCHG_ERXEAX), // handles also XCHG R8d, EAX last_opcode(ATTR_OS16, BX_IA_XCHG_RXAX) // handles also XCHG R8w, AX }; // opcode 98 static const Bit64u BxOpcodeTable98[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CDQE), #endif form_opcode(ATTR_OS32, BX_IA_CWDE), last_opcode(ATTR_OS16, BX_IA_CBW) }; // opcode 99 static const Bit64u BxOpcodeTable99[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CQO), #endif form_opcode(ATTR_OS32, BX_IA_CDQ), last_opcode(ATTR_OS16, BX_IA_CWD) }; // opcode 9A static const Bit64u BxOpcodeTable9A[] = { form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_CALLF_Op32_Ap), last_opcode(ATTR_OS16 | ATTR_IS32, BX_IA_CALLF_Op16_Ap) }; // opcode 9B static const Bit64u BxOpcodeTable9B[] = { last_opcode(0, BX_IA_FWAIT) }; // opcode 9C static const Bit64u BxOpcodeTable9C[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS32_64 | ATTR_IS64, BX_IA_PUSHF_Fq), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_PUSHF_Fd), last_opcode(ATTR_OS16, BX_IA_PUSHF_Fw) }; // opcode 9D static const Bit64u BxOpcodeTable9D[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS32_64 | ATTR_IS64, BX_IA_POPF_Fq), #endif form_opcode(ATTR_OS32 | ATTR_IS32, BX_IA_POPF_Fd), last_opcode(ATTR_OS16, BX_IA_POPF_Fw) }; // opcode 9E static const Bit64u BxOpcodeTable9E_32[] = { last_opcode(0, BX_IA_SAHF) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable9E_64[] = { last_opcode(0, BX_IA_SAHF_LM) }; #endif // opcode 9F static const Bit64u BxOpcodeTable9F_32[] = { last_opcode(0, BX_IA_LAHF) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable9F_64[] = { last_opcode(0, BX_IA_LAHF_LM) }; #endif // opcode A0 static const Bit64u BxOpcodeTableA0_32[] = { last_opcode(0, BX_IA_MOV_ALOd) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableA0_64[] = { last_opcode(0, BX_IA_MOV_ALOq) }; #endif // opcode A1 static const Bit64u BxOpcodeTableA1_32[] = { form_opcode(ATTR_OS32, BX_IA_MOV_EAXOd), last_opcode(ATTR_OS16, BX_IA_MOV_AXOd) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableA1_64[] = { form_opcode(ATTR_OS64, BX_IA_MOV_RAXOq), form_opcode(ATTR_OS32, BX_IA_MOV_EAXOq), last_opcode(ATTR_OS16, BX_IA_MOV_AXOq) }; #endif // opcode A2 static const Bit64u BxOpcodeTableA2_32[] = { last_opcode(0, BX_IA_MOV_OdAL) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableA2_64[] = { last_opcode(0, BX_IA_MOV_OqAL) }; #endif // opcode A3 static const Bit64u BxOpcodeTableA3_32[] = { form_opcode(ATTR_OS32, BX_IA_MOV_OdEAX), last_opcode(ATTR_OS16, BX_IA_MOV_OdAX) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableA3_64[] = { form_opcode(ATTR_OS64, BX_IA_MOV_OqRAX), form_opcode(ATTR_OS32, BX_IA_MOV_OqEAX), last_opcode(ATTR_OS16, BX_IA_MOV_OqAX) }; #endif // opcode A4 static const Bit64u BxOpcodeTableA4[] = { last_opcode(0, BX_IA_REP_MOVSB_YbXb) }; // opcode A5 static const Bit64u BxOpcodeTableA5[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_REP_MOVSQ_YqXq), #endif form_opcode(ATTR_OS32, BX_IA_REP_MOVSD_YdXd), last_opcode(ATTR_OS16, BX_IA_REP_MOVSW_YwXw) }; // opcode A6 static const Bit64u BxOpcodeTableA6[] = { last_opcode(0, BX_IA_REP_CMPSB_XbYb) }; // opcode A7 static const Bit64u BxOpcodeTableA7[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_REP_CMPSQ_XqYq), #endif form_opcode(ATTR_OS32, BX_IA_REP_CMPSD_XdYd), last_opcode(ATTR_OS16, BX_IA_REP_CMPSW_XwYw) }; // opcode A8 static const Bit64u BxOpcodeTableA8[] = { last_opcode(0, BX_IA_TEST_ALIb) }; // opcode A9 static const Bit64u BxOpcodeTableA9[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_TEST_RAXId), #endif form_opcode(ATTR_OS32, BX_IA_TEST_EAXId), last_opcode(ATTR_OS16, BX_IA_TEST_AXIw) }; // opcode AA static const Bit64u BxOpcodeTableAA[] = { last_opcode(0, BX_IA_REP_STOSB_YbAL) }; // opcode AB static const Bit64u BxOpcodeTableAB[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_REP_STOSQ_YqRAX), #endif form_opcode(ATTR_OS32, BX_IA_REP_STOSD_YdEAX), last_opcode(ATTR_OS16, BX_IA_REP_STOSW_YwAX) }; // opcode AC static const Bit64u BxOpcodeTableAC[] = { last_opcode(0, BX_IA_REP_LODSB_ALXb) }; // opcode AD static const Bit64u BxOpcodeTableAD[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_REP_LODSQ_RAXXq), #endif form_opcode(ATTR_OS32, BX_IA_REP_LODSD_EAXXd), last_opcode(ATTR_OS16, BX_IA_REP_LODSW_AXXw) }; // opcode AE static const Bit64u BxOpcodeTableAE[] = { last_opcode(0, BX_IA_REP_SCASB_ALYb) }; // opcode AF static const Bit64u BxOpcodeTableAF[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_REP_SCASQ_RAXYq), #endif form_opcode(ATTR_OS32, BX_IA_REP_SCASD_EAXYd), last_opcode(ATTR_OS16, BX_IA_REP_SCASW_AXYw) }; // opcode B0 - B7 static const Bit64u BxOpcodeTableB0xB7[] = { last_opcode(0, BX_IA_MOV_EbIb) }; // opcode B8 - BF static const Bit64u BxOpcodeTableB8xBF[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_MOV_RRXIq), #endif form_opcode(ATTR_OS32, BX_IA_MOV_EdId), last_opcode(ATTR_OS16, BX_IA_MOV_EwIw) }; // opcode D0 static const Bit64u BxOpcodeTableC0[] = { form_opcode(ATTR_NNN0, BX_IA_ROL_EbIb), form_opcode(ATTR_NNN1, BX_IA_ROR_EbIb), form_opcode(ATTR_NNN2, BX_IA_RCL_EbIb), form_opcode(ATTR_NNN3, BX_IA_RCR_EbIb), form_opcode(ATTR_NNN4, BX_IA_SHL_EbIb), form_opcode(ATTR_NNN5, BX_IA_SHR_EbIb), form_opcode(ATTR_NNN6, BX_IA_SHL_EbIb), last_opcode(ATTR_NNN7, BX_IA_SAR_EbIb) }; // opcode C1 static const Bit64u BxOpcodeTableC1[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN0 | ATTR_OS64, BX_IA_ROL_EqIb), form_opcode(ATTR_NNN1 | ATTR_OS64, BX_IA_ROR_EqIb), form_opcode(ATTR_NNN2 | ATTR_OS64, BX_IA_RCL_EqIb), form_opcode(ATTR_NNN3 | ATTR_OS64, BX_IA_RCR_EqIb), form_opcode(ATTR_NNN4 | ATTR_OS64, BX_IA_SHL_EqIb), form_opcode(ATTR_NNN5 | ATTR_OS64, BX_IA_SHR_EqIb), form_opcode(ATTR_NNN6 | ATTR_OS64, BX_IA_SHL_EqIb), form_opcode(ATTR_NNN7 | ATTR_OS64, BX_IA_SAR_EqIb), #endif form_opcode(ATTR_NNN0 | ATTR_OS32, BX_IA_ROL_EdIb), form_opcode(ATTR_NNN1 | ATTR_OS32, BX_IA_ROR_EdIb), form_opcode(ATTR_NNN2 | ATTR_OS32, BX_IA_RCL_EdIb), form_opcode(ATTR_NNN3 | ATTR_OS32, BX_IA_RCR_EdIb), form_opcode(ATTR_NNN4 | ATTR_OS32, BX_IA_SHL_EdIb), form_opcode(ATTR_NNN5 | ATTR_OS32, BX_IA_SHR_EdIb), form_opcode(ATTR_NNN6 | ATTR_OS32, BX_IA_SHL_EdIb), form_opcode(ATTR_NNN7 | ATTR_OS32, BX_IA_SAR_EdIb), form_opcode(ATTR_NNN0 | ATTR_OS16, BX_IA_ROL_EwIb), form_opcode(ATTR_NNN1 | ATTR_OS16, BX_IA_ROR_EwIb), form_opcode(ATTR_NNN2 | ATTR_OS16, BX_IA_RCL_EwIb), form_opcode(ATTR_NNN3 | ATTR_OS16, BX_IA_RCR_EwIb), form_opcode(ATTR_NNN4 | ATTR_OS16, BX_IA_SHL_EwIb), form_opcode(ATTR_NNN5 | ATTR_OS16, BX_IA_SHR_EwIb), form_opcode(ATTR_NNN6 | ATTR_OS16, BX_IA_SHL_EwIb), last_opcode(ATTR_NNN7 | ATTR_OS16, BX_IA_SAR_EwIb) }; // opcode C2 static const Bit64u BxOpcodeTableC2_32[] = { form_opcode(ATTR_OS32, BX_IA_RET_Op32_Iw), last_opcode(ATTR_OS16, BX_IA_RET_Op16_Iw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableC2_64[] = { last_opcode(0, BX_IA_RET_Op64_Iw) }; #endif // opcode C3 static const Bit64u BxOpcodeTableC3_32[] = { form_opcode(ATTR_OS32, BX_IA_RET_Op32), last_opcode(ATTR_OS16, BX_IA_RET_Op16) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableC3_64[] = { last_opcode(0, BX_IA_RET_Op64) }; #endif // opcode C4 - VEX prefix static const Bit64u BxOpcodeTableC4_32[] = { form_opcode(ATTR_OS32 | ATTR_MOD_MEM | ATTR_IS32, BX_IA_LES_GdMp), last_opcode(ATTR_OS16 | ATTR_MOD_MEM | ATTR_IS32, BX_IA_LES_GwMp) }; // opcode C5 - VEX prefix static const Bit64u BxOpcodeTableC5_32[] = { form_opcode(ATTR_OS32 | ATTR_MOD_MEM | ATTR_IS32, BX_IA_LDS_GdMp), last_opcode(ATTR_OS16 | ATTR_MOD_MEM | ATTR_IS32, BX_IA_LDS_GwMp) }; // opcode C6 static const Bit64u BxOpcodeTableC6[] = { last_opcode(ATTR_NNN0, BX_IA_MOV_EbIb) }; // opcode C7 static const Bit64u BxOpcodeTableC7[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN0 | ATTR_OS64, BX_IA_MOV_EqId), #endif form_opcode(ATTR_NNN0 | ATTR_OS32, BX_IA_MOV_EdId), last_opcode(ATTR_NNN0 | ATTR_OS16, BX_IA_MOV_EwIw) }; // opcode C8 static const Bit64u BxOpcodeTableC8_32[] = { form_opcode(ATTR_OS32, BX_IA_ENTER_Op32_IwIb), last_opcode(ATTR_OS16, BX_IA_ENTER_Op16_IwIb) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableC8_64[] = { last_opcode(0, BX_IA_ENTER_Op64_IwIb) }; #endif // opcode C9 static const Bit64u BxOpcodeTableC9_32[] = { form_opcode(ATTR_OS32, BX_IA_LEAVE_Op32), last_opcode(ATTR_OS16, BX_IA_LEAVE_Op16) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableC9_64[] = { last_opcode(0, BX_IA_LEAVE_Op64) }; #endif // opcode CA static const Bit64u BxOpcodeTableCA[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_RETF_Op64_Iw), #endif form_opcode(ATTR_OS32, BX_IA_RETF_Op32_Iw), last_opcode(ATTR_OS16, BX_IA_RETF_Op16_Iw) }; // opcode CB static const Bit64u BxOpcodeTableCB[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_RETF_Op64), #endif form_opcode(ATTR_OS32, BX_IA_RETF_Op32), last_opcode(ATTR_OS16, BX_IA_RETF_Op16) }; // opcode CC static const Bit64u BxOpcodeTableCC[] = { last_opcode(0, BX_IA_INT3) }; // opcode CD static const Bit64u BxOpcodeTableCD[] = { last_opcode_lockable(0, BX_IA_INT_Ib) }; // opcode CE static const Bit64u BxOpcodeTableCE[] = { last_opcode(0, BX_IA_INTO) }; // opcode CF static const Bit64u BxOpcodeTableCF_32[] = { form_opcode(ATTR_OS32, BX_IA_IRET_Op32), last_opcode(ATTR_OS16, BX_IA_IRET_Op16) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableCF_64[] = { last_opcode(0, BX_IA_IRET_Op64) }; #endif // opcode D0 static const Bit64u BxOpcodeTableD0[] = { form_opcode(ATTR_NNN0, BX_IA_ROL_EbI1), form_opcode(ATTR_NNN1, BX_IA_ROR_EbI1), form_opcode(ATTR_NNN2, BX_IA_RCL_EbI1), form_opcode(ATTR_NNN3, BX_IA_RCR_EbI1), form_opcode(ATTR_NNN4, BX_IA_SHL_EbI1), form_opcode(ATTR_NNN5, BX_IA_SHR_EbI1), form_opcode(ATTR_NNN6, BX_IA_SHL_EbI1), last_opcode(ATTR_NNN7, BX_IA_SAR_EbI1) }; // opcode D1 static const Bit64u BxOpcodeTableD1[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN0 | ATTR_OS64, BX_IA_ROL_EqI1), form_opcode(ATTR_NNN1 | ATTR_OS64, BX_IA_ROR_EqI1), form_opcode(ATTR_NNN2 | ATTR_OS64, BX_IA_RCL_EqI1), form_opcode(ATTR_NNN3 | ATTR_OS64, BX_IA_RCR_EqI1), form_opcode(ATTR_NNN4 | ATTR_OS64, BX_IA_SHL_EqI1), form_opcode(ATTR_NNN5 | ATTR_OS64, BX_IA_SHR_EqI1), form_opcode(ATTR_NNN6 | ATTR_OS64, BX_IA_SHL_EqI1), form_opcode(ATTR_NNN7 | ATTR_OS64, BX_IA_SAR_EqI1), #endif form_opcode(ATTR_NNN0 | ATTR_OS32, BX_IA_ROL_EdI1), form_opcode(ATTR_NNN1 | ATTR_OS32, BX_IA_ROR_EdI1), form_opcode(ATTR_NNN2 | ATTR_OS32, BX_IA_RCL_EdI1), form_opcode(ATTR_NNN3 | ATTR_OS32, BX_IA_RCR_EdI1), form_opcode(ATTR_NNN4 | ATTR_OS32, BX_IA_SHL_EdI1), form_opcode(ATTR_NNN5 | ATTR_OS32, BX_IA_SHR_EdI1), form_opcode(ATTR_NNN6 | ATTR_OS32, BX_IA_SHL_EdI1), form_opcode(ATTR_NNN7 | ATTR_OS32, BX_IA_SAR_EdI1), form_opcode(ATTR_NNN0 | ATTR_OS16, BX_IA_ROL_EwI1), form_opcode(ATTR_NNN1 | ATTR_OS16, BX_IA_ROR_EwI1), form_opcode(ATTR_NNN2 | ATTR_OS16, BX_IA_RCL_EwI1), form_opcode(ATTR_NNN3 | ATTR_OS16, BX_IA_RCR_EwI1), form_opcode(ATTR_NNN4 | ATTR_OS16, BX_IA_SHL_EwI1), form_opcode(ATTR_NNN5 | ATTR_OS16, BX_IA_SHR_EwI1), form_opcode(ATTR_NNN6 | ATTR_OS16, BX_IA_SHL_EwI1), last_opcode(ATTR_NNN7 | ATTR_OS16, BX_IA_SAR_EwI1) }; // opcode D2 static const Bit64u BxOpcodeTableD2[] = { form_opcode(ATTR_NNN0, BX_IA_ROL_Eb), form_opcode(ATTR_NNN1, BX_IA_ROR_Eb), form_opcode(ATTR_NNN2, BX_IA_RCL_Eb), form_opcode(ATTR_NNN3, BX_IA_RCR_Eb), form_opcode(ATTR_NNN4, BX_IA_SHL_Eb), form_opcode(ATTR_NNN5, BX_IA_SHR_Eb), form_opcode(ATTR_NNN6, BX_IA_SHL_Eb), last_opcode(ATTR_NNN7, BX_IA_SAR_Eb) }; // opcode D3 static const Bit64u BxOpcodeTableD3[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN0 | ATTR_OS64, BX_IA_ROL_Eq), form_opcode(ATTR_NNN1 | ATTR_OS64, BX_IA_ROR_Eq), form_opcode(ATTR_NNN2 | ATTR_OS64, BX_IA_RCL_Eq), form_opcode(ATTR_NNN3 | ATTR_OS64, BX_IA_RCR_Eq), form_opcode(ATTR_NNN4 | ATTR_OS64, BX_IA_SHL_Eq), form_opcode(ATTR_NNN5 | ATTR_OS64, BX_IA_SHR_Eq), form_opcode(ATTR_NNN6 | ATTR_OS64, BX_IA_SHL_Eq), form_opcode(ATTR_NNN7 | ATTR_OS64, BX_IA_SAR_Eq), #endif form_opcode(ATTR_NNN0 | ATTR_OS32, BX_IA_ROL_Ed), form_opcode(ATTR_NNN1 | ATTR_OS32, BX_IA_ROR_Ed), form_opcode(ATTR_NNN2 | ATTR_OS32, BX_IA_RCL_Ed), form_opcode(ATTR_NNN3 | ATTR_OS32, BX_IA_RCR_Ed), form_opcode(ATTR_NNN4 | ATTR_OS32, BX_IA_SHL_Ed), form_opcode(ATTR_NNN5 | ATTR_OS32, BX_IA_SHR_Ed), form_opcode(ATTR_NNN6 | ATTR_OS32, BX_IA_SHL_Ed), form_opcode(ATTR_NNN7 | ATTR_OS32, BX_IA_SAR_Ed), form_opcode(ATTR_NNN0 | ATTR_OS16, BX_IA_ROL_Ew), form_opcode(ATTR_NNN1 | ATTR_OS16, BX_IA_ROR_Ew), form_opcode(ATTR_NNN2 | ATTR_OS16, BX_IA_RCL_Ew), form_opcode(ATTR_NNN3 | ATTR_OS16, BX_IA_RCR_Ew), form_opcode(ATTR_NNN4 | ATTR_OS16, BX_IA_SHL_Ew), form_opcode(ATTR_NNN5 | ATTR_OS16, BX_IA_SHR_Ew), form_opcode(ATTR_NNN6 | ATTR_OS16, BX_IA_SHL_Ew), last_opcode(ATTR_NNN7 | ATTR_OS16, BX_IA_SAR_Ew) }; // opcode D4 static const Bit64u BxOpcodeTableD4[] = { last_opcode(ATTR_IS32, BX_IA_AAM) }; // opcode D5 static const Bit64u BxOpcodeTableD5[] = { last_opcode(ATTR_IS32, BX_IA_AAD) }; // opcode D6 static const Bit64u BxOpcodeTableD6[] = { last_opcode(0, BX_IA_SALC) }; // opcode D7 static const Bit64u BxOpcodeTableD7[] = { last_opcode(0, BX_IA_XLAT) }; // opcode E0 static const Bit64u BxOpcodeTableE0_32[] = { form_opcode(ATTR_IS32 | ATTR_OS32, BX_IA_LOOPNE_Jbd), last_opcode(ATTR_IS32 | ATTR_OS16, BX_IA_LOOPNE_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableE0_64[] = { last_opcode(ATTR_IS64, BX_IA_LOOPNE_Jbq) }; #endif // opcode E1 static const Bit64u BxOpcodeTableE1_32[] = { form_opcode(ATTR_IS32 | ATTR_OS32, BX_IA_LOOPE_Jbd), last_opcode(ATTR_IS32 | ATTR_OS16, BX_IA_LOOPE_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableE1_64[] = { last_opcode(ATTR_IS64, BX_IA_LOOPE_Jbq) }; #endif // opcode E2 static const Bit64u BxOpcodeTableE2_32[] = { form_opcode(ATTR_IS32 | ATTR_OS32, BX_IA_LOOP_Jbd), last_opcode(ATTR_IS32 | ATTR_OS16, BX_IA_LOOP_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableE2_64[] = { last_opcode(ATTR_IS64, BX_IA_LOOP_Jbq) }; #endif // opcode E3 static const Bit64u BxOpcodeTableE3_32[] = { form_opcode(ATTR_OS32, BX_IA_JECXZ_Jbd), last_opcode(ATTR_OS16, BX_IA_JCXZ_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableE3_64[] = { last_opcode(ATTR_IS64, BX_IA_JRCXZ_Jbq) }; #endif // opcode E4 static const Bit64u BxOpcodeTableE4[] = { last_opcode(0, BX_IA_IN_ALIb) }; // opcode E5 static const Bit64u BxOpcodeTableE5[] = { form_opcode(ATTR_OS32_64, BX_IA_IN_EAXIb), last_opcode(ATTR_OS16, BX_IA_IN_AXIb) }; // opcode E6 static const Bit64u BxOpcodeTableE6[] = { last_opcode(0, BX_IA_OUT_IbAL) }; // opcode E7 static const Bit64u BxOpcodeTableE7[] = { form_opcode(ATTR_OS32_64, BX_IA_OUT_IbEAX), last_opcode(ATTR_OS16, BX_IA_OUT_IbAX) }; // opcode E8 static const Bit64u BxOpcodeTableE8_32[] = { form_opcode(ATTR_OS32, BX_IA_CALL_Jd), last_opcode(ATTR_OS16, BX_IA_CALL_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableE8_64[] = { last_opcode(0, BX_IA_CALL_Jq) }; #endif // opcode E9 static const Bit64u BxOpcodeTableE9_32[] = { form_opcode(ATTR_OS32, BX_IA_JMP_Jd), last_opcode(ATTR_OS16, BX_IA_JMP_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableE9_64[] = { last_opcode(0, BX_IA_JMP_Jq) }; #endif // opcode EA static const Bit64u BxOpcodeTableEA_32[] = { last_opcode(0, BX_IA_JMPF_Ap) }; // opcode EB static const Bit64u BxOpcodeTableEB_32[] = { form_opcode(ATTR_OS32, BX_IA_JMP_Jbd), last_opcode(ATTR_OS16, BX_IA_JMP_Jbw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTableEB_64[] = { last_opcode(0, BX_IA_JMP_Jbq) }; #endif // opcode EC static const Bit64u BxOpcodeTableEC[] = { last_opcode(0, BX_IA_IN_ALDX) }; // opcode ED static const Bit64u BxOpcodeTableED[] = { form_opcode(ATTR_OS32_64, BX_IA_IN_EAXDX), last_opcode(ATTR_OS16, BX_IA_IN_AXDX) }; // opcode EE static const Bit64u BxOpcodeTableEE[] = { last_opcode(0, BX_IA_OUT_DXAL) }; // opcode EF static const Bit64u BxOpcodeTableEF[] = { form_opcode(ATTR_OS32_64, BX_IA_OUT_DXEAX), last_opcode(ATTR_OS16, BX_IA_OUT_DXAX) }; // opcode F1 static const Bit64u BxOpcodeTableF1[] = { last_opcode(0, BX_IA_INT1) }; // opcode F4 static const Bit64u BxOpcodeTableF4[] = { last_opcode(0, BX_IA_HLT) }; // opcode F5 static const Bit64u BxOpcodeTableF5[] = { last_opcode(0, BX_IA_CMC) }; // opcode F6 static const Bit64u BxOpcodeTableF6[] = { form_opcode(ATTR_NNN0, BX_IA_TEST_EbIb), form_opcode(ATTR_NNN1, BX_IA_TEST_EbIb), form_opcode_lockable(ATTR_NNN2, BX_IA_NOT_Eb), form_opcode_lockable(ATTR_NNN3, BX_IA_NEG_Eb), form_opcode(ATTR_NNN4, BX_IA_MUL_ALEb), form_opcode(ATTR_NNN5, BX_IA_IMUL_ALEb), form_opcode(ATTR_NNN6, BX_IA_DIV_ALEb), last_opcode(ATTR_NNN7, BX_IA_IDIV_ALEb) }; // opcode F7 static const Bit64u BxOpcodeTableF7[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN0 | ATTR_OS64, BX_IA_TEST_EqId), form_opcode(ATTR_NNN1 | ATTR_OS64, BX_IA_TEST_EqId), form_opcode_lockable(ATTR_NNN2 | ATTR_OS64, BX_IA_NOT_Eq), form_opcode_lockable(ATTR_NNN3 | ATTR_OS64, BX_IA_NEG_Eq), form_opcode(ATTR_NNN4 | ATTR_OS64, BX_IA_MUL_RAXEq), form_opcode(ATTR_NNN5 | ATTR_OS64, BX_IA_IMUL_RAXEq), form_opcode(ATTR_NNN6 | ATTR_OS64, BX_IA_DIV_RAXEq), form_opcode(ATTR_NNN7 | ATTR_OS64, BX_IA_IDIV_RAXEq), #endif form_opcode(ATTR_NNN0 | ATTR_OS32, BX_IA_TEST_EdId), form_opcode(ATTR_NNN1 | ATTR_OS32, BX_IA_TEST_EdId), form_opcode_lockable(ATTR_NNN2 | ATTR_OS32, BX_IA_NOT_Ed), form_opcode_lockable(ATTR_NNN3 | ATTR_OS32, BX_IA_NEG_Ed), form_opcode(ATTR_NNN4 | ATTR_OS32, BX_IA_MUL_EAXEd), form_opcode(ATTR_NNN5 | ATTR_OS32, BX_IA_IMUL_EAXEd), form_opcode(ATTR_NNN6 | ATTR_OS32, BX_IA_DIV_EAXEd), form_opcode(ATTR_NNN7 | ATTR_OS32, BX_IA_IDIV_EAXEd), form_opcode(ATTR_NNN0 | ATTR_OS16, BX_IA_TEST_EwIw), form_opcode(ATTR_NNN1 | ATTR_OS16, BX_IA_TEST_EwIw), form_opcode_lockable(ATTR_NNN2 | ATTR_OS16, BX_IA_NOT_Ew), form_opcode_lockable(ATTR_NNN3 | ATTR_OS16, BX_IA_NEG_Ew), form_opcode(ATTR_NNN4 | ATTR_OS16, BX_IA_MUL_AXEw), form_opcode(ATTR_NNN5 | ATTR_OS16, BX_IA_IMUL_AXEw), form_opcode(ATTR_NNN6 | ATTR_OS16, BX_IA_DIV_AXEw), last_opcode(ATTR_NNN7 | ATTR_OS16, BX_IA_IDIV_AXEw) }; // opcode F8 static const Bit64u BxOpcodeTableF8[] = { last_opcode(0, BX_IA_CLC) }; // opcode F9 static const Bit64u BxOpcodeTableF9[] = { last_opcode(0, BX_IA_STC) }; // opcode FA static const Bit64u BxOpcodeTableFA[] = { last_opcode(0, BX_IA_CLI) }; // opcode FB static const Bit64u BxOpcodeTableFB[] = { last_opcode(0, BX_IA_STI) }; // opcode FC static const Bit64u BxOpcodeTableFC[] = { last_opcode(0, BX_IA_CLD) }; // opcode FD static const Bit64u BxOpcodeTableFD[] = { last_opcode(0, BX_IA_STD) }; // opcode FE static const Bit64u BxOpcodeTableFE[] = { form_opcode_lockable(ATTR_NNN0, BX_IA_INC_Eb), last_opcode_lockable(ATTR_NNN1, BX_IA_DEC_Eb) }; // opcode FF static const Bit64u BxOpcodeTableFF[] = { //0 #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_NNN0 | ATTR_OS64, BX_IA_INC_Eq), #endif form_opcode_lockable(ATTR_NNN0 | ATTR_OS32, BX_IA_INC_Ed), form_opcode_lockable(ATTR_NNN0 | ATTR_OS16, BX_IA_INC_Ew), //1 #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_NNN1 | ATTR_OS64, BX_IA_DEC_Eq), #endif form_opcode_lockable(ATTR_NNN1 | ATTR_OS32, BX_IA_DEC_Ed), form_opcode_lockable(ATTR_NNN1 | ATTR_OS16, BX_IA_DEC_Ew), //2 #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN2 | ATTR_IS64, BX_IA_CALL_Eq), // regardless of Osize #endif form_opcode(ATTR_NNN2 | ATTR_IS32 | ATTR_OS16, BX_IA_CALL_Ew), form_opcode(ATTR_NNN2 | ATTR_IS32 | ATTR_OS32, BX_IA_CALL_Ed), //3 #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN3 | ATTR_OS64 | ATTR_MOD_MEM, BX_IA_CALLF_Op64_Ep), #endif form_opcode(ATTR_NNN3 | ATTR_OS32 | ATTR_MOD_MEM, BX_IA_CALLF_Op32_Ep), form_opcode(ATTR_NNN3 | ATTR_OS16 | ATTR_MOD_MEM, BX_IA_CALLF_Op16_Ep), //4 #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN4 | ATTR_IS64, BX_IA_JMP_Eq), // regardless of Osize #endif form_opcode(ATTR_NNN4 | ATTR_IS32 | ATTR_OS16, BX_IA_JMP_Ew), form_opcode(ATTR_NNN4 | ATTR_IS32 | ATTR_OS32, BX_IA_JMP_Ed), //5 #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN5 | ATTR_OS64 | ATTR_MOD_MEM, BX_IA_JMPF_Op64_Ep), #endif form_opcode(ATTR_NNN5 | ATTR_OS32 | ATTR_MOD_MEM, BX_IA_JMPF_Op32_Ep), form_opcode(ATTR_NNN5 | ATTR_OS16 | ATTR_MOD_MEM, BX_IA_JMPF_Op16_Ep), //6 #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN6 | ATTR_IS64 | ATTR_OS32_64, BX_IA_PUSH_Eq), #endif form_opcode(ATTR_NNN6 | ATTR_OS32, BX_IA_PUSH_Ed), last_opcode(ATTR_NNN6 | ATTR_OS16, BX_IA_PUSH_Ew) }; // opcode 0F 00 static const Bit64u BxOpcodeTable0F00[] = { form_opcode(ATTR_NNN0, BX_IA_SLDT_Ew), form_opcode(ATTR_NNN1, BX_IA_STR_Ew), form_opcode(ATTR_NNN2, BX_IA_LLDT_Ew), form_opcode(ATTR_NNN3, BX_IA_LTR_Ew), form_opcode(ATTR_NNN4, BX_IA_VERR_Ew), last_opcode(ATTR_NNN5, BX_IA_VERW_Ew) }; // opcode 0F 01 static const Bit64u BxOpcodeTable0F01[] = { form_opcode(ATTR_IS32 | ATTR_MOD_MEM | ATTR_NNN0, BX_IA_SGDT_Ms), form_opcode(ATTR_IS32 | ATTR_MOD_MEM | ATTR_NNN1, BX_IA_SIDT_Ms), form_opcode(ATTR_IS32 | ATTR_MOD_MEM | ATTR_NNN2, BX_IA_LGDT_Ms), form_opcode(ATTR_IS32 | ATTR_MOD_MEM | ATTR_NNN3, BX_IA_LIDT_Ms), #if BX_SUPPORT_X86_64 form_opcode(ATTR_IS64 | ATTR_MOD_MEM | ATTR_NNN0, BX_IA_SGDT_Op64_Ms), form_opcode(ATTR_IS64 | ATTR_MOD_MEM | ATTR_NNN1, BX_IA_SIDT_Op64_Ms), form_opcode(ATTR_IS64 | ATTR_MOD_MEM | ATTR_NNN2, BX_IA_LGDT_Op64_Ms), form_opcode(ATTR_IS64 | ATTR_MOD_MEM | ATTR_NNN3, BX_IA_LIDT_Op64_Ms), #endif form_opcode(ATTR_NNN4, BX_IA_SMSW_Ew), form_opcode(ATTR_NNN6, BX_IA_LMSW_Ew), form_opcode(ATTR_NNN7 | ATTR_MOD_MEM, BX_IA_INVLPG), form_opcode(ATTR_NNN0 | ATTR_RRR1 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_VMCALL), // 0F 01 C1 form_opcode(ATTR_NNN0 | ATTR_RRR2 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_VMLAUNCH), // 0F 01 C2 form_opcode(ATTR_NNN0 | ATTR_RRR3 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_VMRESUME), // 0F 01 C3 form_opcode(ATTR_NNN0 | ATTR_RRR4 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_VMXOFF), // 0F 01 C4 form_opcode(ATTR_NNN0 | ATTR_RRR6 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_WRMSRNS), // 0F 01 C6 #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN0 | ATTR_RRR6 | ATTR_MODC0 | ATTR_SSE_PREFIX_F2 | ATTR_IS64, BX_IA_RDMSRLIST), form_opcode(ATTR_NNN0 | ATTR_RRR6 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3 | ATTR_IS64, BX_IA_WRMSRLIST), #endif form_opcode(ATTR_NNN1 | ATTR_RRR0 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_MONITOR), // 0F 01 C8 form_opcode(ATTR_NNN1 | ATTR_RRR1 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_MWAIT), // 0F 01 C9 form_opcode(ATTR_NNN1 | ATTR_RRR2 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_CLAC), // 0F 01 CA form_opcode(ATTR_NNN1 | ATTR_RRR3 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_STAC), // 0F 01 CB form_opcode(ATTR_NNN2 | ATTR_RRR0 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_XGETBV), // 0F 01 D0 form_opcode(ATTR_NNN2 | ATTR_RRR1 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_XSETBV), // 0F 01 D1 form_opcode(ATTR_NNN2 | ATTR_RRR4 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_VMFUNC), // 0F 01 D4 #if BX_SUPPORT_SVM form_opcode(ATTR_NNN3 | ATTR_RRR0 | ATTR_MODC0, BX_IA_VMRUN), form_opcode(ATTR_NNN3 | ATTR_RRR1 | ATTR_MODC0, BX_IA_VMMCALL), form_opcode(ATTR_NNN3 | ATTR_RRR2 | ATTR_MODC0, BX_IA_VMLOAD), form_opcode(ATTR_NNN3 | ATTR_RRR3 | ATTR_MODC0, BX_IA_VMSAVE), form_opcode(ATTR_NNN3 | ATTR_RRR4 | ATTR_MODC0, BX_IA_STGI), form_opcode(ATTR_NNN3 | ATTR_RRR5 | ATTR_MODC0, BX_IA_CLGI), form_opcode(ATTR_NNN3 | ATTR_RRR6 | ATTR_MODC0, BX_IA_SKINIT), form_opcode(ATTR_NNN3 | ATTR_RRR7 | ATTR_MODC0, BX_IA_INVLPGA), #endif form_opcode(ATTR_NNN5 | ATTR_RRR0 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_SERIALIZE), // 0F 01 E8 #if BX_SUPPORT_CET form_opcode(ATTR_NNN5 | ATTR_RRR0 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_SETSSBSY), // F3 0F 01 E8 form_opcode(ATTR_NNN5 | ATTR_RRR2 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_SAVEPREVSSP), // F3 0F 01 EA form_opcode(ATTR_NNN5 | ATTR_MOD_MEM | ATTR_SSE_PREFIX_F3, BX_IA_RSTORSSP), #endif #if BX_SUPPORT_PKEYS form_opcode(ATTR_NNN5 | ATTR_RRR6 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_RDPKRU), // 0F 01 EE form_opcode(ATTR_NNN5 | ATTR_RRR7 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_WRPKRU), // 0F 01 EF #endif #if BX_SUPPORT_UINTR && BX_SUPPORT_X86_64 form_opcode(ATTR_IS64 | ATTR_NNN5 | ATTR_RRR4 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_UIRET), form_opcode(ATTR_IS64 | ATTR_NNN5 | ATTR_RRR5 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_TESTUI), form_opcode(ATTR_IS64 | ATTR_NNN5 | ATTR_RRR6 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_CLUI), form_opcode(ATTR_IS64 | ATTR_NNN5 | ATTR_RRR7 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_STUI), #endif #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN7 | ATTR_RRR0 | ATTR_MODC0 | ATTR_IS64, BX_IA_SWAPGS), // 0F 01 F8 #endif form_opcode(ATTR_NNN7 | ATTR_RRR1 | ATTR_MODC0, BX_IA_RDTSCP), // 0F 01 F9 form_opcode(ATTR_NNN7 | ATTR_RRR2 | ATTR_MODC0, BX_IA_MONITORX), // 0F 01 FA form_opcode(ATTR_NNN7 | ATTR_RRR3 | ATTR_MODC0, BX_IA_MWAITX), // 0F 01 FB last_opcode(ATTR_NNN7 | ATTR_RRR4 | ATTR_MODC0, BX_IA_CLZERO) // 0F 01 FC }; // opcode 0F 02 static const Bit64u BxOpcodeTable0F02[] = { form_opcode(ATTR_OS32_64, BX_IA_LAR_GdEw), last_opcode(ATTR_OS16, BX_IA_LAR_GwEw) }; // opcode 0F 03 static const Bit64u BxOpcodeTable0F03[] = { form_opcode(ATTR_OS32_64, BX_IA_LSL_GdEw), last_opcode(ATTR_OS16, BX_IA_LSL_GwEw) }; // opcode 0F 05 static const Bit64u BxOpcodeTable0F05_32[] = { last_opcode(0, BX_IA_SYSCALL_LEGACY) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F05_64[] = { last_opcode(0, BX_IA_SYSCALL) }; #endif // opcode 0F 06 static const Bit64u BxOpcodeTable0F06[] = { last_opcode(0, BX_IA_CLTS) }; // opcode 0F 07 static const Bit64u BxOpcodeTable0F07_32[] = { last_opcode(0, BX_IA_SYSRET_LEGACY) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F07_64[] = { last_opcode(0, BX_IA_SYSRET) }; #endif // opcode 0F 08 static const Bit64u BxOpcodeTable0F08[] = { last_opcode(0, BX_IA_INVD) }; // opcode 0F 09 static const Bit64u BxOpcodeTable0F09[] = { last_opcode(0, BX_IA_WBINVD) }; // opcode 0F 0B static const Bit64u BxOpcodeTable0F0B[] = { last_opcode(0, BX_IA_UD2) }; // opcode 0F 0D - 3DNow! PREFETCHW on AMD, NOP on older Intel CPUs static const Bit64u BxOpcodeTable0F0D[] = { last_opcode(0, BX_IA_PREFETCHW_Mb) }; // opcode 0F 0E - 3DNow! FEMMS static const Bit64u BxOpcodeTable0F0E[] = { last_opcode(0, BX_IA_FEMMS) }; // opcode 0F 0F - 3DNow! Opcode Table // opcode 0F 10 static const Bit64u BxOpcodeTable0F10[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVUPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVUPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MOVSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_MOVSD_VsdWsd) }; // opcode 0F 11 static const Bit64u BxOpcodeTable0F11[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVUPS_WpsVps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVUPD_WpdVpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MOVSS_WssVss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_MOVSD_WsdVsd) }; // opcode 0F 12 static const Bit64u BxOpcodeTable0F12[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM, BX_IA_MOVLPS_VpsMq), form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_MOVHLPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66 | ATTR_MOD_MEM, BX_IA_MOVLPD_VsdMq), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MOVSLDUP_VpsWps), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_MOVDDUP_VpdWq) }; // opcode 0F 13 static const Bit64u BxOpcodeTable0F13[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM, BX_IA_MOVLPS_MqVps), last_opcode(ATTR_SSE_PREFIX_66 | ATTR_MOD_MEM, BX_IA_MOVLPD_MqVsd) }; // opcode 0F 14 static const Bit64u BxOpcodeTable0F14[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_UNPCKLPS_VpsWdq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_UNPCKLPD_VpdWdq) }; // opcode 0F 15 static const Bit64u BxOpcodeTable0F15[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_UNPCKHPS_VpsWdq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_UNPCKHPD_VpdWdq) }; // opcode 0F 16 static const Bit64u BxOpcodeTable0F16[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM, BX_IA_MOVHPS_VpsMq), form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_MOVLHPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66 | ATTR_MOD_MEM, BX_IA_MOVHPD_VsdMq), last_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MOVSHDUP_VpsWps) }; // opcode 0F 17 static const Bit64u BxOpcodeTable0F17[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM, BX_IA_MOVHPS_MqVps), last_opcode(ATTR_SSE_PREFIX_66 | ATTR_MOD_MEM, BX_IA_MOVHPD_MqVsd) }; // opcode 0F 18 - opcode group G16, PREFETCH hints #if BX_CPU_LEVEL >= 6 static const Bit64u BxOpcodeTable0F18[] = { form_opcode(ATTR_NNN0, BX_IA_PREFETCHNTA_Mb), form_opcode(ATTR_NNN1, BX_IA_PREFETCHT0_Mb), form_opcode(ATTR_NNN2, BX_IA_PREFETCHT1_Mb), form_opcode(ATTR_NNN3, BX_IA_PREFETCHT2_Mb), last_opcode(0, BX_IA_PREFETCH_Mb) }; #endif // opcode 0F 1E #if BX_SUPPORT_CET static const Bit64u BxOpcodeTable0F1E[] = { form_opcode(ATTR_OS16_32 | ATTR_NNN1 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_RDSSPD), form_opcode(ATTR_OS64 | ATTR_NNN1 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_RDSSPQ), form_opcode(ATTR_NNN7 | ATTR_RRR2 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_ENDBRANCH64), form_opcode(ATTR_NNN7 | ATTR_RRR3 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_ENDBRANCH32), last_opcode(0, BX_IA_NOP) // multi byte-NOP }; #endif // opcode 0F 19 - 0F 1F: multi-byte NOP static const Bit64u BxOpcodeTableMultiByteNOP[] = { last_opcode(0, BX_IA_NOP) }; // opcode 0F 20 static const Bit64u BxOpcodeTable0F20_32[] = { form_opcode(ATTR_NNN0, BX_IA_MOV_RdCR0), form_opcode(ATTR_NNN2, BX_IA_MOV_RdCR2), form_opcode(ATTR_NNN3, BX_IA_MOV_RdCR3), last_opcode(ATTR_NNN4, BX_IA_MOV_RdCR4) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F20_64[] = { form_opcode(ATTR_NNN0, BX_IA_MOV_RqCR0), form_opcode(ATTR_NNN2, BX_IA_MOV_RqCR2), form_opcode(ATTR_NNN3, BX_IA_MOV_RqCR3), last_opcode(ATTR_NNN4, BX_IA_MOV_RqCR4) }; #endif // opcode 0F 21 static const Bit64u BxOpcodeTable0F21_32[] = { last_opcode(0, BX_IA_MOV_RdDd) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F21_64[] = { last_opcode(0, BX_IA_MOV_RqDq) }; #endif // opcode 0F 22 static const Bit64u BxOpcodeTable0F22_32[] = { form_opcode(ATTR_NNN0, BX_IA_MOV_CR0Rd), form_opcode(ATTR_NNN2, BX_IA_MOV_CR2Rd), form_opcode(ATTR_NNN3, BX_IA_MOV_CR3Rd), last_opcode(ATTR_NNN4, BX_IA_MOV_CR4Rd) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F22_64[] = { form_opcode(ATTR_NNN0, BX_IA_MOV_CR0Rq), form_opcode(ATTR_NNN2, BX_IA_MOV_CR2Rq), form_opcode(ATTR_NNN3, BX_IA_MOV_CR3Rq), last_opcode(ATTR_NNN4, BX_IA_MOV_CR4Rq) }; #endif // opcode 0F 23 static const Bit64u BxOpcodeTable0F23_32[] = { last_opcode(0, BX_IA_MOV_DdRd) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F23_64[] = { last_opcode(0, BX_IA_MOV_DqRq) }; #endif // opcode 0F 24 static const Bit64u BxOpcodeTable0F24[] = { last_opcode(0, BX_IA_ERROR) }; // BX_IA_MOV_RdTd not implemented // opcode 0F 26 static const Bit64u BxOpcodeTable0F26[] = { last_opcode(0, BX_IA_ERROR) }; // BX_IA_MOV_TdRd not implemented // opcode 0F 28 static const Bit64u BxOpcodeTable0F28[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVAPS_VpsWps), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVAPD_VpdWpd) }; // opcode 0F 29 static const Bit64u BxOpcodeTable0F29[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVAPS_WpsVps), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVAPD_WpdVpd) }; // opcode 0F 2A static const Bit64u BxOpcodeTable0F2A[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_CVTPI2PS_VpsQq), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_CVTPI2PD_VpdQq), #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_PREFIX_F3 | ATTR_OS64, BX_IA_CVTSI2SS_VssEq), form_opcode(ATTR_SSE_PREFIX_F2 | ATTR_OS64, BX_IA_CVTSI2SD_VsdEq), #endif form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_CVTSI2SS_VssEd), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_CVTSI2SD_VsdEd) }; // opcode 0F 2B static const Bit64u BxOpcodeTable0F2B[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM, BX_IA_MOVNTPS_MpsVps), form_opcode(ATTR_SSE_PREFIX_66 | ATTR_MOD_MEM, BX_IA_MOVNTPD_MpdVpd), form_opcode(ATTR_SSE_PREFIX_F3 | ATTR_MOD_MEM, BX_IA_MOVNTSS_MssVss), last_opcode(ATTR_SSE_PREFIX_F2 | ATTR_MOD_MEM, BX_IA_MOVNTSD_MsdVsd) }; // opcode 0F 2C static const Bit64u BxOpcodeTable0F2C[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_CVTTPS2PI_PqWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_CVTTPD2PI_PqWpd), #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_PREFIX_F3 | ATTR_OS64, BX_IA_CVTTSS2SI_GqWss), form_opcode(ATTR_SSE_PREFIX_F2 | ATTR_OS64, BX_IA_CVTTSD2SI_GqWsd), #endif form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_CVTTSS2SI_GdWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_CVTTSD2SI_GdWsd) }; // opcode 0F 2D static const Bit64u BxOpcodeTable0F2D[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_CVTPS2PI_PqWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_CVTPD2PI_PqWpd), #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_PREFIX_F3 | ATTR_OS64, BX_IA_CVTSS2SI_GqWss), form_opcode(ATTR_SSE_PREFIX_F2 | ATTR_OS64, BX_IA_CVTSD2SI_GqWsd), #endif form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_CVTSS2SI_GdWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_CVTSD2SI_GdWsd) }; // opcode 0F 2E static const Bit64u BxOpcodeTable0F2E[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_UCOMISS_VssWss), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_UCOMISD_VsdWsd) }; // opcode 0F 2F static const Bit64u BxOpcodeTable0F2F[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_COMISS_VssWss), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_COMISD_VsdWsd) }; // opcode 0F 30 static const Bit64u BxOpcodeTable0F30[] = { last_opcode(0, BX_IA_WRMSR) }; // opcode 0F 31 - end trace to avoid multiple TSC samples in one cycle static const Bit64u BxOpcodeTable0F31[] = { last_opcode(0, BX_IA_RDTSC) }; // opcode 0F 32 - end trace to avoid multiple TSC samples in one cycle static const Bit64u BxOpcodeTable0F32[] = { last_opcode(0, BX_IA_RDMSR) }; // opcode 0F 33 static const Bit64u BxOpcodeTable0F33[] = { last_opcode(0, BX_IA_RDPMC) }; // opcode 0F 34 static const Bit64u BxOpcodeTable0F34[] = { last_opcode(0, BX_IA_SYSENTER) }; // opcode 0F 35 static const Bit64u BxOpcodeTable0F35[] = { last_opcode(0, BX_IA_SYSEXIT) }; // opcode 0F 37 static const Bit64u BxOpcodeTable0F37[] = { last_opcode(ATTR_SSE_NO_PREFIX, BX_IA_GETSEC) }; // opcode 0F 40 static const Bit64u BxOpcodeTable0F40[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVO_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVO_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVO_GwEw) }; // opcode 0F 41 static const Bit64u BxOpcodeTable0F41[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNO_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNO_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNO_GwEw) }; // opcode 0F 42 static const Bit64u BxOpcodeTable0F42[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVB_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVB_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVB_GwEw) }; // opcode 0F 43 static const Bit64u BxOpcodeTable0F43[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNB_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNB_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNB_GwEw) }; // opcode 0F 44 static const Bit64u BxOpcodeTable0F44[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVZ_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVZ_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVZ_GwEw) }; // opcode 0F 45 static const Bit64u BxOpcodeTable0F45[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNZ_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNZ_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNZ_GwEw) }; // opcode 0F 46 static const Bit64u BxOpcodeTable0F46[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVBE_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVBE_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVBE_GwEw) }; // opcode 0F 47 static const Bit64u BxOpcodeTable0F47[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNBE_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNBE_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNBE_GwEw) }; // opcode 0F 48 static const Bit64u BxOpcodeTable0F48[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVS_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVS_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVS_GwEw) }; // opcode 0F 49 static const Bit64u BxOpcodeTable0F49[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNS_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNS_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNS_GwEw) }; // opcode 0F 4A static const Bit64u BxOpcodeTable0F4A[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVP_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVP_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVP_GwEw) }; // opcode 0F 4B static const Bit64u BxOpcodeTable0F4B[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNP_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNP_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNP_GwEw) }; // opcode 0F 4C static const Bit64u BxOpcodeTable0F4C[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVL_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVL_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVL_GwEw) }; // opcode 0F 4D static const Bit64u BxOpcodeTable0F4D[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNL_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNL_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNL_GwEw) }; // opcode 0F 4E static const Bit64u BxOpcodeTable0F4E[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVLE_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVLE_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVLE_GwEw) }; // opcode 0F 4F static const Bit64u BxOpcodeTable0F4F[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_CMOVNLE_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_CMOVNLE_GdEd), last_opcode(ATTR_OS16, BX_IA_CMOVNLE_GwEw) }; // opcode 0F 50 static const Bit64u BxOpcodeTable0F50[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_MOVMSKPS_GdUps), last_opcode(ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_MOVMSKPD_GdUpd) }; // opcode 0F 51 static const Bit64u BxOpcodeTable0F51[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_SQRTPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_SQRTPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_SQRTSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_SQRTSD_VsdWsd) }; // opcode 0F 52 static const Bit64u BxOpcodeTable0F52[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_RSQRTPS_VpsWps), last_opcode(ATTR_SSE_PREFIX_F3, BX_IA_RSQRTSS_VssWss) }; // opcode 0F 53 static const Bit64u BxOpcodeTable0F53[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_RCPPS_VpsWps), last_opcode(ATTR_SSE_PREFIX_F3, BX_IA_RCPSS_VssWss) }; // opcode 0F 54 static const Bit64u BxOpcodeTable0F54[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_ANDPS_VpsWps), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_ANDPD_VpdWpd) }; // opcode 0F 55 static const Bit64u BxOpcodeTable0F55[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_ANDNPS_VpsWps), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_ANDNPD_VpdWpd) }; // opcode 0F 56 static const Bit64u BxOpcodeTable0F56[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_ORPS_VpsWps), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_ORPD_VpdWpd) }; // opcode 0F 57 static const Bit64u BxOpcodeTable0F57[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_XORPS_VpsWps), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_XORPD_VpdWpd) }; // opcode 0F 58 static const Bit64u BxOpcodeTable0F58[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_ADDPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_ADDPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_ADDSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_ADDSD_VsdWsd) }; // opcode 0F 59 static const Bit64u BxOpcodeTable0F59[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MULPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MULPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MULSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_MULSD_VsdWsd) }; // opcode 0F 5A static const Bit64u BxOpcodeTable0F5A[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_CVTPS2PD_VpdWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_CVTPD2PS_VpsWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_CVTSS2SD_VsdWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_CVTSD2SS_VssWsd) }; // opcode 0F 5B static const Bit64u BxOpcodeTable0F5B[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_CVTDQ2PS_VpsWdq), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_CVTPS2DQ_VdqWps), last_opcode(ATTR_SSE_PREFIX_F3, BX_IA_CVTTPS2DQ_VdqWps) }; // opcode 0F 5C static const Bit64u BxOpcodeTable0F5C[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_SUBPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_SUBPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_SUBSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_SUBSD_VsdWsd) }; // opcode 0F 5D static const Bit64u BxOpcodeTable0F5D[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MINPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MINPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MINSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_MINSD_VsdWsd) }; // opcode 0F 5E static const Bit64u BxOpcodeTable0F5E[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_DIVPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_DIVPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_DIVSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_DIVSD_VsdWsd) }; // opcode 0F 5F static const Bit64u BxOpcodeTable0F5F[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MAXPS_VpsWps), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MAXPD_VpdWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MAXSS_VssWss), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_MAXSD_VsdWsd) }; // opcode 0F 60 static const Bit64u BxOpcodeTable0F60[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PUNPCKLBW_PqQd), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKLBW_VdqWdq) }; // opcode 0F 61 static const Bit64u BxOpcodeTable0F61[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PUNPCKLWD_PqQd), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKLWD_VdqWdq) }; // opcode 0F 62 static const Bit64u BxOpcodeTable0F62[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PUNPCKLDQ_PqQd), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKLDQ_VdqWdq) }; // opcode 0F 63 static const Bit64u BxOpcodeTable0F63[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PACKSSWB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PACKSSWB_VdqWdq) }; // opcode 0F 64 static const Bit64u BxOpcodeTable0F64[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PCMPGTB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PCMPGTB_VdqWdq) }; // opcode 0F 65 static const Bit64u BxOpcodeTable0F65[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PCMPGTW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PCMPGTW_VdqWdq) }; // opcode 0F 66 static const Bit64u BxOpcodeTable0F66[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PCMPGTD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PCMPGTD_VdqWdq) }; // opcode 0F 67 static const Bit64u BxOpcodeTable0F67[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PACKUSWB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PACKUSWB_VdqWdq) }; // opcode 0F 68 static const Bit64u BxOpcodeTable0F68[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PUNPCKHBW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKHBW_VdqWdq) }; // opcode 0F 69 static const Bit64u BxOpcodeTable0F69[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PUNPCKHWD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKHWD_VdqWdq) }; // opcode 0F 6A static const Bit64u BxOpcodeTable0F6A[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PUNPCKHDQ_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKHDQ_VdqWdq) }; // opcode 0F 6B static const Bit64u BxOpcodeTable0F6B[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PACKSSDW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PACKSSDW_VdqWdq) }; // opcode 0F 6C - 0F 6D static const Bit64u BxOpcodeTable0F6C[] = { last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKLQDQ_VdqWdq) }; static const Bit64u BxOpcodeTable0F6D[] = { last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PUNPCKHQDQ_VdqWdq) }; // opcode 0F 6E static const Bit64u BxOpcodeTable0F6E[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_NO_PREFIX | ATTR_OS64, BX_IA_MOVQ_PqEq), form_opcode(ATTR_SSE_PREFIX_66 | ATTR_OS64, BX_IA_MOVQ_VdqEq), #endif form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVD_PqEd), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVD_VdqEd) }; // opcode 0F 6F static const Bit64u BxOpcodeTable0F6F[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVQ_PqQq), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVDQA_VdqWdq), last_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MOVDQU_VdqWdq) }; // opcode 0F 70 static const Bit64u BxOpcodeTable0F70[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSHUFW_PqQqIb), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSHUFD_VdqWdqIb), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_PSHUFHW_VdqWdqIb), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_PSHUFLW_VdqWdqIb), }; // opcode 0F 71 static const Bit64u BxOpcodeTable0F71[] = { form_opcode(ATTR_NNN2 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSRLW_NqIb), form_opcode(ATTR_NNN2 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSRLW_UdqIb), form_opcode(ATTR_NNN4 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSRAW_NqIb), form_opcode(ATTR_NNN4 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSRAW_UdqIb), form_opcode(ATTR_NNN6 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSLLW_NqIb), last_opcode(ATTR_NNN6 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSLLW_UdqIb) }; // opcode 0F 72 static const Bit64u BxOpcodeTable0F72[] = { form_opcode(ATTR_NNN2 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSRLD_NqIb), form_opcode(ATTR_NNN2 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSRLD_UdqIb), form_opcode(ATTR_NNN4 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSRAD_NqIb), form_opcode(ATTR_NNN4 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSRAD_UdqIb), form_opcode(ATTR_NNN6 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSLLD_NqIb), last_opcode(ATTR_NNN6 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSLLD_UdqIb) }; // opcode 0F 73 static const Bit64u BxOpcodeTable0F73[] = { form_opcode(ATTR_NNN2 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSRLQ_NqIb), form_opcode(ATTR_NNN2 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSRLQ_UdqIb), form_opcode(ATTR_NNN3 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSRLDQ_UdqIb), form_opcode(ATTR_NNN6 | ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PSLLQ_NqIb), form_opcode(ATTR_NNN6 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSLLQ_UdqIb), last_opcode(ATTR_NNN7 | ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PSLLDQ_UdqIb) }; // opcode 0F 74 static const Bit64u BxOpcodeTable0F74[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PCMPEQB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PCMPEQB_VdqWdq) }; // opcode 0F 75 static const Bit64u BxOpcodeTable0F75[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PCMPEQW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PCMPEQW_VdqWdq) }; // opcode 0F 76 static const Bit64u BxOpcodeTable0F76[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PCMPEQD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PCMPEQD_VdqWdq) }; // opcode 0F 77 static const Bit64u BxOpcodeTable0F77[] = { last_opcode(ATTR_SSE_NO_PREFIX, BX_IA_EMMS) }; // opcode 0F 78 static const Bit64u BxOpcodeTable0F78[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_IS32, BX_IA_VMREAD_EdGd), #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_NO_PREFIX | ATTR_IS64, BX_IA_VMREAD_EqGq), #endif // SSE4A by AMD form_opcode(ATTR_SSE_PREFIX_66 | ATTR_MODC0 | ATTR_NNN0, BX_IA_EXTRQ_UdqIbIb), last_opcode(ATTR_SSE_PREFIX_F2 | ATTR_MODC0, BX_IA_INSERTQ_VdqUqIbIb) }; // opcode 0F 79 static const Bit64u BxOpcodeTable0F79[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_IS32, BX_IA_VMWRITE_GdEd), #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_NO_PREFIX | ATTR_IS64, BX_IA_VMWRITE_GqEq), #endif // SSE4A by AMD form_opcode(ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_EXTRQ_VdqUq), last_opcode(ATTR_SSE_PREFIX_F2 | ATTR_MODC0, BX_IA_INSERTQ_VdqUdq) }; // opcode 0F 7C static const Bit64u BxOpcodeTable0F7C[] = { form_opcode(ATTR_SSE_PREFIX_66, BX_IA_HADDPD_VpdWpd), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_HADDPS_VpsWps) }; // opcode 0F 7D static const Bit64u BxOpcodeTable0F7D[] = { form_opcode(ATTR_SSE_PREFIX_66, BX_IA_HSUBPD_VpdWpd), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_HSUBPS_VpsWps) }; // opcode 0F 7E static const Bit64u BxOpcodeTable0F7E[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_NO_PREFIX | ATTR_OS64, BX_IA_MOVQ_EqPq), form_opcode(ATTR_SSE_PREFIX_66 | ATTR_OS64, BX_IA_MOVQ_EqVq), #endif form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVD_EdPq), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVD_EdVd), last_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MOVQ_VqWq) }; // opcode 0F 7F static const Bit64u BxOpcodeTable0F7F[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_MOVQ_QqPq), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVDQA_WdqVdq), last_opcode(ATTR_SSE_PREFIX_F3, BX_IA_MOVDQU_WdqVdq) }; // opcode 0F 80 static const Bit64u BxOpcodeTable0F80_32[] = { form_opcode(ATTR_OS32, BX_IA_JO_Jd), last_opcode(ATTR_OS16, BX_IA_JO_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F80_64[] = { last_opcode(0, BX_IA_JO_Jq) }; #endif // opcode 0F 81 static const Bit64u BxOpcodeTable0F81_32[] = { form_opcode(ATTR_OS32, BX_IA_JNO_Jd), last_opcode(ATTR_OS16, BX_IA_JNO_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F81_64[] = { last_opcode(0, BX_IA_JNO_Jq) }; #endif // opcode 0F 82 static const Bit64u BxOpcodeTable0F82_32[] = { form_opcode(ATTR_OS32, BX_IA_JB_Jd), last_opcode(ATTR_OS16, BX_IA_JB_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F82_64[] = { last_opcode(0, BX_IA_JB_Jq) }; #endif // opcode 0F 83 static const Bit64u BxOpcodeTable0F83_32[] = { form_opcode(ATTR_OS32, BX_IA_JNB_Jd), last_opcode(ATTR_OS16, BX_IA_JNB_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F83_64[] = { last_opcode(0, BX_IA_JNB_Jq) }; #endif // opcode 0F 84 static const Bit64u BxOpcodeTable0F84_32[] = { form_opcode(ATTR_OS32, BX_IA_JZ_Jd), last_opcode(ATTR_OS16, BX_IA_JZ_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F84_64[] = { last_opcode(0, BX_IA_JZ_Jq) }; #endif // opcode 0F 85 static const Bit64u BxOpcodeTable0F85_32[] = { form_opcode(ATTR_OS32, BX_IA_JNZ_Jd), last_opcode(ATTR_OS16, BX_IA_JNZ_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F85_64[] = { last_opcode(0, BX_IA_JNZ_Jq) }; #endif // opcode 0F 86 static const Bit64u BxOpcodeTable0F86_32[] = { form_opcode(ATTR_OS32, BX_IA_JBE_Jd), last_opcode(ATTR_OS16, BX_IA_JBE_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F86_64[] = { last_opcode(0, BX_IA_JBE_Jq) }; #endif // opcode 0F 87 static const Bit64u BxOpcodeTable0F87_32[] = { form_opcode(ATTR_OS32, BX_IA_JNBE_Jd), last_opcode(ATTR_OS16, BX_IA_JNBE_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F87_64[] = { last_opcode(0, BX_IA_JNBE_Jq) }; #endif // opcode 0F 88 static const Bit64u BxOpcodeTable0F88_32[] = { form_opcode(ATTR_OS32, BX_IA_JS_Jd), last_opcode(ATTR_OS16, BX_IA_JS_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F88_64[] = { last_opcode(0, BX_IA_JS_Jq) }; #endif // opcode 0F 89 static const Bit64u BxOpcodeTable0F89_32[] = { form_opcode(ATTR_OS32, BX_IA_JNS_Jd), last_opcode(ATTR_OS16, BX_IA_JNS_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F89_64[] = { last_opcode(0, BX_IA_JNS_Jq) }; #endif // opcode 0F 8A static const Bit64u BxOpcodeTable0F8A_32[] = { form_opcode(ATTR_OS32, BX_IA_JP_Jd), last_opcode(ATTR_OS16, BX_IA_JP_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F8A_64[] = { last_opcode(0, BX_IA_JP_Jq) }; #endif // opcode 0F 8B static const Bit64u BxOpcodeTable0F8B_32[] = { form_opcode(ATTR_OS32, BX_IA_JNP_Jd), last_opcode(ATTR_OS16, BX_IA_JNP_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F8B_64[] = { last_opcode(0, BX_IA_JNP_Jq) }; #endif // opcode 0F 8C static const Bit64u BxOpcodeTable0F8C_32[] = { form_opcode(ATTR_OS32, BX_IA_JL_Jd), last_opcode(ATTR_OS16, BX_IA_JL_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F8C_64[] = { last_opcode(0, BX_IA_JL_Jq) }; #endif // opcode 0F 8D static const Bit64u BxOpcodeTable0F8D_32[] = { form_opcode(ATTR_OS32, BX_IA_JNL_Jd), last_opcode(ATTR_OS16, BX_IA_JNL_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F8D_64[] = { last_opcode(0, BX_IA_JNL_Jq) }; #endif // opcode 0F 8E static const Bit64u BxOpcodeTable0F8E_32[] = { form_opcode(ATTR_OS32, BX_IA_JLE_Jd), last_opcode(ATTR_OS16, BX_IA_JLE_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F8E_64[] = { last_opcode(0, BX_IA_JLE_Jq) }; #endif // opcode 0F 8F static const Bit64u BxOpcodeTable0F8F_32[] = { form_opcode(ATTR_OS32, BX_IA_JNLE_Jd), last_opcode(ATTR_OS16, BX_IA_JNLE_Jw) }; #if BX_SUPPORT_X86_64 static const Bit64u BxOpcodeTable0F8F_64[] = { last_opcode(0, BX_IA_JNLE_Jq) }; #endif // opcode 0F 90 - 0F 9F static const Bit64u BxOpcodeTable0F90[] = { last_opcode(0, BX_IA_SETO_Eb) }; static const Bit64u BxOpcodeTable0F91[] = { last_opcode(0, BX_IA_SETNO_Eb) }; static const Bit64u BxOpcodeTable0F92[] = { last_opcode(0, BX_IA_SETB_Eb) }; static const Bit64u BxOpcodeTable0F93[] = { last_opcode(0, BX_IA_SETNB_Eb) }; static const Bit64u BxOpcodeTable0F94[] = { last_opcode(0, BX_IA_SETZ_Eb) }; static const Bit64u BxOpcodeTable0F95[] = { last_opcode(0, BX_IA_SETNZ_Eb) }; static const Bit64u BxOpcodeTable0F96[] = { last_opcode(0, BX_IA_SETBE_Eb) }; static const Bit64u BxOpcodeTable0F97[] = { last_opcode(0, BX_IA_SETNBE_Eb) }; static const Bit64u BxOpcodeTable0F98[] = { last_opcode(0, BX_IA_SETS_Eb) }; static const Bit64u BxOpcodeTable0F99[] = { last_opcode(0, BX_IA_SETNS_Eb) }; static const Bit64u BxOpcodeTable0F9A[] = { last_opcode(0, BX_IA_SETP_Eb) }; static const Bit64u BxOpcodeTable0F9B[] = { last_opcode(0, BX_IA_SETNP_Eb) }; static const Bit64u BxOpcodeTable0F9C[] = { last_opcode(0, BX_IA_SETL_Eb) }; static const Bit64u BxOpcodeTable0F9D[] = { last_opcode(0, BX_IA_SETNL_Eb) }; static const Bit64u BxOpcodeTable0F9E[] = { last_opcode(0, BX_IA_SETLE_Eb) }; static const Bit64u BxOpcodeTable0F9F[] = { last_opcode(0, BX_IA_SETNLE_Eb) }; // opcode 0F A0 static const Bit64u BxOpcodeTable0FA0[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_IS64 | ATTR_OS32_64, BX_IA_PUSH_Op64_Sw), #endif form_opcode(ATTR_IS32 | ATTR_OS32, BX_IA_PUSH_Op32_Sw), last_opcode(ATTR_OS16, BX_IA_PUSH_Op16_Sw) }; // opcode 0F A1 static const Bit64u BxOpcodeTable0FA1[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_IS64 | ATTR_OS32_64, BX_IA_POP_Op64_Sw), #endif form_opcode(ATTR_IS32 | ATTR_OS32, BX_IA_POP_Op32_Sw), last_opcode(ATTR_OS16, BX_IA_POP_Op16_Sw) }; // opcode 0F A2 static const Bit64u BxOpcodeTable0FA2[] = { last_opcode(0, BX_IA_CPUID) }; // opcode 0F A3 static const Bit64u BxOpcodeTable0FA3[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_BT_EqGq), #endif form_opcode(ATTR_OS32, BX_IA_BT_EdGd), last_opcode(ATTR_OS16, BX_IA_BT_EwGw) }; // opcode 0F A4 static const Bit64u BxOpcodeTable0FA4[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SHLD_EqGqIb), #endif form_opcode(ATTR_OS32, BX_IA_SHLD_EdGdIb), last_opcode(ATTR_OS16, BX_IA_SHLD_EwGwIb) }; // opcode 0F A5 static const Bit64u BxOpcodeTable0FA5[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SHLD_EqGq), #endif form_opcode(ATTR_OS32, BX_IA_SHLD_EdGd), last_opcode(ATTR_OS16, BX_IA_SHLD_EwGw) }; // opcode 0F A8 static const Bit64u BxOpcodeTable0FA8[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_IS64 | ATTR_OS32_64, BX_IA_PUSH_Op64_Sw), #endif form_opcode(ATTR_IS32 | ATTR_OS32, BX_IA_PUSH_Op32_Sw), last_opcode(ATTR_OS16, BX_IA_PUSH_Op16_Sw) }; // opcode 0F A9 static const Bit64u BxOpcodeTable0FA9[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_IS64 | ATTR_OS32_64, BX_IA_POP_Op64_Sw), #endif form_opcode(ATTR_IS32 | ATTR_OS32, BX_IA_POP_Op32_Sw), last_opcode(ATTR_OS16, BX_IA_POP_Op16_Sw) }; // opcode 0F AA static const Bit64u BxOpcodeTable0FAA[] = { last_opcode(0, BX_IA_RSM) }; // opcode 0F AB static const Bit64u BxOpcodeTable0FAB[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_BTS_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_BTS_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_BTS_EwGw) }; // opcode 0F AC static const Bit64u BxOpcodeTable0FAC[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SHRD_EqGqIb), #endif form_opcode(ATTR_OS32, BX_IA_SHRD_EdGdIb), last_opcode(ATTR_OS16, BX_IA_SHRD_EwGwIb) }; // opcode 0F AD static const Bit64u BxOpcodeTable0FAD[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_SHRD_EqGq), #endif form_opcode(ATTR_OS32, BX_IA_SHRD_EdGd), last_opcode(ATTR_OS16, BX_IA_SHRD_EwGw) }; // opcode 0F AE static const Bit64u BxOpcodeTable0FAE[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS16_32 | ATTR_IS64 | ATTR_MODC0 | ATTR_NNN0 | ATTR_SSE_PREFIX_F3, BX_IA_RDFSBASE_Ed), form_opcode(ATTR_OS16_32 | ATTR_IS64 | ATTR_MODC0 | ATTR_NNN1 | ATTR_SSE_PREFIX_F3, BX_IA_RDGSBASE_Ed), form_opcode(ATTR_OS16_32 | ATTR_IS64 | ATTR_MODC0 | ATTR_NNN2 | ATTR_SSE_PREFIX_F3, BX_IA_WRFSBASE_Ed), form_opcode(ATTR_OS16_32 | ATTR_IS64 | ATTR_MODC0 | ATTR_NNN3 | ATTR_SSE_PREFIX_F3, BX_IA_WRGSBASE_Ed), form_opcode(ATTR_OS64 | ATTR_MODC0 | ATTR_NNN0 | ATTR_SSE_PREFIX_F3, BX_IA_RDFSBASE_Eq), form_opcode(ATTR_OS64 | ATTR_MODC0 | ATTR_NNN1 | ATTR_SSE_PREFIX_F3, BX_IA_RDGSBASE_Eq), form_opcode(ATTR_OS64 | ATTR_MODC0 | ATTR_NNN2 | ATTR_SSE_PREFIX_F3, BX_IA_WRFSBASE_Eq), form_opcode(ATTR_OS64 | ATTR_MODC0 | ATTR_NNN3 | ATTR_SSE_PREFIX_F3, BX_IA_WRGSBASE_Eq), #endif #if BX_SUPPORT_CET form_opcode(ATTR_OS16_32 | ATTR_NNN5 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_INCSSPD), form_opcode(ATTR_OS64 | ATTR_NNN5 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_INCSSPQ), #endif form_opcode(ATTR_NNN5 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_LFENCE), form_opcode(ATTR_NNN6 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_MFENCE), form_opcode(ATTR_NNN7 | ATTR_MODC0 | ATTR_SSE_NO_PREFIX, BX_IA_SFENCE), form_opcode(ATTR_NNN6 | ATTR_MODC0 | ATTR_SSE_PREFIX_66, BX_IA_TPAUSE_Ed), form_opcode(ATTR_NNN6 | ATTR_MODC0 | ATTR_SSE_PREFIX_F2, BX_IA_UMWAIT_Ed), #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN6 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3 | ATTR_OS64, BX_IA_UMONITOR_Eq), #endif form_opcode(ATTR_NNN6 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_UMONITOR_Ed), form_opcode(ATTR_NNN0 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_FXSAVE), form_opcode(ATTR_NNN1 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_FXRSTOR), form_opcode(ATTR_NNN2 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_LDMXCSR), form_opcode(ATTR_NNN3 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_STMXCSR), form_opcode(ATTR_NNN4 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_XSAVE), form_opcode(ATTR_NNN5 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_XRSTOR), form_opcode(ATTR_NNN6 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_XSAVEOPT), form_opcode(ATTR_NNN6 | ATTR_MOD_MEM | ATTR_SSE_PREFIX_66, BX_IA_CLWB), #if BX_SUPPORT_CET form_opcode(ATTR_NNN6 | ATTR_MOD_MEM | ATTR_SSE_PREFIX_F3, BX_IA_CLRSSBSY), #endif form_opcode(ATTR_NNN7 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_CLFLUSH), last_opcode(ATTR_NNN7 | ATTR_MOD_MEM | ATTR_SSE_PREFIX_66, BX_IA_CLFLUSHOPT) }; // opcode 0F AF static const Bit64u BxOpcodeTable0FAF[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_IMUL_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_IMUL_GdEd), last_opcode(ATTR_OS16, BX_IA_IMUL_GwEw) }; // opcode 0F B0 static const Bit64u BxOpcodeTable0FB0[] = { last_opcode_lockable(0, BX_IA_CMPXCHG_EbGb) }; // opcode 0F B1 static const Bit64u BxOpcodeTable0FB1[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_CMPXCHG_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_CMPXCHG_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_CMPXCHG_EwGw) }; // opcode 0F B2 static const Bit64u BxOpcodeTable0FB2[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_MOD_MEM, BX_IA_LSS_GqMp), // TODO: LSS_GdMp for AMD CPU #endif form_opcode(ATTR_OS32 | ATTR_MOD_MEM, BX_IA_LSS_GdMp), last_opcode(ATTR_OS16 | ATTR_MOD_MEM, BX_IA_LSS_GwMp) }; // opcode 0F B3 static const Bit64u BxOpcodeTable0FB3[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_BTR_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_BTR_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_BTR_EwGw) }; // opcode 0F B4 static const Bit64u BxOpcodeTable0FB4[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_MOD_MEM, BX_IA_LFS_GqMp), // TODO: LFS_GdMp for AMD CPU #endif form_opcode(ATTR_OS32 | ATTR_MOD_MEM, BX_IA_LFS_GdMp), last_opcode(ATTR_OS16 | ATTR_MOD_MEM, BX_IA_LFS_GwMp) }; // opcode 0F B5 static const Bit64u BxOpcodeTable0FB5[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_MOD_MEM, BX_IA_LGS_GqMp), // TODO: LGS_GdMp for AMD CPU #endif form_opcode(ATTR_OS32 | ATTR_MOD_MEM, BX_IA_LGS_GdMp), last_opcode(ATTR_OS16 | ATTR_MOD_MEM, BX_IA_LGS_GwMp) }; // opcode 0F B6 static const Bit64u BxOpcodeTable0FB6[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_MOVZX_GqEb), #endif form_opcode(ATTR_OS32, BX_IA_MOVZX_GdEb), last_opcode(ATTR_OS16, BX_IA_MOVZX_GwEb) }; // opcode 0F B7 static const Bit64u BxOpcodeTable0FB7[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_MOVZX_GqEw), #endif form_opcode(ATTR_OS32, BX_IA_MOVZX_GdEw), last_opcode(ATTR_OS16, BX_IA_MOV_GwEw) // MOVZX_GwEw }; // opcode 0F B8 static const Bit64u BxOpcodeTable0FB8[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_SSE_PREFIX_F3, BX_IA_POPCNT_GqEq), #endif form_opcode(ATTR_OS32 | ATTR_SSE_PREFIX_F3, BX_IA_POPCNT_GdEd), last_opcode(ATTR_OS16 | ATTR_SSE_PREFIX_F3, BX_IA_POPCNT_GwEw) }; // opcode 0F B9 static const Bit64u BxOpcodeTable0FB9[] = { last_opcode(0, BX_IA_UD1) }; // opcode 0F BA static const Bit64u BxOpcodeTable0FBA[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_NNN4 | ATTR_OS64, BX_IA_BT_EqIb), form_opcode_lockable(ATTR_NNN5 | ATTR_OS64, BX_IA_BTS_EqIb), form_opcode_lockable(ATTR_NNN6 | ATTR_OS64, BX_IA_BTR_EqIb), form_opcode_lockable(ATTR_NNN7 | ATTR_OS64, BX_IA_BTC_EqIb), #endif form_opcode(ATTR_NNN4 | ATTR_OS32, BX_IA_BT_EdIb), form_opcode_lockable(ATTR_NNN5 | ATTR_OS32, BX_IA_BTS_EdIb), form_opcode_lockable(ATTR_NNN6 | ATTR_OS32, BX_IA_BTR_EdIb), form_opcode_lockable(ATTR_NNN7 | ATTR_OS32, BX_IA_BTC_EdIb), form_opcode(ATTR_NNN4 | ATTR_OS16, BX_IA_BT_EwIb), form_opcode_lockable(ATTR_NNN5 | ATTR_OS16, BX_IA_BTS_EwIb), form_opcode_lockable(ATTR_NNN6 | ATTR_OS16, BX_IA_BTR_EwIb), last_opcode_lockable(ATTR_NNN7 | ATTR_OS16, BX_IA_BTC_EwIb) }; // opcode 0F BB static const Bit64u BxOpcodeTable0FBB[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_BTC_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_BTC_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_BTC_EwGw) }; // opcode 0F BC static const Bit64u BxOpcodeTable0FBC[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_SSE_PREFIX_F3, BX_IA_TZCNT_GqEq), #endif form_opcode(ATTR_OS32 | ATTR_SSE_PREFIX_F3, BX_IA_TZCNT_GdEd), form_opcode(ATTR_OS16 | ATTR_SSE_PREFIX_F3, BX_IA_TZCNT_GwEw), #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_BSF_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_BSF_GdEd), last_opcode(ATTR_OS16, BX_IA_BSF_GwEw) }; // opcode 0F BD static const Bit64u BxOpcodeTable0FBD[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_SSE_PREFIX_F3, BX_IA_LZCNT_GqEq), #endif form_opcode(ATTR_OS32 | ATTR_SSE_PREFIX_F3, BX_IA_LZCNT_GdEd), form_opcode(ATTR_OS16 | ATTR_SSE_PREFIX_F3, BX_IA_LZCNT_GwEw), #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_BSR_GqEq), #endif form_opcode(ATTR_OS32, BX_IA_BSR_GdEd), last_opcode(ATTR_OS16, BX_IA_BSR_GwEw) }; // opcode 0F BE static const Bit64u BxOpcodeTable0FBE[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_MOVSX_GqEb), #endif form_opcode(ATTR_OS32, BX_IA_MOVSX_GdEb), last_opcode(ATTR_OS16, BX_IA_MOVSX_GwEb) }; // opcode 0F BF static const Bit64u BxOpcodeTable0FBF[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_MOVSX_GqEw), #endif form_opcode(ATTR_OS32, BX_IA_MOVSX_GdEw), last_opcode(ATTR_OS16, BX_IA_MOV_GwEw) // MOVSX_GwEw }; // opcode 0F C0 static const Bit64u BxOpcodeTable0FC0[] = { last_opcode_lockable(0, BX_IA_XADD_EbGb) }; // opcode 0F C1 static const Bit64u BxOpcodeTable0FC1[] = { #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64, BX_IA_XADD_EqGq), #endif form_opcode_lockable(ATTR_OS32, BX_IA_XADD_EdGd), last_opcode_lockable(ATTR_OS16, BX_IA_XADD_EwGw) }; // opcode 0F C2 static const Bit64u BxOpcodeTable0FC2[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_CMPPS_VpsWpsIb), form_opcode(ATTR_SSE_PREFIX_66, BX_IA_CMPPD_VpdWpdIb), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_CMPSS_VssWssIb), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_CMPSD_VsdWsdIb) }; static const Bit64u BxOpcodeTable0FC3[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM | ATTR_IS64 | ATTR_OS16_32, BX_IA_MOVNTI_Op64_MdGd), form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM | ATTR_IS64 | ATTR_OS64, BX_IA_MOVNTI_MqGq), #endif last_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM | ATTR_IS32, BX_IA_MOVNTI_Op32_MdGd) }; // opcode 0F C4 static const Bit64u BxOpcodeTable0FC4[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PINSRW_PqEwIb), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PINSRW_VdqEwIb) }; // opcode 0F C5 static const Bit64u BxOpcodeTable0FC5[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PEXTRW_GdNqIb), last_opcode(ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PEXTRW_GdUdqIb) }; // opcode 0F C6 static const Bit64u BxOpcodeTable0FC6[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_SHUFPS_VpsWpsIb), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_SHUFPD_VpdWpdIb) }; // opcode 0F C7 static const Bit64u BxOpcodeTable0FC7[] = { form_opcode(ATTR_OS16 | ATTR_MODC0 | ATTR_NNN6 | ATTR_NO_SSE_PREFIX_F2_F3, BX_IA_RDRAND_Ew), form_opcode(ATTR_OS16 | ATTR_MODC0 | ATTR_NNN7 | ATTR_NO_SSE_PREFIX_F2_F3, BX_IA_RDSEED_Ew), form_opcode(ATTR_OS32 | ATTR_MODC0 | ATTR_NNN6 | ATTR_NO_SSE_PREFIX_F2_F3, BX_IA_RDRAND_Ed), form_opcode(ATTR_OS32 | ATTR_MODC0 | ATTR_NNN7 | ATTR_NO_SSE_PREFIX_F2_F3, BX_IA_RDSEED_Ed), #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64 | ATTR_MODC0 | ATTR_NNN6 | ATTR_NO_SSE_PREFIX_F2_F3, BX_IA_RDRAND_Eq), form_opcode(ATTR_OS64 | ATTR_MODC0 | ATTR_NNN7 | ATTR_NO_SSE_PREFIX_F2_F3, BX_IA_RDSEED_Eq), #endif #if BX_SUPPORT_X86_64 && BX_SUPPORT_UINTR form_opcode(ATTR_IS64 | ATTR_MODC0 | ATTR_NNN6 | ATTR_SSE_PREFIX_F3, BX_IA_SENDUIPI_Gq), #endif form_opcode(ATTR_NNN7 | ATTR_MODC0 | ATTR_SSE_PREFIX_F3, BX_IA_RDPID_Ed), form_opcode_lockable(ATTR_OS16_32 | ATTR_NNN1 | ATTR_MOD_MEM, BX_IA_CMPXCHG8B), #if BX_SUPPORT_X86_64 form_opcode_lockable(ATTR_OS64 | ATTR_NNN1 | ATTR_MOD_MEM, BX_IA_CMPXCHG16B), #endif form_opcode(ATTR_NNN3 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_XRSTORS), form_opcode(ATTR_NNN4 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_XSAVEC), form_opcode(ATTR_NNN5 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_XSAVES), form_opcode(ATTR_NNN6 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_VMPTRLD_Mq), form_opcode(ATTR_NNN6 | ATTR_MOD_MEM | ATTR_SSE_PREFIX_66, BX_IA_VMCLEAR_Mq), form_opcode(ATTR_NNN6 | ATTR_MOD_MEM | ATTR_SSE_PREFIX_F3, BX_IA_VMXON_Mq), last_opcode(ATTR_NNN7 | ATTR_MOD_MEM | ATTR_SSE_NO_PREFIX, BX_IA_VMPTRST_Mq) }; // opcode 0F C8 - 0F CF static const Bit64u BxOpcodeTable0FC8x0FCF[] = { #if BX_SUPPORT_X86_64 form_opcode(ATTR_OS64, BX_IA_BSWAP_RRX), #endif form_opcode(ATTR_OS32, BX_IA_BSWAP_ERX), last_opcode(ATTR_OS16, BX_IA_BSWAP_RX) }; // opcode 0F D0 static const Bit64u BxOpcodeTable0FD0[] = { form_opcode(ATTR_SSE_PREFIX_66, BX_IA_ADDSUBPD_VpdWpd), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_ADDSUBPS_VpsWps) }; // opcode 0F D1 static const Bit64u BxOpcodeTable0FD1[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSRLW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSRLW_VdqWdq) }; // opcode 0F D2 static const Bit64u BxOpcodeTable0FD2[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSRLD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSRLD_VdqWdq) }; // opcode 0F D3 static const Bit64u BxOpcodeTable0FD3[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSRLQ_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSRLQ_VdqWdq) }; // opcode 0F D4 static const Bit64u BxOpcodeTable0FD4[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDQ_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDQ_VdqWdq) }; // opcode 0F D5 static const Bit64u BxOpcodeTable0FD5[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMULLW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMULLW_VdqWdq) }; // opcode 0F D6 static const Bit64u BxOpcodeTable0FD6[] = { form_opcode(ATTR_SSE_PREFIX_66, BX_IA_MOVQ_WqVq), form_opcode(ATTR_SSE_PREFIX_F3 | ATTR_MODC0, BX_IA_MOVQ2DQ_VdqQq), last_opcode(ATTR_SSE_PREFIX_F2 | ATTR_MODC0, BX_IA_MOVDQ2Q_PqUdq) }; // opcode 0F D7 static const Bit64u BxOpcodeTable0FD7[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_PMOVMSKB_GdNq), last_opcode(ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_PMOVMSKB_GdUdq) }; // opcode 0F D8 static const Bit64u BxOpcodeTable0FD8[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBUSB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBUSB_VdqWdq) }; // opcode 0F D9 static const Bit64u BxOpcodeTable0FD9[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBUSW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBUSW_VdqWdq) }; // opcode 0F DA static const Bit64u BxOpcodeTable0FDA[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMINUB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMINUB_VdqWdq) }; // opcode 0F DB static const Bit64u BxOpcodeTable0FDB[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PAND_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PAND_VdqWdq) }; // opcode 0F DC static const Bit64u BxOpcodeTable0FDC[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDUSB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDUSB_VdqWdq) }; // opcode 0F DD static const Bit64u BxOpcodeTable0FDD[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDUSW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDUSW_VdqWdq) }; // opcode 0F DE static const Bit64u BxOpcodeTable0FDE[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMAXUB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMAXUB_VdqWdq) }; // opcode 0F DF static const Bit64u BxOpcodeTable0FDF[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PANDN_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PANDN_VdqWdq) }; // opcode 0F E0 static const Bit64u BxOpcodeTable0FE0[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PAVGB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PAVGB_VdqWdq) }; // opcode 0F E1 static const Bit64u BxOpcodeTable0FE1[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSRAW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSRAW_VdqWdq) }; // opcode 0F E2 static const Bit64u BxOpcodeTable0FE2[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSRAD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSRAD_VdqWdq) }; // opcode 0F E3 static const Bit64u BxOpcodeTable0FE3[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PAVGW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PAVGW_VdqWdq) }; // opcode 0F E4 static const Bit64u BxOpcodeTable0FE4[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMULHUW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMULHUW_VdqWdq) }; // opcode 0F E5 static const Bit64u BxOpcodeTable0FE5[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMULHW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMULHW_VdqWdq) }; // opcode 0F E6 static const Bit64u BxOpcodeTable0FE6[] = { form_opcode(ATTR_SSE_PREFIX_66, BX_IA_CVTTPD2DQ_VqWpd), form_opcode(ATTR_SSE_PREFIX_F3, BX_IA_CVTDQ2PD_VpdWq), last_opcode(ATTR_SSE_PREFIX_F2, BX_IA_CVTPD2DQ_VqWpd) }; // opcode 0F E7 static const Bit64u BxOpcodeTable0FE7[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MOD_MEM, BX_IA_MOVNTQ_MqPq), last_opcode(ATTR_SSE_PREFIX_66 | ATTR_MOD_MEM, BX_IA_MOVNTDQ_MdqVdq) }; // opcode 0F E8 static const Bit64u BxOpcodeTable0FE8[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBSB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBSB_VdqWdq) }; // opcode 0F E9 static const Bit64u BxOpcodeTable0FE9[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBSW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBSW_VdqWdq) }; // opcode 0F EA static const Bit64u BxOpcodeTable0FEA[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMINSW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMINSW_VdqWdq) }; // opcode 0F EB static const Bit64u BxOpcodeTable0FEB[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_POR_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_POR_VdqWdq) }; // opcode 0F EC static const Bit64u BxOpcodeTable0FEC[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDSB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDSB_VdqWdq) }; // opcode 0F ED static const Bit64u BxOpcodeTable0FED[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDSW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDSW_VdqWdq) }; // opcode 0F EE static const Bit64u BxOpcodeTable0FEE[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMAXSW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMAXSW_VdqWdq) }; // opcode 0F EF static const Bit64u BxOpcodeTable0FEF[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PXOR_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PXOR_VdqWdq) }; // opcode 0F F0 static const Bit64u BxOpcodeTable0FF0[4] = { last_opcode(ATTR_SSE_PREFIX_F2 | ATTR_MOD_MEM, BX_IA_LDDQU_VdqMdq) }; // opcode 0F F1 static const Bit64u BxOpcodeTable0FF1[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSLLW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSLLW_VdqWdq) }; // opcode 0F F2 static const Bit64u BxOpcodeTable0FF2[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSLLD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSLLD_VdqWdq) }; // opcode 0F F3 static const Bit64u BxOpcodeTable0FF3[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSLLQ_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSLLQ_VdqWdq) }; // opcode 0F F4 static const Bit64u BxOpcodeTable0FF4[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMULUDQ_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMULUDQ_VdqWdq) }; // opcode 0F F5 static const Bit64u BxOpcodeTable0FF5[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PMADDWD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PMADDWD_VdqWdq) }; // opcode 0F F6 static const Bit64u BxOpcodeTable0FF6[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSADBW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSADBW_VdqWdq) }; // opcode 0F F7 static const Bit64u BxOpcodeTable0FF7[] = { form_opcode(ATTR_SSE_NO_PREFIX | ATTR_MODC0, BX_IA_MASKMOVQ_PqNq), last_opcode(ATTR_SSE_PREFIX_66 | ATTR_MODC0, BX_IA_MASKMOVDQU_VdqUdq) }; // opcode 0F F8 static const Bit64u BxOpcodeTable0FF8[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBB_VdqWdq) }; // opcode 0F F9 static const Bit64u BxOpcodeTable0FF9[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBW_VdqWdq) }; // opcode 0F FA static const Bit64u BxOpcodeTable0FFA[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBD_VdqWdq) }; // opcode 0F FB static const Bit64u BxOpcodeTable0FFB[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PSUBQ_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PSUBQ_VdqWdq) }; // opcode 0F FC static const Bit64u BxOpcodeTable0FFC[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDB_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDB_VdqWdq) }; // opcode 0F FD static const Bit64u BxOpcodeTable0FFD[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDW_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDW_VdqWdq) }; // opcode 0F FE static const Bit64u BxOpcodeTable0FFE[] = { form_opcode(ATTR_SSE_NO_PREFIX, BX_IA_PADDD_PqQq), last_opcode(ATTR_SSE_PREFIX_66, BX_IA_PADDD_VdqWdq) }; // opcode 0F FF static const Bit64u BxOpcodeTable0FFF[] = { last_opcode(0, BX_IA_UD0) }; #endif // BX_FETCHDECODE_OPMAP_H