[41668] | 1 | /* $Id: DisasmTables.cpp 76553 2019-01-01 01:45:53Z vboxsync $ */
|
---|
[1] | 2 | /** @file
|
---|
[41668] | 3 | * VBox disassembler - Tables for X86 (32-bit and 16-bit modes).
|
---|
[1] | 4 | */
|
---|
| 5 |
|
---|
| 6 | /*
|
---|
[76553] | 7 | * Copyright (C) 2006-2019 Oracle Corporation
|
---|
[1] | 8 | *
|
---|
| 9 | * This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
| 10 | * available from http://www.virtualbox.org. This file is free software;
|
---|
| 11 | * you can redistribute it and/or modify it under the terms of the GNU
|
---|
[5999] | 12 | * General Public License (GPL) as published by the Free Software
|
---|
| 13 | * Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
| 14 | * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
| 15 | * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
[1] | 16 | */
|
---|
| 17 |
|
---|
| 18 |
|
---|
[57358] | 19 | /*********************************************************************************************************************************
|
---|
| 20 | * Header Files *
|
---|
| 21 | *********************************************************************************************************************************/
|
---|
[1] | 22 | #include <VBox/dis.h>
|
---|
| 23 | #include <VBox/disopcode.h>
|
---|
| 24 | #include "DisasmInternal.h"
|
---|
| 25 |
|
---|
| 26 |
|
---|
| 27 | //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
---|
[63567] | 28 | /// @todo Verify tables for correctness
|
---|
| 29 | /// @todo opcode type (harmless, potentially dangerous, dangerous)
|
---|
[1] | 30 | //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
---|
| 31 |
|
---|
[9669] | 32 | #ifndef DIS_CORE_ONLY
|
---|
[41863] | 33 | static char g_szInvalidOpcode[] = "Invalid Opcode";
|
---|
[9669] | 34 | #endif
|
---|
[1] | 35 |
|
---|
| 36 | #define INVALID_OPCODE \
|
---|
[41863] | 37 | OP(g_szInvalidOpcode, 0, 0, 0, OP_INVALID, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_INVALID)
|
---|
[1] | 38 | #define INVALID_OPCODE_BLOCK \
|
---|
| 39 | INVALID_OPCODE,\
|
---|
| 40 | INVALID_OPCODE,\
|
---|
| 41 | INVALID_OPCODE,\
|
---|
| 42 | INVALID_OPCODE,\
|
---|
| 43 | INVALID_OPCODE,\
|
---|
| 44 | INVALID_OPCODE,\
|
---|
| 45 | INVALID_OPCODE,\
|
---|
| 46 | INVALID_OPCODE,\
|
---|
| 47 | INVALID_OPCODE,\
|
---|
| 48 | INVALID_OPCODE,\
|
---|
| 49 | INVALID_OPCODE,\
|
---|
| 50 | INVALID_OPCODE,\
|
---|
| 51 | INVALID_OPCODE,\
|
---|
| 52 | INVALID_OPCODE,\
|
---|
| 53 | INVALID_OPCODE,\
|
---|
| 54 | INVALID_OPCODE,
|
---|
| 55 |
|
---|
[41863] | 56 | #define INVALID_OPCODE_MOD_RM(a_Index) \
|
---|
| 57 | OP(g_szInvalidOpcode, IDX_ParseInvOpModRM, 0, 0, OP_INVALID, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_INVALID)
|
---|
| 58 | #define INVALID_OPCODE_BLOCK_MOD_RM(a_UpperDigit) \
|
---|
| 59 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 0),\
|
---|
| 60 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 1),\
|
---|
| 61 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 2),\
|
---|
| 62 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 3),\
|
---|
| 63 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 4),\
|
---|
| 64 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 5),\
|
---|
| 65 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 6),\
|
---|
| 66 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 7),\
|
---|
| 67 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 8),\
|
---|
| 68 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## 9),\
|
---|
| 69 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## a),\
|
---|
| 70 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## b),\
|
---|
| 71 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## c),\
|
---|
| 72 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## d),\
|
---|
| 73 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## e),\
|
---|
| 74 | INVALID_OPCODE_MOD_RM(a_UpperDigit ## f),
|
---|
[41796] | 75 |
|
---|
[41863] | 76 |
|
---|
[13241] | 77 | /* Invalid opcode */
|
---|
[41690] | 78 | const DISOPCODE g_InvalidOpcode[1] =
|
---|
[13241] | 79 | {
|
---|
| 80 | INVALID_OPCODE
|
---|
| 81 | };
|
---|
| 82 |
|
---|
[1] | 83 | /* Tables for the elegant Intel X86 instruction set */
|
---|
[41690] | 84 | const DISOPCODE g_aOneByteMapX86[256] =
|
---|
[1] | 85 | {
|
---|
| 86 | /* 0 */
|
---|
[65876] | 87 | OP("add %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADD, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 88 | OP("add %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADD, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 89 | OP("add %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADD, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 90 | OP("add %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADD, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 91 | OP("add AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_ADD, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 92 | OP("add %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_ADD, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 93 | OP("push ES", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_ES, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 94 | OP("pop ES", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_ES, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 95 | OP("or %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_OR, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 96 | OP("or %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_OR, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 97 | OP("or %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_OR, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 98 | OP("or %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_OR, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 99 | OP("or AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_OR, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 100 | OP("or %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_OR, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[65878] | 101 | OP("push CS", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_CS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64 | DISOPTYPE_POTENTIALLY_DANGEROUS),
|
---|
[65879] | 102 | OP("EscTwo0f", IDX_ParseTwoByteEsc, 0, 0, OP_2B_ESC, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 103 |
|
---|
| 104 | /* 1 */
|
---|
[65876] | 105 | OP("adc %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADC, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 106 | OP("adc %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADC, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 107 | OP("adc %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADC, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 108 | OP("adc %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADC, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 109 | OP("adc AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_ADC, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 110 | OP("adc %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_ADC, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[65878] | 111 | OP("push SS", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_SS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64 | DISOPTYPE_RRM_DANGEROUS),
|
---|
| 112 | OP("pop SS", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_SS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INHIBIT_IRQS | DISOPTYPE_INVALID_64 | DISOPTYPE_RRM_DANGEROUS),
|
---|
[65876] | 113 | OP("sbb %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_SBB, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 114 | OP("sbb %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_SBB, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 115 | OP("sbb %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_SBB, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 116 | OP("sbb %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_SBB, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 117 | OP("sbb AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_SBB, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 118 | OP("sbb %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_SBB, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 119 | OP("push DS", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_DS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
[65878] | 120 | OP("pop DS", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_DS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64 | DISOPTYPE_RRM_DANGEROUS),
|
---|
[1] | 121 |
|
---|
| 122 | /* 2 */
|
---|
[65876] | 123 | OP("and %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_AND, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 124 | OP("and %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_AND, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 125 | OP("and %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_AND, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 126 | OP("and %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_AND, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 127 | OP("and AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_AND, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 128 | OP("and %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_AND, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 129 | OP("SEG ES", 0, 0, 0, OP_SEG, OP_PARM_REG_ES, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 130 | OP("daa", 0, 0, 0, OP_DAA, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
[65876] | 131 | OP("sub %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUB, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 132 | OP("sub %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUB, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 133 | OP("sub %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUB, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 134 | OP("sub %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUB, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 135 | OP("sub AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_SUB, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 136 | OP("sub %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_SUB, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 137 | /* Branch not taken hint prefix for branches on a Pentium 4 or Xeon CPU (or higher)! */
|
---|
[41676] | 138 | OP("SEG CS", 0, 0, 0, OP_SEG, OP_PARM_REG_CS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 139 | OP("das", 0, 0, 0, OP_DAS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
[1] | 140 |
|
---|
| 141 | /* 3 */
|
---|
[41676] | 142 | OP("xor %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_XOR, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 143 | OP("xor %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_XOR, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 144 | OP("xor %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_XOR, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 145 | OP("xor %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_XOR, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[65876] | 146 | OP("xor AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_XOR, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 147 | OP("xor %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_XOR, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 148 | OP("SEG SS", 0, 0, 0, OP_SEG, OP_PARM_REG_SS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 149 | OP("aaa", 0, 0, 0, OP_AAA, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 150 | OP("cmp %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMP, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 151 | OP("cmp %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMP, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 152 | OP("cmp %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMP, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 153 | OP("cmp %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMP, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[65876] | 154 | OP("cmp AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_CMP, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 155 | OP("cmp %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_CMP, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 156 | /* Branch not taken hint prefix for branches on a Pentium 4 or Xeon CPU (or higher)! */
|
---|
[41676] | 157 | OP("SEG DS", 0, 0, 0, OP_SEG, OP_PARM_REG_DS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 158 | OP("aas", 0, 0, 0, OP_AAS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
[1] | 159 |
|
---|
| 160 | /* 4 */
|
---|
[41676] | 161 | OP("inc %eAX", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_EAX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 162 | OP("inc %eCX", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_ECX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 163 | OP("inc %eDX", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_EDX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 164 | OP("inc %eBX", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_EBX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 165 | OP("inc %eSP", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_ESP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 166 | OP("inc %eBP", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_EBP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 167 | OP("inc %eSI", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_ESI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 168 | OP("inc %eDI", IDX_ParseFixedReg, 0, 0, OP_INC, OP_PARM_REG_EDI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 169 | OP("dec %eAX", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_EAX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 170 | OP("dec %eCX", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_ECX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 171 | OP("dec %eDX", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_EDX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 172 | OP("dec %eBX", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_EBX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 173 | OP("dec %eSP", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_ESP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 174 | OP("dec %eBP", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_EBP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 175 | OP("dec %eSI", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_ESI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 176 | OP("dec %eDI", IDX_ParseFixedReg, 0, 0, OP_DEC, OP_PARM_REG_EDI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 177 |
|
---|
| 178 | /* 5 */
|
---|
[65878] | 179 | OP("push %eAX", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_EAX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 180 | OP("push %eCX", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_ECX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 181 | OP("push %eDX", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_EDX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 182 | OP("push %eBX", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_EBX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 183 | OP("push %eSP", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_ESP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 184 | OP("push %eBP", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_EBP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 185 | OP("push %eSI", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_ESI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 186 | OP("push %eDI", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_EDI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 187 | OP("pop %eAX", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_EAX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 188 | OP("pop %eCX", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_ECX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 189 | OP("pop %eDX", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_EDX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 190 | OP("pop %eBX", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_EBX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 191 | OP("pop %eSP", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_ESP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 192 | OP("pop %eBP", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_EBP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 193 | OP("pop %eSI", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_ESI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 194 | OP("pop %eDI", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_EDI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
[1] | 195 |
|
---|
| 196 | /* 6 */
|
---|
[41676] | 197 | OP("pusha", 0, 0, 0, OP_PUSHA, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 198 | OP("popa", 0, 0, 0, OP_POPA, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 199 | OP("bound %Gv,%Ma", IDX_ParseModRM, IDX_UseModRM, 0, OP_BOUND, OP_PARM_Gv, OP_PARM_Ma, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 200 | OP("arpl %Ew,%Gw", IDX_ParseModRM, IDX_UseModRM, 0, OP_ARPL, OP_PARM_Ew, OP_PARM_Gw, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 201 | OP("SEG FS", 0, 0, 0, OP_SEG, OP_PARM_REG_FS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 202 | OP("SEG GS", 0, 0, 0, OP_SEG, OP_PARM_REG_GS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 203 | OP("OP SIZE", 0, 0, 0, OP_OPSIZE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 204 | OP("ADR SIZE", 0, 0, 0, OP_ADDRSIZE,OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 205 | OP("push %Iz", IDX_ParseImmZ, 0, 0, OP_PUSH, OP_PARM_Iz, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
| 206 | OP("imul %Gv,%Ev,%Iz", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmZ, OP_IMUL, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_Iz, DISOPTYPE_HARMLESS),
|
---|
| 207 | OP("push %Ib", IDX_ParseImmByteSX, 0, 0, OP_PUSH, OP_PARM_Ib, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
| 208 | OP("imul %Gv,%Ev,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByteSX, OP_IMUL, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 209 | OP("insb %Yb,DX", IDX_ParseYb, IDX_ParseFixedReg, 0, OP_INSB, OP_PARM_Yb, OP_PARM_REG_DX, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_READ),
|
---|
| 210 | OP("insw/d %Yv,DX", IDX_ParseYv, IDX_ParseFixedReg, 0, OP_INSWD, OP_PARM_Yv, OP_PARM_REG_DX, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_READ),
|
---|
| 211 | OP("outsb DX,%Xb", IDX_ParseFixedReg, IDX_ParseXb, 0, OP_OUTSB, OP_PARM_REG_DX, OP_PARM_Yb, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_WRITE),
|
---|
| 212 | OP("outsw/d DX,%Xv", IDX_ParseFixedReg, IDX_ParseXv, 0, OP_OUTSWD, OP_PARM_REG_DX, OP_PARM_Yv, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_WRITE),
|
---|
[1] | 213 |
|
---|
| 214 |
|
---|
| 215 | /* 7 */
|
---|
[65878] | 216 | OP("jo %Jb", IDX_ParseImmBRel, 0, 0, OP_JO, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 217 | OP("jno %Jb", IDX_ParseImmBRel, 0, 0, OP_JNO, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 218 | OP("jc %Jb", IDX_ParseImmBRel, 0, 0, OP_JC, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 219 | OP("jnc %Jb", IDX_ParseImmBRel, 0, 0, OP_JNC, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 220 | OP("je %Jb", IDX_ParseImmBRel, 0, 0, OP_JE, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 221 | OP("jne %Jb", IDX_ParseImmBRel, 0, 0, OP_JNE, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 222 | OP("jbe %Jb", IDX_ParseImmBRel, 0, 0, OP_JBE, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 223 | OP("jnbe %Jb", IDX_ParseImmBRel, 0, 0, OP_JNBE, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 224 | OP("js %Jb", IDX_ParseImmBRel, 0, 0, OP_JS, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 225 | OP("jns %Jb", IDX_ParseImmBRel, 0, 0, OP_JNS, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 226 | OP("jp %Jb", IDX_ParseImmBRel, 0, 0, OP_JP, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 227 | OP("jnp %Jb", IDX_ParseImmBRel, 0, 0, OP_JNP, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 228 | OP("jl %Jb", IDX_ParseImmBRel, 0, 0, OP_JL, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 229 | OP("jnl %Jb", IDX_ParseImmBRel, 0, 0, OP_JNL, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 230 | OP("jle %Jb", IDX_ParseImmBRel, 0, 0, OP_JLE, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 231 | OP("jnle %Jb", IDX_ParseImmBRel, 0, 0, OP_JNLE, OP_PARM_Jb , OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
[1] | 232 |
|
---|
| 233 | /* 8 */
|
---|
[65860] | 234 | OP("Imm Grp1 %Eb,%Ib", IDX_ParseGrp1, 0, 0, OP_IMM_GRP1,OP_PARM_Eb, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 235 | OP("Imm Grp1 %Ev,%Iz", IDX_ParseGrp1, 0, 0, OP_IMM_GRP1,OP_PARM_Ev, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 236 | OP("Imm Grp1 %Eb,%Ib", IDX_ParseGrp1, 0, 0, OP_IMM_GRP1,OP_PARM_Eb, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 237 | OP("Imm Grp1 %Ev,%Ib", IDX_ParseGrp1, 0, 0, OP_IMM_GRP1,OP_PARM_Ev, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 238 | OP("test %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_TEST, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 239 | OP("test %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_TEST, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 240 | OP("xchg %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_XCHG, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 241 | OP("xchg %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_XCHG, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 242 | OP("mov %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 243 | OP("mov %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 244 | OP("mov %Gb,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV, OP_PARM_Gb, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 245 | OP("mov %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 246 | OP("mov %Ev,%Sw", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV, OP_PARM_Ev, OP_PARM_Sw, OP_PARM_NONE, DISOPTYPE_POTENTIALLY_DANGEROUS),
|
---|
| 247 | OP("lea %Gv,%M", IDX_ParseModRM, IDX_UseModRM, 0, OP_LEA, OP_PARM_Gv, OP_PARM_M, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 248 | OP("mov %Sw,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV, OP_PARM_Sw, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_POTENTIALLY_DANGEROUS | DISOPTYPE_INHIBIT_IRQS),
|
---|
[65860] | 249 | /** @todo this is grp 1a, actually */
|
---|
[41676] | 250 | OP("pop %Ev", IDX_ParseModRM, 0, 0, OP_POP, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 251 |
|
---|
| 252 | /* 9 */
|
---|
[41676] | 253 | OP("nop/pause/xchg %eAX,%eAX", IDX_ParseNopPause, 0, 0, OP_NOP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 254 | OP("xchg %eCX,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_XCHG, OP_PARM_REG_ECX, OP_PARM_REG_EAX, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 255 | OP("xchg %eDX,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_XCHG, OP_PARM_REG_EDX, OP_PARM_REG_EAX, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 256 | OP("xchg %eBX,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_XCHG, OP_PARM_REG_EBX, OP_PARM_REG_EAX, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 257 | OP("xchg %eSP,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_XCHG, OP_PARM_REG_ESP, OP_PARM_REG_EAX, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 258 | OP("xchg %eBP,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_XCHG, OP_PARM_REG_EBP, OP_PARM_REG_EAX, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 259 | OP("xchg %eSI,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_XCHG, OP_PARM_REG_ESI, OP_PARM_REG_EAX, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 260 | OP("xchg %eDI,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_XCHG, OP_PARM_REG_EDI, OP_PARM_REG_EAX, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 261 | OP("cbw", 0, 0, 0, OP_CBW, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 262 | OP("cwd", 0, 0, 0, OP_CWD, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 263 | OP("call %Ap", IDX_ParseImmAddrF, 0, 0, OP_CALL, OP_PARM_Ap, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_INVALID_64),
|
---|
| 264 | OP("wait", 0, 0, 0, OP_WAIT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[65878] | 265 | OP("pushf %Fv", 0, 0, 0, OP_PUSHF, OP_PARM_Fv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_POTENTIALLY_DANGEROUS),
|
---|
| 266 | OP("popf %Fv", 0, 0, 0, OP_POPF, OP_PARM_Fv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DEFAULT_64_OP_SIZE | DISOPTYPE_POTENTIALLY_DANGEROUS),
|
---|
[41676] | 267 | OP("sahf", 0, 0, 0, OP_SAHF, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 268 | OP("lahf", 0, 0, 0, OP_LAHF, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 269 |
|
---|
| 270 |
|
---|
| 271 | /* A */
|
---|
[41676] | 272 | OP("mov AL,%Ob", IDX_ParseFixedReg, IDX_ParseImmAddr, 0, OP_MOV, OP_PARM_REG_AL, OP_PARM_Ob, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 273 | OP("mov %eAX,%Ov", IDX_ParseFixedReg, IDX_ParseImmAddr, 0, OP_MOV, OP_PARM_REG_EAX, OP_PARM_Ov, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 274 | OP("mov %Ob,AL", IDX_ParseImmAddr, IDX_ParseFixedReg, 0, OP_MOV, OP_PARM_Ob, OP_PARM_REG_AL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 275 | OP("mov %Ov,%eAX", IDX_ParseImmAddr, IDX_ParseFixedReg, 0, OP_MOV, OP_PARM_Ov, OP_PARM_REG_EAX,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 276 | OP("movsb %Xb,%Yb", IDX_ParseXb, IDX_ParseYb, 0, OP_MOVSB, OP_PARM_Xb, OP_PARM_Yb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 277 | OP("movsw/d %Xv,%Yv", IDX_ParseXv, IDX_ParseYv, 0, OP_MOVSWD, OP_PARM_Xv, OP_PARM_Yv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 278 | OP("cmpsb %Xb,%Yb", IDX_ParseXb, IDX_ParseYb, 0, OP_CMPSB, OP_PARM_Xb, OP_PARM_Yb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 279 | OP("cmpsw/d %Xv,%Yv", IDX_ParseXv, IDX_ParseYv, 0, OP_CMPWD, OP_PARM_Xv, OP_PARM_Yv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 280 | OP("test AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_TEST, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 281 | OP("test %eAX,%Iz", IDX_ParseFixedReg, IDX_ParseImmZ, 0, OP_TEST, OP_PARM_REG_EAX, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 282 | OP("stosb %Yb,AL", IDX_ParseYb, IDX_ParseFixedReg, 0, OP_STOSB, OP_PARM_Yb, OP_PARM_REG_AL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 283 | OP("stosw/d %Yv,%eAX", IDX_ParseYv, IDX_ParseFixedReg, 0, OP_STOSWD, OP_PARM_Yv, OP_PARM_REG_EAX,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 284 | OP("lodsb AL,%Xb", IDX_ParseFixedReg, IDX_ParseXb, 0, OP_LODSB, OP_PARM_REG_AL, OP_PARM_Xb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 285 | OP("lodsw/d %eAX,%Xv", IDX_ParseFixedReg, IDX_ParseXv, 0, OP_LODSWD, OP_PARM_REG_EAX, OP_PARM_Xv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 286 | OP("scasb AL,%Xb", IDX_ParseFixedReg, IDX_ParseXb, 0, OP_SCASB, OP_PARM_REG_AL, OP_PARM_Xb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 287 | OP("scasw/d %eAX,%Xv", IDX_ParseFixedReg, IDX_ParseXv, 0, OP_SCASWD, OP_PARM_REG_EAX, OP_PARM_Xv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 288 |
|
---|
| 289 |
|
---|
| 290 | /* B */
|
---|
[41676] | 291 | OP("mov AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 292 | OP("mov CL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_CL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 293 | OP("mov DL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_DL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 294 | OP("mov BL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_BL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 295 | OP("mov AH,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_AH, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 296 | OP("mov CH,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_CH, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 297 | OP("mov DH,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_DH, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 298 | OP("mov BH,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_REG_BH, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 299 | OP("mov %eAX,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_EAX, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 300 | OP("mov %eCX,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_ECX, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 301 | OP("mov %eDX,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_EDX, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 302 | OP("mov %eBX,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_EBX, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 303 | OP("mov %eSP,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_ESP, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 304 | OP("mov %eBP,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_EBP, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 305 | OP("mov %eSI,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_ESI, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 306 | OP("mov %eDI,%Iv", IDX_ParseFixedReg, IDX_ParseImmV, 0, OP_MOV, OP_PARM_REG_EDI, OP_PARM_Iv, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
[1] | 307 |
|
---|
| 308 | /* C */
|
---|
[41676] | 309 | OP("Shift Grp2 %Eb,%Ib", IDX_ParseShiftGrp2, 0, 0, OP_SHIFT_GRP2, OP_PARM_Eb, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 310 | OP("Shift Grp2 %Ev,%Ib", IDX_ParseShiftGrp2, 0, 0, OP_SHIFT_GRP2, OP_PARM_Ev, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 311 | OP("retn %Iw", IDX_ParseImmUshort, 0, 0, OP_RETN, OP_PARM_Iw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 312 | OP("retn", 0, 0, 0, OP_RETN, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 313 | OP("les %Gv,%Mp", IDX_ParseModRM, IDX_UseModRM, 0, OP_LES, OP_PARM_Gv, OP_PARM_Mp, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
[65878] | 314 | OP("lds %Gv,%Mp", IDX_ParseModRM, IDX_UseModRM, 0, OP_LDS, OP_PARM_Gv, OP_PARM_Mp, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64 | DISOPTYPE_RRM_DANGEROUS),
|
---|
[63567] | 315 | /** @todo these two are actually group11 */
|
---|
[41676] | 316 | OP("mov %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_Eb, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 317 | OP("mov %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_MOV, OP_PARM_Ev, OP_PARM_Iz, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 318 | OP("enter %Iw,%Ib", IDX_ParseImmUshort, IDX_ParseImmByte, 0, OP_ENTER, OP_PARM_Iw, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 319 | OP("leave", 0, 0, 0, OP_LEAVE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
| 320 | OP("retf %Iw", IDX_ParseImmUshort, 0, 0, OP_RETF, OP_PARM_Iw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW),
|
---|
| 321 | OP("retf", 0, 0, 0, OP_RETF, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW),
|
---|
| 322 | OP("int 3", 0, 0, 0, OP_INT3, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_INTERRUPT),
|
---|
| 323 | OP("int %Ib", IDX_ParseImmByte, 0, 0, OP_INT, OP_PARM_Ib, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_INTERRUPT),
|
---|
| 324 | OP("into", 0, 0, 0, OP_INTO, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_INTERRUPT | DISOPTYPE_INVALID_64),
|
---|
| 325 | OP("iret", 0, 0, 0, OP_IRET, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW),
|
---|
[1] | 326 |
|
---|
| 327 | /* D */
|
---|
[41676] | 328 | OP("Shift Grp2 %Eb,1", IDX_ParseShiftGrp2, 0, 0, OP_SHIFT_GRP2, OP_PARM_Eb, OP_PARM_1, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 329 | OP("Shift Grp2 %Ev,1", IDX_ParseShiftGrp2, 0, 0, OP_SHIFT_GRP2, OP_PARM_Ev, OP_PARM_1, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 330 | OP("Shift Grp2 %Eb,CL", IDX_ParseShiftGrp2, IDX_ParseFixedReg, 0, OP_SHIFT_GRP2, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 331 | OP("Shift Grp2 %Ev,CL", IDX_ParseShiftGrp2, IDX_ParseFixedReg, 0, OP_SHIFT_GRP2, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 332 | OP("aam %Ib", IDX_ParseImmByte, 0, 0, OP_AAM, OP_PARM_Ib, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
| 333 | OP("aad %Ib", IDX_ParseImmByte, 0, 0, OP_AAD, OP_PARM_Ib, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_INVALID_64),
|
---|
[1] | 334 | /* setalc?? */
|
---|
| 335 | INVALID_OPCODE,
|
---|
[41676] | 336 | OP("xlat", 0, 0, 0, OP_XLAT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 337 | OP("esc 0xf0", IDX_ParseEscFP, 0, 0, OP_ESCF0, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 338 | OP("esc 0xf1", IDX_ParseEscFP, 0, 0, OP_ESCF1, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 339 | OP("esc 0xf2", IDX_ParseEscFP, 0, 0, OP_ESCF2, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 340 | OP("esc 0xf3", IDX_ParseEscFP, 0, 0, OP_ESCF3, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 341 | OP("esc 0xf4", IDX_ParseEscFP, 0, 0, OP_ESCF4, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 342 | OP("esc 0xf5", IDX_ParseEscFP, 0, 0, OP_ESCF5, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 343 | OP("esc 0xf6", IDX_ParseEscFP, 0, 0, OP_ESCF6, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 344 | OP("esc 0xf7", IDX_ParseEscFP, 0, 0, OP_ESCF7, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 345 |
|
---|
| 346 |
|
---|
| 347 | /* E */
|
---|
[65878] | 348 | OP("loopne %Jb", IDX_ParseImmBRel, 0, 0, OP_LOOPNE, OP_PARM_Jb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 349 | OP("loope %Jb", IDX_ParseImmBRel, 0, 0, OP_LOOPE, OP_PARM_Jb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 350 | OP("loop %Jb", IDX_ParseImmBRel, 0, 0, OP_LOOP, OP_PARM_Jb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
| 351 | OP("j(e)cxz %Jb", IDX_ParseImmBRel, 0, 0, OP_JECXZ, OP_PARM_Jb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_COND_CONTROLFLOW | DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE | DISOPTYPE_RELATIVE_CONTROLFLOW),
|
---|
[41676] | 352 | OP("in AL,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_IN, OP_PARM_REG_AL, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_READ),
|
---|
| 353 | OP("in %eAX,%Ib", IDX_ParseFixedReg, IDX_ParseImmByte, 0, OP_IN, OP_PARM_REG_EAX, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_READ),
|
---|
| 354 | OP("out %Ib,AL", IDX_ParseImmByte, IDX_ParseFixedReg, 0, OP_OUT, OP_PARM_Ib, OP_PARM_REG_AL, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_WRITE),
|
---|
| 355 | OP("out %Ib,%eAX", IDX_ParseImmByte, IDX_ParseFixedReg, 0, OP_OUT, OP_PARM_Ib, OP_PARM_REG_EAX,OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_WRITE),
|
---|
| 356 | OP("call %Jv", IDX_ParseImmVRel, 0, 0, OP_CALL, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_RELATIVE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
[64485] | 357 | OP("jmp %Jv", IDX_ParseImmVRel, 0, 0, OP_JMP, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW | DISOPTYPE_RELATIVE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
[41676] | 358 | OP("jmp %Ap", IDX_ParseImmAddrF, 0, 0, OP_JMP, OP_PARM_Ap, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW | DISOPTYPE_INVALID_64),
|
---|
| 359 | OP("jmp %Jb", IDX_ParseImmBRel, 0, 0, OP_JMP, OP_PARM_Jb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW | DISOPTYPE_RELATIVE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 360 | OP("in AL,DX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_IN, OP_PARM_REG_AL, OP_PARM_REG_DX, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_READ),
|
---|
| 361 | OP("in %eAX,DX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_IN, OP_PARM_REG_EAX, OP_PARM_REG_DX, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_READ),
|
---|
| 362 | OP("out DX,AL", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_OUT, OP_PARM_REG_DX, OP_PARM_REG_AL, OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_WRITE),
|
---|
| 363 | OP("out DX,%eAX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_OUT, OP_PARM_REG_DX, OP_PARM_REG_EAX,OP_PARM_NONE, DISOPTYPE_PORTIO | DISOPTYPE_PRIVILEGED | DISOPTYPE_PORTIO_WRITE),
|
---|
[1] | 364 |
|
---|
| 365 |
|
---|
| 366 | /* F */
|
---|
[41676] | 367 | OP("lock", 0, 0, 0, OP_LOCK, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 368 | /* softice bp */
|
---|
| 369 | INVALID_OPCODE,
|
---|
[41676] | 370 | OP("repne", 0, 0, 0, OP_REPNE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 371 | OP("rep(e)", 0, 0, 0, OP_REPE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 372 | OP("hlt", 0, 0, 0, OP_HLT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_PRIVILEGED),
|
---|
| 373 | OP("cmc", 0, 0, 0, OP_CMC, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 374 | OP("Unary Grp3 %Eb", IDX_ParseGrp3, 0, 0, OP_UNARY_GRP3, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 375 | OP("Unary Grp3 %Ev", IDX_ParseGrp3, 0, 0, OP_UNARY_GRP3, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 376 | OP("clc", 0, 0, 0, OP_CLC, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 377 | OP("stc", 0, 0, 0, OP_STC, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 378 | OP("cli", 0, 0, 0, OP_CLI, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 379 | OP("sti", 0, 0, 0, OP_STI, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED | DISOPTYPE_INHIBIT_IRQS),
|
---|
| 380 | OP("cld", 0, 0, 0, OP_CLD, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 381 | OP("std", 0, 0, 0, OP_STD, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 382 | OP("inc/dec Grp4", IDX_ParseGrp4, 0, 0, OP_INC_GRP4, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 383 | OP("Indirect Grp5", IDX_ParseGrp5, 0, 0, OP_IND_GRP5, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 384 | };
|
---|
| 385 |
|
---|
| 386 |
|
---|
[41690] | 387 | const DISOPCODE g_aTwoByteMapX86[256] =
|
---|
[1] | 388 | {
|
---|
| 389 | /* 0 */
|
---|
[41676] | 390 | OP("Grp6", IDX_ParseGrp6, 0, 0, OP_GRP6, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 391 | OP("Grp7", IDX_ParseGrp7, 0, 0, OP_GRP7, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 392 | OP("lar %Gv,%Ew", IDX_ParseModRM, IDX_UseModRM, 0, OP_LAR, OP_PARM_Gv, OP_PARM_Ew, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
| 393 | OP("lsl %Gv,%Ew", IDX_ParseModRM, IDX_UseModRM, 0, OP_LSL, OP_PARM_Gv, OP_PARM_Ew, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
[1] | 394 | INVALID_OPCODE,
|
---|
[41676] | 395 | OP("syscall", 0, 0, 0, OP_SYSCALL, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_ONLY_64),
|
---|
| 396 | OP("clts", 0, 0, 0, OP_CLTS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_PRIVILEGED),
|
---|
| 397 | OP("sysret", 0, 0, 0, OP_SYSRET, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW | DISOPTYPE_ONLY_64),
|
---|
| 398 | OP("invd", 0, 0, 0, OP_INVD, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_PRIVILEGED),
|
---|
| 399 | OP("wbinvd", 0, 0, 0, OP_WBINVD, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_PRIVILEGED),
|
---|
[1] | 400 | INVALID_OPCODE,
|
---|
[41676] | 401 | OP("Two Byte Illegal Opcodes UD2", 0, 0, 0, OP_ILLUD2, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_ILLEGAL),
|
---|
[1] | 402 | INVALID_OPCODE,
|
---|
| 403 | /* NOP Ev or prefetch (Intel vs AMD) */
|
---|
[41676] | 404 | OP("nop %Ev/prefetch", IDX_ParseModRM, 0, 0, OP_NOP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 405 | OP("femms", 0, 0, 0, OP_FEMMS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 406 | OP("3DNow! Esc", IDX_Parse3DNow, 0, 0, OP_3DNOW, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 407 |
|
---|
| 408 | /* 1 */
|
---|
[41676] | 409 | OP("movups %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVUPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 410 | OP("movups %Wps,%Vps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVUPS, OP_PARM_Wps, OP_PARM_Vps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53245] | 411 | /* Next instruction has the following format:
|
---|
| 412 | * &name1/name2,
|
---|
| 413 | * where name1 is used when one of the operands
|
---|
| 414 | * is a location in memory, name2 otherwise. */
|
---|
[53172] | 415 | OP("&movlps/movhlps %Vq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVLPS, OP_PARM_Vq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 416 | OP("movlps %Wq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVLPS, OP_PARM_Wq, OP_PARM_Vq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 417 | OP("unpcklps %Vps,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_UNPCKLPS, OP_PARM_Vps, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 418 | OP("unpckhps %Vps,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_UNPCKHPS, OP_PARM_Vps, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 419 | /* can also be movlhps when reg->reg */
|
---|
[53172] | 420 | OP("&movhps/movlhps %Vq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVHPS, OP_PARM_Wq, OP_PARM_Vq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 421 | OP("movhps %Wq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVHPS, OP_PARM_Vq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 422 | OP("prefetch Grp16", IDX_ParseGrp16, 0, 0, OP_PREFETCH_GRP16, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 423 | INVALID_OPCODE,
|
---|
| 424 | INVALID_OPCODE,
|
---|
| 425 | INVALID_OPCODE,
|
---|
| 426 | INVALID_OPCODE,
|
---|
| 427 | INVALID_OPCODE,
|
---|
| 428 | INVALID_OPCODE,
|
---|
[41676] | 429 | OP("nop %Ev", IDX_ParseModRM, 0, 0, OP_NOP, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 430 |
|
---|
| 431 | /* 2 */
|
---|
[41676] | 432 | OP("mov %Rd,%Cd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV_CR, OP_PARM_Rd, OP_PARM_Cd, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED | DISOPTYPE_MOD_FIXED_11 | DISOPTYPE_FORCED_32_OP_SIZE_X86),
|
---|
| 433 | OP("mov %Rd,%Dd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV_DR, OP_PARM_Rd, OP_PARM_Dd, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED | DISOPTYPE_MOD_FIXED_11 | DISOPTYPE_FORCED_32_OP_SIZE_X86),
|
---|
| 434 | OP("mov %Cd,%Rd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV_CR, OP_PARM_Cd, OP_PARM_Rd, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED | DISOPTYPE_MOD_FIXED_11 | DISOPTYPE_FORCED_32_OP_SIZE_X86),
|
---|
| 435 | OP("mov %Dd,%Rd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV_DR, OP_PARM_Dd, OP_PARM_Rd, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED | DISOPTYPE_MOD_FIXED_11 | DISOPTYPE_FORCED_32_OP_SIZE_X86),
|
---|
[1] | 436 | /* only valid for Pentium Pro & Pentium II */
|
---|
[41676] | 437 | OP("mov %Rd,%Td", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV_TR, OP_PARM_Rd, OP_PARM_Td, OP_PARM_NONE, DISOPTYPE_PRIVILEGED),
|
---|
[1] | 438 | INVALID_OPCODE,
|
---|
| 439 | /* only valid for Pentium Pro & Pentium II */
|
---|
[41676] | 440 | OP("mov %Td,%Rd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOV_TR, OP_PARM_Td, OP_PARM_Rd, OP_PARM_NONE, DISOPTYPE_PRIVILEGED),
|
---|
[1] | 441 | INVALID_OPCODE,
|
---|
| 442 |
|
---|
[41676] | 443 | OP("movaps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVAPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 444 | OP("movaps %Wps,%Vps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVAPS, OP_PARM_Wps, OP_PARM_Vps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 445 | OP("cvtpi2ps %Vps,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPI2PS,OP_PARM_Vps, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 446 | OP("movntps %Wps,%Vps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVNTPS, OP_PARM_Wps, OP_PARM_Vps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 447 | OP("cvttps2pi %Qq,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTTPS2PI,OP_PARM_Qq, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 448 | OP("cvtps2pi %Qq,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPS2PI,OP_PARM_Qq, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 449 | OP("ucomiss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_UCOMISS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 450 | OP("comiss %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_COMISS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 451 |
|
---|
| 452 | /* 3 */
|
---|
[41676] | 453 | OP("wrmsr", 0, 0, 0, OP_WRMSR, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 454 | OP("rdtsc", 0, 0, 0, OP_RDTSC, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_POTENTIALLY_DANGEROUS),
|
---|
| 455 | OP("rdmsr", 0, 0, 0, OP_RDMSR, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_PRIVILEGED),
|
---|
| 456 | OP("rdpmc", 0, 0, 0, OP_RDPMC, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_PRIVILEGED),
|
---|
| 457 | OP("sysenter", 0, 0, 0, OP_SYSENTER,OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW),
|
---|
| 458 | OP("sysexit", 0, 0, 0, OP_SYSEXIT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW),
|
---|
[1] | 459 | INVALID_OPCODE,
|
---|
[53052] | 460 | OP("getsec", 0, 0, 0, OP_GETSEC, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[65876] | 461 | OP("3 byte escape A4", IDX_ParseThreeByteEsc4, 0, 0, OP_3B_ESC4, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 462 | INVALID_OPCODE,
|
---|
[65876] | 463 | OP("3 byte escape A5", IDX_ParseThreeByteEsc5, 0, 0, OP_3B_ESC5, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 464 | INVALID_OPCODE,
|
---|
| 465 | /* SSE2 */
|
---|
| 466 | INVALID_OPCODE,
|
---|
| 467 | INVALID_OPCODE,
|
---|
| 468 | INVALID_OPCODE,
|
---|
[61017] | 469 | INVALID_OPCODE,
|
---|
[1] | 470 |
|
---|
| 471 | /* 4 */
|
---|
[41676] | 472 | OP("cmovo %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVO, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 473 | OP("cmovno %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNO, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 474 | OP("cmovc %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVC, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 475 | OP("cmovnc %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNC, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 476 | OP("cmovz %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVZ, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 477 | OP("cmovnz %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNZ, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 478 | OP("cmovbe %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVBE, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 479 | OP("cmovnbe %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNBE, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 480 | OP("cmovs %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVS, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 481 | OP("cmovns %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNS, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 482 | OP("cmovp %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVP, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 483 | OP("cmovnp %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNP, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 484 | OP("cmovl %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVL, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 485 | OP("cmovnl %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNL, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 486 | OP("cmovle %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVLE, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 487 | OP("cmovnle %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMOVNLE, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 488 |
|
---|
| 489 | /* 5 */
|
---|
[41676] | 490 | OP("movmskps %Ed,%Vps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVMSKPS,OP_PARM_Ed, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 491 | OP("sqrtps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_SQRTPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 492 | OP("rsqrtps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_RSQRTPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 493 | OP("rcpps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_RCPPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 494 | OP("andps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_ANDPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 495 | OP("andnps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_ANDNPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 496 | OP("orps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_ORPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 497 | OP("xorps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_XORPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 498 | OP("addps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADDPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 499 | OP("mulps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MULPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 500 | OP("cvtps2pd %Vpd,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPS2PD,OP_PARM_Vpd, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 501 | OP("cvtdq2ps %Vps,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTDQ2PS,OP_PARM_Vps, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 502 | OP("subps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUBPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 503 | OP("minps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MINPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 504 | OP("divps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_DIVPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 505 | OP("maxps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_MAXPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 506 |
|
---|
| 507 | /* 6 */
|
---|
[41676] | 508 | OP("punpcklbw %Pq,%Qd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKLBW, OP_PARM_Pq, OP_PARM_Qd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 509 | OP("punpcklwd %Pq,%Qd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKLWD, OP_PARM_Pq, OP_PARM_Qd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 510 | OP("punpckldq %Pq,%Qd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKLDQ, OP_PARM_Pq, OP_PARM_Qd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 511 | OP("packsswb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PACKSSWB,OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 512 | OP("pcmpgtb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPGTB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 513 | OP("pcmpgtw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPGTW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 514 | OP("pcmpgtd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPGTD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 515 | OP("packuswb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PACKUSWB,OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 516 | OP("punpckhbw %Pq,%Qd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKHBW, OP_PARM_Pq, OP_PARM_Qd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 517 | OP("punpckhwd %Pq,%Qd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKHWD, OP_PARM_Pq, OP_PARM_Qd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 518 | OP("punpckhdq %Pq,%Qd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKHDQ, OP_PARM_Pq, OP_PARM_Qd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 519 | OP("packssdw %Pq,%Qd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PACKSSDW,OP_PARM_Pq, OP_PARM_Qd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[36766] | 520 | INVALID_OPCODE, /** @todo 0x0f 0x6c punpcklqdq Vdq,Wdq */
|
---|
| 521 | INVALID_OPCODE, /** @todo 0x0f 0x6d punpckhqdq Vdq,Wdq */
|
---|
[41676] | 522 | OP("movd %Pd,%Ed", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVD, OP_PARM_Pd, OP_PARM_Ed, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 523 | OP("movq %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVQ, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 524 |
|
---|
| 525 | /* 7 */
|
---|
[41676] | 526 | OP("pshufw %Pq,%Qq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PSHUFW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 527 | OP("Grp12", IDX_ParseGrp12, 0, 0, OP_GRP12, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 528 | OP("Grp13", IDX_ParseGrp13, 0, 0, OP_GRP13, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 529 | OP("Grp14", IDX_ParseGrp14, 0, 0, OP_GRP14, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 530 | OP("pcmpeqb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPEQB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 531 | OP("pcmpeqw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPEQW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 532 | OP("pcmpeqd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPEQD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 533 | OP("emms", 0, 0, 0, OP_EMMS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53007] | 534 | OP("vmread %Ey,%Gy", IDX_ParseModRM, IDX_UseModRM, 0, OP_VMREAD, OP_PARM_Ey, OP_PARM_Gy, OP_PARM_NONE, DISOPTYPE_HARMLESS|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 535 | OP("vmwrite %Gy,%Ey", IDX_ParseModRM, IDX_UseModRM, 0, OP_VMWRITE, OP_PARM_Gy, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
[41676] | 536 | OP("MMX UD 0x7A", 0, 0, 0, OP_MMX_UD7A,OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 537 | OP("MMX UD 0x7B", 0, 0, 0, OP_MMX_UD7B,OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 538 | OP("MMX UD 0x7C", 0, 0, 0, OP_MMX_UD7C,OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS), /** @todo 0x0f 0x7c haddpd/haddps */
|
---|
| 539 | OP("MMX UD 0x7D", 0, 0, 0, OP_MMX_UD7D,OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS), /** @todo 0x0f 0x7d hsubpd/hsubps */
|
---|
| 540 | OP("movd %Ed,%Pd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVD, OP_PARM_Ed, OP_PARM_Pd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 541 | OP("movq %Qq,%Pq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVQ, OP_PARM_Qq, OP_PARM_Pq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 542 |
|
---|
| 543 | /* 8 */
|
---|
[41676] | 544 | OP("jo %Jv", IDX_ParseImmVRel, 0, 0, OP_JO, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 545 | OP("jno %Jv", IDX_ParseImmVRel, 0, 0, OP_JNO, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 546 | OP("jc %Jv", IDX_ParseImmVRel, 0, 0, OP_JC, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 547 | OP("jnc %Jv", IDX_ParseImmVRel, 0, 0, OP_JNC, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 548 | OP("je %Jv", IDX_ParseImmVRel, 0, 0, OP_JE, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 549 | OP("jne %Jv", IDX_ParseImmVRel, 0, 0, OP_JNE, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 550 | OP("jbe %Jv", IDX_ParseImmVRel, 0, 0, OP_JBE, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 551 | OP("jnbe %Jv", IDX_ParseImmVRel, 0, 0, OP_JNBE, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 552 | OP("js %Jv", IDX_ParseImmVRel, 0, 0, OP_JS, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 553 | OP("jns %Jv", IDX_ParseImmVRel, 0, 0, OP_JNS, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 554 | OP("jp %Jv", IDX_ParseImmVRel, 0, 0, OP_JP, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 555 | OP("jnp %Jv", IDX_ParseImmVRel, 0, 0, OP_JNP, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 556 | OP("jl %Jv", IDX_ParseImmVRel, 0, 0, OP_JL, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 557 | OP("jnl %Jv", IDX_ParseImmVRel, 0, 0, OP_JNL, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 558 | OP("jle %Jv", IDX_ParseImmVRel, 0, 0, OP_JLE, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 559 | OP("jnle %Jv", IDX_ParseImmVRel, 0, 0, OP_JNLE, OP_PARM_Jv, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW|DISOPTYPE_RELATIVE_CONTROLFLOW|DISOPTYPE_COND_CONTROLFLOW|DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
[1] | 560 |
|
---|
| 561 | /* 9 */
|
---|
[41676] | 562 | OP("seto %Eb", IDX_ParseModRM, 0, 0, OP_SETO, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 563 | OP("setno %Eb", IDX_ParseModRM, 0, 0, OP_SETNO, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 564 | OP("setc %Eb", IDX_ParseModRM, 0, 0, OP_SETC, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 565 | OP("setnc %Eb", IDX_ParseModRM, 0, 0, OP_SETNC, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 566 | OP("sete %Eb", IDX_ParseModRM, 0, 0, OP_SETE, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 567 | OP("setne %Eb", IDX_ParseModRM, 0, 0, OP_SETNE, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 568 | OP("setbe %Eb", IDX_ParseModRM, 0, 0, OP_SETBE, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 569 | OP("setnbe %Eb", IDX_ParseModRM, 0, 0, OP_SETNBE, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 570 | OP("sets %Eb", IDX_ParseModRM, 0, 0, OP_SETS, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 571 | OP("setns %Eb", IDX_ParseModRM, 0, 0, OP_SETNS, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 572 | OP("setp %Eb", IDX_ParseModRM, 0, 0, OP_SETP, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 573 | OP("setnp %Eb", IDX_ParseModRM, 0, 0, OP_SETNP, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 574 | OP("setl %Eb", IDX_ParseModRM, 0, 0, OP_SETL, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 575 | OP("setnl %Eb", IDX_ParseModRM, 0, 0, OP_SETNL, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 576 | OP("setle %Eb", IDX_ParseModRM, 0, 0, OP_SETLE, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 577 | OP("setnle %Eb", IDX_ParseModRM, 0, 0, OP_SETNLE, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 578 |
|
---|
| 579 | /* a */
|
---|
[41676] | 580 | OP("push fs", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_FS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
| 581 | OP("pop fs", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_FS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
| 582 | OP("cpuid", 0, 0, 0, OP_CPUID, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_POTENTIALLY_DANGEROUS),
|
---|
| 583 | OP("bt %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_BT, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 584 | OP("shld %Ev,%Gv,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_SHLD, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 585 | OP("shld %Ev,%Gv,CL", IDX_ParseModRM, IDX_UseModRM, 0, OP_SHLD, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 586 | INVALID_OPCODE,
|
---|
| 587 | INVALID_OPCODE,
|
---|
[41676] | 588 | OP("push gs", IDX_ParseFixedReg, 0, 0, OP_PUSH, OP_PARM_REG_GS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
| 589 | OP("pop gs", IDX_ParseFixedReg, 0, 0, OP_POP, OP_PARM_REG_GS, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
| 590 | OP("rsm", 0, 0, 0, OP_RSM, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 591 | OP("bts %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_BTS, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 592 | OP("shrd %Ev,%Gv,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_SHRD, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 593 | OP("shrd %Ev,%Gv,CL", IDX_ParseModRM, IDX_UseModRM, IDX_ParseFixedReg,OP_SHRD, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_REG_CL, DISOPTYPE_HARMLESS),
|
---|
| 594 | OP("Grp15", IDX_ParseGrp15, 0, 0, OP_GRP15, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 595 | OP("imul %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_IMUL, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 596 |
|
---|
| 597 | /* b */
|
---|
[41676] | 598 | OP("cmpxchg %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMPXCHG, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 599 | OP("cmpxchg %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_CMPXCHG, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 600 | OP("lss %Gv,%Mp", IDX_ParseModRM, IDX_UseModRM, 0, OP_LSS, OP_PARM_Gv, OP_PARM_Mp, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_RRM_DANGEROUS),
|
---|
| 601 | OP("btr %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_BTR, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 602 | OP("lfs %Gv,%Mp", IDX_ParseModRM, IDX_UseModRM, 0, OP_LFS, OP_PARM_Gv, OP_PARM_Mp, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 603 | OP("lgs %Gv,%Mp", IDX_ParseModRM, IDX_UseModRM, 0, OP_LGS, OP_PARM_Gv, OP_PARM_Mp, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 604 | OP("movzx %Gv,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVZX, OP_PARM_Gv, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 605 | OP("movzx %Gv,%Ew", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVZX, OP_PARM_Gv, OP_PARM_Ew, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[36766] | 606 | INVALID_OPCODE, /** @todo 0x0f 0xb8 popcnt Gv,Ev / jmpe */
|
---|
[41676] | 607 | OP("Grp10 Invalid Op", IDX_ParseGrp10, 0, 0, OP_GRP10_INV,OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 608 | OP("Grp8", IDX_ParseGrp8, 0, 0, OP_GRP8, OP_PARM_Ev, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 609 | OP("btc %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_BTC, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[42719] | 610 | OP("bsf %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_BSF, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 611 | OP("bsr %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_BSR, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 612 | OP("movsx %Gv,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSX, OP_PARM_Gv, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 613 | OP("movsx %Gv,%Ew", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSX, OP_PARM_Gv, OP_PARM_Ew, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 614 |
|
---|
| 615 | /* c */
|
---|
[41676] | 616 | OP("xadd %Eb,%Gb", IDX_ParseModRM, IDX_UseModRM, 0, OP_XADD, OP_PARM_Eb, OP_PARM_Gb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 617 | OP("xadd %Ev,%Gv", IDX_ParseModRM, IDX_UseModRM, 0, OP_XADD, OP_PARM_Ev, OP_PARM_Gv, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 618 | OP("cmpps %Vps,%Wps,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_CMPPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 619 | /* SSE2 */
|
---|
[61017] | 620 | OP("movnti %Ed,%Gd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVNTI, OP_PARM_Ed, OP_PARM_Gd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 621 | OP("pinsrw %Pq,%Ed,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_PINSRW, OP_PARM_Pq, OP_PARM_Ed, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 622 | OP("pextrw %Gd,%Pq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_PEXTRW, OP_PARM_Gd, OP_PARM_Pq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 623 | OP("shufps %Vps,%Wps,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_SHUFPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 624 | OP("Grp9", IDX_ParseGrp9, 0, 0, OP_GRP9, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 625 | OP("bswap EAX", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_EAX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 626 | OP("bswap ECX", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_ECX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 627 | OP("bswap EDX", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_EDX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 628 | OP("bswap EBX", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_EBX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 629 | OP("bswap ESP", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_ESP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 630 | OP("bswap EBP", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_EBP, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 631 | OP("bswap ESI", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_ESI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
| 632 | OP("bswap EDI", IDX_ParseFixedReg, 0, 0, OP_BSWAP, OP_PARM_REG_EDI, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_REXB_EXTENDS_OPREG),
|
---|
[1] | 633 |
|
---|
| 634 | /* d */
|
---|
[36766] | 635 | INVALID_OPCODE, /** @todo 0x0f 0xd0 addsubpd/addsubps */
|
---|
[41676] | 636 | OP("psrlw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRLW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 637 | OP("psrld %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRLD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 638 | OP("psrlq %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRLQ, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 639 | OP("paddq %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDQ, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 640 | OP("pmullw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULLW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[36766] | 641 | INVALID_OPCODE, /** @todo 0x0f 0xd7 pmovmskb/pmovmskb */
|
---|
[47412] | 642 | OP("pmovmskb %Gd,%Pq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVMSKB,OP_PARM_Gd, OP_PARM_Pq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 643 | OP("psubusb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBUSB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 644 | OP("psubusw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBUSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 645 | OP("pminub %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINUB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 646 | OP("pand %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PAND, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 647 | OP("paddusb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDUSB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 648 | OP("paddusw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDUSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 649 | OP("pmaxub %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXUB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 650 | OP("pandn %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PANDN, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 651 |
|
---|
| 652 | /* e */
|
---|
[53094] | 653 | OP("pavgb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PAVGB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 654 | OP("psraw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRAW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 655 | OP("psrad %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRAD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 656 | OP("pavgw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PAVGW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 657 | OP("pmulhuw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULHUW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 658 | OP("pmulhw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULHW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 659 | INVALID_OPCODE,
|
---|
[41676] | 660 | OP("movntq %Wq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVNTQ, OP_PARM_Wq, OP_PARM_Vq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 661 | OP("psubsb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBSB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 662 | OP("psubsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 663 | OP("pminsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 664 | OP("por %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_POR, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 665 | OP("paddsb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDSB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 666 | OP("paddsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 667 | OP("pmaxsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 668 | OP("pxor %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PXOR, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 669 |
|
---|
| 670 | /* f */
|
---|
[53094] | 671 | INVALID_OPCODE,
|
---|
[41676] | 672 | OP("psllw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSLLW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 673 | OP("pslld %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSLLD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 674 | OP("psllq %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSSQ, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 675 | OP("pmuludq %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULUDQ, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 676 | OP("pmaddwd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMADDWD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 677 | OP("psadbw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSADBW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 678 | OP("maskmovq %Ppi,%Qpi", IDX_ParseModRM, IDX_UseModRM, 0, OP_MASKMOVQ,OP_PARM_Ppi, OP_PARM_Qpi, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 679 | OP("psubb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 680 | OP("psubw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 681 | OP("psubd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 682 | OP("psubq %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBQ, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 683 | OP("paddb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 684 | OP("paddw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 685 | OP("paddd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 686 | INVALID_OPCODE,
|
---|
| 687 | };
|
---|
| 688 |
|
---|
[41692] | 689 | /** Two byte opcode map with prefix 0x66 */
|
---|
[41690] | 690 | const DISOPCODE g_aTwoByteMapX86_PF66[256] =
|
---|
[1] | 691 | {
|
---|
| 692 | /* 0 */
|
---|
| 693 | INVALID_OPCODE_BLOCK
|
---|
| 694 |
|
---|
| 695 | /* 1 */
|
---|
[41676] | 696 | OP("movupd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVUPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 697 | OP("movupd %Wpd,%Vpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVUPD, OP_PARM_Wpd, OP_PARM_Vpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 698 | OP("movlpd %Vq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVLPD, OP_PARM_Vq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[61135] | 699 | OP("movlpd %Wq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVLPD, OP_PARM_Wq, OP_PARM_Vq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 700 | OP("unpcklpd %Vpd,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_UNPCKLPD,OP_PARM_Vpd, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 701 | OP("unpckhpd %Vpd,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_UNPCKHPD,OP_PARM_Vpd, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 702 | OP("movhpd %Vq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVHPD, OP_PARM_Vq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 703 | OP("movhpd %Wq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVHPD, OP_PARM_Wq, OP_PARM_Vq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 704 | INVALID_OPCODE,
|
---|
| 705 | INVALID_OPCODE,
|
---|
| 706 | INVALID_OPCODE,
|
---|
| 707 | INVALID_OPCODE,
|
---|
| 708 | INVALID_OPCODE,
|
---|
| 709 | INVALID_OPCODE,
|
---|
| 710 | INVALID_OPCODE,
|
---|
| 711 | INVALID_OPCODE,
|
---|
| 712 |
|
---|
| 713 | /* 2 */
|
---|
| 714 | INVALID_OPCODE,
|
---|
| 715 | INVALID_OPCODE,
|
---|
| 716 | INVALID_OPCODE,
|
---|
| 717 | INVALID_OPCODE,
|
---|
| 718 | INVALID_OPCODE,
|
---|
| 719 | INVALID_OPCODE,
|
---|
| 720 | INVALID_OPCODE,
|
---|
| 721 | INVALID_OPCODE,
|
---|
[41676] | 722 | OP("movapd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVAPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 723 | OP("movapd %Wpd,%Vpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVAPD, OP_PARM_Wpd, OP_PARM_Vpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 724 | OP("cvtpi2pd %Vpd,%Qdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPI2PD,OP_PARM_Vpd, OP_PARM_Qdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 725 | OP("movntpd %Wpd,%Vpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVNTPD, OP_PARM_Wpd, OP_PARM_Vpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 726 | OP("cvttpd2pi %Qdq,%Wpd",IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTTPD2PI,OP_PARM_Qdq, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 727 | OP("cvtpd2pi %Qdq,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPD2PI,OP_PARM_Qdq, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 728 | OP("ucomisd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_UCOMISD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 729 | OP("comisd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_COMISD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 730 |
|
---|
| 731 | /* 3 */
|
---|
[13088] | 732 | INVALID_OPCODE,
|
---|
| 733 | INVALID_OPCODE,
|
---|
| 734 | INVALID_OPCODE,
|
---|
| 735 | INVALID_OPCODE,
|
---|
| 736 | INVALID_OPCODE,
|
---|
| 737 | INVALID_OPCODE,
|
---|
| 738 | INVALID_OPCODE,
|
---|
| 739 | INVALID_OPCODE,
|
---|
[65876] | 740 | OP("3 byte escape A4", IDX_ParseThreeByteEsc4, 0, 0, OP_3B_ESC4, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13088] | 741 | INVALID_OPCODE,
|
---|
[65876] | 742 | OP("3 byte escape A5", IDX_ParseThreeByteEsc5, 0, 0, OP_3B_ESC5, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13088] | 743 | INVALID_OPCODE,
|
---|
| 744 | INVALID_OPCODE,
|
---|
| 745 | INVALID_OPCODE,
|
---|
| 746 | INVALID_OPCODE,
|
---|
| 747 | INVALID_OPCODE,
|
---|
[1] | 748 |
|
---|
| 749 | /* 4 */
|
---|
| 750 | INVALID_OPCODE_BLOCK
|
---|
| 751 |
|
---|
| 752 | /* 5 */
|
---|
[41676] | 753 | OP("movmskpd %Ed,%Vpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVMSKPD,OP_PARM_Ed, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 754 | OP("sqrtpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_SQRTPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 755 | INVALID_OPCODE,
|
---|
| 756 | INVALID_OPCODE,
|
---|
[41676] | 757 | OP("andpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_ANDPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 758 | OP("andnpd %Vps,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_ANDNPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 759 | OP("orpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_ORPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 760 | OP("xorpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_XORPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 761 | OP("addpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADDPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 762 | OP("mulpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MULPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 763 | OP("cvtpd2ps %Vps,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPD2PS,OP_PARM_Vps, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[61135] | 764 | OP("cvtps2dq %Vdq,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPS2DQ,OP_PARM_Vdq, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 765 | OP("subpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUBPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 766 | OP("minpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MINPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 767 | OP("divpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_DIVPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 768 | OP("maxpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MAXPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 769 |
|
---|
| 770 | /* 6 */
|
---|
[41676] | 771 | OP("punpcklbw %Vdq,%Wdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKLBW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 772 | OP("punpcklwd %Vdq,%Wdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKLWD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 773 | OP("punpckldq %Vdq,%Wdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKLDQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 774 | OP("packsswb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PACKSSWB,OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 775 | OP("pcmpgtb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPGTB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 776 | OP("pcmpgtw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPGTW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 777 | OP("pcmpgtd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPGTD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 778 | OP("packuswb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PACKUSWB,OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 779 | OP("punpckhbw %Pdq,%Qdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKHBW, OP_PARM_Pdq, OP_PARM_Qdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 780 | OP("punpckhwd %Pdq,%Qdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKHWD, OP_PARM_Pdq, OP_PARM_Qdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 781 | OP("punpckhdq %Pdq,%Qdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKHDQ, OP_PARM_Pdq, OP_PARM_Qdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 782 | OP("packssdw %Pdq,%Qdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PACKSSDW,OP_PARM_Pdq, OP_PARM_Qdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 783 | OP("punpcklqdq %Vdq,%Wdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKLQDQ,OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 784 | OP("punpckhqdq %Vdq,%Wdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_PUNPCKHQDQ,OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 785 | OP("movd %Vdq,%Ed", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVD, OP_PARM_Vdq, OP_PARM_Ed, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 786 | OP("movdqa %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVDQA, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 787 |
|
---|
| 788 | /* 7 */
|
---|
[41676] | 789 | OP("pshufd %Vdq,%Wdq,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_PSHUFD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 790 | INVALID_OPCODE,
|
---|
| 791 | INVALID_OPCODE,
|
---|
| 792 | INVALID_OPCODE,
|
---|
[41676] | 793 | OP("pcmpeqb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPEQB, OP_PARM_Vdq, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 794 | OP("pcmpeqw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPEQW, OP_PARM_Vdq, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 795 | OP("pcmpeqd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPEQD, OP_PARM_Vdq, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 796 | INVALID_OPCODE,
|
---|
| 797 | INVALID_OPCODE,
|
---|
| 798 | INVALID_OPCODE,
|
---|
| 799 | INVALID_OPCODE,
|
---|
| 800 | INVALID_OPCODE,
|
---|
[53007] | 801 | INVALID_OPCODE,
|
---|
| 802 | INVALID_OPCODE,
|
---|
[41676] | 803 | OP("movd %Ed,%Vdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVD, OP_PARM_Ed, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 804 | OP("movdqa %Qq,%Pq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVDQA, OP_PARM_Wdq, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 805 |
|
---|
| 806 | /* 8 */
|
---|
| 807 | INVALID_OPCODE_BLOCK
|
---|
| 808 |
|
---|
| 809 | /* 9 */
|
---|
| 810 | INVALID_OPCODE_BLOCK
|
---|
| 811 |
|
---|
| 812 | /* a */
|
---|
| 813 | INVALID_OPCODE_BLOCK
|
---|
| 814 |
|
---|
| 815 | /* b */
|
---|
| 816 | INVALID_OPCODE_BLOCK
|
---|
| 817 |
|
---|
| 818 | /* c */
|
---|
| 819 | INVALID_OPCODE,
|
---|
| 820 | INVALID_OPCODE,
|
---|
[41676] | 821 | OP("cmppd %Vpd,%Wpd,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_CMPPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 822 | INVALID_OPCODE,
|
---|
[41676] | 823 | OP("pinsrw %Vdq,%Ed,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_PINSRW, OP_PARM_Vdq, OP_PARM_Ed, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 824 | OP("pextrw %Gd,%Vdq,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_PEXTRW, OP_PARM_Gd, OP_PARM_Vdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 825 | OP("shufpd %Vpd,%Wpd,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_SHUFPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 826 | INVALID_OPCODE,
|
---|
| 827 | INVALID_OPCODE,
|
---|
| 828 | INVALID_OPCODE,
|
---|
| 829 | INVALID_OPCODE,
|
---|
| 830 | INVALID_OPCODE,
|
---|
| 831 | INVALID_OPCODE,
|
---|
| 832 | INVALID_OPCODE,
|
---|
| 833 | INVALID_OPCODE,
|
---|
| 834 | INVALID_OPCODE,
|
---|
| 835 |
|
---|
| 836 | /* d */
|
---|
| 837 | INVALID_OPCODE,
|
---|
[41676] | 838 | OP("psrlw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRLW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 839 | OP("psrld %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRLD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 840 | OP("psrlq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRLQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 841 | OP("paddq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 842 | OP("pmullw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULLW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 843 | OP("movq %Wq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVQ, OP_PARM_Wq, OP_PARM_Vq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[47412] | 844 | OP("pmovmskb %Gd,%Vdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVMSKB,OP_PARM_Gd, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 845 | OP("psubusb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBUSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 846 | OP("psubusw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBUSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 847 | OP("pminub %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINUB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 848 | OP("pand %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PAND, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 849 | OP("paddusb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDUSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 850 | OP("paddusw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDUSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 851 | OP("pmaxub %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXUB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 852 | OP("pandn %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PANDN, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 853 |
|
---|
| 854 | /* e */
|
---|
[53094] | 855 | OP("pavgb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PAVGB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 856 | OP("psraw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRAW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 857 | OP("psrad %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSRAD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 858 | OP("pavgw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PAVGW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 859 | OP("pmulhuw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULHUW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 860 | OP("pmulhw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULHW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 861 | OP("cvttpd2dq %Vdq,%Wpd",IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTTPD2DQ,OP_PARM_Vdq, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 862 | OP("movntdq %Wdq,%Vdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVNTDQ, OP_PARM_Wdq, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 863 | OP("psubsb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 864 | OP("psubsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 865 | OP("pminsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 866 | OP("por %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_POR, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 867 | OP("paddsb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 868 | OP("paddsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 869 | OP("pmaxsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 870 | OP("pxor %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PXOR, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 871 |
|
---|
| 872 | /* f */
|
---|
| 873 | INVALID_OPCODE,
|
---|
[41676] | 874 | OP("psllw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSLLW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 875 | OP("pslld %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSLLD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 876 | OP("psllq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSSQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 877 | OP("pmuludq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULUDQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 878 | OP("pmaddwd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMADDWD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 879 | OP("psadbw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSADBW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 880 | OP("maskmovdqu %Vdq,%Wdq",IDX_ParseModRM, IDX_UseModRM, 0, OP_MASKMOVDQU, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 881 | OP("psubb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 882 | OP("psubw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 883 | OP("psubd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 884 | OP("psubq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSUBD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 885 | OP("paddb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 886 | OP("paddw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 887 | OP("paddd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PADDD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 888 | INVALID_OPCODE,
|
---|
| 889 | };
|
---|
| 890 |
|
---|
| 891 | /* Two byte opcode map with prefix 0xF2 */
|
---|
[41690] | 892 | const DISOPCODE g_aTwoByteMapX86_PFF2[256] =
|
---|
[1] | 893 | {
|
---|
| 894 | /* 0 */
|
---|
| 895 | INVALID_OPCODE_BLOCK
|
---|
| 896 |
|
---|
| 897 | /* 1 */
|
---|
[41676] | 898 | OP("movsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 899 | OP("movsd %Wsd,%Vsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSD, OP_PARM_Wpd, OP_PARM_Vpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53052] | 900 | OP("movddup %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVDDUP, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 901 | INVALID_OPCODE,
|
---|
| 902 | INVALID_OPCODE,
|
---|
| 903 | INVALID_OPCODE,
|
---|
| 904 | INVALID_OPCODE,
|
---|
| 905 | INVALID_OPCODE,
|
---|
| 906 | INVALID_OPCODE,
|
---|
| 907 | INVALID_OPCODE,
|
---|
| 908 | INVALID_OPCODE,
|
---|
| 909 | INVALID_OPCODE,
|
---|
| 910 | INVALID_OPCODE,
|
---|
| 911 | INVALID_OPCODE,
|
---|
| 912 | INVALID_OPCODE,
|
---|
| 913 | INVALID_OPCODE,
|
---|
| 914 |
|
---|
| 915 | /* 2 */
|
---|
| 916 | INVALID_OPCODE,
|
---|
| 917 | INVALID_OPCODE,
|
---|
| 918 | INVALID_OPCODE,
|
---|
| 919 | INVALID_OPCODE,
|
---|
| 920 | INVALID_OPCODE,
|
---|
| 921 | INVALID_OPCODE,
|
---|
| 922 | INVALID_OPCODE,
|
---|
| 923 | INVALID_OPCODE,
|
---|
| 924 | INVALID_OPCODE,
|
---|
| 925 | INVALID_OPCODE,
|
---|
[41676] | 926 | OP("cvtsi2sd %Vsd,%Ed", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTSI2SD,OP_PARM_Vsd, OP_PARM_Ed, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 927 | INVALID_OPCODE,
|
---|
[41676] | 928 | OP("cvttsd2si %Gd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTTSD2SI,OP_PARM_Gd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 929 | OP("cvtsd2si %Gd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTSD2SI,OP_PARM_Gd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 930 | INVALID_OPCODE,
|
---|
| 931 | INVALID_OPCODE,
|
---|
| 932 |
|
---|
| 933 | /* 3 */
|
---|
[13241] | 934 | INVALID_OPCODE,
|
---|
| 935 | INVALID_OPCODE,
|
---|
| 936 | INVALID_OPCODE,
|
---|
| 937 | INVALID_OPCODE,
|
---|
| 938 | INVALID_OPCODE,
|
---|
| 939 | INVALID_OPCODE,
|
---|
| 940 | INVALID_OPCODE,
|
---|
| 941 | INVALID_OPCODE,
|
---|
[65876] | 942 | OP("3 byte escape A4", IDX_ParseThreeByteEsc4, 0, 0, OP_3B_ESC4, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 943 | INVALID_OPCODE,
|
---|
| 944 | INVALID_OPCODE,
|
---|
| 945 | INVALID_OPCODE,
|
---|
| 946 | INVALID_OPCODE,
|
---|
| 947 | INVALID_OPCODE,
|
---|
| 948 | INVALID_OPCODE,
|
---|
| 949 | INVALID_OPCODE,
|
---|
[1] | 950 |
|
---|
| 951 | /* 4 */
|
---|
| 952 | INVALID_OPCODE_BLOCK
|
---|
| 953 |
|
---|
| 954 | /* 5 */
|
---|
| 955 | INVALID_OPCODE,
|
---|
[41676] | 956 | OP("sqrtsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_SQRTSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 957 | INVALID_OPCODE,
|
---|
| 958 | INVALID_OPCODE,
|
---|
| 959 | INVALID_OPCODE,
|
---|
| 960 | INVALID_OPCODE,
|
---|
| 961 | INVALID_OPCODE,
|
---|
| 962 | INVALID_OPCODE,
|
---|
[41676] | 963 | OP("addsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADDSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 964 | OP("mulsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MULSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 965 | OP("cvtsd2ss %Vss,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTSD2SS,OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 966 | INVALID_OPCODE,
|
---|
[41676] | 967 | OP("subsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUBSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 968 | OP("minsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MINSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 969 | OP("divsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_DIVSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 970 | OP("maxsd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, OP_MAXSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 971 |
|
---|
| 972 | /* 6 */
|
---|
| 973 | INVALID_OPCODE_BLOCK
|
---|
| 974 |
|
---|
| 975 | /* 7 */
|
---|
[41676] | 976 | OP("pshuflw %Vdq,%Wdq,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_PSHUFLW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 977 | INVALID_OPCODE,
|
---|
| 978 | INVALID_OPCODE,
|
---|
| 979 | INVALID_OPCODE,
|
---|
| 980 | INVALID_OPCODE,
|
---|
| 981 | INVALID_OPCODE,
|
---|
| 982 | INVALID_OPCODE,
|
---|
| 983 | INVALID_OPCODE,
|
---|
| 984 | INVALID_OPCODE,
|
---|
| 985 | INVALID_OPCODE,
|
---|
| 986 | INVALID_OPCODE,
|
---|
| 987 | INVALID_OPCODE,
|
---|
| 988 | INVALID_OPCODE,
|
---|
| 989 | INVALID_OPCODE,
|
---|
| 990 | INVALID_OPCODE,
|
---|
| 991 | INVALID_OPCODE,
|
---|
| 992 |
|
---|
| 993 | /* 8 */
|
---|
| 994 | INVALID_OPCODE_BLOCK
|
---|
| 995 |
|
---|
| 996 | /* 9 */
|
---|
| 997 | INVALID_OPCODE_BLOCK
|
---|
| 998 |
|
---|
| 999 | /* a */
|
---|
| 1000 | INVALID_OPCODE_BLOCK
|
---|
| 1001 |
|
---|
| 1002 | /* b */
|
---|
| 1003 | INVALID_OPCODE_BLOCK
|
---|
| 1004 |
|
---|
| 1005 | /* c */
|
---|
| 1006 | INVALID_OPCODE,
|
---|
| 1007 | INVALID_OPCODE,
|
---|
[41676] | 1008 | OP("cmpsd %Vsd,%Wsd,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_CMPSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 1009 | INVALID_OPCODE,
|
---|
| 1010 | INVALID_OPCODE,
|
---|
| 1011 | INVALID_OPCODE,
|
---|
| 1012 | INVALID_OPCODE,
|
---|
| 1013 | INVALID_OPCODE,
|
---|
| 1014 | INVALID_OPCODE,
|
---|
| 1015 | INVALID_OPCODE,
|
---|
| 1016 | INVALID_OPCODE,
|
---|
| 1017 | INVALID_OPCODE,
|
---|
| 1018 | INVALID_OPCODE,
|
---|
| 1019 | INVALID_OPCODE,
|
---|
| 1020 | INVALID_OPCODE,
|
---|
| 1021 | INVALID_OPCODE,
|
---|
| 1022 |
|
---|
| 1023 | /* d */
|
---|
| 1024 | INVALID_OPCODE,
|
---|
| 1025 | INVALID_OPCODE,
|
---|
| 1026 | INVALID_OPCODE,
|
---|
| 1027 | INVALID_OPCODE,
|
---|
| 1028 | INVALID_OPCODE,
|
---|
| 1029 | INVALID_OPCODE,
|
---|
[41676] | 1030 | OP("movdq2q %Pq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVDQ2Q, OP_PARM_Pq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1031 | INVALID_OPCODE,
|
---|
| 1032 | INVALID_OPCODE,
|
---|
| 1033 | INVALID_OPCODE,
|
---|
| 1034 | INVALID_OPCODE,
|
---|
| 1035 | INVALID_OPCODE,
|
---|
| 1036 | INVALID_OPCODE,
|
---|
| 1037 | INVALID_OPCODE,
|
---|
| 1038 | INVALID_OPCODE,
|
---|
| 1039 | INVALID_OPCODE,
|
---|
| 1040 |
|
---|
| 1041 | /* e */
|
---|
| 1042 | INVALID_OPCODE,
|
---|
| 1043 | INVALID_OPCODE,
|
---|
| 1044 | INVALID_OPCODE,
|
---|
| 1045 | INVALID_OPCODE,
|
---|
| 1046 | INVALID_OPCODE,
|
---|
| 1047 | INVALID_OPCODE,
|
---|
[41676] | 1048 | OP("cvtpd2dq %Vdq,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTPD2DQ,OP_PARM_Vdq, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1049 | INVALID_OPCODE,
|
---|
| 1050 | INVALID_OPCODE,
|
---|
| 1051 | INVALID_OPCODE,
|
---|
| 1052 | INVALID_OPCODE,
|
---|
| 1053 | INVALID_OPCODE,
|
---|
| 1054 | INVALID_OPCODE,
|
---|
| 1055 | INVALID_OPCODE,
|
---|
| 1056 | INVALID_OPCODE,
|
---|
| 1057 | INVALID_OPCODE,
|
---|
| 1058 |
|
---|
| 1059 | /* f */
|
---|
[53094] | 1060 | OP("lddqu %Vdq,%Mdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_LDDQU, OP_PARM_Vdq, OP_PARM_Mdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1061 | INVALID_OPCODE,
|
---|
| 1062 | INVALID_OPCODE,
|
---|
| 1063 | INVALID_OPCODE,
|
---|
| 1064 | INVALID_OPCODE,
|
---|
| 1065 | INVALID_OPCODE,
|
---|
| 1066 | INVALID_OPCODE,
|
---|
| 1067 | INVALID_OPCODE,
|
---|
| 1068 | INVALID_OPCODE,
|
---|
| 1069 | INVALID_OPCODE,
|
---|
| 1070 | INVALID_OPCODE,
|
---|
| 1071 | INVALID_OPCODE,
|
---|
| 1072 | INVALID_OPCODE,
|
---|
| 1073 | INVALID_OPCODE,
|
---|
| 1074 | INVALID_OPCODE,
|
---|
| 1075 | INVALID_OPCODE
|
---|
[1] | 1076 | };
|
---|
| 1077 |
|
---|
| 1078 |
|
---|
| 1079 | /* Two byte opcode map with prefix 0xF3 */
|
---|
[41690] | 1080 | const DISOPCODE g_aTwoByteMapX86_PFF3[256] =
|
---|
[1] | 1081 | {
|
---|
| 1082 | /* 0 */
|
---|
| 1083 | INVALID_OPCODE_BLOCK
|
---|
| 1084 |
|
---|
| 1085 | /* 1 */
|
---|
[41676] | 1086 | OP("movss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1087 | OP("movss %Wss,%Vss", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSS, OP_PARM_Wss, OP_PARM_Vss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53052] | 1088 | OP("movsldup %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSLDUP,OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1089 | INVALID_OPCODE,
|
---|
| 1090 | INVALID_OPCODE,
|
---|
| 1091 | INVALID_OPCODE,
|
---|
[53052] | 1092 | OP("movshdup %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVSHDUP,OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1093 | INVALID_OPCODE,
|
---|
| 1094 | INVALID_OPCODE,
|
---|
| 1095 | INVALID_OPCODE,
|
---|
| 1096 | INVALID_OPCODE,
|
---|
| 1097 | INVALID_OPCODE,
|
---|
| 1098 | INVALID_OPCODE,
|
---|
| 1099 | INVALID_OPCODE,
|
---|
| 1100 | INVALID_OPCODE,
|
---|
| 1101 | INVALID_OPCODE,
|
---|
| 1102 |
|
---|
| 1103 | /* 2 */
|
---|
| 1104 | INVALID_OPCODE,
|
---|
| 1105 | INVALID_OPCODE,
|
---|
| 1106 | INVALID_OPCODE,
|
---|
| 1107 | INVALID_OPCODE,
|
---|
| 1108 | INVALID_OPCODE,
|
---|
| 1109 | INVALID_OPCODE,
|
---|
| 1110 | INVALID_OPCODE,
|
---|
| 1111 | INVALID_OPCODE,
|
---|
| 1112 | INVALID_OPCODE,
|
---|
| 1113 | INVALID_OPCODE,
|
---|
[41676] | 1114 | OP("cvtsi2ss %Vss,%Ed", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTSI2SS,OP_PARM_Vss, OP_PARM_Ed, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1115 | INVALID_OPCODE,
|
---|
[41676] | 1116 | OP("cvttss2si %Gd,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTTSS2SI,OP_PARM_Gd, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1117 | OP("cvtss2si %Gd,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTSS2SI,OP_PARM_Gd, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1118 | INVALID_OPCODE,
|
---|
| 1119 | INVALID_OPCODE,
|
---|
| 1120 |
|
---|
| 1121 | /* 3 */
|
---|
| 1122 | INVALID_OPCODE_BLOCK
|
---|
| 1123 |
|
---|
| 1124 | /* 4 */
|
---|
| 1125 | INVALID_OPCODE_BLOCK
|
---|
| 1126 |
|
---|
| 1127 | /* 5 */
|
---|
| 1128 | INVALID_OPCODE,
|
---|
[41676] | 1129 | OP("sqrtss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_SQRTSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1130 | OP("rsqrtss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_RSQRTSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53052] | 1131 | OP("rcpss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_RCPSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1132 | INVALID_OPCODE,
|
---|
| 1133 | INVALID_OPCODE,
|
---|
| 1134 | INVALID_OPCODE,
|
---|
| 1135 | INVALID_OPCODE,
|
---|
[41676] | 1136 | OP("addss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADDSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1137 | OP("mulss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_MULSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1138 | //??
|
---|
[41676] | 1139 | OP("cvtss2sd %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTSD2SS,OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1140 | OP("cvttps2dq %Vdq,%Wps",IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTTPS2DQ,OP_PARM_Vdq, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1141 | OP("subss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_SUBSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1142 | OP("minss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_MINSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1143 | OP("divss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_DIVSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1144 | OP("maxss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, OP_MAXSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1145 |
|
---|
| 1146 | /* 6 */
|
---|
| 1147 | INVALID_OPCODE,
|
---|
| 1148 | INVALID_OPCODE,
|
---|
| 1149 | INVALID_OPCODE,
|
---|
| 1150 | INVALID_OPCODE,
|
---|
| 1151 | INVALID_OPCODE,
|
---|
| 1152 | INVALID_OPCODE,
|
---|
| 1153 | INVALID_OPCODE,
|
---|
| 1154 | INVALID_OPCODE,
|
---|
| 1155 | INVALID_OPCODE,
|
---|
| 1156 | INVALID_OPCODE,
|
---|
| 1157 | INVALID_OPCODE,
|
---|
| 1158 | INVALID_OPCODE,
|
---|
| 1159 | INVALID_OPCODE,
|
---|
| 1160 | INVALID_OPCODE,
|
---|
[22661] | 1161 | INVALID_OPCODE,
|
---|
[41676] | 1162 | OP("movdqu %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVDQU, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1163 |
|
---|
| 1164 | /* 7 */
|
---|
[41676] | 1165 | OP("pshufhw %Vdq,%Wdq,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_PSHUFHW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 1166 | INVALID_OPCODE,
|
---|
| 1167 | INVALID_OPCODE,
|
---|
| 1168 | INVALID_OPCODE,
|
---|
| 1169 | INVALID_OPCODE,
|
---|
| 1170 | INVALID_OPCODE,
|
---|
| 1171 | INVALID_OPCODE,
|
---|
| 1172 | INVALID_OPCODE,
|
---|
| 1173 | INVALID_OPCODE,
|
---|
| 1174 | INVALID_OPCODE,
|
---|
| 1175 | INVALID_OPCODE,
|
---|
| 1176 | INVALID_OPCODE,
|
---|
| 1177 | INVALID_OPCODE,
|
---|
| 1178 | INVALID_OPCODE,
|
---|
[41676] | 1179 | OP("movq %Vq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVQ, OP_PARM_Vq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1180 | OP("movdqu %Wdq,%Vdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVDQU, OP_PARM_Wdq, OP_PARM_Vdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1181 |
|
---|
| 1182 | /* 8 */
|
---|
| 1183 | INVALID_OPCODE_BLOCK
|
---|
| 1184 |
|
---|
| 1185 | /* 9 */
|
---|
| 1186 | INVALID_OPCODE_BLOCK
|
---|
| 1187 |
|
---|
| 1188 | /* a */
|
---|
| 1189 | INVALID_OPCODE_BLOCK
|
---|
| 1190 |
|
---|
| 1191 | /* b */
|
---|
[53007] | 1192 | INVALID_OPCODE,
|
---|
| 1193 | INVALID_OPCODE,
|
---|
| 1194 | INVALID_OPCODE,
|
---|
| 1195 | INVALID_OPCODE,
|
---|
| 1196 | INVALID_OPCODE,
|
---|
| 1197 | INVALID_OPCODE,
|
---|
| 1198 | INVALID_OPCODE,
|
---|
| 1199 | INVALID_OPCODE,
|
---|
| 1200 | OP("popcnt %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_POPCNT, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1201 | INVALID_OPCODE,
|
---|
| 1202 | INVALID_OPCODE,
|
---|
| 1203 | INVALID_OPCODE,
|
---|
| 1204 | OP("tzcnt %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_TZCNT, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1205 | OP("lzcnt %Gv,%Ev", IDX_ParseModRM, IDX_UseModRM, 0, OP_LZCNT, OP_PARM_Gv, OP_PARM_Ev, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1206 | INVALID_OPCODE,
|
---|
| 1207 | INVALID_OPCODE,
|
---|
[1] | 1208 |
|
---|
| 1209 | /* c */
|
---|
| 1210 | INVALID_OPCODE,
|
---|
| 1211 | INVALID_OPCODE,
|
---|
[41676] | 1212 | OP("cmpss %Vss,%Wss,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte,OP_CMPSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[1] | 1213 | INVALID_OPCODE,
|
---|
| 1214 | INVALID_OPCODE,
|
---|
| 1215 | INVALID_OPCODE,
|
---|
| 1216 | INVALID_OPCODE,
|
---|
| 1217 | INVALID_OPCODE,
|
---|
| 1218 | INVALID_OPCODE,
|
---|
| 1219 | INVALID_OPCODE,
|
---|
| 1220 | INVALID_OPCODE,
|
---|
| 1221 | INVALID_OPCODE,
|
---|
| 1222 | INVALID_OPCODE,
|
---|
| 1223 | INVALID_OPCODE,
|
---|
| 1224 | INVALID_OPCODE,
|
---|
| 1225 | INVALID_OPCODE,
|
---|
| 1226 |
|
---|
| 1227 | /* d */
|
---|
| 1228 | INVALID_OPCODE,
|
---|
| 1229 | INVALID_OPCODE,
|
---|
| 1230 | INVALID_OPCODE,
|
---|
| 1231 | INVALID_OPCODE,
|
---|
| 1232 | INVALID_OPCODE,
|
---|
| 1233 | INVALID_OPCODE,
|
---|
[41676] | 1234 | OP("movq2dq %Vdq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVQ2DQ, OP_PARM_Vdq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1235 | INVALID_OPCODE,
|
---|
| 1236 | INVALID_OPCODE,
|
---|
| 1237 | INVALID_OPCODE,
|
---|
| 1238 | INVALID_OPCODE,
|
---|
| 1239 | INVALID_OPCODE,
|
---|
| 1240 | INVALID_OPCODE,
|
---|
| 1241 | INVALID_OPCODE,
|
---|
| 1242 | INVALID_OPCODE,
|
---|
| 1243 | INVALID_OPCODE,
|
---|
| 1244 |
|
---|
| 1245 | /* e */
|
---|
| 1246 | INVALID_OPCODE,
|
---|
| 1247 | INVALID_OPCODE,
|
---|
| 1248 | INVALID_OPCODE,
|
---|
| 1249 | INVALID_OPCODE,
|
---|
| 1250 | INVALID_OPCODE,
|
---|
| 1251 | INVALID_OPCODE,
|
---|
[41676] | 1252 | OP("cvtdq2pd %Vpd,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_CVTDQ2PD,OP_PARM_Vpd, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 1253 | INVALID_OPCODE,
|
---|
| 1254 | INVALID_OPCODE,
|
---|
| 1255 | INVALID_OPCODE,
|
---|
| 1256 | INVALID_OPCODE,
|
---|
| 1257 | INVALID_OPCODE,
|
---|
| 1258 | INVALID_OPCODE,
|
---|
| 1259 | INVALID_OPCODE,
|
---|
| 1260 | INVALID_OPCODE,
|
---|
| 1261 | INVALID_OPCODE,
|
---|
| 1262 |
|
---|
| 1263 | /* f */
|
---|
| 1264 | INVALID_OPCODE_BLOCK
|
---|
| 1265 | };
|
---|
| 1266 |
|
---|
[13241] | 1267 | /** Three byte opcode map (0xF 0x38 0x0x) */
|
---|
[41690] | 1268 | const DISOPCODE g_aThreeByteMapX86_0F38_0[16] =
|
---|
[13241] | 1269 | {
|
---|
| 1270 | /* 0 */
|
---|
[41676] | 1271 | OP("pshufb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSHUFB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1272 | OP("phaddw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHADDW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1273 | OP("phaddd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHADDD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1274 | OP("phaddsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHADDSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1275 | OP("pmaddubsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMADDUBSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1276 | OP("phsubw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHSUBW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1277 | OP("phsubd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHSUBD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1278 | OP("phsubsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHSUBSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1279 | OP("psignb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSIGNB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1280 | OP("psignw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSIGNW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1281 | OP("psignd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSIGND, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1282 | OP("pmulhrsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULHRSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1283 | INVALID_OPCODE,
|
---|
| 1284 | INVALID_OPCODE,
|
---|
| 1285 | INVALID_OPCODE,
|
---|
| 1286 | INVALID_OPCODE,
|
---|
| 1287 | };
|
---|
| 1288 |
|
---|
| 1289 | /** Three byte opcode map (0x0F 0x38 0x1x) */
|
---|
[41690] | 1290 | const DISOPCODE g_aThreeByteMapX86_0F38_1[16] =
|
---|
[13241] | 1291 | {
|
---|
| 1292 | /* 1 */
|
---|
| 1293 | INVALID_OPCODE,
|
---|
| 1294 | INVALID_OPCODE,
|
---|
| 1295 | INVALID_OPCODE,
|
---|
| 1296 | INVALID_OPCODE,
|
---|
| 1297 | INVALID_OPCODE,
|
---|
| 1298 | INVALID_OPCODE,
|
---|
| 1299 | INVALID_OPCODE,
|
---|
| 1300 | INVALID_OPCODE,
|
---|
| 1301 | INVALID_OPCODE,
|
---|
| 1302 | INVALID_OPCODE,
|
---|
| 1303 | INVALID_OPCODE,
|
---|
| 1304 | INVALID_OPCODE,
|
---|
[41676] | 1305 | OP("pabsb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PABSB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1306 | OP("pabsw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PABSW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1307 | OP("pabsd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PABSD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1308 | INVALID_OPCODE,
|
---|
| 1309 | };
|
---|
| 1310 |
|
---|
[53007] | 1311 | /** Three byte opcode map (0x0F 0x38 0xFx) */
|
---|
| 1312 | const DISOPCODE g_aThreeByteMapX86_0F38_F[16] =
|
---|
| 1313 | {
|
---|
| 1314 | /* F */
|
---|
| 1315 | OP("movbe %Gy,%My", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVBEGM, OP_PARM_Gy, OP_PARM_My, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1316 | OP("movbe %My,%Gy", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVBEMG, OP_PARM_My, OP_PARM_Gy, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1317 | INVALID_OPCODE,
|
---|
| 1318 | INVALID_OPCODE,
|
---|
| 1319 | INVALID_OPCODE,
|
---|
| 1320 | INVALID_OPCODE,
|
---|
| 1321 | INVALID_OPCODE,
|
---|
| 1322 | INVALID_OPCODE,
|
---|
| 1323 | INVALID_OPCODE,
|
---|
| 1324 | INVALID_OPCODE,
|
---|
| 1325 | INVALID_OPCODE,
|
---|
| 1326 | INVALID_OPCODE,
|
---|
| 1327 | INVALID_OPCODE,
|
---|
| 1328 | INVALID_OPCODE,
|
---|
| 1329 | INVALID_OPCODE,
|
---|
[53032] | 1330 | INVALID_OPCODE,
|
---|
[53007] | 1331 | };
|
---|
| 1332 |
|
---|
[41690] | 1333 | /** These tables are mostly sparse, so use another level of indirection to save space. */
|
---|
| 1334 | PCDISOPCODE const g_apThreeByteMapX86_0F38[16] =
|
---|
[13241] | 1335 | {
|
---|
| 1336 | /* 0 */
|
---|
| 1337 | &g_aThreeByteMapX86_0F38_0[0],
|
---|
| 1338 | /* 1 */
|
---|
| 1339 | &g_aThreeByteMapX86_0F38_1[0],
|
---|
| 1340 | /* 2 */
|
---|
| 1341 | NULL,
|
---|
| 1342 | /* 3 */
|
---|
| 1343 | NULL,
|
---|
| 1344 | /* 4 */
|
---|
| 1345 | NULL,
|
---|
| 1346 | /* 5 */
|
---|
| 1347 | NULL,
|
---|
| 1348 | /* 6 */
|
---|
| 1349 | NULL,
|
---|
| 1350 | /* 7 */
|
---|
| 1351 | NULL,
|
---|
| 1352 | /* 8 */
|
---|
| 1353 | NULL,
|
---|
| 1354 | /* 9 */
|
---|
| 1355 | NULL,
|
---|
| 1356 | /* a */
|
---|
| 1357 | NULL,
|
---|
| 1358 | /* b */
|
---|
| 1359 | NULL,
|
---|
| 1360 | /* c */
|
---|
| 1361 | NULL,
|
---|
| 1362 | /* d */
|
---|
| 1363 | NULL,
|
---|
| 1364 | /* e */
|
---|
| 1365 | NULL,
|
---|
| 1366 | /* f */
|
---|
[53007] | 1367 | &g_aThreeByteMapX86_0F38_F[0],
|
---|
[13241] | 1368 | };
|
---|
| 1369 |
|
---|
| 1370 | /** Three byte opcode map (0x66 0x0F 0x38 0x0x) */
|
---|
[41690] | 1371 | const DISOPCODE g_aThreeByteMapX86_660F38_0[16] =
|
---|
[13241] | 1372 | {
|
---|
| 1373 | /* 0 */
|
---|
[41676] | 1374 | OP("pshufb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSHUFB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1375 | OP("phaddw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHADDW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1376 | OP("phaddd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHADDD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1377 | OP("phaddsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHADDSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1378 | OP("pmaddubsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMADDUBSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1379 | OP("phsubw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHSUBW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1380 | OP("phsubd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHSUBD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1381 | OP("phsubsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHSUBSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1382 | OP("psignb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSIGNB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1383 | OP("psignw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSIGNW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1384 | OP("psignd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PSIGND, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1385 | OP("pmulhrsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULHRSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1386 | INVALID_OPCODE,
|
---|
| 1387 | INVALID_OPCODE,
|
---|
| 1388 | INVALID_OPCODE,
|
---|
| 1389 | INVALID_OPCODE,
|
---|
| 1390 | };
|
---|
| 1391 |
|
---|
| 1392 | /** Three byte opcode map (0x66 0x0F 0x38 0x1x) */
|
---|
[41690] | 1393 | const DISOPCODE g_aThreeByteMapX86_660F38_1[16] =
|
---|
[13241] | 1394 | {
|
---|
| 1395 | /* 1 */
|
---|
[41676] | 1396 | OP("pblendvb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PBLENDVB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1397 | INVALID_OPCODE,
|
---|
| 1398 | INVALID_OPCODE,
|
---|
| 1399 | INVALID_OPCODE,
|
---|
[41676] | 1400 | OP("blendvps %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_BLENDVPS, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1401 | OP("blendvpd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_BLENDVPD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1402 | INVALID_OPCODE,
|
---|
[41676] | 1403 | OP("ptest %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PTEST, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1404 | INVALID_OPCODE,
|
---|
| 1405 | INVALID_OPCODE,
|
---|
| 1406 | INVALID_OPCODE,
|
---|
| 1407 | INVALID_OPCODE,
|
---|
[41676] | 1408 | OP("pabsb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PABSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1409 | OP("pabsw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PABSW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1410 | OP("pabsd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PABSD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1411 | INVALID_OPCODE,
|
---|
| 1412 | };
|
---|
| 1413 |
|
---|
[53164] | 1414 | /** Three byte opcode map (0x66 0x0F 0x38 0x2x) */
|
---|
| 1415 | const DISOPCODE g_aThreeByteMapX86_660F38_2[16] =
|
---|
| 1416 | {
|
---|
| 1417 | /* 2 */
|
---|
| 1418 | OP("pmovsxbw %Vdq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVSX, OP_PARM_Vdq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1419 | OP("pmovsxbd %Vdq,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVSX, OP_PARM_Vdq, OP_PARM_Wd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1420 | OP("pmovsxbq %Vdq,%Ww", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVSX, OP_PARM_Vdq, OP_PARM_Ww, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1421 | OP("pmovsxwd %Vdq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVSX, OP_PARM_Vdq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1422 | OP("pmovsxwq %Vdq,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVSX, OP_PARM_Vdq, OP_PARM_Wd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1423 | OP("pmovsxdq %Vdq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVSX, OP_PARM_Vdq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1424 | INVALID_OPCODE,
|
---|
| 1425 | INVALID_OPCODE,
|
---|
| 1426 | OP("pmuldq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULDQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1427 | OP("pcmpeqq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPEQQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1428 | OP("movntdqa %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVNTDQA, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1429 | OP("packusdw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PACKUSDW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1430 | INVALID_OPCODE,
|
---|
| 1431 | INVALID_OPCODE,
|
---|
| 1432 | INVALID_OPCODE,
|
---|
| 1433 | INVALID_OPCODE,
|
---|
| 1434 | };
|
---|
[13241] | 1435 |
|
---|
[53164] | 1436 | /** Three byte opcode map (0x66 0x0F 0x38 0x3x) */
|
---|
| 1437 | const DISOPCODE g_aThreeByteMapX86_660F38_3[16] =
|
---|
| 1438 | {
|
---|
| 1439 | /* 3 */
|
---|
| 1440 | OP("pmovzxbw %Vdq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVZX, OP_PARM_Vdq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1441 | OP("pmovzxbd %Vdq,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVZX, OP_PARM_Vdq, OP_PARM_Wd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1442 | OP("pmovzxbq %Vdq,%Ww", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVZX, OP_PARM_Vdq, OP_PARM_Ww, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1443 | OP("pmovzxwd %Vdq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVZX, OP_PARM_Vdq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1444 | OP("pmovzxwq %Vdq,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVZX, OP_PARM_Vdq, OP_PARM_Wd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1445 | OP("pmovzxdq %Vdq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMOVZX, OP_PARM_Vdq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1446 | INVALID_OPCODE,
|
---|
| 1447 | OP("pcmpgtq %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PCMPGTQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1448 | OP("pminsb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1449 | OP("pminsd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1450 | OP("pminuw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINUW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1451 | OP("pminud %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMINUD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1452 | OP("pmaxsb %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXSB, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1453 | OP("pmaxsd %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXSD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1454 | OP("pmaxuw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXUW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1455 | OP("pmaxud %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMAXUD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1456 | };
|
---|
| 1457 |
|
---|
| 1458 | /** Three byte opcode map (0x66 0x0F 0x38 0x4x) */
|
---|
| 1459 | const DISOPCODE g_aThreeByteMapX86_660F38_4[16] =
|
---|
| 1460 | {
|
---|
| 1461 | /* 4 */
|
---|
| 1462 | OP("pmulld %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PMULLD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1463 | OP("phminposuw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PHMINPOSUW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1464 | INVALID_OPCODE,
|
---|
| 1465 | INVALID_OPCODE,
|
---|
| 1466 | INVALID_OPCODE,
|
---|
| 1467 | INVALID_OPCODE,
|
---|
| 1468 | INVALID_OPCODE,
|
---|
| 1469 | INVALID_OPCODE,
|
---|
| 1470 | INVALID_OPCODE,
|
---|
| 1471 | INVALID_OPCODE,
|
---|
| 1472 | INVALID_OPCODE,
|
---|
| 1473 | INVALID_OPCODE,
|
---|
| 1474 | INVALID_OPCODE,
|
---|
| 1475 | INVALID_OPCODE,
|
---|
| 1476 | INVALID_OPCODE,
|
---|
| 1477 | INVALID_OPCODE,
|
---|
| 1478 | };
|
---|
| 1479 |
|
---|
[13241] | 1480 | /** Three byte opcode map (0x66 0x0F 0x38 0x8x) */
|
---|
[41690] | 1481 | const DISOPCODE g_aThreeByteMapX86_660F38_8[16] =
|
---|
[13241] | 1482 | {
|
---|
| 1483 | /* 8 */
|
---|
[53164] | 1484 | OP("invept %Gy,%Mdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_INVEPT, OP_PARM_Gy, OP_PARM_Mdq, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 1485 | OP("invvpid %Gy,%Mdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_INVVPID, OP_PARM_Gy, OP_PARM_Mdq, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 1486 | OP("invpcid %Gy,%Mdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_INVPCID, OP_PARM_Gy, OP_PARM_Mdq, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
[13241] | 1487 | INVALID_OPCODE,
|
---|
| 1488 | INVALID_OPCODE,
|
---|
| 1489 | INVALID_OPCODE,
|
---|
| 1490 | INVALID_OPCODE,
|
---|
| 1491 | INVALID_OPCODE,
|
---|
| 1492 | INVALID_OPCODE,
|
---|
| 1493 | INVALID_OPCODE,
|
---|
| 1494 | INVALID_OPCODE,
|
---|
| 1495 | INVALID_OPCODE,
|
---|
| 1496 | INVALID_OPCODE,
|
---|
| 1497 | INVALID_OPCODE,
|
---|
| 1498 | INVALID_OPCODE,
|
---|
| 1499 | INVALID_OPCODE,
|
---|
[53164] | 1500 | };
|
---|
| 1501 |
|
---|
| 1502 | /** Three byte opcode map (0x66 0x0F 0x38 0xDx) */
|
---|
| 1503 | const DISOPCODE g_aThreeByteMapX86_660F38_D[16] =
|
---|
| 1504 | {
|
---|
| 1505 | /* D */
|
---|
[13241] | 1506 | INVALID_OPCODE,
|
---|
[53164] | 1507 | INVALID_OPCODE,
|
---|
| 1508 | INVALID_OPCODE,
|
---|
| 1509 | INVALID_OPCODE,
|
---|
| 1510 | INVALID_OPCODE,
|
---|
| 1511 | INVALID_OPCODE,
|
---|
| 1512 | INVALID_OPCODE,
|
---|
| 1513 | INVALID_OPCODE,
|
---|
| 1514 | INVALID_OPCODE,
|
---|
| 1515 | INVALID_OPCODE,
|
---|
| 1516 | INVALID_OPCODE,
|
---|
| 1517 | OP("aesimc %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_AESIMC, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1518 | OP("aesenc %Vdq,%Hdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_AESENC, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1519 | OP("aesenclast %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_AESENCLAST, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1520 | OP("aesdec %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_AESDEC, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1521 | OP("aesdeclast %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, OP_AESDECLAST, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[13241] | 1522 | };
|
---|
| 1523 |
|
---|
[53007] | 1524 | const DISOPCODE g_aThreeByteMapX86_660F38_F[16] =
|
---|
| 1525 | {
|
---|
[53164] | 1526 | /* F */
|
---|
[53007] | 1527 | OP("movbe %Gw,%Mw", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVBEGM, OP_PARM_Gw, OP_PARM_Mw, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1528 | OP("movbe %Mw,%Gw", IDX_ParseModRM, IDX_UseModRM, 0, OP_MOVBEMG, OP_PARM_Mw, OP_PARM_Gw, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1529 | INVALID_OPCODE,
|
---|
| 1530 | INVALID_OPCODE,
|
---|
| 1531 | INVALID_OPCODE,
|
---|
| 1532 | INVALID_OPCODE,
|
---|
| 1533 | OP("adcx %Gy,%Ey", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADCX, OP_PARM_Gy, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1534 | INVALID_OPCODE,
|
---|
| 1535 | INVALID_OPCODE,
|
---|
| 1536 | INVALID_OPCODE,
|
---|
| 1537 | INVALID_OPCODE,
|
---|
| 1538 | INVALID_OPCODE,
|
---|
| 1539 | INVALID_OPCODE,
|
---|
| 1540 | INVALID_OPCODE,
|
---|
| 1541 | INVALID_OPCODE,
|
---|
| 1542 | INVALID_OPCODE,
|
---|
| 1543 | };
|
---|
| 1544 |
|
---|
[13241] | 1545 | /** Three byte opcode map with prefix 0x66 (0xF 0x38) */
|
---|
[41690] | 1546 | PCDISOPCODE const g_apThreeByteMapX86_660F38[16] =
|
---|
[13241] | 1547 | {
|
---|
| 1548 | /* 0 */
|
---|
| 1549 | &g_aThreeByteMapX86_660F38_0[0],
|
---|
| 1550 | /* 1 */
|
---|
| 1551 | &g_aThreeByteMapX86_660F38_1[0],
|
---|
| 1552 | /* 2 */
|
---|
[53164] | 1553 | &g_aThreeByteMapX86_660F38_2[0],
|
---|
[13241] | 1554 | /* 3 */
|
---|
[53164] | 1555 | &g_aThreeByteMapX86_660F38_3[0],
|
---|
[13241] | 1556 | /* 4 */
|
---|
[53164] | 1557 | &g_aThreeByteMapX86_660F38_4[0],
|
---|
[13241] | 1558 | /* 5 */
|
---|
| 1559 | NULL,
|
---|
| 1560 | /* 6 */
|
---|
| 1561 | NULL,
|
---|
| 1562 | /* 7 */
|
---|
| 1563 | NULL,
|
---|
| 1564 | /* 8 */
|
---|
| 1565 | &g_aThreeByteMapX86_660F38_8[0],
|
---|
| 1566 | /* 9 */
|
---|
| 1567 | NULL,
|
---|
| 1568 | /* a */
|
---|
| 1569 | NULL,
|
---|
| 1570 | /* b */
|
---|
| 1571 | NULL,
|
---|
| 1572 | /* c */
|
---|
| 1573 | NULL,
|
---|
| 1574 | /* d */
|
---|
[53164] | 1575 | &g_aThreeByteMapX86_660F38_D[0],
|
---|
[13241] | 1576 | /* e */
|
---|
| 1577 | NULL,
|
---|
| 1578 | /* f */
|
---|
[53007] | 1579 | &g_aThreeByteMapX86_660F38_F[0],
|
---|
[13241] | 1580 | };
|
---|
| 1581 |
|
---|
[53007] | 1582 | const DISOPCODE g_aThreeByteMapX86_F20F38_F[16] =
|
---|
| 1583 | {
|
---|
| 1584 | /* According to Intel opcodes map in Intel® 64 and IA-32 Architectures Software Developer’s Manual dated September 2014
|
---|
| 1585 | it should be %Gd (always dword regardless of operand-size attribute), but from the description of the command
|
---|
| 1586 | it is clear that REX.W prefix can change this size to 64 bit, therefore it is set to %Gy. Seems to be a mistake. */
|
---|
| 1587 | OP("crc32 %Gy,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_CRC32GDEB, OP_PARM_Gy, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1588 | OP("crc32 %Gy,%Ey", IDX_ParseModRM, IDX_UseModRM, 0, OP_CRC32GDEY, OP_PARM_Gy, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1589 | INVALID_OPCODE,
|
---|
| 1590 | INVALID_OPCODE,
|
---|
| 1591 | INVALID_OPCODE,
|
---|
| 1592 | INVALID_OPCODE,
|
---|
| 1593 | INVALID_OPCODE,
|
---|
| 1594 | INVALID_OPCODE,
|
---|
| 1595 | INVALID_OPCODE,
|
---|
| 1596 | INVALID_OPCODE,
|
---|
| 1597 | INVALID_OPCODE,
|
---|
| 1598 | INVALID_OPCODE,
|
---|
| 1599 | INVALID_OPCODE,
|
---|
| 1600 | INVALID_OPCODE,
|
---|
| 1601 | INVALID_OPCODE,
|
---|
| 1602 | INVALID_OPCODE,
|
---|
| 1603 | };
|
---|
| 1604 |
|
---|
| 1605 | const DISOPCODE g_aThreeByteMapX86_66F20F38_F[16] =
|
---|
| 1606 | {
|
---|
| 1607 | /* According to Intel opcodes map in Intel® 64 and IA-32 Architectures Software Developer’s Manual dated September 2014
|
---|
| 1608 | it should be %Gd (always dword regardless of operand-size attribute), but from the description of the command
|
---|
| 1609 | it is clear that REX.W prefix can change this size to 64 bit, therefore it is set to %Gy. Seems to be a mistake. */
|
---|
| 1610 | OP("crc32 %Gy,%Eb", IDX_ParseModRM, IDX_UseModRM, 0, OP_CRC32GDEB, OP_PARM_Gy, OP_PARM_Eb, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1611 | OP("crc32 %Gy,%Ew", IDX_ParseModRM, IDX_UseModRM, 0, OP_CRC32GDEY, OP_PARM_Gy, OP_PARM_Ew, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1612 | INVALID_OPCODE,
|
---|
| 1613 | INVALID_OPCODE,
|
---|
| 1614 | INVALID_OPCODE,
|
---|
| 1615 | INVALID_OPCODE,
|
---|
| 1616 | INVALID_OPCODE,
|
---|
| 1617 | INVALID_OPCODE,
|
---|
| 1618 | INVALID_OPCODE,
|
---|
| 1619 | INVALID_OPCODE,
|
---|
| 1620 | INVALID_OPCODE,
|
---|
| 1621 | INVALID_OPCODE,
|
---|
| 1622 | INVALID_OPCODE,
|
---|
| 1623 | INVALID_OPCODE,
|
---|
| 1624 | INVALID_OPCODE,
|
---|
| 1625 | INVALID_OPCODE,
|
---|
| 1626 | };
|
---|
| 1627 |
|
---|
[13241] | 1628 | /** Three byte opcode map with prefix 0xF2 (0xF 0x38) */
|
---|
| 1629 | /** @todo remainder missing (too lazy now) */
|
---|
[41690] | 1630 | PCDISOPCODE const g_apThreeByteMapX86_F20F38[16] =
|
---|
[13241] | 1631 | {
|
---|
| 1632 | /* 0 */
|
---|
| 1633 | NULL,
|
---|
| 1634 | /* 1 */
|
---|
| 1635 | NULL,
|
---|
| 1636 | /* 2 */
|
---|
| 1637 | NULL,
|
---|
| 1638 | /* 3 */
|
---|
| 1639 | NULL,
|
---|
| 1640 | /* 4 */
|
---|
| 1641 | NULL,
|
---|
| 1642 | /* 5 */
|
---|
| 1643 | NULL,
|
---|
| 1644 | /* 6 */
|
---|
| 1645 | NULL,
|
---|
| 1646 | /* 7 */
|
---|
| 1647 | NULL,
|
---|
| 1648 | /* 8 */
|
---|
| 1649 | NULL,
|
---|
| 1650 | /* 9 */
|
---|
| 1651 | NULL,
|
---|
| 1652 | /* a */
|
---|
| 1653 | NULL,
|
---|
| 1654 | /* b */
|
---|
| 1655 | NULL,
|
---|
| 1656 | /* c */
|
---|
| 1657 | NULL,
|
---|
| 1658 | /* d */
|
---|
| 1659 | NULL,
|
---|
| 1660 | /* e */
|
---|
| 1661 | NULL,
|
---|
| 1662 | /* f */
|
---|
[53007] | 1663 | &g_aThreeByteMapX86_F20F38_F[0],
|
---|
| 1664 | };
|
---|
| 1665 |
|
---|
[53032] | 1666 | /** Three byte opcode map with prefixes 0x66 0xF2 (0xF 0x38) */
|
---|
| 1667 | PCDISOPCODE const g_apThreeByteMapX86_66F20F38[16] =
|
---|
| 1668 | {
|
---|
| 1669 | /* 0 */
|
---|
| 1670 | NULL,
|
---|
| 1671 | /* 1 */
|
---|
| 1672 | NULL,
|
---|
| 1673 | /* 2 */
|
---|
| 1674 | NULL,
|
---|
| 1675 | /* 3 */
|
---|
| 1676 | NULL,
|
---|
| 1677 | /* 4 */
|
---|
| 1678 | NULL,
|
---|
| 1679 | /* 5 */
|
---|
| 1680 | NULL,
|
---|
| 1681 | /* 6 */
|
---|
| 1682 | NULL,
|
---|
| 1683 | /* 7 */
|
---|
| 1684 | NULL,
|
---|
| 1685 | /* 8 */
|
---|
| 1686 | NULL,
|
---|
| 1687 | /* 9 */
|
---|
| 1688 | NULL,
|
---|
| 1689 | /* a */
|
---|
| 1690 | NULL,
|
---|
| 1691 | /* b */
|
---|
| 1692 | NULL,
|
---|
| 1693 | /* c */
|
---|
| 1694 | NULL,
|
---|
| 1695 | /* d */
|
---|
| 1696 | NULL,
|
---|
| 1697 | /* e */
|
---|
| 1698 | NULL,
|
---|
| 1699 | /* f */
|
---|
| 1700 | &g_aThreeByteMapX86_66F20F38_F[0],
|
---|
| 1701 | };
|
---|
| 1702 |
|
---|
[53007] | 1703 | const DISOPCODE g_aThreeByteMapX86_F30F38_F[16] =
|
---|
| 1704 | {
|
---|
| 1705 | INVALID_OPCODE,
|
---|
| 1706 | INVALID_OPCODE,
|
---|
| 1707 | INVALID_OPCODE,
|
---|
| 1708 | INVALID_OPCODE,
|
---|
| 1709 | INVALID_OPCODE,
|
---|
| 1710 | INVALID_OPCODE,
|
---|
| 1711 | OP("adox %Gy,%Ey", IDX_ParseModRM, IDX_UseModRM, 0, OP_ADOX, OP_PARM_Gy, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1712 | INVALID_OPCODE,
|
---|
| 1713 | INVALID_OPCODE,
|
---|
| 1714 | INVALID_OPCODE,
|
---|
| 1715 | INVALID_OPCODE,
|
---|
| 1716 | INVALID_OPCODE,
|
---|
| 1717 | INVALID_OPCODE,
|
---|
| 1718 | INVALID_OPCODE,
|
---|
| 1719 | INVALID_OPCODE,
|
---|
| 1720 | INVALID_OPCODE,
|
---|
| 1721 | };
|
---|
| 1722 |
|
---|
| 1723 | /** Three byte opcode map with prefix 0xF3 (0xF 0x38) */
|
---|
| 1724 | PCDISOPCODE const g_apThreeByteMapX86_F30F38[16] =
|
---|
| 1725 | {
|
---|
| 1726 | /* 0 */
|
---|
[13241] | 1727 | NULL,
|
---|
[53007] | 1728 | /* 1 */
|
---|
| 1729 | NULL,
|
---|
| 1730 | /* 2 */
|
---|
| 1731 | NULL,
|
---|
| 1732 | /* 3 */
|
---|
| 1733 | NULL,
|
---|
| 1734 | /* 4 */
|
---|
| 1735 | NULL,
|
---|
| 1736 | /* 5 */
|
---|
| 1737 | NULL,
|
---|
| 1738 | /* 6 */
|
---|
| 1739 | NULL,
|
---|
| 1740 | /* 7 */
|
---|
| 1741 | NULL,
|
---|
| 1742 | /* 8 */
|
---|
| 1743 | NULL,
|
---|
| 1744 | /* 9 */
|
---|
| 1745 | NULL,
|
---|
| 1746 | /* a */
|
---|
| 1747 | NULL,
|
---|
| 1748 | /* b */
|
---|
| 1749 | NULL,
|
---|
| 1750 | /* c */
|
---|
| 1751 | NULL,
|
---|
| 1752 | /* d */
|
---|
| 1753 | NULL,
|
---|
| 1754 | /* e */
|
---|
| 1755 | NULL,
|
---|
| 1756 | /* f */
|
---|
| 1757 | &g_aThreeByteMapX86_F30F38_F[0],
|
---|
[13241] | 1758 | };
|
---|
| 1759 |
|
---|
[53155] | 1760 | const DISOPCODE g_aThreeByteMapX86_0F3A_0[16] =
|
---|
| 1761 | {
|
---|
| 1762 | INVALID_OPCODE,
|
---|
| 1763 | INVALID_OPCODE,
|
---|
| 1764 | INVALID_OPCODE,
|
---|
| 1765 | INVALID_OPCODE,
|
---|
| 1766 | INVALID_OPCODE,
|
---|
| 1767 | INVALID_OPCODE,
|
---|
| 1768 | INVALID_OPCODE,
|
---|
| 1769 | INVALID_OPCODE,
|
---|
| 1770 | INVALID_OPCODE,
|
---|
| 1771 | INVALID_OPCODE,
|
---|
| 1772 | INVALID_OPCODE,
|
---|
| 1773 | INVALID_OPCODE,
|
---|
| 1774 | INVALID_OPCODE,
|
---|
| 1775 | INVALID_OPCODE,
|
---|
| 1776 | INVALID_OPCODE,
|
---|
| 1777 | OP("palignr %Pq,%Qq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PALIGNR, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1778 | };
|
---|
| 1779 |
|
---|
| 1780 | PCDISOPCODE const g_apThreeByteMapX86_0F3A[16] =
|
---|
| 1781 | {
|
---|
| 1782 | /* 0 */
|
---|
| 1783 | g_aThreeByteMapX86_0F3A_0,
|
---|
| 1784 | /* 1 */
|
---|
| 1785 | NULL,
|
---|
| 1786 | /* 2 */
|
---|
| 1787 | NULL,
|
---|
| 1788 | /* 3 */
|
---|
| 1789 | NULL,
|
---|
| 1790 | /* 4 */
|
---|
| 1791 | NULL,
|
---|
| 1792 | /* 5 */
|
---|
| 1793 | NULL,
|
---|
| 1794 | /* 6 */
|
---|
| 1795 | NULL,
|
---|
| 1796 | /* 7 */
|
---|
| 1797 | NULL,
|
---|
| 1798 | /* 8 */
|
---|
| 1799 | NULL,
|
---|
| 1800 | /* 9 */
|
---|
| 1801 | NULL,
|
---|
| 1802 | /* a */
|
---|
| 1803 | NULL,
|
---|
| 1804 | /* b */
|
---|
| 1805 | NULL,
|
---|
| 1806 | /* c */
|
---|
| 1807 | NULL,
|
---|
| 1808 | /* d */
|
---|
| 1809 | NULL,
|
---|
| 1810 | /* e */
|
---|
| 1811 | NULL,
|
---|
| 1812 | /* f */
|
---|
| 1813 | NULL,
|
---|
| 1814 | };
|
---|
| 1815 |
|
---|
| 1816 | const DISOPCODE g_aThreeByteMapX86_660F3A_0[16] =
|
---|
| 1817 | {
|
---|
| 1818 | INVALID_OPCODE,
|
---|
| 1819 | INVALID_OPCODE,
|
---|
| 1820 | INVALID_OPCODE,
|
---|
| 1821 | INVALID_OPCODE,
|
---|
| 1822 | INVALID_OPCODE,
|
---|
| 1823 | INVALID_OPCODE,
|
---|
| 1824 | INVALID_OPCODE,
|
---|
| 1825 | INVALID_OPCODE,
|
---|
| 1826 | OP("roundps %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_ROUNDPS, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1827 | OP("roundpd %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_ROUNDPD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1828 | OP("roundss %Vss,%Wss,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_ROUNDSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1829 | OP("roundsd %Vsd,%Wsd,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_ROUNDSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1830 | OP("blendps %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_BLENDPS, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1831 | OP("blendpd %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_BLENDPD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1832 | OP("pblendw %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PBLENDW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1833 | OP("palignr %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PALIGNR, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1834 | };
|
---|
| 1835 |
|
---|
[53150] | 1836 | const DISOPCODE g_aThreeByteMapX86_660F3A_10[16] =
|
---|
| 1837 | {
|
---|
| 1838 | INVALID_OPCODE,
|
---|
| 1839 | INVALID_OPCODE,
|
---|
| 1840 | INVALID_OPCODE,
|
---|
| 1841 | INVALID_OPCODE,
|
---|
| 1842 | OP("pextrb %Eb,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PEXTRB, OP_PARM_Eb, OP_PARM_Vdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1843 | OP("pextrw %Ew,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PEXTRW, OP_PARM_Ew, OP_PARM_Vdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1844 | OP("pextrd %Ed,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PEXTRD, OP_PARM_Ed, OP_PARM_Vdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1845 | OP("extractps %Ed,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_EXTRACTPS, OP_PARM_Ed, OP_PARM_Vdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1846 | INVALID_OPCODE,
|
---|
| 1847 | INVALID_OPCODE,
|
---|
| 1848 | INVALID_OPCODE,
|
---|
| 1849 | INVALID_OPCODE,
|
---|
| 1850 | INVALID_OPCODE,
|
---|
| 1851 | INVALID_OPCODE,
|
---|
| 1852 | INVALID_OPCODE,
|
---|
| 1853 | INVALID_OPCODE,
|
---|
| 1854 | };
|
---|
| 1855 |
|
---|
| 1856 | const DISOPCODE g_aThreeByteMapX86_660F3A_20[16] =
|
---|
| 1857 | {
|
---|
[53155] | 1858 | // pinsrb %Vdq,%Ry/Mb,%Ib
|
---|
[53150] | 1859 | OP("pinsrb %Vdq,%Ey,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PINSRB, OP_PARM_Vdq, OP_PARM_Ey, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53155] | 1860 | // insertps %Vdq,%Udq/Md,%Ib
|
---|
[53150] | 1861 | OP("insertps %Vdq,%Wdq,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_INSERTPS, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1862 | OP("pinsrd %Vdq,%Ey,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PINSRD, OP_PARM_Vdq, OP_PARM_Ey, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1863 | INVALID_OPCODE,
|
---|
| 1864 | INVALID_OPCODE,
|
---|
| 1865 | INVALID_OPCODE,
|
---|
| 1866 | INVALID_OPCODE,
|
---|
| 1867 | INVALID_OPCODE,
|
---|
| 1868 | INVALID_OPCODE,
|
---|
| 1869 | INVALID_OPCODE,
|
---|
| 1870 | INVALID_OPCODE,
|
---|
| 1871 | INVALID_OPCODE,
|
---|
| 1872 | INVALID_OPCODE,
|
---|
| 1873 | INVALID_OPCODE,
|
---|
| 1874 | INVALID_OPCODE,
|
---|
| 1875 | INVALID_OPCODE,
|
---|
| 1876 | };
|
---|
| 1877 |
|
---|
| 1878 | const DISOPCODE g_aThreeByteMapX86_660F3A_40[16] =
|
---|
| 1879 | {
|
---|
| 1880 | OP("dpps %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_DPPS, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1881 | OP("dppd %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_DPPD, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1882 | OP("mpsadbw %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_MPSADBW, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1883 | INVALID_OPCODE,
|
---|
| 1884 | OP("pclmulqdq %Vdq,%Wdq,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PCLMULQDQ, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1885 | INVALID_OPCODE,
|
---|
| 1886 | INVALID_OPCODE,
|
---|
| 1887 | INVALID_OPCODE,
|
---|
| 1888 | INVALID_OPCODE,
|
---|
| 1889 | INVALID_OPCODE,
|
---|
| 1890 | INVALID_OPCODE,
|
---|
| 1891 | INVALID_OPCODE,
|
---|
| 1892 | INVALID_OPCODE,
|
---|
| 1893 | INVALID_OPCODE,
|
---|
| 1894 | INVALID_OPCODE,
|
---|
| 1895 | INVALID_OPCODE,
|
---|
| 1896 | };
|
---|
| 1897 |
|
---|
| 1898 | const DISOPCODE g_aThreeByteMapX86_660F3A_60[16] =
|
---|
| 1899 | {
|
---|
| 1900 | OP("pcmpestrm %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PCMPESTRM, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1901 | OP("pcmpestri %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PCMPESTRI, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1902 | OP("pcmpistrm %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PCMPISTRM, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1903 | OP("pcmpistri %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_PCMPISTRI, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1904 | INVALID_OPCODE,
|
---|
| 1905 | INVALID_OPCODE,
|
---|
| 1906 | INVALID_OPCODE,
|
---|
| 1907 | INVALID_OPCODE,
|
---|
| 1908 | INVALID_OPCODE,
|
---|
| 1909 | INVALID_OPCODE,
|
---|
| 1910 | INVALID_OPCODE,
|
---|
| 1911 | INVALID_OPCODE,
|
---|
| 1912 | INVALID_OPCODE,
|
---|
| 1913 | INVALID_OPCODE,
|
---|
| 1914 | INVALID_OPCODE,
|
---|
| 1915 | INVALID_OPCODE,
|
---|
| 1916 | };
|
---|
| 1917 |
|
---|
| 1918 | const DISOPCODE g_aThreeByteMapX86_660F3A_D0[16] =
|
---|
| 1919 | {
|
---|
| 1920 | INVALID_OPCODE,
|
---|
| 1921 | INVALID_OPCODE,
|
---|
| 1922 | INVALID_OPCODE,
|
---|
| 1923 | INVALID_OPCODE,
|
---|
| 1924 | INVALID_OPCODE,
|
---|
| 1925 | INVALID_OPCODE,
|
---|
| 1926 | INVALID_OPCODE,
|
---|
| 1927 | INVALID_OPCODE,
|
---|
| 1928 | INVALID_OPCODE,
|
---|
| 1929 | INVALID_OPCODE,
|
---|
| 1930 | INVALID_OPCODE,
|
---|
| 1931 | INVALID_OPCODE,
|
---|
| 1932 | INVALID_OPCODE,
|
---|
| 1933 | INVALID_OPCODE,
|
---|
| 1934 | INVALID_OPCODE,
|
---|
| 1935 | OP("aeskeygen %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, OP_AESKEYGEN, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 1936 | };
|
---|
| 1937 |
|
---|
[13241] | 1938 | /** Three byte opcode map with prefix 0x66 (0xF 0x3A) */
|
---|
| 1939 | /** @todo remainder missing (too lazy now) */
|
---|
[41690] | 1940 | PCDISOPCODE const g_apThreeByteMapX86_660F3A[16] =
|
---|
[13241] | 1941 | {
|
---|
| 1942 | /* 0 */
|
---|
[53155] | 1943 | g_aThreeByteMapX86_660F3A_0,
|
---|
[13241] | 1944 | /* 1 */
|
---|
[53150] | 1945 | g_aThreeByteMapX86_660F3A_10,
|
---|
[13241] | 1946 | /* 2 */
|
---|
[53150] | 1947 | g_aThreeByteMapX86_660F3A_20,
|
---|
[13241] | 1948 | /* 3 */
|
---|
| 1949 | NULL,
|
---|
| 1950 | /* 4 */
|
---|
[53150] | 1951 | g_aThreeByteMapX86_660F3A_40,
|
---|
[13241] | 1952 | /* 5 */
|
---|
| 1953 | NULL,
|
---|
| 1954 | /* 6 */
|
---|
[53150] | 1955 | g_aThreeByteMapX86_660F3A_60,
|
---|
[13241] | 1956 | /* 7 */
|
---|
| 1957 | NULL,
|
---|
| 1958 | /* 8 */
|
---|
| 1959 | NULL,
|
---|
| 1960 | /* 9 */
|
---|
| 1961 | NULL,
|
---|
| 1962 | /* a */
|
---|
| 1963 | NULL,
|
---|
| 1964 | /* b */
|
---|
| 1965 | NULL,
|
---|
| 1966 | /* c */
|
---|
| 1967 | NULL,
|
---|
| 1968 | /* d */
|
---|
[53150] | 1969 | g_aThreeByteMapX86_660F3A_D0,
|
---|
[13241] | 1970 | /* e */
|
---|
| 1971 | NULL,
|
---|
| 1972 | /* f */
|
---|
| 1973 | NULL,
|
---|
| 1974 | };
|
---|
| 1975 |
|
---|
[1] | 1976 | /* 3DNow! map (0x0F 0x0F prefix) */
|
---|
[41690] | 1977 | const DISOPCODE g_aTwoByteMapX86_3DNow[256] =
|
---|
[1] | 1978 | {
|
---|
| 1979 | /* 0 */
|
---|
[41863] | 1980 | INVALID_OPCODE_MOD_RM(0x00),
|
---|
| 1981 | INVALID_OPCODE_MOD_RM(0x01),
|
---|
| 1982 | INVALID_OPCODE_MOD_RM(0x02),
|
---|
| 1983 | INVALID_OPCODE_MOD_RM(0x03),
|
---|
| 1984 | INVALID_OPCODE_MOD_RM(0x04),
|
---|
| 1985 | INVALID_OPCODE_MOD_RM(0x05),
|
---|
| 1986 | INVALID_OPCODE_MOD_RM(0x06),
|
---|
| 1987 | INVALID_OPCODE_MOD_RM(0x07),
|
---|
| 1988 | INVALID_OPCODE_MOD_RM(0x08),
|
---|
| 1989 | INVALID_OPCODE_MOD_RM(0x09),
|
---|
| 1990 | INVALID_OPCODE_MOD_RM(0x0a),
|
---|
| 1991 | INVALID_OPCODE_MOD_RM(0x0c),
|
---|
[41676] | 1992 | OP("pi2fw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PI2FW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 1993 | OP("pi2fd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PI2FD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 1994 | INVALID_OPCODE_MOD_RM(0x0e),
|
---|
| 1995 | INVALID_OPCODE_MOD_RM(0x0f),
|
---|
[1] | 1996 |
|
---|
| 1997 | /* 1 */
|
---|
[41863] | 1998 | INVALID_OPCODE_MOD_RM(0x10),
|
---|
| 1999 | INVALID_OPCODE_MOD_RM(0x11),
|
---|
| 2000 | INVALID_OPCODE_MOD_RM(0x12),
|
---|
| 2001 | INVALID_OPCODE_MOD_RM(0x13),
|
---|
| 2002 | INVALID_OPCODE_MOD_RM(0x14),
|
---|
| 2003 | INVALID_OPCODE_MOD_RM(0x15),
|
---|
| 2004 | INVALID_OPCODE_MOD_RM(0x16),
|
---|
| 2005 | INVALID_OPCODE_MOD_RM(0x17),
|
---|
| 2006 | INVALID_OPCODE_MOD_RM(0x18),
|
---|
| 2007 | INVALID_OPCODE_MOD_RM(0x19),
|
---|
| 2008 | INVALID_OPCODE_MOD_RM(0x1a),
|
---|
| 2009 | INVALID_OPCODE_MOD_RM(0x1b),
|
---|
[41676] | 2010 | OP("pf2iw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PF2IW, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2011 | OP("pf2id %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PF2ID, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2012 | INVALID_OPCODE_MOD_RM(0x1e),
|
---|
| 2013 | INVALID_OPCODE_MOD_RM(0x1f),
|
---|
[1] | 2014 |
|
---|
| 2015 | /* 2 */
|
---|
[41863] | 2016 | INVALID_OPCODE_BLOCK_MOD_RM(0x2)
|
---|
[1] | 2017 |
|
---|
| 2018 | /* 3 */
|
---|
[41863] | 2019 | INVALID_OPCODE_BLOCK_MOD_RM(0x3)
|
---|
[1] | 2020 |
|
---|
| 2021 | /* 4 */
|
---|
[41863] | 2022 | INVALID_OPCODE_BLOCK_MOD_RM(0x4)
|
---|
[1] | 2023 |
|
---|
| 2024 | /* 5 */
|
---|
[41863] | 2025 | INVALID_OPCODE_BLOCK_MOD_RM(0x5)
|
---|
[1] | 2026 |
|
---|
| 2027 | /* 6 */
|
---|
[41863] | 2028 | INVALID_OPCODE_BLOCK_MOD_RM(0x6)
|
---|
[1] | 2029 |
|
---|
| 2030 | /* 7 */
|
---|
[41863] | 2031 | INVALID_OPCODE_BLOCK_MOD_RM(0x7)
|
---|
[1] | 2032 |
|
---|
| 2033 | /* 8 */
|
---|
[41863] | 2034 | INVALID_OPCODE_MOD_RM(0x80),
|
---|
| 2035 | INVALID_OPCODE_MOD_RM(0x81),
|
---|
| 2036 | INVALID_OPCODE_MOD_RM(0x82),
|
---|
| 2037 | INVALID_OPCODE_MOD_RM(0x83),
|
---|
| 2038 | INVALID_OPCODE_MOD_RM(0x84),
|
---|
| 2039 | INVALID_OPCODE_MOD_RM(0x85),
|
---|
| 2040 | INVALID_OPCODE_MOD_RM(0x86),
|
---|
| 2041 | INVALID_OPCODE_MOD_RM(0x87),
|
---|
| 2042 | INVALID_OPCODE_MOD_RM(0x88),
|
---|
| 2043 | INVALID_OPCODE_MOD_RM(0x89),
|
---|
[41676] | 2044 | OP("pfnacc %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFNACC, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2045 | INVALID_OPCODE_MOD_RM(0x8b),
|
---|
| 2046 | INVALID_OPCODE_MOD_RM(0x8c),
|
---|
| 2047 | INVALID_OPCODE_MOD_RM(0x8d),
|
---|
[41676] | 2048 | OP("pfpnacc %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFPNACC, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2049 | INVALID_OPCODE_MOD_RM(0x8f),
|
---|
[1] | 2050 |
|
---|
| 2051 | /* 9 */
|
---|
[41676] | 2052 | OP("pfcmpge %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFCMPGE, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2053 | INVALID_OPCODE_MOD_RM(0x91),
|
---|
| 2054 | INVALID_OPCODE_MOD_RM(0x92),
|
---|
| 2055 | INVALID_OPCODE_MOD_RM(0x93),
|
---|
[41676] | 2056 | OP("pfmin %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFMIN, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2057 | INVALID_OPCODE_MOD_RM(0x95),
|
---|
[41676] | 2058 | OP("pfrcp %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFRCP, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2059 | OP("pfrsqrt %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFRSQRT, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2060 | INVALID_OPCODE_MOD_RM(0x98),
|
---|
| 2061 | INVALID_OPCODE_MOD_RM(0x99),
|
---|
[41676] | 2062 | OP("pfsub %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFSUB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2063 | INVALID_OPCODE_MOD_RM(0x9b),
|
---|
| 2064 | INVALID_OPCODE_MOD_RM(0x9c),
|
---|
| 2065 | INVALID_OPCODE_MOD_RM(0x9d),
|
---|
[41676] | 2066 | OP("pfadd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFADD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2067 | INVALID_OPCODE_MOD_RM(0x9f),
|
---|
[1] | 2068 |
|
---|
| 2069 | /* a */
|
---|
[41676] | 2070 | OP("pfcmpgt %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFCMPGT, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2071 | INVALID_OPCODE_MOD_RM(0xa1),
|
---|
| 2072 | INVALID_OPCODE_MOD_RM(0xa2),
|
---|
| 2073 | INVALID_OPCODE_MOD_RM(0xa3),
|
---|
[41676] | 2074 | OP("pfmax %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFMAX, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2075 | INVALID_OPCODE_MOD_RM(0xa5),
|
---|
[41676] | 2076 | OP("pfrcpit1 %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFRCPIT1,OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41867] | 2077 | OP("pfrsqit1 %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFRSQRTIT1, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2078 | INVALID_OPCODE_MOD_RM(0xa8),
|
---|
| 2079 | INVALID_OPCODE_MOD_RM(0xa9),
|
---|
[41676] | 2080 | OP("pfsubr %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFSUBR, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2081 | INVALID_OPCODE_MOD_RM(0xab),
|
---|
| 2082 | INVALID_OPCODE_MOD_RM(0xac),
|
---|
| 2083 | INVALID_OPCODE_MOD_RM(0xad),
|
---|
[41676] | 2084 | OP("pfacc %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFACC, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2085 | INVALID_OPCODE_MOD_RM(0xaf),
|
---|
[1] | 2086 |
|
---|
| 2087 | /* b */
|
---|
[41676] | 2088 | OP("pfcmpeq %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFCMPEQ, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2089 | INVALID_OPCODE_MOD_RM(0xb1),
|
---|
| 2090 | INVALID_OPCODE_MOD_RM(0xb2),
|
---|
| 2091 | INVALID_OPCODE_MOD_RM(0xb3),
|
---|
[41676] | 2092 | OP("pfmul %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFMUL, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2093 | INVALID_OPCODE_MOD_RM(0xb5),
|
---|
[41676] | 2094 | OP("pfrcpit2 %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFRCPIT2,OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[46950] | 2095 | OP("pmulhrw %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFMULHRW,OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2096 | INVALID_OPCODE_MOD_RM(0xb8),
|
---|
| 2097 | INVALID_OPCODE_MOD_RM(0xb9),
|
---|
| 2098 | INVALID_OPCODE_MOD_RM(0xba),
|
---|
[41676] | 2099 | OP("pswapd %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PFSWAPD, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2100 | INVALID_OPCODE_MOD_RM(0xbc),
|
---|
| 2101 | INVALID_OPCODE_MOD_RM(0xbd),
|
---|
| 2102 | INVALID_OPCODE_MOD_RM(0xbe),
|
---|
[41676] | 2103 | OP("pavgusb %Pq,%Qq", IDX_ParseModRM, IDX_UseModRM, 0, OP_PAVGUSB, OP_PARM_Pq, OP_PARM_Qq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2104 |
|
---|
| 2105 | /* c */
|
---|
[41863] | 2106 | INVALID_OPCODE_BLOCK_MOD_RM(0xc)
|
---|
[1] | 2107 |
|
---|
| 2108 | /* d */
|
---|
[41863] | 2109 | INVALID_OPCODE_BLOCK_MOD_RM(0xd)
|
---|
[1] | 2110 |
|
---|
| 2111 | /* e */
|
---|
[41863] | 2112 | INVALID_OPCODE_BLOCK_MOD_RM(0xe)
|
---|
[1] | 2113 |
|
---|
| 2114 | /* f */
|
---|
[41863] | 2115 | INVALID_OPCODE_BLOCK_MOD_RM(0xf)
|
---|
[1] | 2116 | };
|
---|
| 2117 |
|
---|
| 2118 |
|
---|
| 2119 |
|
---|
| 2120 | /* Floating point opcode starting with escape byte 0xD8 (values 0-0xBF)*/
|
---|
[41690] | 2121 | const DISOPCODE g_aMapX86_EscF0_Low[8] =
|
---|
[1] | 2122 | {
|
---|
| 2123 | /* 0 */
|
---|
[41676] | 2124 | OP("fadd %Md", IDX_ParseModRM, 0, 0, OP_FADD, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2125 | OP("fmul %Md", IDX_ParseModRM, 0, 0, OP_FMUL, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2126 | OP("fcom %Md", IDX_ParseModRM, 0, 0, OP_FCOM, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2127 | OP("fcomp %Md", IDX_ParseModRM, 0, 0, OP_FCOMP, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2128 | OP("fsub %Md", IDX_ParseModRM, 0, 0, OP_FSUB, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2129 | OP("fsubr %Md", IDX_ParseModRM, 0, 0, OP_FSUBR, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2130 | OP("fdiv %Md", IDX_ParseModRM, 0, 0, OP_FDIV, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2131 | OP("fdivr %Md", IDX_ParseModRM, 0, 0, OP_FDIVR, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2132 | };
|
---|
| 2133 |
|
---|
| 2134 | /* Floating point opcode starting with escape byte 0xD8 (outside 0-0xBF)*/
|
---|
[41690] | 2135 | const DISOPCODE g_aMapX86_EscF0_High[16*4] =
|
---|
[1] | 2136 | {
|
---|
| 2137 | /* c */
|
---|
[41676] | 2138 | OP("fadd ST(0),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2139 | OP("fadd ST(0),ST(1)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2140 | OP("fadd ST(0),ST(2)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2141 | OP("fadd ST(0),ST(3)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2142 | OP("fadd ST(0),ST(4)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2143 | OP("fadd ST(0),ST(5)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2144 | OP("fadd ST(0),ST(6)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2145 | OP("fadd ST(0),ST(7)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2146 | OP("fmul ST(0),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2147 | OP("fmul ST(0),ST(1)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2148 | OP("fmul ST(0),ST(2)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2149 | OP("fmul ST(0),ST(3)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2150 | OP("fmul ST(0),ST(4)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2151 | OP("fmul ST(0),ST(5)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2152 | OP("fmul ST(0),ST(6)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2153 | OP("fmul ST(0),ST(7)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2154 |
|
---|
| 2155 | /* d */
|
---|
[41676] | 2156 | OP("fcom ST(0),ST(0)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2157 | OP("fcom ST(0),ST(1)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2158 | OP("fcom ST(0),ST(2)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2159 | OP("fcom ST(0),ST(3)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2160 | OP("fcom ST(0),ST(4)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2161 | OP("fcom ST(0),ST(5)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2162 | OP("fcom ST(0),ST(6)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2163 | OP("fcom ST(0),ST(7)", 0, 0, 0, OP_FCOM, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2164 | OP("fcomp ST(0),ST(0)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2165 | OP("fcomp ST(0),ST(1)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2166 | OP("fcomp ST(0),ST(2)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2167 | OP("fcomp ST(0),ST(3)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2168 | OP("fcomp ST(0),ST(4)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2169 | OP("fcomp ST(0),ST(5)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2170 | OP("fcomp ST(0),ST(6)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2171 | OP("fcomp ST(0),ST(7)", 0, 0, 0, OP_FCOMP, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2172 |
|
---|
| 2173 |
|
---|
| 2174 | /* e */
|
---|
[41676] | 2175 | OP("fsub ST(0),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2176 | OP("fsub ST(0),ST(1)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2177 | OP("fsub ST(0),ST(2)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2178 | OP("fsub ST(0),ST(3)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2179 | OP("fsub ST(0),ST(4)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2180 | OP("fsub ST(0),ST(5)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2181 | OP("fsub ST(0),ST(6)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2182 | OP("fsub ST(0),ST(7)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2183 | OP("fsubr ST(0),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2184 | OP("fsubr ST(0),ST(1)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2185 | OP("fsubr ST(0),ST(2)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2186 | OP("fsubr ST(0),ST(3)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2187 | OP("fsubr ST(0),ST(4)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2188 | OP("fsubr ST(0),ST(5)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2189 | OP("fsubr ST(0),ST(6)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2190 | OP("fsubr ST(0),ST(7)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2191 |
|
---|
| 2192 | /* f */
|
---|
[41676] | 2193 | OP("fdiv ST(0),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2194 | OP("fdiv ST(0),ST(1)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2195 | OP("fdiv ST(0),ST(2)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2196 | OP("fdiv ST(0),ST(3)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2197 | OP("fdiv ST(0),ST(4)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2198 | OP("fdiv ST(0),ST(5)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2199 | OP("fdiv ST(0),ST(6)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2200 | OP("fdiv ST(0),ST(7)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2201 | OP("fdivr ST(0),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2202 | OP("fdivr ST(0),ST(1)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2203 | OP("fdivr ST(0),ST(2)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2204 | OP("fdivr ST(0),ST(3)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2205 | OP("fdivr ST(0),ST(4)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2206 | OP("fdivr ST(0),ST(5)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2207 | OP("fdivr ST(0),ST(6)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2208 | OP("fdivr ST(0),ST(7)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2209 | };
|
---|
| 2210 |
|
---|
| 2211 | /* Floating point opcode starting with escape byte 0xD9 (values 0-0xBF)*/
|
---|
[41690] | 2212 | const DISOPCODE g_aMapX86_EscF1_Low[8] =
|
---|
[1] | 2213 | {
|
---|
| 2214 | /* 0 */
|
---|
[41676] | 2215 | OP("fld %Md", IDX_ParseModRM, 0, 0, OP_FLD, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2216 | INVALID_OPCODE,
|
---|
[41676] | 2217 | OP("fst %Md", IDX_ParseModRM, 0, 0, OP_FST, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2218 | OP("fstp %Md", IDX_ParseModRM, 0, 0, OP_FSTP, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[63567] | 2219 | /// @todo ??
|
---|
[41676] | 2220 | OP("fldenv %M", IDX_ParseModRM, 0, 0, OP_FLDENV, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2221 | OP("fldcw %Ew", IDX_ParseModRM, 0, 0, OP_FSUBR, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[63567] | 2222 | /// @todo ??
|
---|
[41676] | 2223 | OP("fstenv %M", IDX_ParseModRM, 0, 0, OP_FSTENV, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2224 | OP("fstcw %Ew", IDX_ParseModRM, 0, 0, OP_FSTCW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2225 | };
|
---|
| 2226 |
|
---|
| 2227 |
|
---|
| 2228 | /* Floating point opcode starting with escape byte 0xD9 (outside 0-0xBF)*/
|
---|
[41690] | 2229 | const DISOPCODE g_aMapX86_EscF1_High[16*4] =
|
---|
[1] | 2230 | {
|
---|
| 2231 | /* c */
|
---|
[41676] | 2232 | OP("fld ST(0),ST(0)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2233 | OP("fld ST(0),ST(1)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2234 | OP("fld ST(0),ST(2)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2235 | OP("fld ST(0),ST(3)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2236 | OP("fld ST(0),ST(4)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2237 | OP("fld ST(0),ST(5)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2238 | OP("fld ST(0),ST(6)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2239 | OP("fld ST(0),ST(7)", 0, 0, 0, OP_FLD, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2240 | OP("fxch ST(0),ST(0)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2241 | OP("fxch ST(0),ST(1)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2242 | OP("fxch ST(0),ST(2)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2243 | OP("fxch ST(0),ST(3)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2244 | OP("fxch ST(0),ST(4)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2245 | OP("fxch ST(0),ST(5)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2246 | OP("fxch ST(0),ST(6)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2247 | OP("fxch ST(0),ST(7)", 0, 0, 0, OP_FXCH, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2248 |
|
---|
| 2249 | /* d */
|
---|
[41676] | 2250 | OP("fnop", 0, 0, 0, OP_FNOP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2251 | INVALID_OPCODE,
|
---|
| 2252 | INVALID_OPCODE,
|
---|
| 2253 | INVALID_OPCODE,
|
---|
| 2254 | INVALID_OPCODE,
|
---|
| 2255 | INVALID_OPCODE,
|
---|
| 2256 | INVALID_OPCODE,
|
---|
| 2257 | INVALID_OPCODE,
|
---|
| 2258 | INVALID_OPCODE,
|
---|
| 2259 | INVALID_OPCODE,
|
---|
| 2260 | INVALID_OPCODE,
|
---|
| 2261 | INVALID_OPCODE,
|
---|
| 2262 | INVALID_OPCODE,
|
---|
| 2263 | INVALID_OPCODE,
|
---|
| 2264 | INVALID_OPCODE,
|
---|
| 2265 | INVALID_OPCODE,
|
---|
| 2266 |
|
---|
| 2267 |
|
---|
| 2268 | /* e */
|
---|
[41676] | 2269 | OP("fchs", 0, 0, 0, OP_FCHS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2270 | OP("fabs", 0, 0, 0, OP_FABS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2271 | INVALID_OPCODE,
|
---|
| 2272 | INVALID_OPCODE,
|
---|
[41676] | 2273 | OP("ftst", 0, 0, 0, OP_FCHS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2274 | OP("fxam", 0, 0, 0, OP_FCHS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2275 | INVALID_OPCODE,
|
---|
| 2276 | INVALID_OPCODE,
|
---|
[41676] | 2277 | OP("fld1", 0, 0, 0, OP_FLD1, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2278 | OP("fldl2t", 0, 0, 0, OP_FLDL2T, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2279 | OP("fldl2e", 0, 0, 0, OP_FLDL2E, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2280 | OP("fldpi", 0, 0, 0, OP_FLDPI, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2281 | OP("fldlg2", 0, 0, 0, OP_FLDLG2, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2282 | OP("fldln2", 0, 0, 0, OP_FLDLN2, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2283 | OP("fldz", 0, 0, 0, OP_FLDZ, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2284 | INVALID_OPCODE,
|
---|
| 2285 |
|
---|
| 2286 | /* f */
|
---|
[41676] | 2287 | OP("f2xm1", 0, 0, 0, OP_F2XM1, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2288 | OP("fyl2x", 0, 0, 0, OP_FYL2X, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2289 | OP("fptan", 0, 0, 0, OP_FPTAN, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2290 | OP("fpatan", 0, 0, 0, OP_FPATAN, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2291 | OP("fxtract", 0, 0, 0, OP_FXTRACT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2292 | OP("frem1", 0, 0, 0, OP_FREM1, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2293 | OP("fdecstp", 0, 0, 0, OP_FDECSTP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2294 | OP("fincstp", 0, 0, 0, OP_FINCSTP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2295 | OP("fprem", 0, 0, 0, OP_FPREM, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2296 | OP("fyl2xp1", 0, 0, 0, OP_FYL2XP1, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2297 | OP("fsqrt", 0, 0, 0, OP_FSQRT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2298 | OP("fsincos", 0, 0, 0, OP_FSINCOS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2299 | OP("frndint", 0, 0, 0, OP_FRNDINT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2300 | OP("fscale", 0, 0, 0, OP_FSCALE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2301 | OP("fsin", 0, 0, 0, OP_FSIN, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2302 | OP("fcos", 0, 0, 0, OP_FCOS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2303 | };
|
---|
| 2304 |
|
---|
| 2305 |
|
---|
| 2306 | /* Floating point opcode starting with escape byte 0xDA (values 0-0xBF)*/
|
---|
[41690] | 2307 | const DISOPCODE g_aMapX86_EscF2_Low[8] =
|
---|
[1] | 2308 | {
|
---|
| 2309 | /* 0 */
|
---|
[41676] | 2310 | OP("fiadd %Md", IDX_ParseModRM, 0, 0, OP_FIADD, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2311 | OP("fimul %Md", IDX_ParseModRM, 0, 0, OP_FIMUL, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2312 | OP("ficom %Md", IDX_ParseModRM, 0, 0, OP_FICOM, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2313 | OP("ficomp %Md", IDX_ParseModRM, 0, 0, OP_FICOMP, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2314 | OP("fisub %Md", IDX_ParseModRM, 0, 0, OP_FISUB, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2315 | OP("fisubr %Md", IDX_ParseModRM, 0, 0, OP_FISUBR, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2316 | OP("fidiv %Md", IDX_ParseModRM, 0, 0, OP_FIDIV, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2317 | OP("fidivr %Md", IDX_ParseModRM, 0, 0, OP_FIDIVR, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2318 | };
|
---|
| 2319 |
|
---|
| 2320 |
|
---|
| 2321 | /* Floating point opcode starting with escape byte 0xD9 (outside 0-0xBF)*/
|
---|
[41690] | 2322 | const DISOPCODE g_aMapX86_EscF2_High[16*4] =
|
---|
[1] | 2323 | {
|
---|
| 2324 | /* c */
|
---|
[41676] | 2325 | OP("fcmovb ST(0),ST(0)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2326 | OP("fcmovb ST(0),ST(1)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2327 | OP("fcmovb ST(0),ST(2)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2328 | OP("fcmovb ST(0),ST(3)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2329 | OP("fcmovb ST(0),ST(4)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2330 | OP("fcmovb ST(0),ST(5)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2331 | OP("fcmovb ST(0),ST(6)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2332 | OP("fcmovb ST(0),ST(7)", 0, 0, 0, OP_FCMOVB, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2333 | OP("fcmove ST(0),ST(0)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2334 | OP("fcmove ST(0),ST(1)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2335 | OP("fcmove ST(0),ST(2)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2336 | OP("fcmove ST(0),ST(3)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2337 | OP("fcmove ST(0),ST(4)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2338 | OP("fcmove ST(0),ST(5)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2339 | OP("fcmove ST(0),ST(6)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2340 | OP("fcmove ST(0),ST(7)", 0, 0, 0, OP_FCMOVE, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2341 |
|
---|
| 2342 | /* d */
|
---|
[65876] | 2343 | OP("fcmovbe ST(0),ST(0)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2344 | OP("fcmovbe ST(0),ST(1)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2345 | OP("fcmovbe ST(0),ST(2)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2346 | OP("fcmovbe ST(0),ST(3)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2347 | OP("fcmovbe ST(0),ST(4)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2348 | OP("fcmovbe ST(0),ST(5)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2349 | OP("fcmovbe ST(0),ST(6)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2350 | OP("fcmovbe ST(0),ST(7)", 0, 0, 0, OP_FCMOVBE, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 2351 | OP("fcmovu ST(0),ST(0)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2352 | OP("fcmovu ST(0),ST(1)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2353 | OP("fcmovu ST(0),ST(2)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2354 | OP("fcmovu ST(0),ST(3)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2355 | OP("fcmovu ST(0),ST(4)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2356 | OP("fcmovu ST(0),ST(5)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2357 | OP("fcmovu ST(0),ST(6)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2358 | OP("fcmovu ST(0),ST(7)", 0, 0, 0, OP_FCMOVU, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2359 |
|
---|
| 2360 | /* e */
|
---|
| 2361 | INVALID_OPCODE,
|
---|
| 2362 | INVALID_OPCODE,
|
---|
| 2363 | INVALID_OPCODE,
|
---|
| 2364 | INVALID_OPCODE,
|
---|
| 2365 | INVALID_OPCODE,
|
---|
| 2366 | INVALID_OPCODE,
|
---|
| 2367 | INVALID_OPCODE,
|
---|
| 2368 | INVALID_OPCODE,
|
---|
| 2369 | INVALID_OPCODE,
|
---|
[41676] | 2370 | OP("fucompp", 0, 0, 0, OP_FUCOMPP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2371 | INVALID_OPCODE,
|
---|
| 2372 | INVALID_OPCODE,
|
---|
| 2373 | INVALID_OPCODE,
|
---|
| 2374 | INVALID_OPCODE,
|
---|
| 2375 | INVALID_OPCODE,
|
---|
| 2376 | INVALID_OPCODE,
|
---|
| 2377 |
|
---|
| 2378 | /* f */
|
---|
| 2379 | INVALID_OPCODE_BLOCK
|
---|
| 2380 | };
|
---|
| 2381 |
|
---|
| 2382 |
|
---|
| 2383 | /* Floating point opcode starting with escape byte 0xDB (values 0-0xBF)*/
|
---|
[41690] | 2384 | const DISOPCODE g_aMapX86_EscF3_Low[8] =
|
---|
[1] | 2385 | {
|
---|
| 2386 | /* 0 */
|
---|
[41676] | 2387 | OP("fild %Md", IDX_ParseModRM, 0, 0, OP_FILD, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2388 | INVALID_OPCODE,
|
---|
[41676] | 2389 | OP("fist %Md", IDX_ParseModRM, 0, 0, OP_FIST, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2390 | OP("fistp %Md", IDX_ParseModRM, 0, 0, OP_FISTP, OP_PARM_Md, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2391 | INVALID_OPCODE,
|
---|
[41676] | 2392 | OP("fld %Mq", IDX_ParseModRM, 0, 0, OP_FLD, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2393 | INVALID_OPCODE,
|
---|
[41676] | 2394 | OP("fstp %Mq", IDX_ParseModRM, 0, 0, OP_FSTP, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2395 | };
|
---|
| 2396 |
|
---|
| 2397 |
|
---|
| 2398 | /* Floating point opcode starting with escape byte 0xDB (outside 0-0xBF)*/
|
---|
[41690] | 2399 | const DISOPCODE g_aMapX86_EscF3_High[16*4] =
|
---|
[1] | 2400 | {
|
---|
| 2401 | /* c */
|
---|
[65876] | 2402 | OP("fcmovnb ST(0),ST(0)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2403 | OP("fcmovnb ST(0),ST(1)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2404 | OP("fcmovnb ST(0),ST(2)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2405 | OP("fcmovnb ST(0),ST(3)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2406 | OP("fcmovnb ST(0),ST(4)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2407 | OP("fcmovnb ST(0),ST(5)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2408 | OP("fcmovnb ST(0),ST(6)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2409 | OP("fcmovnb ST(0),ST(7)", 0, 0, 0, OP_FCMOVNB, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2410 | OP("fcmovne ST(0),ST(0)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2411 | OP("fcmovne ST(0),ST(1)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2412 | OP("fcmovne ST(0),ST(2)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2413 | OP("fcmovne ST(0),ST(3)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2414 | OP("fcmovne ST(0),ST(4)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2415 | OP("fcmovne ST(0),ST(5)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2416 | OP("fcmovne ST(0),ST(6)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2417 | OP("fcmovne ST(0),ST(7)", 0, 0, 0, OP_FCMOVNE, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2418 |
|
---|
| 2419 | /* d */
|
---|
[65876] | 2420 | OP("fcmovnbe ST(0),ST(0)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2421 | OP("fcmovnbe ST(0),ST(1)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2422 | OP("fcmovnbe ST(0),ST(2)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2423 | OP("fcmovnbe ST(0),ST(3)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2424 | OP("fcmovnbe ST(0),ST(4)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2425 | OP("fcmovnbe ST(0),ST(5)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2426 | OP("fcmovnbe ST(0),ST(6)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2427 | OP("fcmovnbe ST(0),ST(7)", 0, 0, 0, OP_FCMOVNBE,OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2428 | OP("fcmovnu ST(0),ST(0)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2429 | OP("fcmovnu ST(0),ST(1)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2430 | OP("fcmovnu ST(0),ST(2)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2431 | OP("fcmovnu ST(0),ST(3)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2432 | OP("fcmovnu ST(0),ST(4)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2433 | OP("fcmovnu ST(0),ST(5)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2434 | OP("fcmovnu ST(0),ST(6)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2435 | OP("fcmovnu ST(0),ST(7)", 0, 0, 0, OP_FCMOVNU, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2436 |
|
---|
| 2437 | /* e */
|
---|
| 2438 | INVALID_OPCODE,
|
---|
| 2439 | INVALID_OPCODE,
|
---|
[41676] | 2440 | OP("fclex", 0, 0, 0, OP_FCLEX, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2441 | OP("finit", 0, 0, 0, OP_FINIT, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2442 | INVALID_OPCODE,
|
---|
| 2443 | INVALID_OPCODE,
|
---|
| 2444 | INVALID_OPCODE,
|
---|
| 2445 | INVALID_OPCODE,
|
---|
[65876] | 2446 | OP("fucomi ST(0),ST(0)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2447 | OP("fucomi ST(0),ST(1)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2448 | OP("fucomi ST(0),ST(2)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2449 | OP("fucomi ST(0),ST(3)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2450 | OP("fucomi ST(0),ST(4)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2451 | OP("fucomi ST(0),ST(5)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2452 | OP("fucomi ST(0),ST(6)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2453 | OP("fucomi ST(0),ST(7)", 0, 0, 0, OP_FUCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2454 |
|
---|
| 2455 |
|
---|
| 2456 | /* e */
|
---|
[65876] | 2457 | OP("fcomi ST(0),ST(0)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2458 | OP("fcomi ST(0),ST(1)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2459 | OP("fcomi ST(0),ST(2)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2460 | OP("fcomi ST(0),ST(3)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2461 | OP("fcomi ST(0),ST(4)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2462 | OP("fcomi ST(0),ST(5)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2463 | OP("fcomi ST(0),ST(6)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2464 | OP("fcomi ST(0),ST(7)", 0, 0, 0, OP_FCOMI, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2465 | INVALID_OPCODE,
|
---|
| 2466 | INVALID_OPCODE,
|
---|
| 2467 | INVALID_OPCODE,
|
---|
| 2468 | INVALID_OPCODE,
|
---|
| 2469 | INVALID_OPCODE,
|
---|
| 2470 | INVALID_OPCODE,
|
---|
| 2471 | INVALID_OPCODE,
|
---|
| 2472 | INVALID_OPCODE,
|
---|
| 2473 | };
|
---|
| 2474 |
|
---|
| 2475 |
|
---|
| 2476 | /* Floating point opcode starting with escape byte 0xDC (values 0-0xBF)*/
|
---|
[41690] | 2477 | const DISOPCODE g_aMapX86_EscF4_Low[8] =
|
---|
[1] | 2478 | {
|
---|
| 2479 | /* 0 */
|
---|
[41676] | 2480 | OP("fadd %Mq", IDX_ParseModRM, 0, 0, OP_FADD, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2481 | OP("fmul %Mq", IDX_ParseModRM, 0, 0, OP_FMUL, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2482 | OP("fcom %Mq", IDX_ParseModRM, 0, 0, OP_FCOM, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2483 | OP("fcomp %Mq", IDX_ParseModRM, 0, 0, OP_FCOMP, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2484 | OP("fsub %Mq", IDX_ParseModRM, 0, 0, OP_FSUB, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2485 | OP("fsubr %Mq", IDX_ParseModRM, 0, 0, OP_FSUBR, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2486 | OP("fdiv %Mq", IDX_ParseModRM, 0, 0, OP_FDIV, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2487 | OP("fdivr %Mq", IDX_ParseModRM, 0, 0, OP_FDIVR, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2488 | };
|
---|
| 2489 |
|
---|
| 2490 |
|
---|
| 2491 | /* Floating point opcode starting with escape byte 0xDC (outside 0-0xBF)*/
|
---|
[41690] | 2492 | const DISOPCODE g_aMapX86_EscF4_High[16*4] =
|
---|
[1] | 2493 | {
|
---|
| 2494 | /* c */
|
---|
[41676] | 2495 | OP("fadd ST(0),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2496 | OP("fadd ST(1),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2497 | OP("fadd ST(2),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2498 | OP("fadd ST(3),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2499 | OP("fadd ST(4),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2500 | OP("fadd ST(5),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2501 | OP("fadd ST(6),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2502 | OP("fadd ST(7),ST(0)", 0, 0, 0, OP_FADD, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2503 | OP("fmul ST(0),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2504 | OP("fmul ST(1),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2505 | OP("fmul ST(2),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2506 | OP("fmul ST(3),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2507 | OP("fmul ST(4),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2508 | OP("fmul ST(5),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2509 | OP("fmul ST(6),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2510 | OP("fmul ST(7),ST(0)", 0, 0, 0, OP_FMUL, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2511 |
|
---|
| 2512 | /* d */
|
---|
| 2513 | INVALID_OPCODE_BLOCK
|
---|
| 2514 |
|
---|
| 2515 |
|
---|
| 2516 | /* e */
|
---|
[41676] | 2517 | OP("fsubr ST(0),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2518 | OP("fsubr ST(1),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2519 | OP("fsubr ST(2),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2520 | OP("fsubr ST(3),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2521 | OP("fsubr ST(4),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2522 | OP("fsubr ST(5),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2523 | OP("fsubr ST(6),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2524 | OP("fsubr ST(7),ST(0)", 0, 0, 0, OP_FSUBR, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2525 | OP("fsub ST(0),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2526 | OP("fsub ST(1),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2527 | OP("fsub ST(2),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2528 | OP("fsub ST(3),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2529 | OP("fsub ST(4),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2530 | OP("fsub ST(5),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2531 | OP("fsub ST(6),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2532 | OP("fsub ST(7),ST(0)", 0, 0, 0, OP_FSUB, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2533 |
|
---|
| 2534 | /* f */
|
---|
[41676] | 2535 | OP("fdivr ST(0),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2536 | OP("fdivr ST(1),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2537 | OP("fdivr ST(2),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2538 | OP("fdivr ST(3),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2539 | OP("fdivr ST(4),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2540 | OP("fdivr ST(5),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2541 | OP("fdivr ST(6),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2542 | OP("fdivr ST(7),ST(0)", 0, 0, 0, OP_FDIVR, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2543 | OP("fdiv ST(0),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2544 | OP("fdiv ST(1),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2545 | OP("fdiv ST(2),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2546 | OP("fdiv ST(3),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2547 | OP("fdiv ST(4),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2548 | OP("fdiv ST(5),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2549 | OP("fdiv ST(6),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2550 | OP("fdiv ST(7),ST(0)", 0, 0, 0, OP_FDIV, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2551 | };
|
---|
| 2552 |
|
---|
| 2553 |
|
---|
| 2554 | /* Floating point opcode starting with escape byte 0xDD (values 0-0xBF)*/
|
---|
[41690] | 2555 | const DISOPCODE g_aMapX86_EscF5_Low[8] =
|
---|
[1] | 2556 | {
|
---|
| 2557 | /* 0 */
|
---|
[41676] | 2558 | OP("fld %Mq", IDX_ParseModRM, 0, 0, OP_FLD, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS /* fixme: wasn't initialized! */),
|
---|
[1] | 2559 | INVALID_OPCODE,
|
---|
[41676] | 2560 | OP("fst %Mq", IDX_ParseModRM, 0, 0, OP_FST, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS /* fixme: wasn't initialized! */),
|
---|
| 2561 | OP("fstp %Mq", IDX_ParseModRM, 0, 0, OP_FSTP, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS /* fixme: wasn't initialized! */),
|
---|
| 2562 | OP("frstor %M", IDX_ParseModRM, 0, 0, OP_FRSTOR, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS /* fixme: wasn't initialized! */),
|
---|
[1] | 2563 | INVALID_OPCODE,
|
---|
[60416] | 2564 | OP("fnsave %M", IDX_ParseModRM, 0, 0, OP_FSAVE, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS /* fixme: wasn't initialized! */),
|
---|
[41676] | 2565 | OP("fnstsw %Mw", IDX_ParseModRM, 0, 0, OP_FNSTSW, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS /* fixme: wasn't initialized! */),
|
---|
[1] | 2566 | };
|
---|
| 2567 |
|
---|
| 2568 |
|
---|
| 2569 | /* Floating point opcode starting with escape byte 0xDD (outside 0-0xBF)*/
|
---|
[41690] | 2570 | const DISOPCODE g_aMapX86_EscF5_High[16*4] =
|
---|
[1] | 2571 | {
|
---|
| 2572 | /* c */
|
---|
[41676] | 2573 | OP("ffree ST(0)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_0, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2574 | OP("ffree ST(1)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_1, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2575 | OP("ffree ST(2)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_2, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2576 | OP("ffree ST(3)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_3, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2577 | OP("ffree ST(4)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_4, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2578 | OP("ffree ST(5)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_5, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2579 | OP("ffree ST(6)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_6, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2580 | OP("ffree ST(7)", 0, 0, 0, OP_FFREE, OP_PARM_REGFP_7, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2581 | INVALID_OPCODE,
|
---|
| 2582 | INVALID_OPCODE,
|
---|
| 2583 | INVALID_OPCODE,
|
---|
| 2584 | INVALID_OPCODE,
|
---|
| 2585 | INVALID_OPCODE,
|
---|
| 2586 | INVALID_OPCODE,
|
---|
| 2587 | INVALID_OPCODE,
|
---|
| 2588 | INVALID_OPCODE,
|
---|
| 2589 |
|
---|
| 2590 | /* d */
|
---|
[41676] | 2591 | OP("fst ST(0)", 0, 0, 0, OP_FST, OP_PARM_REGFP_0, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2592 | OP("fst ST(1)", 0, 0, 0, OP_FST, OP_PARM_REGFP_1, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2593 | OP("fst ST(2)", 0, 0, 0, OP_FST, OP_PARM_REGFP_2, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2594 | OP("fst ST(3)", 0, 0, 0, OP_FST, OP_PARM_REGFP_3, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2595 | OP("fst ST(4)", 0, 0, 0, OP_FST, OP_PARM_REGFP_4, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2596 | OP("fst ST(5)", 0, 0, 0, OP_FST, OP_PARM_REGFP_5, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2597 | OP("fst ST(6)", 0, 0, 0, OP_FST, OP_PARM_REGFP_6, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2598 | OP("fst ST(7)", 0, 0, 0, OP_FST, OP_PARM_REGFP_7, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2599 | OP("fstp ST(0)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_0, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2600 | OP("fstp ST(1)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_1, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2601 | OP("fstp ST(2)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_2, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2602 | OP("fstp ST(3)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_3, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2603 | OP("fstp ST(4)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_4, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2604 | OP("fstp ST(5)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_5, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2605 | OP("fstp ST(6)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_6, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2606 | OP("fstp ST(7)", 0, 0, 0, OP_FSTP, OP_PARM_REGFP_7, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2607 |
|
---|
| 2608 |
|
---|
| 2609 | /* e */
|
---|
[41676] | 2610 | OP("fucom ST(0)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_0, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2611 | OP("fucom ST(1)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_1, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2612 | OP("fucom ST(2)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_2, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2613 | OP("fucom ST(3)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_3, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2614 | OP("fucom ST(4)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_4, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2615 | OP("fucom ST(5)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_5, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2616 | OP("fucom ST(6)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_6, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2617 | OP("fucom ST(7)", 0, 0, 0, OP_FUCOM, OP_PARM_REGFP_7, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2618 | OP("fucomp ST(0)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_0, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2619 | OP("fucomp ST(1)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_1, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2620 | OP("fucomp ST(2)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_2, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2621 | OP("fucomp ST(3)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_3, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2622 | OP("fucomp ST(4)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_4, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2623 | OP("fucomp ST(5)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_5, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2624 | OP("fucomp ST(6)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_6, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2625 | OP("fucomp ST(7)", 0, 0, 0, OP_FUCOMP, OP_PARM_REGFP_7, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2626 |
|
---|
| 2627 | /* f */
|
---|
| 2628 | INVALID_OPCODE_BLOCK
|
---|
| 2629 | };
|
---|
| 2630 |
|
---|
| 2631 |
|
---|
| 2632 |
|
---|
| 2633 | /* Floating point opcode starting with escape byte 0xDE (values 0-0xBF)*/
|
---|
[41690] | 2634 | const DISOPCODE g_aMapX86_EscF6_Low[8] =
|
---|
[1] | 2635 | {
|
---|
| 2636 | /* 0 */
|
---|
[41676] | 2637 | OP("fiadd %Mw", IDX_ParseModRM, 0, 0, OP_FIADD, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2638 | OP("fimul %Mw", IDX_ParseModRM, 0, 0, OP_FIMUL, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2639 | OP("ficom %Mw", IDX_ParseModRM, 0, 0, OP_FICOM, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2640 | OP("ficomp %Mw", IDX_ParseModRM, 0, 0, OP_FICOMP, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2641 | OP("fisub %Mw", IDX_ParseModRM, 0, 0, OP_FISUB, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2642 | OP("fisubr %Mw", IDX_ParseModRM, 0, 0, OP_FISUBR, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2643 | OP("fidiv %Mw", IDX_ParseModRM, 0, 0, OP_FIDIV, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2644 | OP("fidivr %Mw", IDX_ParseModRM, 0, 0, OP_FIDIVR, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2645 | };
|
---|
| 2646 |
|
---|
| 2647 |
|
---|
| 2648 | /* Floating point opcode starting with escape byte 0xDE (outside 0-0xBF)*/
|
---|
[41690] | 2649 | const DISOPCODE g_aMapX86_EscF6_High[16*4] =
|
---|
[1] | 2650 | {
|
---|
| 2651 | /* c */
|
---|
[41676] | 2652 | OP("faddp ST(0),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2653 | OP("faddp ST(1),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2654 | OP("faddp ST(2),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2655 | OP("faddp ST(3),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2656 | OP("faddp ST(4),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2657 | OP("faddp ST(5),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2658 | OP("faddp ST(6),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2659 | OP("faddp ST(7),ST(0)", 0, 0, 0, OP_FADDP, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2660 | OP("fmulp ST(0),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2661 | OP("fmulp ST(1),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2662 | OP("fmulp ST(2),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2663 | OP("fmulp ST(3),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2664 | OP("fmulp ST(4),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2665 | OP("fmulp ST(5),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2666 | OP("fmulp ST(6),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2667 | OP("fmulp ST(7),ST(0)", 0, 0, 0, OP_FMULP, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2668 |
|
---|
| 2669 | /* d */
|
---|
| 2670 | INVALID_OPCODE,
|
---|
[41676] | 2671 | OP("fcompp", 0, 0, 0, OP_FCOMPP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2672 | INVALID_OPCODE,
|
---|
| 2673 | INVALID_OPCODE,
|
---|
| 2674 | INVALID_OPCODE,
|
---|
| 2675 | INVALID_OPCODE,
|
---|
| 2676 | INVALID_OPCODE,
|
---|
| 2677 | INVALID_OPCODE,
|
---|
| 2678 | INVALID_OPCODE,
|
---|
| 2679 | INVALID_OPCODE,
|
---|
| 2680 | INVALID_OPCODE,
|
---|
| 2681 | INVALID_OPCODE,
|
---|
| 2682 | INVALID_OPCODE,
|
---|
| 2683 | INVALID_OPCODE,
|
---|
| 2684 | INVALID_OPCODE,
|
---|
| 2685 | INVALID_OPCODE,
|
---|
| 2686 |
|
---|
| 2687 |
|
---|
| 2688 | /* e */
|
---|
[41676] | 2689 | OP("fsubrp ST(0),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2690 | OP("fsubrp ST(1),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2691 | OP("fsubrp ST(2),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2692 | OP("fsubrp ST(3),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2693 | OP("fsubrp ST(4),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2694 | OP("fsubrp ST(5),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2695 | OP("fsubrp ST(6),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2696 | OP("fsubrp ST(7),ST(0)", 0, 0, 0, OP_FSUBRP, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2697 | OP("fsubp ST(0),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2698 | OP("fsubp ST(1),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2699 | OP("fsubp ST(2),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2700 | OP("fsubp ST(3),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2701 | OP("fsubp ST(4),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2702 | OP("fsubp ST(5),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2703 | OP("fsubp ST(6),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2704 | OP("fsubp ST(7),ST(0)", 0, 0, 0, OP_FSUBP, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2705 |
|
---|
| 2706 | /* f */
|
---|
[41676] | 2707 | OP("fdivrp ST(0),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2708 | OP("fdivrp ST(1),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2709 | OP("fdivrp ST(2),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2710 | OP("fdivrp ST(3),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2711 | OP("fdivrp ST(4),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2712 | OP("fdivrp ST(5),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2713 | OP("fdivrp ST(6),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2714 | OP("fdivrp ST(7),ST(0)", 0, 0, 0, OP_FDIVRP, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2715 | OP("fdivp ST(0),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2716 | OP("fdivp ST(1),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_1, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2717 | OP("fdivp ST(2),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_2, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2718 | OP("fdivp ST(3),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_3, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2719 | OP("fdivp ST(4),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_4, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2720 | OP("fdivp ST(5),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_5, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2721 | OP("fdivp ST(6),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_6, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2722 | OP("fdivp ST(7),ST(0)", 0, 0, 0, OP_FDIVP, OP_PARM_REGFP_7, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2723 | };
|
---|
| 2724 |
|
---|
| 2725 | /* Floating point opcode starting with escape byte 0xDF (values 0-0xBF)*/
|
---|
[41690] | 2726 | const DISOPCODE g_aMapX86_EscF7_Low[8] =
|
---|
[1] | 2727 | {
|
---|
| 2728 | /* 0 */
|
---|
[41676] | 2729 | OP("fild %Mw", IDX_ParseModRM, 0, 0, OP_FILD, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2730 | INVALID_OPCODE,
|
---|
[41676] | 2731 | OP("fist %Mw", IDX_ParseModRM, 0, 0, OP_FIST, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2732 | OP("fistp %Mw", IDX_ParseModRM, 0, 0, OP_FISTP, OP_PARM_Mw, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2733 | OP("fbld %M", IDX_ParseModRM, 0, 0, OP_FBLD, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2734 | OP("fild %Mq", IDX_ParseModRM, 0, 0, OP_FILD, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2735 | OP("fbstp %M", IDX_ParseModRM, 0, 0, OP_FBSTP, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2736 | OP("fistp %Mq", IDX_ParseModRM, 0, 0, OP_FISTP, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2737 | };
|
---|
| 2738 |
|
---|
| 2739 |
|
---|
| 2740 | /* Floating point opcode starting with escape byte 0xDF (outside 0-0xBF)*/
|
---|
[41690] | 2741 | const DISOPCODE g_aMapX86_EscF7_High[16*4] =
|
---|
[1] | 2742 | {
|
---|
| 2743 | /* c */
|
---|
| 2744 | INVALID_OPCODE_BLOCK
|
---|
| 2745 |
|
---|
| 2746 | /* d */
|
---|
| 2747 | INVALID_OPCODE_BLOCK
|
---|
| 2748 |
|
---|
| 2749 | /* e */
|
---|
[41676] | 2750 | OP("fnstsw ax", IDX_ParseFixedReg, 0, 0, OP_FNSTSW, OP_PARM_REG_AX, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2751 | INVALID_OPCODE,
|
---|
| 2752 | INVALID_OPCODE,
|
---|
| 2753 | INVALID_OPCODE,
|
---|
| 2754 | INVALID_OPCODE,
|
---|
| 2755 | INVALID_OPCODE,
|
---|
| 2756 | INVALID_OPCODE,
|
---|
| 2757 | INVALID_OPCODE,
|
---|
[65876] | 2758 | OP("fucomip ST(0),ST(0)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2759 | OP("fucomip ST(0),ST(1)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2760 | OP("fucomip ST(0),ST(2)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2761 | OP("fucomip ST(0),ST(3)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2762 | OP("fucomip ST(0),ST(4)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2763 | OP("fucomip ST(0),ST(5)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2764 | OP("fucomip ST(0),ST(6)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2765 | OP("fucomip ST(0),ST(7)", 0, 0, 0, OP_FUCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2766 |
|
---|
| 2767 | /* f */
|
---|
[41676] | 2768 | OP("fcomip ST(0),ST(0)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_0,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2769 | OP("fcomip ST(0),ST(1)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_1,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2770 | OP("fcomip ST(0),ST(2)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_2,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2771 | OP("fcomip ST(0),ST(3)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_3,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2772 | OP("fcomip ST(0),ST(4)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_4,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2773 | OP("fcomip ST(0),ST(5)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_5,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2774 | OP("fcomip ST(0),ST(6)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_6,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2775 | OP("fcomip ST(0),ST(7)", 0, 0, 0, OP_FCOMIP, OP_PARM_REGFP_0, OP_PARM_REGFP_7,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2776 | INVALID_OPCODE,
|
---|
| 2777 | INVALID_OPCODE,
|
---|
| 2778 | INVALID_OPCODE,
|
---|
| 2779 | INVALID_OPCODE,
|
---|
| 2780 | INVALID_OPCODE,
|
---|
| 2781 | INVALID_OPCODE,
|
---|
| 2782 | INVALID_OPCODE,
|
---|
| 2783 | INVALID_OPCODE,
|
---|
| 2784 | };
|
---|
| 2785 |
|
---|
| 2786 |
|
---|
[41707] | 2787 | const PCDISOPCODE g_apMapX86_FP_Low[8] =
|
---|
[1] | 2788 | {
|
---|
| 2789 | g_aMapX86_EscF0_Low,
|
---|
| 2790 | g_aMapX86_EscF1_Low,
|
---|
| 2791 | g_aMapX86_EscF2_Low,
|
---|
| 2792 | g_aMapX86_EscF3_Low,
|
---|
| 2793 | g_aMapX86_EscF4_Low,
|
---|
| 2794 | g_aMapX86_EscF5_Low,
|
---|
| 2795 | g_aMapX86_EscF6_Low,
|
---|
| 2796 | g_aMapX86_EscF7_Low
|
---|
| 2797 | };
|
---|
| 2798 |
|
---|
[41707] | 2799 | const PCDISOPCODE g_apMapX86_FP_High[8] =
|
---|
[1] | 2800 | {
|
---|
| 2801 | g_aMapX86_EscF0_High,
|
---|
| 2802 | g_aMapX86_EscF1_High,
|
---|
| 2803 | g_aMapX86_EscF2_High,
|
---|
| 2804 | g_aMapX86_EscF3_High,
|
---|
| 2805 | g_aMapX86_EscF4_High,
|
---|
| 2806 | g_aMapX86_EscF5_High,
|
---|
| 2807 | g_aMapX86_EscF6_High,
|
---|
| 2808 | g_aMapX86_EscF7_High
|
---|
| 2809 | };
|
---|
| 2810 |
|
---|
| 2811 | /* Opcode extensions (Group tables) */
|
---|
[41690] | 2812 | const DISOPCODE g_aMapX86_Group1[8*4] =
|
---|
[1] | 2813 | {
|
---|
| 2814 | /* 80 */
|
---|
[65876] | 2815 | OP("add %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ADD, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2816 | OP("or %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_OR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2817 | OP("adc %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ADC, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2818 | OP("sbb %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SBB, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2819 | OP("and %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_AND, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2820 | OP("sub %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SUB, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2821 | OP("xor %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_XOR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2822 | OP("cmp %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_CMP, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2823 |
|
---|
| 2824 | /* 81 */
|
---|
[41676] | 2825 | OP("add %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_ADD, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2826 | OP("or %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_OR, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2827 | OP("adc %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_ADC, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2828 | OP("sbb %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_SBB, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2829 | OP("and %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_AND, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2830 | OP("sub %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_SUB, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2831 | OP("xor %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_XOR, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2832 | OP("cmp %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_CMP, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2833 |
|
---|
| 2834 | /* 82 */
|
---|
[65876] | 2835 | OP("add %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ADD, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2836 | OP("or %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_OR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2837 | OP("adc %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ADC, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2838 | OP("sbb %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SBB, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2839 | OP("and %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_AND, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2840 | OP("sub %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SUB, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2841 | OP("xor %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_XOR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2842 | OP("cmp %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_CMP, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2843 |
|
---|
| 2844 | /* 83 */
|
---|
[65876] | 2845 | OP("add %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_ADD, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2846 | OP("or %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_OR, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2847 | OP("adc %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_ADC, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2848 | OP("sbb %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_SBB, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2849 | OP("and %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_AND, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2850 | OP("sub %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_SUB, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2851 | OP("xor %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_XOR, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2852 | OP("cmp %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByteSX, 0, OP_CMP, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2853 | };
|
---|
| 2854 |
|
---|
[41690] | 2855 | const DISOPCODE g_aMapX86_Group2[8*6] =
|
---|
[1] | 2856 | {
|
---|
| 2857 | /* C0 */
|
---|
[65876] | 2858 | OP("rol %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ROL, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2859 | OP("ror %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ROR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2860 | OP("rcl %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_RCL, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2861 | OP("rcr %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_RCR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2862 | OP("shl/sal %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SHL, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2863 | OP("shr %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SHR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2864 | OP("shl/sal %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SHL, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2865 | OP("sar %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SAR, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2866 |
|
---|
| 2867 | /* C1 */
|
---|
[65876] | 2868 | OP("rol %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ROL, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2869 | OP("ror %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_ROR, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2870 | OP("rcl %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_RCL, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2871 | OP("rcr %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_RCR, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2872 | OP("shl/sal %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SHL, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2873 | OP("shr %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SHR, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2874 | OP("shl/sal %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SHL, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2875 | OP("sar %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_SAR, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2876 |
|
---|
| 2877 | /* D0 */
|
---|
[41676] | 2878 | OP("rol %Eb,1", IDX_ParseModRM, 0, 0, OP_ROL, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2879 | OP("ror %Eb,1", IDX_ParseModRM, 0, 0, OP_ROR, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2880 | OP("rcl %Eb,1", IDX_ParseModRM, 0, 0, OP_RCL, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2881 | OP("rcr %Eb,1", IDX_ParseModRM, 0, 0, OP_RCR, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2882 | OP("shl/sal %Eb,1", IDX_ParseModRM, 0, 0, OP_SHL, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2883 | OP("shr %Eb,1", IDX_ParseModRM, 0, 0, OP_SHR, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2884 | OP("shl/sal %Eb,1", IDX_ParseModRM, 0, 0, OP_SHL, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2885 | OP("sar %Eb,1", IDX_ParseModRM, 0, 0, OP_SAR, OP_PARM_Eb, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2886 |
|
---|
| 2887 | /* D1 */
|
---|
[41676] | 2888 | OP("rol %Ev,1", IDX_ParseModRM, 0, 0, OP_ROL, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2889 | OP("ror %Ev,1", IDX_ParseModRM, 0, 0, OP_ROR, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2890 | OP("rcl %Ev,1", IDX_ParseModRM, 0, 0, OP_RCL, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2891 | OP("rcr %Ev,1", IDX_ParseModRM, 0, 0, OP_RCR, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2892 | OP("shl/sal %Ev,1", IDX_ParseModRM, 0, 0, OP_SHL, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2893 | OP("shr %Ev,1", IDX_ParseModRM, 0, 0, OP_SHR, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2894 | OP("shl/sal %Ev,1", IDX_ParseModRM, 0, 0, OP_SHL, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2895 | OP("sar %Ev,1", IDX_ParseModRM, 0, 0, OP_SAR, OP_PARM_Ev, OP_PARM_1 , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2896 |
|
---|
| 2897 | /* D2 */
|
---|
[41676] | 2898 | OP("rol %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_ROL, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2899 | OP("ror %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_ROR, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2900 | OP("rcl %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_RCL, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2901 | OP("rcr %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_RCR, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2902 | OP("shl/sal %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SHL, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2903 | OP("shr %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SHR, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2904 | OP("shl/sal %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SHL, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2905 | OP("sar %Eb,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SAR, OP_PARM_Eb, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2906 |
|
---|
| 2907 | /* D3 */
|
---|
[41676] | 2908 | OP("rol %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_ROL, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2909 | OP("ror %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_ROR, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2910 | OP("rcl %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_RCL, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2911 | OP("rcr %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_RCR, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2912 | OP("shl/sal %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SHL, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2913 | OP("shr %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SHR, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2914 | OP("shl/sal %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SHL, OP_PARM_Ev, OP_PARM_REG_CL, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2915 | OP("sar %Ev,CL", IDX_ParseModRM, IDX_ParseFixedReg, 0, OP_SAR, OP_PARM_Ev, OP_PARM_REG_CL ,OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2916 |
|
---|
| 2917 | };
|
---|
| 2918 |
|
---|
| 2919 |
|
---|
[41690] | 2920 | const DISOPCODE g_aMapX86_Group3[8*2] =
|
---|
[1] | 2921 | {
|
---|
| 2922 | /* F6 */
|
---|
[65876] | 2923 | OP("test %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_TEST, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2924 | //AMD manual claims test??
|
---|
[41863] | 2925 | INVALID_OPCODE_MOD_RM(0xf601),
|
---|
[41676] | 2926 | OP("not %Eb", IDX_ParseModRM, 0, 0, OP_NOT, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2927 | OP("neg %Eb", IDX_ParseModRM, 0, 0, OP_NEG, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2928 | OP("mul %Eb", IDX_ParseModRM, 0, 0, OP_MUL, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2929 | OP("imul %Eb", IDX_ParseModRM, 0, 0, OP_IMUL, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2930 | OP("div %Eb", IDX_ParseModRM, 0, 0, OP_DIV, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2931 | OP("idiv %Eb", IDX_ParseModRM, 0, 0, OP_IDIV, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2932 |
|
---|
| 2933 | /* F7 */
|
---|
[41676] | 2934 | OP("test %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_TEST, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2935 | //AMD manual claims test??
|
---|
[41863] | 2936 | INVALID_OPCODE_MOD_RM(0xf701),
|
---|
[41676] | 2937 | OP("not %Ev", IDX_ParseModRM, 0, 0, OP_NOT, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2938 | OP("neg %Ev", IDX_ParseModRM, 0, 0, OP_NEG, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2939 | OP("mul %Ev", IDX_ParseModRM, 0, 0, OP_MUL, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2940 | OP("imul %Ev", IDX_ParseModRM, 0, 0, OP_IMUL, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2941 | OP("div %Ev", IDX_ParseModRM, 0, 0, OP_DIV, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2942 | OP("idiv %Ev", IDX_ParseModRM, 0, 0, OP_IDIV, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 2943 | };
|
---|
| 2944 |
|
---|
[41690] | 2945 | const DISOPCODE g_aMapX86_Group4[8] =
|
---|
[1] | 2946 | {
|
---|
| 2947 | /* FE */
|
---|
[41676] | 2948 | OP("inc %Eb", IDX_ParseModRM, 0, 0, OP_INC, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2949 | OP("dec %Eb", IDX_ParseModRM, 0, 0, OP_DEC, OP_PARM_Eb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 2950 | INVALID_OPCODE_MOD_RM(0xfe02),
|
---|
| 2951 | INVALID_OPCODE_MOD_RM(0xfe03),
|
---|
| 2952 | INVALID_OPCODE_MOD_RM(0xfe04),
|
---|
| 2953 | INVALID_OPCODE_MOD_RM(0xfe05),
|
---|
| 2954 | INVALID_OPCODE_MOD_RM(0xfe06),
|
---|
| 2955 | INVALID_OPCODE_MOD_RM(0xfe07),
|
---|
[1] | 2956 | };
|
---|
| 2957 |
|
---|
[41690] | 2958 | const DISOPCODE g_aMapX86_Group5[8] =
|
---|
[1] | 2959 | {
|
---|
| 2960 | /* FF */
|
---|
[41676] | 2961 | OP("inc %Ev", IDX_ParseModRM, 0, 0, OP_INC, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2962 | OP("dec %Ev", IDX_ParseModRM, 0, 0, OP_DEC, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 2963 | OP("call %Ev", IDX_ParseModRM, 0, 0, OP_CALL, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 2964 | OP("call %Ep", IDX_ParseModRM, 0, 0, OP_CALL, OP_PARM_Ep, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW),
|
---|
| 2965 | OP("jmp %Ev", IDX_ParseModRM, 0, 0, OP_JMP, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW | DISOPTYPE_FORCED_64_OP_SIZE),
|
---|
| 2966 | OP("jmp %Ep", IDX_ParseModRM, 0, 0, OP_JMP, OP_PARM_Ep, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_CONTROLFLOW | DISOPTYPE_UNCOND_CONTROLFLOW),
|
---|
| 2967 | OP("push %Ev", IDX_ParseModRM, 0, 0, OP_PUSH, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS | DISOPTYPE_DEFAULT_64_OP_SIZE),
|
---|
[41863] | 2968 | INVALID_OPCODE_MOD_RM(0xff07),
|
---|
[1] | 2969 | };
|
---|
| 2970 |
|
---|
| 2971 |
|
---|
[41690] | 2972 | const DISOPCODE g_aMapX86_Group6[8] =
|
---|
[1] | 2973 | {
|
---|
| 2974 | /* 0F 00 */
|
---|
[41676] | 2975 | OP("sldt %Ew", IDX_ParseModRM, 0, 0, OP_SLDT, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
| 2976 | OP("str %Ev", IDX_ParseModRM, 0, 0, OP_STR, OP_PARM_Ev, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
| 2977 | OP("lldt %Ew", IDX_ParseModRM, 0, 0, OP_LLDT, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 2978 | OP("ltr %Ew", IDX_ParseModRM, 0, 0, OP_LTR, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 2979 | OP("verr %Ew", IDX_ParseModRM, 0, 0, OP_VERR, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
| 2980 | OP("verw %Ew", IDX_ParseModRM, 0, 0, OP_VERW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
[41863] | 2981 | INVALID_OPCODE_MOD_RM(0x0f0006),
|
---|
| 2982 | INVALID_OPCODE_MOD_RM(0x0f0007),
|
---|
[1] | 2983 | };
|
---|
| 2984 |
|
---|
[41796] | 2985 | /* Note!! Group 7 is NOT using the INVALID_OPCODE_MOD_RM because of monitor and vmcall. */
|
---|
[41690] | 2986 | const DISOPCODE g_aMapX86_Group7_mem[8] =
|
---|
[1] | 2987 | {
|
---|
| 2988 | /* 0F 01 */
|
---|
[41676] | 2989 | OP("sgdt %Ms", IDX_ParseModRM, 0, 0, OP_SGDT, OP_PARM_Ms, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
| 2990 | OP("sidt %Ms", IDX_ParseModRM, 0, 0, OP_SIDT, OP_PARM_Ms, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
| 2991 | OP("lgdt %Ms", IDX_ParseModRM, 0, 0, OP_LGDT, OP_PARM_Ms, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 2992 | OP("lidt %Ms", IDX_ParseModRM, 0, 0, OP_LIDT, OP_PARM_Ms, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 2993 | OP("smsw %Ew", IDX_ParseModRM, 0, 0, OP_SMSW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
[1] | 2994 | INVALID_OPCODE,
|
---|
[41676] | 2995 | OP("lmsw %Ew", IDX_ParseModRM, 0, 0, OP_LMSW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 2996 | OP("invlpg %Mb", IDX_ParseModRM, 0, 0, OP_INVLPG, OP_PARM_Mb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
[1] | 2997 | };
|
---|
| 2998 |
|
---|
[41796] | 2999 | /* Note!! Group 7 is NOT using the INVALID_OPCODE_MOD_RM because of monitor and vmcall. */
|
---|
[41690] | 3000 | const DISOPCODE g_aMapX86_Group7_mod11_rm000[8] =
|
---|
[1] | 3001 | {
|
---|
| 3002 | /* 0F 01 MOD=11b */
|
---|
| 3003 | INVALID_OPCODE,
|
---|
[41676] | 3004 | OP("monitor %eAX,%eCX,%eDX", IDX_ParseFixedReg, IDX_ParseFixedReg, IDX_ParseFixedReg, OP_MONITOR, OP_PARM_REG_EAX, OP_PARM_REG_ECX, OP_PARM_REG_EDX, DISOPTYPE_HARMLESS ),
|
---|
[1] | 3005 | INVALID_OPCODE,
|
---|
| 3006 | INVALID_OPCODE,
|
---|
[41676] | 3007 | OP("smsw %Ew", IDX_ParseModRM, 0, 0, OP_SMSW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
[1] | 3008 | INVALID_OPCODE,
|
---|
[41676] | 3009 | OP("lmsw %Ew", IDX_ParseModRM, 0, 0, OP_LMSW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
| 3010 | OP("swapgs", 0, 0, 0, OP_SWAPGS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS )
|
---|
[1] | 3011 | };
|
---|
| 3012 |
|
---|
[41796] | 3013 | /* Note!! Group 7 is NOT using the INVALID_OPCODE_MOD_RM because of monitor and vmcall. */
|
---|
[41690] | 3014 | const DISOPCODE g_aMapX86_Group7_mod11_rm001[8] =
|
---|
[1] | 3015 | {
|
---|
| 3016 | /* 0F 01 MOD=11b */
|
---|
[41676] | 3017 | OP("vmcall", 0, 0, 0, OP_VMCALL, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS ),
|
---|
| 3018 | OP("mwait %eAX,%eCX", IDX_ParseFixedReg, IDX_ParseFixedReg, 0, OP_MWAIT, OP_PARM_REG_EAX, OP_PARM_REG_ECX,OP_PARM_NONE, DISOPTYPE_HARMLESS ),
|
---|
[55111] | 3019 | INVALID_OPCODE, /* xsetbv */
|
---|
| 3020 | OP("vmmcall", 0, 0, 0, OP_VMMCALL, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS ),
|
---|
[41676] | 3021 | OP("smsw %Ew", IDX_ParseModRM, 0, 0, OP_SMSW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP),
|
---|
[1] | 3022 | INVALID_OPCODE,
|
---|
[41676] | 3023 | OP("lmsw %Ew", IDX_ParseModRM, 0, 0, OP_LMSW, OP_PARM_Ew, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED),
|
---|
[1] | 3024 | INVALID_OPCODE,
|
---|
| 3025 | };
|
---|
| 3026 |
|
---|
[41690] | 3027 | const DISOPCODE g_aMapX86_Group8[8] =
|
---|
[1] | 3028 | {
|
---|
| 3029 | /* 0F BA */
|
---|
[41863] | 3030 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3031 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3032 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3033 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[41676] | 3034 | OP("bt %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_BT, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3035 | OP("bts %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_BTS, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3036 | OP("btr %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_BTR, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3037 | OP("btc %Ev,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_BTC, OP_PARM_Ev, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 3038 | };
|
---|
| 3039 |
|
---|
[41690] | 3040 | const DISOPCODE g_aMapX86_Group9[8] =
|
---|
[1] | 3041 | {
|
---|
| 3042 | /* 0F C7 */
|
---|
[41863] | 3043 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[41676] | 3044 | OP("cmpxchg8b %Mq", IDX_ParseModRM, 0, 0, OP_CMPXCHG8B, OP_PARM_Mq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3045 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3046 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3047 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3048 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3049 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3050 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3051 | };
|
---|
| 3052 |
|
---|
[41690] | 3053 | const DISOPCODE g_aMapX86_Group10[8] =
|
---|
[1] | 3054 | {
|
---|
| 3055 | /* 0F B9 */
|
---|
[41863] | 3056 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3057 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3058 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3059 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3060 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3061 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3062 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3063 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3064 | };
|
---|
| 3065 |
|
---|
| 3066 |
|
---|
[41690] | 3067 | const DISOPCODE g_aMapX86_Group11[8*2] =
|
---|
[1] | 3068 | {
|
---|
| 3069 | /* 0F C6 */
|
---|
[41676] | 3070 | OP("mov %Eb,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_MOV, OP_PARM_Eb, OP_PARM_Ib , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 3071 | INVALID_OPCODE,
|
---|
| 3072 | INVALID_OPCODE,
|
---|
| 3073 | INVALID_OPCODE,
|
---|
| 3074 | INVALID_OPCODE,
|
---|
| 3075 | INVALID_OPCODE,
|
---|
| 3076 | INVALID_OPCODE,
|
---|
| 3077 | INVALID_OPCODE,
|
---|
| 3078 | /* 0F C7 */
|
---|
[41676] | 3079 | OP("mov %Ev,%Iz", IDX_ParseModRM, IDX_ParseImmZ, 0, OP_MOV, OP_PARM_Ev, OP_PARM_Iz , OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 3080 | INVALID_OPCODE,
|
---|
| 3081 | INVALID_OPCODE,
|
---|
| 3082 | INVALID_OPCODE,
|
---|
| 3083 | INVALID_OPCODE,
|
---|
| 3084 | INVALID_OPCODE,
|
---|
| 3085 | INVALID_OPCODE,
|
---|
| 3086 | INVALID_OPCODE,
|
---|
| 3087 | };
|
---|
| 3088 |
|
---|
| 3089 |
|
---|
| 3090 | /* 0xF 0x71 */
|
---|
[41690] | 3091 | const DISOPCODE g_aMapX86_Group12[8*2] =
|
---|
[1] | 3092 | {
|
---|
[41863] | 3093 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3094 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3095 | OP("psrlw %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRLW, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3096 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3097 | OP("psraw %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRAW, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3098 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3099 | OP("psllw %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSLLW, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3100 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3101 |
|
---|
| 3102 | /* Group 12 with prefix 0x66 */
|
---|
[41863] | 3103 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3104 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3105 | OP("psrlw %Pdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRLW, OP_PARM_Pdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3106 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3107 | OP("psraw %Pdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRAW, OP_PARM_Pdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3108 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3109 | OP("psllw %Pdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSLLW, OP_PARM_Pdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3110 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3111 | };
|
---|
| 3112 |
|
---|
| 3113 | /* 0xF 0x72 */
|
---|
[41690] | 3114 | const DISOPCODE g_aMapX86_Group13[8*2] =
|
---|
[1] | 3115 | {
|
---|
[41863] | 3116 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3117 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3118 | OP("psrld %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRLD, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3119 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3120 | OP("psrad %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRAD, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3121 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3122 | OP("pslld %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSLLD, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3123 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3124 |
|
---|
| 3125 | /* Group 13 with prefix 0x66 */
|
---|
[41863] | 3126 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3127 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3128 | OP("psrld %Wdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRLD, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3129 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3130 | OP("psrad %Wdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRAD, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3131 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3132 | OP("pslld %Wdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSLLD, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3133 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3134 | };
|
---|
| 3135 |
|
---|
| 3136 | /* 0xF 0x73 */
|
---|
[41690] | 3137 | const DISOPCODE g_aMapX86_Group14[8*2] =
|
---|
[1] | 3138 | {
|
---|
[41863] | 3139 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3140 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3141 | OP("psrlq %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRLQ, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3142 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3143 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3144 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3145 | OP("psllq %Pq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSLLQ, OP_PARM_Pq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3146 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3147 |
|
---|
| 3148 | /* Group 14 with prefix 0x66 */
|
---|
[41863] | 3149 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3150 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3151 | OP("psrlq %Wdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRLD, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3152 | OP("psrldq %Wdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSRLDQ, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3153 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3154 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[65876] | 3155 | OP("psllq %Wdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSLLD, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3156 | OP("pslldq %Wdq,%Ib", IDX_ParseModRM, IDX_ParseImmByte, 0, OP_PSLLDQ, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 3157 | };
|
---|
| 3158 |
|
---|
| 3159 |
|
---|
| 3160 | /* 0xF 0xAE */
|
---|
[41690] | 3161 | const DISOPCODE g_aMapX86_Group15_mem[8] =
|
---|
[1] | 3162 | {
|
---|
[41676] | 3163 | OP("fxsave %M", IDX_ParseModRM, 0, 0, OP_FXSAVE, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3164 | OP("fxrstor %M", IDX_ParseModRM, 0, 0, OP_FXRSTOR, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3165 | OP("ldmxcsr %M", IDX_ParseModRM, 0, 0, OP_LDMXCSR, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3166 | OP("stmxcsr %M", IDX_ParseModRM, 0, 0, OP_STMXCSR, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[68191] | 3167 | OP("xsave %M", IDX_ParseModRM, 0, 0, OP_XSAVE, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3168 | OP("xrstor %M", IDX_ParseModRM, 0, 0, OP_XRSTOR, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3169 | OP("xsaveopt %M", IDX_ParseModRM, 0, 0, OP_XSAVEOPT, OP_PARM_M, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41676] | 3170 | OP("clflush %Mb", IDX_ParseModRM, 0, 0, OP_CLFLUSH, OP_PARM_Mb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 3171 | };
|
---|
| 3172 |
|
---|
| 3173 | /* 0xF 0xAE */
|
---|
[41690] | 3174 | const DISOPCODE g_aMapX86_Group15_mod11_rm000[8] =
|
---|
[1] | 3175 | {
|
---|
[41863] | 3176 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3177 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3178 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3179 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3180 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[47453] | 3181 | /** @todo mfence + lfence + sfence instructions do not require rm=0,
|
---|
[47306] | 3182 | * they work for any RM value. See bs2-cpu-instr-1.asm for details. */
|
---|
[41676] | 3183 | OP("lfence", IDX_ParseModFence, 0, 0, OP_LFENCE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3184 | OP("mfence", IDX_ParseModFence, 0, 0, OP_MFENCE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3185 | OP("sfence", IDX_ParseModFence, 0, 0, OP_SFENCE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 3186 | };
|
---|
| 3187 |
|
---|
| 3188 | /* 0xF 0x18 */
|
---|
[41690] | 3189 | const DISOPCODE g_aMapX86_Group16[8] =
|
---|
[1] | 3190 | {
|
---|
[41676] | 3191 | OP("prefetchnta %Mb", IDX_ParseModRM, 0, 0, OP_PREFETCH,OP_PARM_Mb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3192 | OP("prefetcht0 %Mb", IDX_ParseModRM, 0, 0, OP_PREFETCH,OP_PARM_Mb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3193 | OP("prefetcht1 %Mb", IDX_ParseModRM, 0, 0, OP_PREFETCH,OP_PARM_Mb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3194 | OP("prefetcht2 %Mb", IDX_ParseModRM, 0, 0, OP_PREFETCH,OP_PARM_Mb, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[41863] | 3195 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3196 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3197 | INVALID_OPCODE_MOD_RM(0x),
|
---|
| 3198 | INVALID_OPCODE_MOD_RM(0x),
|
---|
[1] | 3199 | };
|
---|
| 3200 |
|
---|
| 3201 | /* 0x90 or 0xF3 0x90 */
|
---|
[41690] | 3202 | const DISOPCODE g_aMapX86_NopPause[2] =
|
---|
[1] | 3203 | {
|
---|
[41676] | 3204 | OP("nop", 0, 0, 0, OP_NOP, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3205 | OP("pause", 0, 0, 0, OP_PAUSE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[1] | 3206 | };
|
---|
| 3207 |
|
---|
[53094] | 3208 | /* Vex codes for two bytes opcodes starting with 0Fh */
|
---|
| 3209 | const DISOPCODE g_aMapTwoBytesVex[256] =
|
---|
| 3210 | {
|
---|
| 3211 | /* 0 */
|
---|
| 3212 | INVALID_OPCODE_BLOCK
|
---|
| 3213 |
|
---|
| 3214 | /* 1 */
|
---|
| 3215 | OPVEX("vmovups %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVUPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3216 | OPVEX("vmovups %Wps,%Vps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVUPS, OP_PARM_Wps, OP_PARM_Vps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53172] | 3217 | OPVEX("&vmovlps/vmovlps %Vq,%Hq,%Wq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVLPS, OP_PARM_Vq, OP_PARM_Hq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 3218 | OPVEX("vmovlps %Mq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVLPS, OP_PARM_Mq, OP_PARM_Vq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3219 | OPVEX("vunpcklps %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_UNPCKLPS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3220 | OPVEX("vunpckhps %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_UNPCKHPS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53172] | 3221 | OPVEX("&vmovhps/vmovlhps %Vdq,%Hq,%Wq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVHPS, OP_PARM_Vdq, OP_PARM_Hq, OP_PARM_Wq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 3222 | OPVEX("vmovhps %Mq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVHPS, OP_PARM_Mq, OP_PARM_Vq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3223 | INVALID_OPCODE,
|
---|
| 3224 | INVALID_OPCODE,
|
---|
| 3225 | INVALID_OPCODE,
|
---|
| 3226 | INVALID_OPCODE,
|
---|
| 3227 | INVALID_OPCODE,
|
---|
| 3228 | INVALID_OPCODE,
|
---|
| 3229 | INVALID_OPCODE,
|
---|
| 3230 | INVALID_OPCODE,
|
---|
| 3231 |
|
---|
| 3232 | /* 2 */
|
---|
| 3233 | INVALID_OPCODE,
|
---|
| 3234 | INVALID_OPCODE,
|
---|
| 3235 | INVALID_OPCODE,
|
---|
| 3236 | INVALID_OPCODE,
|
---|
| 3237 | INVALID_OPCODE,
|
---|
| 3238 | INVALID_OPCODE,
|
---|
| 3239 | INVALID_OPCODE,
|
---|
| 3240 | INVALID_OPCODE,
|
---|
| 3241 | OPVEX("vmovaps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVAPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3242 | OPVEX("vmovaps %Wps,%Vps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVAPS, OP_PARM_Wps, OP_PARM_Vps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3243 | INVALID_OPCODE,
|
---|
| 3244 | OPVEX("vmovntps %Mps,%Vps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVNTPS, OP_PARM_Mps, OP_PARM_Vps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3245 | INVALID_OPCODE,
|
---|
| 3246 | INVALID_OPCODE,
|
---|
| 3247 | OPVEX("vucomiss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_UCOMISS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3248 | OPVEX("vcomiss %Vss,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_COMISS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3249 |
|
---|
| 3250 | /* 3 */
|
---|
| 3251 | INVALID_OPCODE_BLOCK
|
---|
| 3252 |
|
---|
| 3253 | /* 4 */
|
---|
| 3254 | INVALID_OPCODE_BLOCK
|
---|
| 3255 |
|
---|
| 3256 | /* 5 */
|
---|
| 3257 | OPVEX("vmovmskps %Gy,%Ups", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVMSKPS, OP_PARM_Gy, OP_PARM_Ups, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3258 | OPVEX("vsqrtps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_SQRTPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3259 | OPVEX("vrsqrtps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_RSQRTPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3260 | OPVEX("vrcpps %Vps,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_RCPPS, OP_PARM_Vps, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3261 | OPVEX("vandps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ANDPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3262 | OPVEX("vandnps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ANDNPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3263 | OPVEX("vorps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ORPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3264 | OPVEX("vxorps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_XORPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3265 | OPVEX("vaddps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ADDPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3266 | OPVEX("vmulps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MULPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3267 | OPVEX("vcvtps2pd %Vpd,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTPS2PD, OP_PARM_Vpd, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3268 | OPVEX("vcvtdq2ps %Vps,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTDQ2PS, OP_PARM_Vps, OP_PARM_Wdq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3269 | OPVEX("vsubps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SUBPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3270 | OPVEX("vminps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MINPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3271 | OPVEX("vdivps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_DIVPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3272 | OPVEX("vmaxps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MAXPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3273 |
|
---|
| 3274 | /* 6 */
|
---|
| 3275 | INVALID_OPCODE_BLOCK
|
---|
| 3276 |
|
---|
| 3277 | /* 7 */
|
---|
| 3278 | INVALID_OPCODE,
|
---|
| 3279 | INVALID_OPCODE,
|
---|
| 3280 | INVALID_OPCODE,
|
---|
| 3281 | INVALID_OPCODE,
|
---|
| 3282 | INVALID_OPCODE,
|
---|
| 3283 | INVALID_OPCODE,
|
---|
| 3284 | INVALID_OPCODE,
|
---|
[53245] | 3285 | /* Next instruction has the following format:
|
---|
| 3286 | * @name1/name2,
|
---|
| 3287 | * where name2 is used when VEX.L bit is set,
|
---|
| 3288 | * name1 otherwise. */
|
---|
[53172] | 3289 | OPVEX("@vzeroupper/vzeroall", 0, 0, 0, 0, OP_EMMS, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 3290 | INVALID_OPCODE,
|
---|
| 3291 | INVALID_OPCODE,
|
---|
| 3292 | INVALID_OPCODE,
|
---|
| 3293 | INVALID_OPCODE,
|
---|
| 3294 | INVALID_OPCODE,
|
---|
| 3295 | INVALID_OPCODE,
|
---|
| 3296 | INVALID_OPCODE,
|
---|
| 3297 | INVALID_OPCODE,
|
---|
| 3298 |
|
---|
| 3299 | /* 8 */
|
---|
| 3300 | INVALID_OPCODE_BLOCK
|
---|
| 3301 |
|
---|
| 3302 | /* 9 */
|
---|
| 3303 | INVALID_OPCODE_BLOCK
|
---|
| 3304 |
|
---|
| 3305 | /* a */
|
---|
| 3306 | INVALID_OPCODE_BLOCK
|
---|
| 3307 |
|
---|
| 3308 | /* b */
|
---|
| 3309 | INVALID_OPCODE_BLOCK
|
---|
| 3310 |
|
---|
| 3311 | /* c */
|
---|
| 3312 | INVALID_OPCODE,
|
---|
| 3313 | INVALID_OPCODE,
|
---|
| 3314 | OPVEX("vcmpss %Vps,%Hps,%Wps,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_CMPSS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 3315 | INVALID_OPCODE,
|
---|
| 3316 | INVALID_OPCODE,
|
---|
| 3317 | INVALID_OPCODE,
|
---|
| 3318 | OPVEX("vshufps %Vps,%Hps,%Wps,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_SHUFPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 3319 | INVALID_OPCODE,
|
---|
| 3320 | INVALID_OPCODE,
|
---|
| 3321 | INVALID_OPCODE,
|
---|
| 3322 | INVALID_OPCODE,
|
---|
| 3323 | INVALID_OPCODE,
|
---|
| 3324 | INVALID_OPCODE,
|
---|
| 3325 | INVALID_OPCODE,
|
---|
| 3326 | INVALID_OPCODE,
|
---|
| 3327 | INVALID_OPCODE,
|
---|
| 3328 |
|
---|
| 3329 | /* d */
|
---|
| 3330 | INVALID_OPCODE_BLOCK
|
---|
| 3331 |
|
---|
| 3332 | /* e */
|
---|
| 3333 | INVALID_OPCODE_BLOCK
|
---|
| 3334 |
|
---|
| 3335 | /* f */
|
---|
| 3336 | INVALID_OPCODE_BLOCK
|
---|
| 3337 | };
|
---|
| 3338 |
|
---|
| 3339 | /* Vex codes for two bytes opcodes starting with 0Fh with prefix 66H*/
|
---|
| 3340 | const DISOPCODE g_aMapTwoBytesVex_66H[256] =
|
---|
| 3341 | {
|
---|
| 3342 | /* 0 */
|
---|
| 3343 | INVALID_OPCODE_BLOCK
|
---|
| 3344 |
|
---|
| 3345 | /* 1 */
|
---|
| 3346 | OPVEX("vmovupd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVUPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3347 | OPVEX("vmovupd %Wpd,%Vpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVUPD, OP_PARM_Wpd, OP_PARM_Vpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3348 | OPVEX("vmovlpd %Vq,%Hq,%Mq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVLPD, OP_PARM_Vq, OP_PARM_Hq, OP_PARM_Mq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3349 | OPVEX("vmovlpd %Mq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVLPD, OP_PARM_Mq, OP_PARM_Vq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3350 | OPVEX("vunpcklpd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_UNPCKLPD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3351 | OPVEX("vunpckhpd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_UNPCKHPD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3352 | OPVEX("vmovhpd %Vdq,%Hq,%Mq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVHPD, OP_PARM_Vdq, OP_PARM_Hq, OP_PARM_Mq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3353 | OPVEX("vmovhpd %Mq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVHPD, OP_PARM_Mq, OP_PARM_Vq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3354 | INVALID_OPCODE,
|
---|
| 3355 | INVALID_OPCODE,
|
---|
| 3356 | INVALID_OPCODE,
|
---|
| 3357 | INVALID_OPCODE,
|
---|
| 3358 | INVALID_OPCODE,
|
---|
| 3359 | INVALID_OPCODE,
|
---|
| 3360 | INVALID_OPCODE,
|
---|
| 3361 | INVALID_OPCODE,
|
---|
| 3362 |
|
---|
| 3363 | /* 2 */
|
---|
| 3364 | INVALID_OPCODE,
|
---|
| 3365 | INVALID_OPCODE,
|
---|
| 3366 | INVALID_OPCODE,
|
---|
| 3367 | INVALID_OPCODE,
|
---|
| 3368 | INVALID_OPCODE,
|
---|
| 3369 | INVALID_OPCODE,
|
---|
| 3370 | INVALID_OPCODE,
|
---|
| 3371 | INVALID_OPCODE,
|
---|
| 3372 | OPVEX("vmovapd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVAPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3373 | OPVEX("vmovapd %Wpd,%Vpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVAPD, OP_PARM_Wpd, OP_PARM_Vpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3374 | INVALID_OPCODE,
|
---|
| 3375 | OPVEX("vmovntpd %Mpd,%Vpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVNTPD, OP_PARM_Mpd, OP_PARM_Vpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3376 | INVALID_OPCODE,
|
---|
| 3377 | INVALID_OPCODE,
|
---|
| 3378 | OPVEX("vucomisd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_UCOMISD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3379 | OPVEX("vcomisd %Vsd,%Wsd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_COMISD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3380 |
|
---|
| 3381 | /* 3 */
|
---|
| 3382 | INVALID_OPCODE_BLOCK
|
---|
| 3383 |
|
---|
| 3384 | /* 4 */
|
---|
| 3385 | INVALID_OPCODE_BLOCK
|
---|
| 3386 |
|
---|
| 3387 | /* 5 */
|
---|
| 3388 | OPVEX("vmovmskpd %Gy,%Upd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVMSKPD, OP_PARM_Gy, OP_PARM_Upd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3389 | OPVEX("vsqrtpd %Vpd,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_SQRTPD, OP_PARM_Vpd, OP_PARM_Wpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3390 | INVALID_OPCODE,
|
---|
| 3391 | INVALID_OPCODE,
|
---|
| 3392 | OPVEX("vandpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ANDPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3393 | OPVEX("vandnpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ANDNPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3394 | OPVEX("vorpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ORPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3395 | OPVEX("vxorpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_XORPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3396 | OPVEX("vaddpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ADDPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3397 | OPVEX("vmulpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MULPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3398 | OPVEX("vcvtpd2ps %Vps,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTPD2PS, OP_PARM_Vps, OP_PARM_Wpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3399 | OPVEX("vcvtps2dq %Vdq,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTPS2DQ, OP_PARM_Vdq, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3400 | OPVEX("vsubpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SUBPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3401 | OPVEX("vminpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MINPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3402 | OPVEX("vdivpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_DIVPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3403 | OPVEX("vmaxpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MAXPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3404 |
|
---|
| 3405 |
|
---|
| 3406 | /* 6 */
|
---|
| 3407 | OPVEX("vpunpcklbw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKLBW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3408 | OPVEX("vpunpcklwd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKLWD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3409 | OPVEX("vpunpckldq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKLDQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3410 | OPVEX("vpacksswb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PACKSSWB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3411 | OPVEX("vpcmpgtb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPGTB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3412 | OPVEX("vpcmpgtw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPGTW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3413 | OPVEX("vpcmpgtd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPGTD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3414 | OPVEX("vpackuswb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PACKUSWB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3415 | OPVEX("vpunpckhbw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKHBW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3416 | OPVEX("vpunpckhwd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKHWD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3417 | OPVEX("vpunpckhdq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKHDQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3418 | OPVEX("vpackssdw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PACKSSDW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3419 | OPVEX("vpunpcklqdq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKLQDQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3420 | OPVEX("vpunpckhqdq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PUNPCKHQDQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53172] | 3421 | OPVEX("#vmovd/vmovq %Vy,%Ey", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVD, OP_PARM_Vy, OP_PARM_Ey, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53094] | 3422 | OPVEX("vmovdqa %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVDQA, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3423 |
|
---|
| 3424 | /* 7 */
|
---|
| 3425 | OPVEX("vpshufd %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PSHUFD, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3426 | INVALID_OPCODE,
|
---|
| 3427 | INVALID_OPCODE,
|
---|
| 3428 | INVALID_OPCODE,
|
---|
| 3429 | OPVEX("vpcmpeqb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPEQB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3430 | OPVEX("vpcmpeqw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPEQW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3431 | OPVEX("vpcmpeqd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPEQD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3432 | INVALID_OPCODE,
|
---|
| 3433 | INVALID_OPCODE,
|
---|
| 3434 | INVALID_OPCODE,
|
---|
| 3435 | INVALID_OPCODE,
|
---|
| 3436 | INVALID_OPCODE,
|
---|
| 3437 | OPVEX("vhaddpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_HADDPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3438 | OPVEX("vhsubpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_HSUBPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3439 | OPVEX("vmovd/vmovq %Ey,%Vy", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVD, OP_PARM_Ey, OP_PARM_Vy, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3440 | OPVEX("vmovdqa %Wx,%Vx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVDQA, OP_PARM_Wx, OP_PARM_Vx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3441 |
|
---|
| 3442 | /* 8 */
|
---|
| 3443 | INVALID_OPCODE_BLOCK
|
---|
| 3444 |
|
---|
| 3445 | /* 9 */
|
---|
| 3446 | INVALID_OPCODE_BLOCK
|
---|
| 3447 |
|
---|
| 3448 | /* a */
|
---|
| 3449 | INVALID_OPCODE_BLOCK
|
---|
| 3450 |
|
---|
| 3451 | /* b */
|
---|
| 3452 | INVALID_OPCODE_BLOCK
|
---|
| 3453 |
|
---|
| 3454 | /* c */
|
---|
| 3455 | INVALID_OPCODE,
|
---|
| 3456 | INVALID_OPCODE,
|
---|
| 3457 | OPVEX("vcmpps %Vpd,%Hpd,%Wpd,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_CMPSS, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 3458 | INVALID_OPCODE,
|
---|
| 3459 | // vpinsrw Vdq,Hdq,Ry/Mw,Ib
|
---|
[53131] | 3460 | OPVEX("vpinsrw %Vdq,%Hdq,%Ey,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PINSRW, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Ey, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53094] | 3461 | OPVEX("vpextrw %Gd,%Udq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PEXTRW, OP_PARM_Gd, OP_PARM_Udq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3462 | OPVEX("vshufpd %Vpd,%Hpd,%Wpd,%Ib",IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_SHUFPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 3463 | INVALID_OPCODE,
|
---|
| 3464 | INVALID_OPCODE,
|
---|
| 3465 | INVALID_OPCODE,
|
---|
| 3466 | INVALID_OPCODE,
|
---|
| 3467 | INVALID_OPCODE,
|
---|
| 3468 | INVALID_OPCODE,
|
---|
| 3469 | INVALID_OPCODE,
|
---|
| 3470 | INVALID_OPCODE,
|
---|
| 3471 | INVALID_OPCODE,
|
---|
| 3472 |
|
---|
| 3473 | /* d */
|
---|
| 3474 | OPVEX("vaddsubpd %Vpd,%Hpd,%Wpd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ADDSUBPD, OP_PARM_Vpd, OP_PARM_Hpd, OP_PARM_Wpd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3475 | OPVEX("vpsrlw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSRLW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3476 | OPVEX("vpsrld %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSRLD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3477 | OPVEX("vpsrlq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSRLQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3478 | OPVEX("vpaddq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3479 | OPVEX("vpmullw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMULLW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3480 | OPVEX("vmovq %Wq,%Vq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVQ, OP_PARM_Wq, OP_PARM_Vq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3481 | OPVEX("vpmovmskb %Gd,%Ux", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVMSKB, OP_PARM_Gd, OP_PARM_Ux, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3482 | OPVEX("vpsubusb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBUSB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3483 | OPVEX("vpsubusw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBUSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3484 | OPVEX("vpminub %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMINUB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3485 | OPVEX("vpand %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PAND, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3486 | OPVEX("vpaddusb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDUSB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3487 | OPVEX("vpaddusw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDUSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3488 | OPVEX("vpmaxub %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMAXUB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3489 | OPVEX("vpandn %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PANDN, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3490 |
|
---|
| 3491 | /* e */
|
---|
| 3492 | OPVEX("vpavgb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PAVGB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3493 | OPVEX("vpsraw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSRAW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3494 | OPVEX("vpsrad %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSRAD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3495 | OPVEX("vpavgw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PAVGW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3496 | OPVEX("vpmulhuw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMULHUW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3497 | OPVEX("vpmulhw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMULHW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3498 | OPVEX("vcvttpd2dq %Vx,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTTPD2DQ, OP_PARM_Vx, OP_PARM_Wpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3499 | OPVEX("vmovntdq %Mx,%Vx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVNTDQ, OP_PARM_Mx, OP_PARM_Vx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3500 | OPVEX("vpsubsb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBSB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3501 | OPVEX("vpsubsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3502 | OPVEX("vpminsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMINSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3503 | OPVEX("vpor %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_POR, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3504 | OPVEX("vpaddsb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDSB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3505 | OPVEX("vpaddsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3506 | OPVEX("vpmaxsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMAXSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3507 | OPVEX("vpxor %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PXOR, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3508 |
|
---|
| 3509 | /* f */
|
---|
| 3510 | INVALID_OPCODE,
|
---|
| 3511 | OPVEX("vpsllw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSLLW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3512 | OPVEX("vpslld %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSLLD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3513 | OPVEX("vpsllq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSLLQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3514 | OPVEX("vpmuludq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMULUDQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3515 | OPVEX("vpmaddwd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMADDWD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3516 | OPVEX("vpsadbw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSADBW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3517 | OPVEX("vmaskmovdqu %Vdq,%Udq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MASKMOVDQU,OP_PARM_Vdq, OP_PARM_Udq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3518 | OPVEX("vpsubb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3519 | OPVEX("vpsubw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3520 | OPVEX("vpsubd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3521 | OPVEX("vpsubq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSUBQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3522 | OPVEX("vpaddb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3523 | OPVEX("vpaddw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3524 | OPVEX("vpaddd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PADDD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3525 | INVALID_OPCODE,
|
---|
| 3526 | };
|
---|
| 3527 |
|
---|
| 3528 | const DISOPCODE g_aMapTwoBytesVex_F2H[256] =
|
---|
| 3529 | {
|
---|
| 3530 | /* 0 */
|
---|
| 3531 | INVALID_OPCODE_BLOCK
|
---|
| 3532 |
|
---|
| 3533 | /* 1 */
|
---|
| 3534 | OPVEX("vmovsd %Vx,%Hx,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVSD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3535 | OPVEX("vmovsd %Wsd,%Hx,%Vsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVSD, OP_PARM_Wsd, OP_PARM_Hx, OP_PARM_Vsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3536 | OPVEX("vmovddup %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVDDUP, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3537 | INVALID_OPCODE,
|
---|
| 3538 | INVALID_OPCODE,
|
---|
| 3539 | INVALID_OPCODE,
|
---|
| 3540 | INVALID_OPCODE,
|
---|
| 3541 | INVALID_OPCODE,
|
---|
| 3542 | INVALID_OPCODE,
|
---|
| 3543 | INVALID_OPCODE,
|
---|
| 3544 | INVALID_OPCODE,
|
---|
| 3545 | INVALID_OPCODE,
|
---|
| 3546 | INVALID_OPCODE,
|
---|
| 3547 | INVALID_OPCODE,
|
---|
| 3548 | INVALID_OPCODE,
|
---|
| 3549 | INVALID_OPCODE,
|
---|
| 3550 |
|
---|
| 3551 | /* 2 */
|
---|
| 3552 | INVALID_OPCODE_BLOCK
|
---|
| 3553 |
|
---|
| 3554 | /* 3 */
|
---|
| 3555 | INVALID_OPCODE_BLOCK
|
---|
| 3556 |
|
---|
| 3557 | /* 4 */
|
---|
| 3558 | INVALID_OPCODE_BLOCK
|
---|
| 3559 |
|
---|
| 3560 | /* 5 */
|
---|
| 3561 | INVALID_OPCODE,
|
---|
| 3562 | OPVEX("vsqrtsd %Vsd,%Hsd,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SQRTSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3563 | INVALID_OPCODE,
|
---|
| 3564 | INVALID_OPCODE,
|
---|
| 3565 | INVALID_OPCODE,
|
---|
| 3566 | INVALID_OPCODE,
|
---|
| 3567 | INVALID_OPCODE,
|
---|
| 3568 | INVALID_OPCODE,
|
---|
| 3569 | OPVEX("vaddsd %Vsd,%Hsd,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ADDSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3570 | OPVEX("vmulsd %Vsd,%Hsd,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MULSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3571 | OPVEX("vcvtsd2ss %Vss,%Hx,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_CVTSD2SS, OP_PARM_Vss, OP_PARM_Hx, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3572 | INVALID_OPCODE,
|
---|
| 3573 | OPVEX("vsubsd %Vsd,%Hsd,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SUBSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3574 | OPVEX("vminsd %Vsd,%Hsd,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MINSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3575 | OPVEX("vdivsd %Vsd,%Hsd,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_DIVSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3576 | OPVEX("vmaxsd %Vsd,%Hsd,%Wsd", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MAXSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3577 |
|
---|
| 3578 | /* 6 */
|
---|
| 3579 | INVALID_OPCODE_BLOCK
|
---|
| 3580 |
|
---|
| 3581 | /* 7 */
|
---|
| 3582 | OPVEX("vpshuflw %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PSHUFLW, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3583 | INVALID_OPCODE,
|
---|
| 3584 | INVALID_OPCODE,
|
---|
| 3585 | INVALID_OPCODE,
|
---|
| 3586 | INVALID_OPCODE,
|
---|
| 3587 | INVALID_OPCODE,
|
---|
| 3588 | INVALID_OPCODE,
|
---|
| 3589 | INVALID_OPCODE,
|
---|
| 3590 | INVALID_OPCODE,
|
---|
| 3591 | INVALID_OPCODE,
|
---|
| 3592 | INVALID_OPCODE,
|
---|
| 3593 | INVALID_OPCODE,
|
---|
| 3594 | OPVEX("vhaddps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_HADDPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3595 | OPVEX("vhsubps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_HSUBPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3596 | INVALID_OPCODE,
|
---|
| 3597 | INVALID_OPCODE,
|
---|
| 3598 |
|
---|
| 3599 | /* 8 */
|
---|
| 3600 | INVALID_OPCODE_BLOCK
|
---|
| 3601 |
|
---|
| 3602 | /* 9 */
|
---|
| 3603 | INVALID_OPCODE_BLOCK
|
---|
| 3604 |
|
---|
| 3605 | /* a */
|
---|
| 3606 | INVALID_OPCODE_BLOCK
|
---|
| 3607 |
|
---|
| 3608 | /* b */
|
---|
| 3609 | INVALID_OPCODE_BLOCK
|
---|
| 3610 |
|
---|
| 3611 | /* c */
|
---|
| 3612 | INVALID_OPCODE,
|
---|
| 3613 | INVALID_OPCODE,
|
---|
| 3614 | OPVEX("vcmpsd %Vsd,%Hsd,%Wsd,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_CMPSD, OP_PARM_Vsd, OP_PARM_Hsd, OP_PARM_Wsd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 3615 | INVALID_OPCODE,
|
---|
| 3616 | INVALID_OPCODE,
|
---|
| 3617 | INVALID_OPCODE,
|
---|
| 3618 | INVALID_OPCODE,
|
---|
| 3619 | INVALID_OPCODE,
|
---|
| 3620 | INVALID_OPCODE,
|
---|
| 3621 | INVALID_OPCODE,
|
---|
| 3622 | INVALID_OPCODE,
|
---|
| 3623 | INVALID_OPCODE,
|
---|
| 3624 | INVALID_OPCODE,
|
---|
| 3625 | INVALID_OPCODE,
|
---|
| 3626 | INVALID_OPCODE,
|
---|
| 3627 | INVALID_OPCODE,
|
---|
| 3628 |
|
---|
| 3629 | /* d */
|
---|
| 3630 | OPVEX("vaddsubps %Vps,%Hps,%Wps", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ADDSUBPS, OP_PARM_Vps, OP_PARM_Hps, OP_PARM_Wps, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3631 | INVALID_OPCODE,
|
---|
| 3632 | INVALID_OPCODE,
|
---|
| 3633 | INVALID_OPCODE,
|
---|
| 3634 | INVALID_OPCODE,
|
---|
| 3635 | INVALID_OPCODE,
|
---|
| 3636 | INVALID_OPCODE,
|
---|
| 3637 | INVALID_OPCODE,
|
---|
| 3638 | INVALID_OPCODE,
|
---|
| 3639 | INVALID_OPCODE,
|
---|
| 3640 | INVALID_OPCODE,
|
---|
| 3641 | INVALID_OPCODE,
|
---|
| 3642 | INVALID_OPCODE,
|
---|
| 3643 | INVALID_OPCODE,
|
---|
| 3644 | INVALID_OPCODE,
|
---|
| 3645 | INVALID_OPCODE,
|
---|
| 3646 |
|
---|
| 3647 | /* e */
|
---|
| 3648 | INVALID_OPCODE,
|
---|
| 3649 | INVALID_OPCODE,
|
---|
| 3650 | INVALID_OPCODE,
|
---|
| 3651 | INVALID_OPCODE,
|
---|
| 3652 | INVALID_OPCODE,
|
---|
| 3653 | INVALID_OPCODE,
|
---|
| 3654 | OPVEX("vcvtpd2dq %Vx,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTPD2DQ, OP_PARM_Vx, OP_PARM_Wpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3655 | INVALID_OPCODE,
|
---|
| 3656 | INVALID_OPCODE,
|
---|
| 3657 | INVALID_OPCODE,
|
---|
| 3658 | INVALID_OPCODE,
|
---|
| 3659 | INVALID_OPCODE,
|
---|
| 3660 | INVALID_OPCODE,
|
---|
| 3661 | INVALID_OPCODE,
|
---|
| 3662 | INVALID_OPCODE,
|
---|
| 3663 | INVALID_OPCODE,
|
---|
| 3664 |
|
---|
| 3665 | /* f */
|
---|
| 3666 | OPVEX("vlddqu %Vx,%Mx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_LDDQU, OP_PARM_Vx, OP_PARM_Mx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3667 | INVALID_OPCODE,
|
---|
| 3668 | INVALID_OPCODE,
|
---|
| 3669 | INVALID_OPCODE,
|
---|
| 3670 | INVALID_OPCODE,
|
---|
| 3671 | INVALID_OPCODE,
|
---|
| 3672 | INVALID_OPCODE,
|
---|
| 3673 | INVALID_OPCODE,
|
---|
| 3674 | INVALID_OPCODE,
|
---|
| 3675 | INVALID_OPCODE,
|
---|
| 3676 | INVALID_OPCODE,
|
---|
| 3677 | INVALID_OPCODE,
|
---|
| 3678 | INVALID_OPCODE,
|
---|
| 3679 | INVALID_OPCODE,
|
---|
| 3680 | INVALID_OPCODE,
|
---|
| 3681 | INVALID_OPCODE,
|
---|
| 3682 | };
|
---|
| 3683 |
|
---|
| 3684 | /* Vex codes for two bytes opcodes starting with 0Fh with prefix F3H*/
|
---|
| 3685 | const DISOPCODE g_aMapTwoBytesVex_F3H[256] =
|
---|
| 3686 | {
|
---|
| 3687 |
|
---|
| 3688 | /* 0 */
|
---|
| 3689 | INVALID_OPCODE_BLOCK
|
---|
| 3690 |
|
---|
| 3691 | /* 1 */
|
---|
| 3692 | OPVEX("vmovss %Vx,%Hx,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVSS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3693 | OPVEX("vmovss %Wss,%Hx,%Vss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MOVSS, OP_PARM_Wss, OP_PARM_Hx, OP_PARM_Vss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3694 | OPVEX("vmovsldup %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVSLDUP, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3695 | INVALID_OPCODE,
|
---|
| 3696 | INVALID_OPCODE,
|
---|
| 3697 | INVALID_OPCODE,
|
---|
| 3698 | OPVEX("vmovshdup %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVSHDUP, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3699 | INVALID_OPCODE,
|
---|
| 3700 | INVALID_OPCODE,
|
---|
| 3701 | INVALID_OPCODE,
|
---|
| 3702 | INVALID_OPCODE,
|
---|
| 3703 | INVALID_OPCODE,
|
---|
| 3704 | INVALID_OPCODE,
|
---|
| 3705 | INVALID_OPCODE,
|
---|
| 3706 | INVALID_OPCODE,
|
---|
| 3707 | INVALID_OPCODE,
|
---|
| 3708 |
|
---|
| 3709 | /* 2 */
|
---|
| 3710 | INVALID_OPCODE,
|
---|
| 3711 | INVALID_OPCODE,
|
---|
| 3712 | INVALID_OPCODE,
|
---|
| 3713 | INVALID_OPCODE,
|
---|
| 3714 | INVALID_OPCODE,
|
---|
| 3715 | INVALID_OPCODE,
|
---|
| 3716 | INVALID_OPCODE,
|
---|
| 3717 | INVALID_OPCODE,
|
---|
| 3718 | INVALID_OPCODE,
|
---|
| 3719 | INVALID_OPCODE,
|
---|
| 3720 | OPVEX("vcvtsi2ss %Vss,%Hss,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_CVTSI2SS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3721 | INVALID_OPCODE,
|
---|
| 3722 | OPVEX("vcvttss2si %Gy,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTTSS2SI, OP_PARM_Gy, OP_PARM_Wss, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3723 | OPVEX("vcvtss2si %Gy,%Wss", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTSS2SI, OP_PARM_Gy, OP_PARM_Wss, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3724 | INVALID_OPCODE,
|
---|
| 3725 | INVALID_OPCODE,
|
---|
| 3726 |
|
---|
| 3727 | /* 3 */
|
---|
| 3728 | INVALID_OPCODE_BLOCK
|
---|
| 3729 |
|
---|
| 3730 | /* 4 */
|
---|
| 3731 | INVALID_OPCODE_BLOCK
|
---|
| 3732 |
|
---|
| 3733 | /* 5 */
|
---|
| 3734 | INVALID_OPCODE,
|
---|
| 3735 | OPVEX("vsqrtss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SQRTSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3736 | OPVEX("vrsqrtss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_RSQRTSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3737 | OPVEX("vrcpss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_RCPSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3738 | INVALID_OPCODE,
|
---|
| 3739 | INVALID_OPCODE,
|
---|
| 3740 | INVALID_OPCODE,
|
---|
| 3741 | INVALID_OPCODE,
|
---|
| 3742 | OPVEX("vaddss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ADDSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3743 | OPVEX("vmulss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MULSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3744 | OPVEX("vcvtss2sd %Vsd,%Hx,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_CVTSS2SD, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3745 | OPVEX("vcvttps2dq %Vdq,%Wps", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTTPS2DQ, OP_PARM_Vdq, OP_PARM_Wps, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3746 | OPVEX("vsubss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SUBSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3747 | OPVEX("vminss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MINSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3748 | OPVEX("vdivss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_DIVSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3749 | OPVEX("vmaxss %Vss,%Hss,%Wss", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MAXSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3750 |
|
---|
| 3751 | /* 6 */
|
---|
| 3752 | INVALID_OPCODE,
|
---|
| 3753 | INVALID_OPCODE,
|
---|
| 3754 | INVALID_OPCODE,
|
---|
| 3755 | INVALID_OPCODE,
|
---|
| 3756 | INVALID_OPCODE,
|
---|
| 3757 | INVALID_OPCODE,
|
---|
| 3758 | INVALID_OPCODE,
|
---|
| 3759 | INVALID_OPCODE,
|
---|
| 3760 | INVALID_OPCODE,
|
---|
| 3761 | INVALID_OPCODE,
|
---|
| 3762 | INVALID_OPCODE,
|
---|
| 3763 | INVALID_OPCODE,
|
---|
| 3764 | INVALID_OPCODE,
|
---|
| 3765 | INVALID_OPCODE,
|
---|
| 3766 | INVALID_OPCODE,
|
---|
| 3767 | OPVEX("vmovdqu %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVDQU, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3768 |
|
---|
| 3769 | /* 7 */
|
---|
| 3770 | OPVEX("vpshufhw %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PSHUFHW, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3771 | INVALID_OPCODE,
|
---|
| 3772 | INVALID_OPCODE,
|
---|
| 3773 | INVALID_OPCODE,
|
---|
| 3774 | INVALID_OPCODE,
|
---|
| 3775 | INVALID_OPCODE,
|
---|
| 3776 | INVALID_OPCODE,
|
---|
| 3777 | INVALID_OPCODE,
|
---|
| 3778 | INVALID_OPCODE,
|
---|
| 3779 | INVALID_OPCODE,
|
---|
| 3780 | INVALID_OPCODE,
|
---|
| 3781 | INVALID_OPCODE,
|
---|
| 3782 | INVALID_OPCODE,
|
---|
| 3783 | INVALID_OPCODE,
|
---|
| 3784 | OPVEX("vmovq %Vq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVQ, OP_PARM_Vq, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3785 | OPVEX("vmovdqu %Wx,%Vx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVDQU, OP_PARM_Wx, OP_PARM_Vx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3786 |
|
---|
| 3787 | /* 8 */
|
---|
| 3788 | INVALID_OPCODE_BLOCK
|
---|
| 3789 |
|
---|
| 3790 | /* 9 */
|
---|
| 3791 | INVALID_OPCODE_BLOCK
|
---|
| 3792 |
|
---|
| 3793 | /* a */
|
---|
| 3794 | INVALID_OPCODE_BLOCK
|
---|
| 3795 |
|
---|
| 3796 | /* b */
|
---|
| 3797 | INVALID_OPCODE_BLOCK
|
---|
| 3798 |
|
---|
| 3799 | /* c */
|
---|
| 3800 | INVALID_OPCODE,
|
---|
| 3801 | INVALID_OPCODE,
|
---|
| 3802 | OPVEX("vcmpps %Vss,%Hss,%Wss,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_CMPSS, OP_PARM_Vss, OP_PARM_Hss, OP_PARM_Wss, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 3803 | INVALID_OPCODE,
|
---|
| 3804 | INVALID_OPCODE,
|
---|
| 3805 | INVALID_OPCODE,
|
---|
| 3806 | INVALID_OPCODE,
|
---|
| 3807 | INVALID_OPCODE,
|
---|
| 3808 | INVALID_OPCODE,
|
---|
| 3809 | INVALID_OPCODE,
|
---|
| 3810 | INVALID_OPCODE,
|
---|
| 3811 | INVALID_OPCODE,
|
---|
| 3812 | INVALID_OPCODE,
|
---|
| 3813 | INVALID_OPCODE,
|
---|
| 3814 | INVALID_OPCODE,
|
---|
| 3815 | INVALID_OPCODE,
|
---|
| 3816 |
|
---|
| 3817 | /* d */
|
---|
| 3818 | INVALID_OPCODE_BLOCK
|
---|
| 3819 |
|
---|
| 3820 | /* e */
|
---|
| 3821 | INVALID_OPCODE,
|
---|
| 3822 | INVALID_OPCODE,
|
---|
| 3823 | INVALID_OPCODE,
|
---|
| 3824 | INVALID_OPCODE,
|
---|
| 3825 | INVALID_OPCODE,
|
---|
| 3826 | INVALID_OPCODE,
|
---|
| 3827 | OPVEX("vcvtdq2pd %Vx,%Wpd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_CVTDQ2PD, OP_PARM_Vx, OP_PARM_Wpd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3828 | INVALID_OPCODE,
|
---|
| 3829 | INVALID_OPCODE,
|
---|
| 3830 | INVALID_OPCODE,
|
---|
| 3831 | INVALID_OPCODE,
|
---|
| 3832 | INVALID_OPCODE,
|
---|
| 3833 | INVALID_OPCODE,
|
---|
| 3834 | INVALID_OPCODE,
|
---|
| 3835 | INVALID_OPCODE,
|
---|
| 3836 | INVALID_OPCODE,
|
---|
| 3837 |
|
---|
| 3838 | /* f */
|
---|
| 3839 | INVALID_OPCODE_BLOCK
|
---|
| 3840 | };
|
---|
| 3841 |
|
---|
[53131] | 3842 | const DISOPCODE g_aMapThreeBytesVex_0F38_F[16] =
|
---|
| 3843 | {
|
---|
| 3844 | INVALID_OPCODE,
|
---|
| 3845 | INVALID_OPCODE,
|
---|
| 3846 | OPVEX("andn %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_ANDN, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3847 | INVALID_OPCODE,
|
---|
| 3848 | INVALID_OPCODE,
|
---|
| 3849 | OPVEX("bzhi %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_BZHI, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3850 | INVALID_OPCODE,
|
---|
| 3851 | OPVEX("bextr %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_BEXTR, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3852 | INVALID_OPCODE,
|
---|
| 3853 | INVALID_OPCODE,
|
---|
| 3854 | INVALID_OPCODE,
|
---|
| 3855 | INVALID_OPCODE,
|
---|
| 3856 | INVALID_OPCODE,
|
---|
| 3857 | INVALID_OPCODE,
|
---|
| 3858 | INVALID_OPCODE,
|
---|
| 3859 | INVALID_OPCODE
|
---|
| 3860 | };
|
---|
| 3861 |
|
---|
| 3862 | const DISOPCODE g_aMapThreeBytesVex_F30F38_F[16] =
|
---|
| 3863 | {
|
---|
| 3864 | INVALID_OPCODE,
|
---|
| 3865 | INVALID_OPCODE,
|
---|
| 3866 | INVALID_OPCODE,
|
---|
| 3867 | INVALID_OPCODE,
|
---|
| 3868 | INVALID_OPCODE,
|
---|
| 3869 | OPVEX("pext %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PEXT, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3870 | INVALID_OPCODE,
|
---|
| 3871 | OPVEX("sarx %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SARX, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3872 | INVALID_OPCODE,
|
---|
| 3873 | INVALID_OPCODE,
|
---|
| 3874 | INVALID_OPCODE,
|
---|
| 3875 | INVALID_OPCODE,
|
---|
| 3876 | INVALID_OPCODE,
|
---|
| 3877 | INVALID_OPCODE,
|
---|
| 3878 | INVALID_OPCODE,
|
---|
| 3879 | INVALID_OPCODE
|
---|
| 3880 | };
|
---|
| 3881 |
|
---|
| 3882 | const DISOPCODE g_aMapThreeBytesVex_F20F38_F[16] =
|
---|
| 3883 | {
|
---|
| 3884 | INVALID_OPCODE,
|
---|
| 3885 | INVALID_OPCODE,
|
---|
| 3886 | INVALID_OPCODE,
|
---|
| 3887 | INVALID_OPCODE,
|
---|
| 3888 | INVALID_OPCODE,
|
---|
| 3889 | OPVEX("pdep %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PDEP, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3890 | OPVEX("mulx %By,%Gy,%Ey", IDX_ParseVexDest, IDX_ParseModRM, IDX_UseModRM, 0, OP_MULX, OP_PARM_By, OP_PARM_Gy, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3891 | OPVEX("shrx %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_SHRX, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3892 | INVALID_OPCODE,
|
---|
| 3893 | INVALID_OPCODE,
|
---|
| 3894 | INVALID_OPCODE,
|
---|
| 3895 | INVALID_OPCODE,
|
---|
| 3896 | INVALID_OPCODE,
|
---|
| 3897 | INVALID_OPCODE,
|
---|
| 3898 | INVALID_OPCODE,
|
---|
| 3899 | INVALID_OPCODE
|
---|
| 3900 | };
|
---|
| 3901 |
|
---|
| 3902 | const DISOPCODE g_aMapThreeBytesVex_660F38[256] =
|
---|
| 3903 | {
|
---|
| 3904 |
|
---|
| 3905 | /* 0 */
|
---|
| 3906 | OPVEX("vpshufb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSHUFB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3907 | OPVEX("vphaddw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PHADDW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3908 | OPVEX("vphaddd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PHADDD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3909 | OPVEX("vphaddsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PHADDSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3910 | OPVEX("vpmaddubsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMADDUBSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3911 | OPVEX("vphsubw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PHSUBW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3912 | OPVEX("vphsubd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PHSUBD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3913 | OPVEX("vphsubsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PHSUBSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3914 | OPVEX("vpsignb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSIGNB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3915 | OPVEX("vpsignw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSIGNW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3916 | OPVEX("vpsignd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSIGND, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3917 | OPVEX("vpmulhrsw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMULHRSW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3918 | OPVEX("vpermilps %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PERMILPS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3919 | OPVEX("vpermilpd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PERMILPD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3920 | OPVEX("vtestps %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_TESTPS, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3921 | OPVEX("vtestpd %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_TESTPD, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3922 |
|
---|
| 3923 | /* 1 */
|
---|
| 3924 | INVALID_OPCODE,
|
---|
| 3925 | INVALID_OPCODE,
|
---|
| 3926 | INVALID_OPCODE,
|
---|
| 3927 | OPVEX("vcvtph2ps %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_CVTPH2PS, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3928 | INVALID_OPCODE,
|
---|
| 3929 | INVALID_OPCODE,
|
---|
| 3930 | OPVEX("vpermps %Vqq,%Hqq,%Wqq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PERMPS, OP_PARM_Vqq, OP_PARM_Hqq, OP_PARM_Wqq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3931 | OPVEX("vptest %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PTEST, OP_PARM_Vx, OP_PARM_Wd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3932 | OPVEX("vbroadcastss %Vx,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_BROADCASTSS, OP_PARM_Vx, OP_PARM_Wd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3933 | OPVEX("vbroadcastsd %Vqq,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_BROADCASTSD, OP_PARM_Vqq, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3934 | OPVEX("vbroadcastf128 %Vqq,%Mdq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_BROADCASTF128, OP_PARM_Vqq, OP_PARM_Wdq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3935 | INVALID_OPCODE,
|
---|
| 3936 | OPVEX("vpabsb %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PABSB, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3937 | OPVEX("vpabsw %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PABSW, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3938 | OPVEX("vpabsd %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PABSD, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3939 | INVALID_OPCODE,
|
---|
| 3940 |
|
---|
| 3941 | /* 2 */
|
---|
| 3942 | OPVEX("vpmovsxbw %Vx,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVSX, OP_PARM_Vx, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3943 | OPVEX("vpmovsxbd %Vx,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVSX, OP_PARM_Vx, OP_PARM_Wd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3944 | OPVEX("vpmovsxbq %Vx,%Ww", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVSX, OP_PARM_Vx, OP_PARM_Ww, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3945 | OPVEX("vpmovsxwd %Vx,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVSX, OP_PARM_Vx, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3946 | OPVEX("vpmovsxwq %Vx,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVSX, OP_PARM_Vx, OP_PARM_Wd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3947 | OPVEX("vpmovsxdq %Vx,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVSX, OP_PARM_Vx, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3948 | INVALID_OPCODE,
|
---|
| 3949 | INVALID_OPCODE,
|
---|
| 3950 | OPVEX("vpmuldq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMULDQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3951 | OPVEX("vpcmpeqq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPEQQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3952 | OPVEX("vmovntdqa %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_MOVNTDQA, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3953 | OPVEX("vpackusdw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PACKUSDW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3954 | OPVEX("vmaskmovps %Vx,%Hx,%Mx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MASKMOVPS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Mx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3955 | OPVEX("vmaskmovpd %Vx,%Hx,%Mx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MASKMOVPD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Mx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3956 | OPVEX("vmaskmovps %Mx,%Hx,%Vx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MASKMOVPS, OP_PARM_Mx, OP_PARM_Hx, OP_PARM_Vx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3957 | OPVEX("vmaskmovpd %Mx,%Hx,%Vx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_MASKMOVPD, OP_PARM_Mx, OP_PARM_Hx, OP_PARM_Vx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3958 |
|
---|
| 3959 | /* 3 */
|
---|
| 3960 | OPVEX("vpmovzxbw %Vx,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVZX, OP_PARM_Vx, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3961 | OPVEX("vpmovzxbd %Vx,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVZX, OP_PARM_Vx, OP_PARM_Wd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3962 | OPVEX("vpmovzxbq %Vx,%Ww", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVZX, OP_PARM_Vx, OP_PARM_Ww, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3963 | OPVEX("vpmovzxwd %Vx,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVZX, OP_PARM_Vx, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3964 | OPVEX("vpmovzxwq %Vx,%Wd", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVZX, OP_PARM_Vx, OP_PARM_Wd, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3965 | OPVEX("vpmovzxdq %Vx,%Wq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PMOVZX, OP_PARM_Vx, OP_PARM_Wq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3966 | OPVEX("vpermd %Vqq,%Hqq,%Wqq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PERMD, OP_PARM_Vqq, OP_PARM_Hqq, OP_PARM_Wqq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3967 | OPVEX("vpcmpgtq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PCMPGTQ, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3968 | OPVEX("vpminsb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMINSB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3969 | OPVEX("vpminsd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMINSB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3970 | OPVEX("vpminuw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMINUW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3971 | OPVEX("vpminud %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMINUD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3972 | OPVEX("vpmaxsb %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMAXSB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3973 | OPVEX("vpmaxsd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMAXSD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3974 | OPVEX("vpmaxuw %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMAXUW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3975 | OPVEX("vpmaxud %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMAXUD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3976 |
|
---|
| 3977 | /* 4 */
|
---|
| 3978 | OPVEX("vpmulld %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMULLD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3979 | OPVEX("vphminposuw %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PHMINPOSUW,OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 3980 | INVALID_OPCODE,
|
---|
| 3981 | INVALID_OPCODE,
|
---|
| 3982 | INVALID_OPCODE,
|
---|
[53172] | 3983 | OPVEX("#vpsrlvd/vpsrlvq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSRLVD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 3984 | OPVEX("vpsravd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSRAVD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53172] | 3985 | OPVEX("#vpsllvd/vpsllvq %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PSLLVD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 3986 | INVALID_OPCODE,
|
---|
| 3987 | INVALID_OPCODE,
|
---|
| 3988 | INVALID_OPCODE,
|
---|
| 3989 | INVALID_OPCODE,
|
---|
| 3990 | INVALID_OPCODE,
|
---|
| 3991 | INVALID_OPCODE,
|
---|
| 3992 | INVALID_OPCODE,
|
---|
| 3993 | INVALID_OPCODE,
|
---|
| 3994 |
|
---|
| 3995 | /* 5 */
|
---|
| 3996 | INVALID_OPCODE,
|
---|
| 3997 | INVALID_OPCODE,
|
---|
| 3998 | INVALID_OPCODE,
|
---|
| 3999 | INVALID_OPCODE,
|
---|
| 4000 | INVALID_OPCODE,
|
---|
| 4001 | INVALID_OPCODE,
|
---|
| 4002 | INVALID_OPCODE,
|
---|
| 4003 | INVALID_OPCODE,
|
---|
| 4004 | OPVEX("vpbroadcastd %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PBROADCASTD, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4005 | OPVEX("vpbroadcastq %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PBROADCASTQ, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4006 | OPVEX("vpbroadcasti128 %Vqq,%Mdq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PBROADCASTI128, OP_PARM_Vqq, OP_PARM_Mdq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4007 | INVALID_OPCODE,
|
---|
| 4008 | INVALID_OPCODE,
|
---|
| 4009 | INVALID_OPCODE,
|
---|
| 4010 | INVALID_OPCODE,
|
---|
| 4011 | INVALID_OPCODE,
|
---|
| 4012 |
|
---|
| 4013 | /* 6 */
|
---|
| 4014 | INVALID_OPCODE_BLOCK
|
---|
| 4015 |
|
---|
| 4016 | /* 7 */
|
---|
| 4017 | INVALID_OPCODE,
|
---|
| 4018 | INVALID_OPCODE,
|
---|
| 4019 | INVALID_OPCODE,
|
---|
| 4020 | INVALID_OPCODE,
|
---|
| 4021 | INVALID_OPCODE,
|
---|
| 4022 | INVALID_OPCODE,
|
---|
| 4023 | INVALID_OPCODE,
|
---|
| 4024 | INVALID_OPCODE,
|
---|
| 4025 | OPVEX("vpbroadcastb %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PBROADCASTB, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4026 | OPVEX("vpbroadcastw %Vx,%Wx", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_PBROADCASTW, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4027 | INVALID_OPCODE,
|
---|
| 4028 | INVALID_OPCODE,
|
---|
| 4029 | INVALID_OPCODE,
|
---|
| 4030 | INVALID_OPCODE,
|
---|
| 4031 | INVALID_OPCODE,
|
---|
| 4032 | INVALID_OPCODE,
|
---|
| 4033 |
|
---|
| 4034 | /* 8 */
|
---|
| 4035 | INVALID_OPCODE,
|
---|
| 4036 | INVALID_OPCODE,
|
---|
| 4037 | INVALID_OPCODE,
|
---|
| 4038 | INVALID_OPCODE,
|
---|
| 4039 | INVALID_OPCODE,
|
---|
| 4040 | INVALID_OPCODE,
|
---|
| 4041 | INVALID_OPCODE,
|
---|
| 4042 | INVALID_OPCODE,
|
---|
| 4043 | INVALID_OPCODE,
|
---|
| 4044 | INVALID_OPCODE,
|
---|
| 4045 | INVALID_OPCODE,
|
---|
| 4046 | INVALID_OPCODE,
|
---|
[53172] | 4047 | OPVEX("#vpmaskmovd/vpmaskmovq %Vx,%Hx,%Mx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_PMASKMOVD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Mx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4048 | INVALID_OPCODE,
|
---|
[53172] | 4049 | OPVEX("#vpmaskmovd/vpmaskmovq %Mx,%Vx,%Hx", IDX_ParseModRM, IDX_UseModRM, IDX_ParseVexDest, 0, OP_PMASKMOVD, OP_PARM_Mx, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4050 | INVALID_OPCODE,
|
---|
| 4051 |
|
---|
| 4052 | /* 9 */
|
---|
[53172] | 4053 | /* Seems incorrect format is used in the Intel opcode tables.
|
---|
| 4054 | * Correct form according to Intel® 64 and IA-32 Architectures Software Developer’s Manual Volume 2 (2A, 2B & 2C): Instruction Set Reference, A-Z
|
---|
| 4055 | * is the following:
|
---|
| 4056 | * v?gather?d/q %Vx, %Md/q, %Hx ,
|
---|
| 4057 | * where d/q is defined by VEX.W bit.
|
---|
[53245] | 4058 | *
|
---|
| 4059 | * The instruction are in the following format:
|
---|
| 4060 | * #name1/name2 format
|
---|
| 4061 | * if REX.W is set name2 is used,
|
---|
| 4062 | * otherwise name1.
|
---|
[53172] | 4063 | */
|
---|
| 4064 | OPVEX("#vpgatherdd/vpgatherdq %Vx,%My,%Hx", IDX_ParseModRM, IDX_UseModRM, IDX_ParseVexDest, 0, OP_GATHER, OP_PARM_Vx, OP_PARM_My, OP_PARM_Hx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4065 | OPVEX("#vpgatherqd/vpgatherqq %Vx,%My,%Hx", IDX_ParseModRM, IDX_UseModRM, IDX_ParseVexDest, 0, OP_GATHER, OP_PARM_Vx, OP_PARM_My, OP_PARM_Hx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4066 | OPVEX("#vgatherdps/vgatherdpd %Vx,%My,%Hx", IDX_ParseModRM, IDX_UseModRM, IDX_ParseVexDest, 0, OP_GATHER, OP_PARM_Vx, OP_PARM_My, OP_PARM_Hx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4067 | OPVEX("#vgatherqps/vgatherqpd %Vx,%My,%Hx", IDX_ParseModRM, IDX_UseModRM, IDX_ParseVexDest, 0, OP_GATHER, OP_PARM_Vx, OP_PARM_My, OP_PARM_Hx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4068 | INVALID_OPCODE,
|
---|
| 4069 | INVALID_OPCODE,
|
---|
[53172] | 4070 | OPVEX("#vfmaddsub132ps/vfmaddsub132pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADDSUB132PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4071 | OPVEX("#vfmsubadd132ps/vfmsubadd132pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUBADD132PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4072 | OPVEX("#vfmadd132ps/vfmadd132pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADD132PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4073 | OPVEX("#vfmadd132ss/vfmadd132sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADD132SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4074 | OPVEX("#vfmsub132ps/vfmsub132pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUB132PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4075 | OPVEX("#vfmsub132ss/vfmsub132sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUB132SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4076 | OPVEX("#vfnmadd132ps/vfnmadd132pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMADD132PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4077 | OPVEX("#vfnmadd132ss/vfnmadd132sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMADD132SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4078 | OPVEX("#vfnmsub132ps/vfnmsub132pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMSUB132PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4079 | OPVEX("#vfnmsub132ss/vfnmsub132sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMSUB132SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4080 |
|
---|
| 4081 | /* a */
|
---|
| 4082 | INVALID_OPCODE,
|
---|
| 4083 | INVALID_OPCODE,
|
---|
| 4084 | INVALID_OPCODE,
|
---|
| 4085 | INVALID_OPCODE,
|
---|
| 4086 | INVALID_OPCODE,
|
---|
| 4087 | INVALID_OPCODE,
|
---|
[53172] | 4088 | OPVEX("#vfmaddsub213ps/vfmaddsub213pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADDSUB213PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4089 | OPVEX("#vfmsubadd213ps/vfmsubadd213pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUBADD213PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4090 | OPVEX("#vfmadd213ps/vfmadd213pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADD213PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4091 | OPVEX("#vfmadd213ss/vfmadd213sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADD213SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4092 | OPVEX("#vfmsub213ps/vfmsub213pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUB213PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4093 | OPVEX("#vfmsub213ss/vfmsub213sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUB213SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4094 | OPVEX("#vfnmadd213ps/vfnmadd213pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMADD213PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4095 | OPVEX("#vfnmadd213ss/vfnmadd213sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMADD213SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4096 | OPVEX("#vfnmsub213ps/vfnmsub213pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMSUB213PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4097 | OPVEX("#vfnmsub213ss/vfnmsub213sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMSUB213SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4098 |
|
---|
| 4099 | /* b */
|
---|
| 4100 | INVALID_OPCODE,
|
---|
| 4101 | INVALID_OPCODE,
|
---|
| 4102 | INVALID_OPCODE,
|
---|
| 4103 | INVALID_OPCODE,
|
---|
| 4104 | INVALID_OPCODE,
|
---|
| 4105 | INVALID_OPCODE,
|
---|
[53172] | 4106 | OPVEX("#vfmaddsub231ps/vfmaddsub231pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADDSUB231PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4107 | OPVEX("#vfmsubadd231ps/vfmsubadd231pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUBADD231PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4108 | OPVEX("#vfmadd231ps/vfmadd231pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADD231PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4109 | OPVEX("#vfmadd231ss/vfmadd231sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMADD231SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4110 | OPVEX("#vfmsub231ps/vfmsub231pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUB231PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4111 | OPVEX("#vfmsub231ss/vfmsub231sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FMSUB231SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4112 | OPVEX("#vfnmadd231ps/vfnmadd231pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMADD231PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4113 | OPVEX("#vfnmadd231ss/vfnmadd231sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMADD231SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4114 | OPVEX("#vfnmsub231ps/vfnmsub231pd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMSUB231PS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4115 | OPVEX("#vfnmsub231ss/vfnmsub231sd %Vx,%Hx,%Wx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_FNMSUB231SS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4116 |
|
---|
| 4117 | /* c */
|
---|
| 4118 | INVALID_OPCODE_BLOCK
|
---|
| 4119 |
|
---|
| 4120 | /* d */
|
---|
| 4121 | INVALID_OPCODE,
|
---|
| 4122 | INVALID_OPCODE,
|
---|
| 4123 | INVALID_OPCODE,
|
---|
| 4124 | INVALID_OPCODE,
|
---|
| 4125 | INVALID_OPCODE,
|
---|
| 4126 | INVALID_OPCODE,
|
---|
| 4127 | INVALID_OPCODE,
|
---|
| 4128 | INVALID_OPCODE,
|
---|
| 4129 | INVALID_OPCODE,
|
---|
| 4130 | INVALID_OPCODE,
|
---|
| 4131 | INVALID_OPCODE,
|
---|
| 4132 | OPVEX("vaesimc %Vdq,%Wdq", IDX_ParseModRM, IDX_UseModRM, 0, 0, OP_AESIMC, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_NONE, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4133 | OPVEX("vaesenc %Vdq,%Hdq,%Wdq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_AESENC, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4134 | OPVEX("vaesenclast %Vdq,%Hdq,%Wdq",IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_AESENCLAST,OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4135 | OPVEX("vaesdec %Vdq,%Hdq,%Wdq", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_AESDEC, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4136 | OPVEX("vaesdeclast %Vdq,%Hdq,%Wdq",IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_AESDECLAST,OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Wdq, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4137 |
|
---|
| 4138 | /* e */
|
---|
| 4139 | INVALID_OPCODE_BLOCK
|
---|
| 4140 |
|
---|
| 4141 | /* f */
|
---|
| 4142 | INVALID_OPCODE,
|
---|
| 4143 | INVALID_OPCODE,
|
---|
| 4144 | INVALID_OPCODE,
|
---|
| 4145 | INVALID_OPCODE,
|
---|
| 4146 | INVALID_OPCODE,
|
---|
| 4147 | INVALID_OPCODE,
|
---|
| 4148 | INVALID_OPCODE,
|
---|
[53245] | 4149 | OPVEX("shlx %Gy,%By,%Ey", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, 0, OP_BEXTR, OP_PARM_Gy, OP_PARM_By, OP_PARM_Ey, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4150 | INVALID_OPCODE,
|
---|
| 4151 | INVALID_OPCODE,
|
---|
| 4152 | INVALID_OPCODE,
|
---|
| 4153 | INVALID_OPCODE,
|
---|
| 4154 | INVALID_OPCODE,
|
---|
| 4155 | INVALID_OPCODE,
|
---|
| 4156 | INVALID_OPCODE,
|
---|
| 4157 | INVALID_OPCODE,
|
---|
| 4158 | };
|
---|
| 4159 |
|
---|
| 4160 | const DISOPCODE g_aMapThreeBytesVex_660F3A[256] =
|
---|
| 4161 | {
|
---|
| 4162 | /* 0 */
|
---|
[53245] | 4163 | OPVEX("vpermq %Vqq,%Wqq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PERMQ, OP_PARM_Vqq, OP_PARM_Wqq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4164 | OPVEX("vpermpd %Vqq,%Wqq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PERMPD, OP_PARM_Vqq, OP_PARM_Wqq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4165 | OPVEX("vpblendd %Vx,%Hx,%Wx,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PBLENDD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4166 | INVALID_OPCODE,
|
---|
[53245] | 4167 | OPVEX("vpermilps %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PERMILPS, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4168 | OPVEX("vpermilpd %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PERMILPD, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4169 | OPVEX("vperm2f128 %Vqq,%Hqq,%Wqq,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PERM2F128, OP_PARM_Vqq, OP_PARM_Hqq, OP_PARM_Wqq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4170 | INVALID_OPCODE,
|
---|
[53245] | 4171 | OPVEX("vroundps %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_ROUNDPS, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4172 | OPVEX("vroundpd %Vx,%Wx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_ROUNDPD, OP_PARM_Vx, OP_PARM_Wx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4173 | OPVEX("vroundss %Vss,%Wss,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_ROUNDSS, OP_PARM_Vss, OP_PARM_Wss, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4174 | OPVEX("vroundsd %Vsd,%Wsd,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_ROUNDSD, OP_PARM_Vsd, OP_PARM_Wsd, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4175 | OPVEX("vblendps %Vx,%Hx,%Wx,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_BLENDPS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4176 | OPVEX("vblendpd %Vx,%Hx,%Wx,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_BLENDPD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4177 | OPVEX("vpblendw %Vx,%Hx,%Wx,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PBLENDW, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4178 | OPVEX("vpalignr %Vx,%Hx,%Wx,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PALIGNR, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4179 |
|
---|
| 4180 | /* 1 */
|
---|
| 4181 | INVALID_OPCODE,
|
---|
| 4182 | INVALID_OPCODE,
|
---|
| 4183 | INVALID_OPCODE,
|
---|
| 4184 | INVALID_OPCODE,
|
---|
| 4185 | // vpextrb %Rd/Mb,%Vdq,%Ib
|
---|
[53245] | 4186 | OPVEX("vpextrb %Eb,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PEXTRB, OP_PARM_Eb, OP_PARM_Vdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4187 | // vpextrw %Rd/Mw,%Vdq,%Ib
|
---|
[53245] | 4188 | OPVEX("vpextrw %Ew,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PEXTRW, OP_PARM_Ew, OP_PARM_Vdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4189 | OPVEX("#vpextrd/vpextrq %Ey,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PEXTRD, OP_PARM_Ey, OP_PARM_Vdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4190 | OPVEX("vextractps %Ed,%Vdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_EXTRACTPS, OP_PARM_Ed, OP_PARM_Vdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4191 | OPVEX("vinsertf128 %Vqq,%Hqq,%Wqq,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_INSERTF128, OP_PARM_Vqq, OP_PARM_Hqq, OP_PARM_Wqq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53245] | 4192 | OPVEX("vextractf128 %Wdq,%Vqq,%Ib",IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_EXTRACTF128, OP_PARM_Eb, OP_PARM_Vdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4193 | INVALID_OPCODE,
|
---|
| 4194 | INVALID_OPCODE,
|
---|
| 4195 | INVALID_OPCODE,
|
---|
[53245] | 4196 | OPVEX("vcvtps2ph %Wx,%Vx,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_CVTPS2PH, OP_PARM_Wx, OP_PARM_Vx, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4197 | INVALID_OPCODE,
|
---|
| 4198 | INVALID_OPCODE,
|
---|
| 4199 |
|
---|
| 4200 | /* 2 */
|
---|
| 4201 | // vpinsrb %Vdq,%Hdq,%Ry/Mb,%Ib
|
---|
[53155] | 4202 | OPVEX("vpinsrb %Vdq,%Hdq,%Eb,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PINSRB, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Eb, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4203 | // vinsertps %Vdq,%Hdq,%Udq/Md,%Ib
|
---|
[53155] | 4204 | OPVEX("vinsertps %Vdq,%Hdq,%Wd,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_INSERTPS, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Wd, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53172] | 4205 | OPVEX("#vpinsrd/vpinsrq %Vdq,%Hdq,%Ey,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PINSRD, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Ey, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4206 | INVALID_OPCODE,
|
---|
| 4207 | INVALID_OPCODE,
|
---|
| 4208 | INVALID_OPCODE,
|
---|
| 4209 | INVALID_OPCODE,
|
---|
| 4210 | INVALID_OPCODE,
|
---|
| 4211 | INVALID_OPCODE,
|
---|
| 4212 | INVALID_OPCODE,
|
---|
| 4213 | INVALID_OPCODE,
|
---|
| 4214 | INVALID_OPCODE,
|
---|
| 4215 | INVALID_OPCODE,
|
---|
| 4216 | INVALID_OPCODE,
|
---|
| 4217 | INVALID_OPCODE,
|
---|
| 4218 | INVALID_OPCODE,
|
---|
| 4219 |
|
---|
| 4220 | /* 3 */
|
---|
| 4221 | INVALID_OPCODE,
|
---|
| 4222 | INVALID_OPCODE,
|
---|
| 4223 | INVALID_OPCODE,
|
---|
| 4224 | INVALID_OPCODE,
|
---|
| 4225 | INVALID_OPCODE,
|
---|
| 4226 | INVALID_OPCODE,
|
---|
| 4227 | INVALID_OPCODE,
|
---|
| 4228 | INVALID_OPCODE,
|
---|
| 4229 | OPVEX("vinserti128 %Vqq,%Hqq,%Wqq,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_INSERTI128, OP_PARM_Vqq, OP_PARM_Hqq, OP_PARM_Wqq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
[53245] | 4230 | OPVEX("vextracti128 %Wdq,%Vqq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_EXTRACTI128, OP_PARM_Wdq, OP_PARM_Vqq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4231 | INVALID_OPCODE,
|
---|
| 4232 | INVALID_OPCODE,
|
---|
| 4233 | INVALID_OPCODE,
|
---|
| 4234 | INVALID_OPCODE,
|
---|
| 4235 | INVALID_OPCODE,
|
---|
| 4236 | INVALID_OPCODE,
|
---|
| 4237 |
|
---|
| 4238 | /* 4 */
|
---|
| 4239 | OPVEX("vdpps %Vx,%Hx,%Wx,%Ib", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_DPPS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4240 | OPVEX("vdppd %Vdq,%Hdq,%Wdq,%Ib",IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_DPPD, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4241 | OPVEX("vmpsadbw %Vx,%Hx,%Wx,%Ib",IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_MPSADBW,OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4242 | INVALID_OPCODE,
|
---|
| 4243 | OPVEX("vpclmulqdq %Vdq,%Hdq,%Wdq,%Ib",IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PCLMULQDQ, OP_PARM_Vdq, OP_PARM_Hdq, OP_PARM_Wdq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4244 | INVALID_OPCODE,
|
---|
| 4245 | OPVEX("vperm2i128 %Vqq,%Hqq,%Wqq,%Ib",IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PERM2I128, OP_PARM_Vqq, OP_PARM_Hqq, OP_PARM_Wqq, OP_PARM_Ib, DISOPTYPE_HARMLESS),
|
---|
| 4246 | INVALID_OPCODE,
|
---|
| 4247 | INVALID_OPCODE,
|
---|
| 4248 | INVALID_OPCODE,
|
---|
[53155] | 4249 | OPVEX("vblendvps %Vx,%Hx,%Wx,%Lx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_BLENDVPS, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Lx, DISOPTYPE_HARMLESS),
|
---|
| 4250 | OPVEX("vblendvpd %Vx,%Hx,%Wx,%Lx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_BLENDVPD, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Lx, DISOPTYPE_HARMLESS),
|
---|
| 4251 | OPVEX("vpblendvb %Vx,%Hx,%Wx,%Lx", IDX_ParseModRM, IDX_ParseVexDest, IDX_UseModRM, IDX_ParseImmByte, OP_PBLENDVB, OP_PARM_Vx, OP_PARM_Hx, OP_PARM_Wx, OP_PARM_Lx, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4252 | INVALID_OPCODE,
|
---|
| 4253 | INVALID_OPCODE,
|
---|
| 4254 | INVALID_OPCODE,
|
---|
| 4255 |
|
---|
| 4256 | /* 5 */
|
---|
| 4257 | INVALID_OPCODE_BLOCK
|
---|
| 4258 |
|
---|
| 4259 | /* 6 */
|
---|
[53245] | 4260 | OPVEX("vpcmpestrm %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PCMPESTRM, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4261 | OPVEX("vpcmpestri %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PCMPESTRI, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4262 | OPVEX("vpcmpistrm %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PCMPISTRM, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
| 4263 | OPVEX("vpcmpistri %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_PCMPISTRI, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4264 | INVALID_OPCODE,
|
---|
| 4265 | INVALID_OPCODE,
|
---|
| 4266 | INVALID_OPCODE,
|
---|
| 4267 | INVALID_OPCODE,
|
---|
| 4268 | INVALID_OPCODE,
|
---|
| 4269 | INVALID_OPCODE,
|
---|
| 4270 | INVALID_OPCODE,
|
---|
| 4271 | INVALID_OPCODE,
|
---|
| 4272 | INVALID_OPCODE,
|
---|
| 4273 | INVALID_OPCODE,
|
---|
| 4274 | INVALID_OPCODE,
|
---|
| 4275 | INVALID_OPCODE,
|
---|
| 4276 |
|
---|
| 4277 | /* 7 */
|
---|
| 4278 | INVALID_OPCODE_BLOCK
|
---|
| 4279 |
|
---|
| 4280 | /* 8 */
|
---|
| 4281 | INVALID_OPCODE_BLOCK
|
---|
| 4282 |
|
---|
| 4283 | /* 9 */
|
---|
| 4284 | INVALID_OPCODE_BLOCK
|
---|
| 4285 |
|
---|
| 4286 | /* a */
|
---|
| 4287 | INVALID_OPCODE_BLOCK
|
---|
| 4288 |
|
---|
| 4289 | /* b */
|
---|
| 4290 | INVALID_OPCODE_BLOCK
|
---|
| 4291 |
|
---|
| 4292 | /* c */
|
---|
| 4293 | INVALID_OPCODE_BLOCK
|
---|
| 4294 |
|
---|
| 4295 | /* d */
|
---|
| 4296 | INVALID_OPCODE,
|
---|
| 4297 | INVALID_OPCODE,
|
---|
| 4298 | INVALID_OPCODE,
|
---|
| 4299 | INVALID_OPCODE,
|
---|
| 4300 | INVALID_OPCODE,
|
---|
| 4301 | INVALID_OPCODE,
|
---|
| 4302 | INVALID_OPCODE,
|
---|
| 4303 | INVALID_OPCODE,
|
---|
| 4304 | INVALID_OPCODE,
|
---|
| 4305 | INVALID_OPCODE,
|
---|
| 4306 | INVALID_OPCODE,
|
---|
| 4307 | INVALID_OPCODE,
|
---|
| 4308 | INVALID_OPCODE,
|
---|
| 4309 | INVALID_OPCODE,
|
---|
| 4310 | INVALID_OPCODE,
|
---|
[53245] | 4311 | OPVEX("vaeskeygen %Vdq,%Wdq,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_AESKEYGEN, OP_PARM_Vdq, OP_PARM_Wdq, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4312 |
|
---|
| 4313 | /* e */
|
---|
| 4314 | INVALID_OPCODE_BLOCK
|
---|
| 4315 |
|
---|
| 4316 | /* f */
|
---|
| 4317 | INVALID_OPCODE_BLOCK
|
---|
| 4318 | };
|
---|
| 4319 |
|
---|
| 4320 | const DISOPCODE g_aMapThreeBytesVex_F20F3A_F0[1] =
|
---|
| 4321 | {
|
---|
[53245] | 4322 | OPVEX("rorx %Gy,%Ey,%Ib", IDX_ParseModRM, IDX_UseModRM, IDX_ParseImmByte, 0, OP_RORX, OP_PARM_Gy, OP_PARM_Ey, OP_PARM_Ib, OP_PARM_NONE, DISOPTYPE_HARMLESS),
|
---|
[53131] | 4323 | };
|
---|
| 4324 |
|
---|
| 4325 |
|
---|
[53094] | 4326 | PCDISOPCODE const g_aVexOpcodesMap[3] =
|
---|
| 4327 | {
|
---|
[53131] | 4328 | &g_aMapTwoBytesVex[0], // 0fh 2-byte opcodes
|
---|
| 4329 | &g_aMapThreeBytesVex_0F38_F[0],// 0f38h 3-byte opcodes
|
---|
| 4330 | NULL, // 0f3ah 3-byte opcodes
|
---|
[53094] | 4331 | };
|
---|
| 4332 |
|
---|
| 4333 | PCDISOPCODE const g_aVexOpcodesMap_66H[3] =
|
---|
| 4334 | {
|
---|
[53131] | 4335 | &g_aMapTwoBytesVex_66H[0], // 0fh 2-byte opcodes
|
---|
| 4336 | &g_aMapThreeBytesVex_660F38[0],// 0f38h 3-byte opcodes
|
---|
| 4337 | &g_aMapThreeBytesVex_660F3A[0],// 0f3ah 3-byte opcodes
|
---|
[53094] | 4338 | };
|
---|
| 4339 |
|
---|
| 4340 | PCDISOPCODE const g_aVexOpcodesMap_F2H[3] =
|
---|
| 4341 | {
|
---|
[53131] | 4342 | &g_aMapTwoBytesVex_F2H[0], // 0fh 2-byte opcodes
|
---|
| 4343 | &g_aMapThreeBytesVex_F20F38_F[0],// 0f38h 3-byte opcodes
|
---|
| 4344 | &g_aMapThreeBytesVex_F20F3A_F0[0],// 0f3ah 3-byte opcodes
|
---|
[53094] | 4345 | };
|
---|
| 4346 |
|
---|
| 4347 | PCDISOPCODE const g_aVexOpcodesMap_F3H[3] =
|
---|
| 4348 | {
|
---|
[53131] | 4349 | &g_aMapTwoBytesVex_F3H[0], // 0fh 2-byte opcodes
|
---|
| 4350 | &g_aMapThreeBytesVex_F30F38_F[0],// 0f38h 3-byte opcodes
|
---|
| 4351 | NULL, // 0f3ah 3-byte opcodes
|
---|
[53094] | 4352 | };
|
---|