mirror of
https://github.com/dynup/kpatch
synced 2024-12-25 14:52:05 +00:00
ecc5141676
We need a disassembler library to help with converting data section relocation references to their corresponding symbols. Unfortunately, the only library I could find that's widely available in enterprise Linux distros was libopcodes, which is part of binutils. But its interface is far too clunky for our needs. The best alternative I can find is to just copy the kernel's disassembler library code from arch/x86/lib.
1147 lines
40 KiB
C
1147 lines
40 KiB
C
/* x86 opcode map generated from x86-opcode-map.txt */
|
|
/* Do not change this code. */
|
|
|
|
/* Table: one byte opcode */
|
|
const insn_attr_t inat_primary_table[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x00] = INAT_MODRM,
|
|
[0x01] = INAT_MODRM,
|
|
[0x02] = INAT_MODRM,
|
|
[0x03] = INAT_MODRM,
|
|
[0x04] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x05] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x08] = INAT_MODRM,
|
|
[0x09] = INAT_MODRM,
|
|
[0x0a] = INAT_MODRM,
|
|
[0x0b] = INAT_MODRM,
|
|
[0x0c] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x0d] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x0f] = INAT_MAKE_ESCAPE(1),
|
|
[0x10] = INAT_MODRM,
|
|
[0x11] = INAT_MODRM,
|
|
[0x12] = INAT_MODRM,
|
|
[0x13] = INAT_MODRM,
|
|
[0x14] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x15] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x18] = INAT_MODRM,
|
|
[0x19] = INAT_MODRM,
|
|
[0x1a] = INAT_MODRM,
|
|
[0x1b] = INAT_MODRM,
|
|
[0x1c] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x1d] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x20] = INAT_MODRM,
|
|
[0x21] = INAT_MODRM,
|
|
[0x22] = INAT_MODRM,
|
|
[0x23] = INAT_MODRM,
|
|
[0x24] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x25] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x26] = INAT_MAKE_PREFIX(INAT_PFX_ES),
|
|
[0x28] = INAT_MODRM,
|
|
[0x29] = INAT_MODRM,
|
|
[0x2a] = INAT_MODRM,
|
|
[0x2b] = INAT_MODRM,
|
|
[0x2c] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x2d] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x2e] = INAT_MAKE_PREFIX(INAT_PFX_CS),
|
|
[0x30] = INAT_MODRM,
|
|
[0x31] = INAT_MODRM,
|
|
[0x32] = INAT_MODRM,
|
|
[0x33] = INAT_MODRM,
|
|
[0x34] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x35] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x36] = INAT_MAKE_PREFIX(INAT_PFX_SS),
|
|
[0x38] = INAT_MODRM,
|
|
[0x39] = INAT_MODRM,
|
|
[0x3a] = INAT_MODRM,
|
|
[0x3b] = INAT_MODRM,
|
|
[0x3c] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x3d] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0x3e] = INAT_MAKE_PREFIX(INAT_PFX_DS),
|
|
[0x40] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x41] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x42] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x43] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x44] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x45] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x46] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x47] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x48] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x49] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x4a] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x4b] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x4c] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x4d] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x4e] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x4f] = INAT_MAKE_PREFIX(INAT_PFX_REX),
|
|
[0x50] = INAT_FORCE64,
|
|
[0x51] = INAT_FORCE64,
|
|
[0x52] = INAT_FORCE64,
|
|
[0x53] = INAT_FORCE64,
|
|
[0x54] = INAT_FORCE64,
|
|
[0x55] = INAT_FORCE64,
|
|
[0x56] = INAT_FORCE64,
|
|
[0x57] = INAT_FORCE64,
|
|
[0x58] = INAT_FORCE64,
|
|
[0x59] = INAT_FORCE64,
|
|
[0x5a] = INAT_FORCE64,
|
|
[0x5b] = INAT_FORCE64,
|
|
[0x5c] = INAT_FORCE64,
|
|
[0x5d] = INAT_FORCE64,
|
|
[0x5e] = INAT_FORCE64,
|
|
[0x5f] = INAT_FORCE64,
|
|
[0x62] = INAT_MODRM,
|
|
[0x63] = INAT_MODRM | INAT_MODRM,
|
|
[0x64] = INAT_MAKE_PREFIX(INAT_PFX_FS),
|
|
[0x65] = INAT_MAKE_PREFIX(INAT_PFX_GS),
|
|
[0x66] = INAT_MAKE_PREFIX(INAT_PFX_OPNDSZ),
|
|
[0x67] = INAT_MAKE_PREFIX(INAT_PFX_ADDRSZ),
|
|
[0x68] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x69] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_MODRM,
|
|
[0x6a] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_FORCE64,
|
|
[0x6b] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM,
|
|
[0x70] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x71] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x72] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x73] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x74] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x75] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x76] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x77] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x78] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x79] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x7a] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x7b] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x7c] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x7d] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x7e] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x7f] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0x80] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_MAKE_GROUP(1),
|
|
[0x81] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_MODRM | INAT_MAKE_GROUP(1),
|
|
[0x82] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_MAKE_GROUP(1),
|
|
[0x83] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_MAKE_GROUP(1),
|
|
[0x84] = INAT_MODRM,
|
|
[0x85] = INAT_MODRM,
|
|
[0x86] = INAT_MODRM,
|
|
[0x87] = INAT_MODRM,
|
|
[0x88] = INAT_MODRM,
|
|
[0x89] = INAT_MODRM,
|
|
[0x8a] = INAT_MODRM,
|
|
[0x8b] = INAT_MODRM,
|
|
[0x8c] = INAT_MODRM,
|
|
[0x8d] = INAT_MODRM,
|
|
[0x8e] = INAT_MODRM,
|
|
[0x8f] = INAT_MAKE_GROUP(2) | INAT_MODRM | INAT_FORCE64,
|
|
[0x9a] = INAT_MAKE_IMM(INAT_IMM_PTR),
|
|
[0x9c] = INAT_FORCE64,
|
|
[0x9d] = INAT_FORCE64,
|
|
[0xa0] = INAT_MOFFSET,
|
|
[0xa1] = INAT_MOFFSET,
|
|
[0xa2] = INAT_MOFFSET,
|
|
[0xa3] = INAT_MOFFSET,
|
|
[0xa8] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xa9] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
[0xb0] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb1] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb2] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb3] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb4] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb5] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb6] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb7] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xb8] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xb9] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xba] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xbb] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xbc] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xbd] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xbe] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xbf] = INAT_MAKE_IMM(INAT_IMM_VWORD),
|
|
[0xc0] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_MAKE_GROUP(3),
|
|
[0xc1] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_MAKE_GROUP(3),
|
|
[0xc2] = INAT_MAKE_IMM(INAT_IMM_WORD) | INAT_FORCE64,
|
|
[0xc4] = INAT_MODRM | INAT_MAKE_PREFIX(INAT_PFX_VEX3),
|
|
[0xc5] = INAT_MODRM | INAT_MAKE_PREFIX(INAT_PFX_VEX2),
|
|
[0xc6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_MAKE_GROUP(4),
|
|
[0xc7] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_MODRM | INAT_MAKE_GROUP(5),
|
|
[0xc8] = INAT_MAKE_IMM(INAT_IMM_WORD) | INAT_SCNDIMM,
|
|
[0xc9] = INAT_FORCE64,
|
|
[0xca] = INAT_MAKE_IMM(INAT_IMM_WORD),
|
|
[0xcd] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xd0] = INAT_MODRM | INAT_MAKE_GROUP(3),
|
|
[0xd1] = INAT_MODRM | INAT_MAKE_GROUP(3),
|
|
[0xd2] = INAT_MODRM | INAT_MAKE_GROUP(3),
|
|
[0xd3] = INAT_MODRM | INAT_MAKE_GROUP(3),
|
|
[0xd4] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xd5] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xd8] = INAT_MODRM,
|
|
[0xd9] = INAT_MODRM,
|
|
[0xda] = INAT_MODRM,
|
|
[0xdb] = INAT_MODRM,
|
|
[0xdc] = INAT_MODRM,
|
|
[0xdd] = INAT_MODRM,
|
|
[0xde] = INAT_MODRM,
|
|
[0xdf] = INAT_MODRM,
|
|
[0xe0] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_FORCE64,
|
|
[0xe1] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_FORCE64,
|
|
[0xe2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_FORCE64,
|
|
[0xe3] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_FORCE64,
|
|
[0xe4] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xe5] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xe6] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xe7] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
[0xe8] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0xe9] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0xea] = INAT_MAKE_IMM(INAT_IMM_PTR),
|
|
[0xeb] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_FORCE64,
|
|
[0xf0] = INAT_MAKE_PREFIX(INAT_PFX_LOCK),
|
|
[0xf2] = INAT_MAKE_PREFIX(INAT_PFX_REPNE) | INAT_MAKE_PREFIX(INAT_PFX_REPNE),
|
|
[0xf3] = INAT_MAKE_PREFIX(INAT_PFX_REPE) | INAT_MAKE_PREFIX(INAT_PFX_REPE),
|
|
[0xf6] = INAT_MODRM | INAT_MAKE_GROUP(6),
|
|
[0xf7] = INAT_MODRM | INAT_MAKE_GROUP(7),
|
|
[0xfe] = INAT_MAKE_GROUP(8),
|
|
[0xff] = INAT_MAKE_GROUP(9),
|
|
};
|
|
|
|
/* Table: 2-byte opcode (0x0f) */
|
|
const insn_attr_t inat_escape_table_1[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x00] = INAT_MAKE_GROUP(10),
|
|
[0x01] = INAT_MAKE_GROUP(11),
|
|
[0x02] = INAT_MODRM,
|
|
[0x03] = INAT_MODRM,
|
|
[0x0d] = INAT_MAKE_GROUP(12),
|
|
[0x0f] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM,
|
|
[0x10] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x11] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x12] = INAT_MODRM | INAT_VEXOK | INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x13] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x14] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x15] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x16] = INAT_MODRM | INAT_VEXOK | INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x17] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x18] = INAT_MAKE_GROUP(13),
|
|
[0x1a] = INAT_MODRM | INAT_MODRM | INAT_MODRM | INAT_MODRM,
|
|
[0x1b] = INAT_MODRM | INAT_MODRM | INAT_MODRM | INAT_MODRM,
|
|
[0x1f] = INAT_MODRM,
|
|
[0x20] = INAT_MODRM,
|
|
[0x21] = INAT_MODRM,
|
|
[0x22] = INAT_MODRM,
|
|
[0x23] = INAT_MODRM,
|
|
[0x28] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x29] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x2a] = INAT_MODRM | INAT_VARIANT,
|
|
[0x2b] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x2c] = INAT_MODRM | INAT_VARIANT,
|
|
[0x2d] = INAT_MODRM | INAT_VARIANT,
|
|
[0x2e] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x2f] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x38] = INAT_MAKE_ESCAPE(2),
|
|
[0x3a] = INAT_MAKE_ESCAPE(3),
|
|
[0x40] = INAT_MODRM,
|
|
[0x41] = INAT_MODRM,
|
|
[0x42] = INAT_MODRM,
|
|
[0x43] = INAT_MODRM,
|
|
[0x44] = INAT_MODRM,
|
|
[0x45] = INAT_MODRM,
|
|
[0x46] = INAT_MODRM,
|
|
[0x47] = INAT_MODRM,
|
|
[0x48] = INAT_MODRM,
|
|
[0x49] = INAT_MODRM,
|
|
[0x4a] = INAT_MODRM,
|
|
[0x4b] = INAT_MODRM,
|
|
[0x4c] = INAT_MODRM,
|
|
[0x4d] = INAT_MODRM,
|
|
[0x4e] = INAT_MODRM,
|
|
[0x4f] = INAT_MODRM,
|
|
[0x50] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x51] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x52] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x53] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x54] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x55] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x56] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x57] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x58] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x59] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x5a] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x5b] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x5c] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x5d] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x5e] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x5f] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x60] = INAT_MODRM | INAT_VARIANT,
|
|
[0x61] = INAT_MODRM | INAT_VARIANT,
|
|
[0x62] = INAT_MODRM | INAT_VARIANT,
|
|
[0x63] = INAT_MODRM | INAT_VARIANT,
|
|
[0x64] = INAT_MODRM | INAT_VARIANT,
|
|
[0x65] = INAT_MODRM | INAT_VARIANT,
|
|
[0x66] = INAT_MODRM | INAT_VARIANT,
|
|
[0x67] = INAT_MODRM | INAT_VARIANT,
|
|
[0x68] = INAT_MODRM | INAT_VARIANT,
|
|
[0x69] = INAT_MODRM | INAT_VARIANT,
|
|
[0x6a] = INAT_MODRM | INAT_VARIANT,
|
|
[0x6b] = INAT_MODRM | INAT_VARIANT,
|
|
[0x6c] = INAT_VARIANT,
|
|
[0x6d] = INAT_VARIANT,
|
|
[0x6e] = INAT_MODRM | INAT_VARIANT,
|
|
[0x6f] = INAT_MODRM | INAT_VARIANT,
|
|
[0x70] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x71] = INAT_MAKE_GROUP(14),
|
|
[0x72] = INAT_MAKE_GROUP(15),
|
|
[0x73] = INAT_MAKE_GROUP(16),
|
|
[0x74] = INAT_MODRM | INAT_VARIANT,
|
|
[0x75] = INAT_MODRM | INAT_VARIANT,
|
|
[0x76] = INAT_MODRM | INAT_VARIANT,
|
|
[0x77] = INAT_VEXOK | INAT_VEXOK,
|
|
[0x78] = INAT_MODRM,
|
|
[0x79] = INAT_MODRM,
|
|
[0x7c] = INAT_VARIANT,
|
|
[0x7d] = INAT_VARIANT,
|
|
[0x7e] = INAT_MODRM | INAT_VARIANT,
|
|
[0x7f] = INAT_MODRM | INAT_VARIANT,
|
|
[0x80] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x81] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x82] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x83] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x84] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x85] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x86] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x87] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x88] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x89] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x8a] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x8b] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x8c] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x8d] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x8e] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x8f] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_FORCE64,
|
|
[0x90] = INAT_MODRM,
|
|
[0x91] = INAT_MODRM,
|
|
[0x92] = INAT_MODRM,
|
|
[0x93] = INAT_MODRM,
|
|
[0x94] = INAT_MODRM,
|
|
[0x95] = INAT_MODRM,
|
|
[0x96] = INAT_MODRM,
|
|
[0x97] = INAT_MODRM,
|
|
[0x98] = INAT_MODRM,
|
|
[0x99] = INAT_MODRM,
|
|
[0x9a] = INAT_MODRM,
|
|
[0x9b] = INAT_MODRM,
|
|
[0x9c] = INAT_MODRM,
|
|
[0x9d] = INAT_MODRM,
|
|
[0x9e] = INAT_MODRM,
|
|
[0x9f] = INAT_MODRM,
|
|
[0xa0] = INAT_FORCE64,
|
|
[0xa1] = INAT_FORCE64,
|
|
[0xa3] = INAT_MODRM,
|
|
[0xa4] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM,
|
|
[0xa5] = INAT_MODRM,
|
|
[0xa6] = INAT_MAKE_GROUP(17),
|
|
[0xa7] = INAT_MAKE_GROUP(18),
|
|
[0xa8] = INAT_FORCE64,
|
|
[0xa9] = INAT_FORCE64,
|
|
[0xab] = INAT_MODRM,
|
|
[0xac] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM,
|
|
[0xad] = INAT_MODRM,
|
|
[0xae] = INAT_MAKE_GROUP(19),
|
|
[0xaf] = INAT_MODRM,
|
|
[0xb0] = INAT_MODRM,
|
|
[0xb1] = INAT_MODRM,
|
|
[0xb2] = INAT_MODRM,
|
|
[0xb3] = INAT_MODRM,
|
|
[0xb4] = INAT_MODRM,
|
|
[0xb5] = INAT_MODRM,
|
|
[0xb6] = INAT_MODRM,
|
|
[0xb7] = INAT_MODRM,
|
|
[0xb8] = INAT_VARIANT,
|
|
[0xb9] = INAT_MAKE_GROUP(20),
|
|
[0xba] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_MAKE_GROUP(21),
|
|
[0xbb] = INAT_MODRM,
|
|
[0xbc] = INAT_MODRM | INAT_VARIANT,
|
|
[0xbd] = INAT_MODRM | INAT_VARIANT,
|
|
[0xbe] = INAT_MODRM,
|
|
[0xbf] = INAT_MODRM,
|
|
[0xc0] = INAT_MODRM,
|
|
[0xc1] = INAT_MODRM,
|
|
[0xc2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0xc3] = INAT_MODRM,
|
|
[0xc4] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0xc5] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0xc6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0xc7] = INAT_MAKE_GROUP(22),
|
|
[0xd0] = INAT_VARIANT,
|
|
[0xd1] = INAT_MODRM | INAT_VARIANT,
|
|
[0xd2] = INAT_MODRM | INAT_VARIANT,
|
|
[0xd3] = INAT_MODRM | INAT_VARIANT,
|
|
[0xd4] = INAT_MODRM | INAT_VARIANT,
|
|
[0xd5] = INAT_MODRM | INAT_VARIANT,
|
|
[0xd6] = INAT_VARIANT,
|
|
[0xd7] = INAT_MODRM | INAT_VARIANT,
|
|
[0xd8] = INAT_MODRM | INAT_VARIANT,
|
|
[0xd9] = INAT_MODRM | INAT_VARIANT,
|
|
[0xda] = INAT_MODRM | INAT_VARIANT,
|
|
[0xdb] = INAT_MODRM | INAT_VARIANT,
|
|
[0xdc] = INAT_MODRM | INAT_VARIANT,
|
|
[0xdd] = INAT_MODRM | INAT_VARIANT,
|
|
[0xde] = INAT_MODRM | INAT_VARIANT,
|
|
[0xdf] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe0] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe1] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe2] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe3] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe4] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe5] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe6] = INAT_VARIANT,
|
|
[0xe7] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe8] = INAT_MODRM | INAT_VARIANT,
|
|
[0xe9] = INAT_MODRM | INAT_VARIANT,
|
|
[0xea] = INAT_MODRM | INAT_VARIANT,
|
|
[0xeb] = INAT_MODRM | INAT_VARIANT,
|
|
[0xec] = INAT_MODRM | INAT_VARIANT,
|
|
[0xed] = INAT_MODRM | INAT_VARIANT,
|
|
[0xee] = INAT_MODRM | INAT_VARIANT,
|
|
[0xef] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf0] = INAT_VARIANT,
|
|
[0xf1] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf2] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf3] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf4] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf5] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf6] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf7] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf8] = INAT_MODRM | INAT_VARIANT,
|
|
[0xf9] = INAT_MODRM | INAT_VARIANT,
|
|
[0xfa] = INAT_MODRM | INAT_VARIANT,
|
|
[0xfb] = INAT_MODRM | INAT_VARIANT,
|
|
[0xfc] = INAT_MODRM | INAT_VARIANT,
|
|
[0xfd] = INAT_MODRM | INAT_VARIANT,
|
|
[0xfe] = INAT_MODRM | INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_escape_table_1_1[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x10] = INAT_MODRM | INAT_VEXOK,
|
|
[0x11] = INAT_MODRM | INAT_VEXOK,
|
|
[0x12] = INAT_MODRM | INAT_VEXOK,
|
|
[0x13] = INAT_MODRM | INAT_VEXOK,
|
|
[0x14] = INAT_MODRM | INAT_VEXOK,
|
|
[0x15] = INAT_MODRM | INAT_VEXOK,
|
|
[0x16] = INAT_MODRM | INAT_VEXOK,
|
|
[0x17] = INAT_MODRM | INAT_VEXOK,
|
|
[0x28] = INAT_MODRM | INAT_VEXOK,
|
|
[0x29] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2a] = INAT_MODRM,
|
|
[0x2b] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2c] = INAT_MODRM,
|
|
[0x2d] = INAT_MODRM,
|
|
[0x2e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2f] = INAT_MODRM | INAT_VEXOK,
|
|
[0x50] = INAT_MODRM | INAT_VEXOK,
|
|
[0x51] = INAT_MODRM | INAT_VEXOK,
|
|
[0x54] = INAT_MODRM | INAT_VEXOK,
|
|
[0x55] = INAT_MODRM | INAT_VEXOK,
|
|
[0x56] = INAT_MODRM | INAT_VEXOK,
|
|
[0x57] = INAT_MODRM | INAT_VEXOK,
|
|
[0x58] = INAT_MODRM | INAT_VEXOK,
|
|
[0x59] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5b] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5f] = INAT_MODRM | INAT_VEXOK,
|
|
[0x60] = INAT_MODRM | INAT_VEXOK,
|
|
[0x61] = INAT_MODRM | INAT_VEXOK,
|
|
[0x62] = INAT_MODRM | INAT_VEXOK,
|
|
[0x63] = INAT_MODRM | INAT_VEXOK,
|
|
[0x64] = INAT_MODRM | INAT_VEXOK,
|
|
[0x65] = INAT_MODRM | INAT_VEXOK,
|
|
[0x66] = INAT_MODRM | INAT_VEXOK,
|
|
[0x67] = INAT_MODRM | INAT_VEXOK,
|
|
[0x68] = INAT_MODRM | INAT_VEXOK,
|
|
[0x69] = INAT_MODRM | INAT_VEXOK,
|
|
[0x6a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x6b] = INAT_MODRM | INAT_VEXOK,
|
|
[0x6c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x6d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x6e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x6f] = INAT_MODRM | INAT_VEXOK,
|
|
[0x70] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x74] = INAT_MODRM | INAT_VEXOK,
|
|
[0x75] = INAT_MODRM | INAT_VEXOK,
|
|
[0x76] = INAT_MODRM | INAT_VEXOK,
|
|
[0x7c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x7d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x7e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x7f] = INAT_MODRM | INAT_VEXOK,
|
|
[0xbc] = INAT_MODRM,
|
|
[0xbd] = INAT_MODRM,
|
|
[0xc2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0xc4] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0xc5] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0xc6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0xd0] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd1] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd2] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd3] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd4] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd5] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd6] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd7] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd8] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd9] = INAT_MODRM | INAT_VEXOK,
|
|
[0xda] = INAT_MODRM | INAT_VEXOK,
|
|
[0xdb] = INAT_MODRM | INAT_VEXOK,
|
|
[0xdc] = INAT_MODRM | INAT_VEXOK,
|
|
[0xdd] = INAT_MODRM | INAT_VEXOK,
|
|
[0xde] = INAT_MODRM | INAT_VEXOK,
|
|
[0xdf] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe0] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe1] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe2] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe3] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe4] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe5] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe6] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe7] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe8] = INAT_MODRM | INAT_VEXOK,
|
|
[0xe9] = INAT_MODRM | INAT_VEXOK,
|
|
[0xea] = INAT_MODRM | INAT_VEXOK,
|
|
[0xeb] = INAT_MODRM | INAT_VEXOK,
|
|
[0xec] = INAT_MODRM | INAT_VEXOK,
|
|
[0xed] = INAT_MODRM | INAT_VEXOK,
|
|
[0xee] = INAT_MODRM | INAT_VEXOK,
|
|
[0xef] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf1] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf2] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf3] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf4] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf5] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf6] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf7] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf8] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf9] = INAT_MODRM | INAT_VEXOK,
|
|
[0xfa] = INAT_MODRM | INAT_VEXOK,
|
|
[0xfb] = INAT_MODRM | INAT_VEXOK,
|
|
[0xfc] = INAT_MODRM | INAT_VEXOK,
|
|
[0xfd] = INAT_MODRM | INAT_VEXOK,
|
|
[0xfe] = INAT_MODRM | INAT_VEXOK,
|
|
};
|
|
const insn_attr_t inat_escape_table_1_2[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x10] = INAT_MODRM | INAT_VEXOK,
|
|
[0x11] = INAT_MODRM | INAT_VEXOK,
|
|
[0x12] = INAT_MODRM | INAT_VEXOK,
|
|
[0x16] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x51] = INAT_MODRM | INAT_VEXOK,
|
|
[0x52] = INAT_MODRM | INAT_VEXOK,
|
|
[0x53] = INAT_MODRM | INAT_VEXOK,
|
|
[0x58] = INAT_MODRM | INAT_VEXOK,
|
|
[0x59] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5b] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5f] = INAT_MODRM | INAT_VEXOK,
|
|
[0x6f] = INAT_MODRM | INAT_VEXOK,
|
|
[0x70] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x7e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x7f] = INAT_MODRM | INAT_VEXOK,
|
|
[0xb8] = INAT_MODRM,
|
|
[0xbc] = INAT_MODRM,
|
|
[0xbd] = INAT_MODRM,
|
|
[0xc2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0xd6] = INAT_MODRM,
|
|
[0xe6] = INAT_MODRM | INAT_VEXOK,
|
|
};
|
|
const insn_attr_t inat_escape_table_1_3[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x10] = INAT_MODRM | INAT_VEXOK,
|
|
[0x11] = INAT_MODRM | INAT_VEXOK,
|
|
[0x12] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x51] = INAT_MODRM | INAT_VEXOK,
|
|
[0x58] = INAT_MODRM | INAT_VEXOK,
|
|
[0x59] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x5f] = INAT_MODRM | INAT_VEXOK,
|
|
[0x70] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x7c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x7d] = INAT_MODRM | INAT_VEXOK,
|
|
[0xbc] = INAT_MODRM,
|
|
[0xbd] = INAT_MODRM,
|
|
[0xc2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0xd0] = INAT_MODRM | INAT_VEXOK,
|
|
[0xd6] = INAT_MODRM,
|
|
[0xe6] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf0] = INAT_MODRM | INAT_VEXOK,
|
|
};
|
|
|
|
/* Table: 3-byte opcode 1 (0x0f 0x38) */
|
|
const insn_attr_t inat_escape_table_2[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x00] = INAT_MODRM | INAT_VARIANT,
|
|
[0x01] = INAT_MODRM | INAT_VARIANT,
|
|
[0x02] = INAT_MODRM | INAT_VARIANT,
|
|
[0x03] = INAT_MODRM | INAT_VARIANT,
|
|
[0x04] = INAT_MODRM | INAT_VARIANT,
|
|
[0x05] = INAT_MODRM | INAT_VARIANT,
|
|
[0x06] = INAT_MODRM | INAT_VARIANT,
|
|
[0x07] = INAT_MODRM | INAT_VARIANT,
|
|
[0x08] = INAT_MODRM | INAT_VARIANT,
|
|
[0x09] = INAT_MODRM | INAT_VARIANT,
|
|
[0x0a] = INAT_MODRM | INAT_VARIANT,
|
|
[0x0b] = INAT_MODRM | INAT_VARIANT,
|
|
[0x0c] = INAT_VARIANT,
|
|
[0x0d] = INAT_VARIANT,
|
|
[0x0e] = INAT_VARIANT,
|
|
[0x0f] = INAT_VARIANT,
|
|
[0x10] = INAT_VARIANT,
|
|
[0x13] = INAT_VARIANT,
|
|
[0x14] = INAT_VARIANT,
|
|
[0x15] = INAT_VARIANT,
|
|
[0x16] = INAT_VARIANT,
|
|
[0x17] = INAT_VARIANT,
|
|
[0x18] = INAT_VARIANT,
|
|
[0x19] = INAT_VARIANT,
|
|
[0x1a] = INAT_VARIANT,
|
|
[0x1c] = INAT_MODRM | INAT_VARIANT,
|
|
[0x1d] = INAT_MODRM | INAT_VARIANT,
|
|
[0x1e] = INAT_MODRM | INAT_VARIANT,
|
|
[0x20] = INAT_VARIANT,
|
|
[0x21] = INAT_VARIANT,
|
|
[0x22] = INAT_VARIANT,
|
|
[0x23] = INAT_VARIANT,
|
|
[0x24] = INAT_VARIANT,
|
|
[0x25] = INAT_VARIANT,
|
|
[0x28] = INAT_VARIANT,
|
|
[0x29] = INAT_VARIANT,
|
|
[0x2a] = INAT_VARIANT,
|
|
[0x2b] = INAT_VARIANT,
|
|
[0x2c] = INAT_VARIANT,
|
|
[0x2d] = INAT_VARIANT,
|
|
[0x2e] = INAT_VARIANT,
|
|
[0x2f] = INAT_VARIANT,
|
|
[0x30] = INAT_VARIANT,
|
|
[0x31] = INAT_VARIANT,
|
|
[0x32] = INAT_VARIANT,
|
|
[0x33] = INAT_VARIANT,
|
|
[0x34] = INAT_VARIANT,
|
|
[0x35] = INAT_VARIANT,
|
|
[0x36] = INAT_VARIANT,
|
|
[0x37] = INAT_VARIANT,
|
|
[0x38] = INAT_VARIANT,
|
|
[0x39] = INAT_VARIANT,
|
|
[0x3a] = INAT_VARIANT,
|
|
[0x3b] = INAT_VARIANT,
|
|
[0x3c] = INAT_VARIANT,
|
|
[0x3d] = INAT_VARIANT,
|
|
[0x3e] = INAT_VARIANT,
|
|
[0x3f] = INAT_VARIANT,
|
|
[0x40] = INAT_VARIANT,
|
|
[0x41] = INAT_VARIANT,
|
|
[0x45] = INAT_VARIANT,
|
|
[0x46] = INAT_VARIANT,
|
|
[0x47] = INAT_VARIANT,
|
|
[0x58] = INAT_VARIANT,
|
|
[0x59] = INAT_VARIANT,
|
|
[0x5a] = INAT_VARIANT,
|
|
[0x78] = INAT_VARIANT,
|
|
[0x79] = INAT_VARIANT,
|
|
[0x80] = INAT_VARIANT,
|
|
[0x81] = INAT_VARIANT,
|
|
[0x82] = INAT_VARIANT,
|
|
[0x8c] = INAT_VARIANT,
|
|
[0x8e] = INAT_VARIANT,
|
|
[0x90] = INAT_VARIANT,
|
|
[0x91] = INAT_VARIANT,
|
|
[0x92] = INAT_VARIANT,
|
|
[0x93] = INAT_VARIANT,
|
|
[0x96] = INAT_VARIANT,
|
|
[0x97] = INAT_VARIANT,
|
|
[0x98] = INAT_VARIANT,
|
|
[0x99] = INAT_VARIANT,
|
|
[0x9a] = INAT_VARIANT,
|
|
[0x9b] = INAT_VARIANT,
|
|
[0x9c] = INAT_VARIANT,
|
|
[0x9d] = INAT_VARIANT,
|
|
[0x9e] = INAT_VARIANT,
|
|
[0x9f] = INAT_VARIANT,
|
|
[0xa6] = INAT_VARIANT,
|
|
[0xa7] = INAT_VARIANT,
|
|
[0xa8] = INAT_VARIANT,
|
|
[0xa9] = INAT_VARIANT,
|
|
[0xaa] = INAT_VARIANT,
|
|
[0xab] = INAT_VARIANT,
|
|
[0xac] = INAT_VARIANT,
|
|
[0xad] = INAT_VARIANT,
|
|
[0xae] = INAT_VARIANT,
|
|
[0xaf] = INAT_VARIANT,
|
|
[0xb6] = INAT_VARIANT,
|
|
[0xb7] = INAT_VARIANT,
|
|
[0xb8] = INAT_VARIANT,
|
|
[0xb9] = INAT_VARIANT,
|
|
[0xba] = INAT_VARIANT,
|
|
[0xbb] = INAT_VARIANT,
|
|
[0xbc] = INAT_VARIANT,
|
|
[0xbd] = INAT_VARIANT,
|
|
[0xbe] = INAT_VARIANT,
|
|
[0xbf] = INAT_VARIANT,
|
|
[0xdb] = INAT_VARIANT,
|
|
[0xdc] = INAT_VARIANT,
|
|
[0xdd] = INAT_VARIANT,
|
|
[0xde] = INAT_VARIANT,
|
|
[0xdf] = INAT_VARIANT,
|
|
[0xf0] = INAT_MODRM | INAT_MODRM | INAT_VARIANT,
|
|
[0xf1] = INAT_MODRM | INAT_MODRM | INAT_VARIANT,
|
|
[0xf2] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xf3] = INAT_MAKE_GROUP(23),
|
|
[0xf5] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY | INAT_VARIANT,
|
|
[0xf6] = INAT_VARIANT,
|
|
[0xf7] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY | INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_escape_table_2_1[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x00] = INAT_MODRM | INAT_VEXOK,
|
|
[0x01] = INAT_MODRM | INAT_VEXOK,
|
|
[0x02] = INAT_MODRM | INAT_VEXOK,
|
|
[0x03] = INAT_MODRM | INAT_VEXOK,
|
|
[0x04] = INAT_MODRM | INAT_VEXOK,
|
|
[0x05] = INAT_MODRM | INAT_VEXOK,
|
|
[0x06] = INAT_MODRM | INAT_VEXOK,
|
|
[0x07] = INAT_MODRM | INAT_VEXOK,
|
|
[0x08] = INAT_MODRM | INAT_VEXOK,
|
|
[0x09] = INAT_MODRM | INAT_VEXOK,
|
|
[0x0a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x0b] = INAT_MODRM | INAT_VEXOK,
|
|
[0x0c] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x0d] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x0e] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x0f] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x10] = INAT_MODRM,
|
|
[0x13] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x14] = INAT_MODRM,
|
|
[0x15] = INAT_MODRM,
|
|
[0x16] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x17] = INAT_MODRM | INAT_VEXOK,
|
|
[0x18] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x19] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x1a] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x1c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x1d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x1e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x20] = INAT_MODRM | INAT_VEXOK,
|
|
[0x21] = INAT_MODRM | INAT_VEXOK,
|
|
[0x22] = INAT_MODRM | INAT_VEXOK,
|
|
[0x23] = INAT_MODRM | INAT_VEXOK,
|
|
[0x24] = INAT_MODRM | INAT_VEXOK,
|
|
[0x25] = INAT_MODRM | INAT_VEXOK,
|
|
[0x28] = INAT_MODRM | INAT_VEXOK,
|
|
[0x29] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2b] = INAT_MODRM | INAT_VEXOK,
|
|
[0x2c] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x2d] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x2e] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x2f] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x30] = INAT_MODRM | INAT_VEXOK,
|
|
[0x31] = INAT_MODRM | INAT_VEXOK,
|
|
[0x32] = INAT_MODRM | INAT_VEXOK,
|
|
[0x33] = INAT_MODRM | INAT_VEXOK,
|
|
[0x34] = INAT_MODRM | INAT_VEXOK,
|
|
[0x35] = INAT_MODRM | INAT_VEXOK,
|
|
[0x36] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x37] = INAT_MODRM | INAT_VEXOK,
|
|
[0x38] = INAT_MODRM | INAT_VEXOK,
|
|
[0x39] = INAT_MODRM | INAT_VEXOK,
|
|
[0x3a] = INAT_MODRM | INAT_VEXOK,
|
|
[0x3b] = INAT_MODRM | INAT_VEXOK,
|
|
[0x3c] = INAT_MODRM | INAT_VEXOK,
|
|
[0x3d] = INAT_MODRM | INAT_VEXOK,
|
|
[0x3e] = INAT_MODRM | INAT_VEXOK,
|
|
[0x3f] = INAT_MODRM | INAT_VEXOK,
|
|
[0x40] = INAT_MODRM | INAT_VEXOK,
|
|
[0x41] = INAT_MODRM | INAT_VEXOK,
|
|
[0x45] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x46] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x47] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x58] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x59] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x5a] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x78] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x79] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x80] = INAT_MODRM,
|
|
[0x81] = INAT_MODRM,
|
|
[0x82] = INAT_MODRM,
|
|
[0x8c] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x8e] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x90] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x91] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x92] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x93] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x96] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x97] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x98] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x99] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x9a] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x9b] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x9c] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x9d] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x9e] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x9f] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xa6] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xa7] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xa8] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xa9] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xaa] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xab] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xac] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xad] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xae] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xaf] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xb6] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xb7] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xb8] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xb9] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xba] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xbb] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xbc] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xbd] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xbe] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xbf] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xdb] = INAT_MODRM | INAT_VEXOK,
|
|
[0xdc] = INAT_MODRM | INAT_VEXOK,
|
|
[0xdd] = INAT_MODRM | INAT_VEXOK,
|
|
[0xde] = INAT_MODRM | INAT_VEXOK,
|
|
[0xdf] = INAT_MODRM | INAT_VEXOK,
|
|
[0xf0] = INAT_MODRM,
|
|
[0xf1] = INAT_MODRM,
|
|
[0xf6] = INAT_MODRM,
|
|
[0xf7] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
};
|
|
const insn_attr_t inat_escape_table_2_2[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0xf5] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xf6] = INAT_MODRM,
|
|
[0xf7] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
};
|
|
const insn_attr_t inat_escape_table_2_3[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0xf0] = INAT_MODRM | INAT_MODRM,
|
|
[0xf1] = INAT_MODRM | INAT_MODRM,
|
|
[0xf5] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xf6] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0xf7] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
};
|
|
|
|
/* Table: 3-byte opcode 2 (0x0f 0x3a) */
|
|
const insn_attr_t inat_escape_table_3[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x00] = INAT_VARIANT,
|
|
[0x01] = INAT_VARIANT,
|
|
[0x02] = INAT_VARIANT,
|
|
[0x04] = INAT_VARIANT,
|
|
[0x05] = INAT_VARIANT,
|
|
[0x06] = INAT_VARIANT,
|
|
[0x08] = INAT_VARIANT,
|
|
[0x09] = INAT_VARIANT,
|
|
[0x0a] = INAT_VARIANT,
|
|
[0x0b] = INAT_VARIANT,
|
|
[0x0c] = INAT_VARIANT,
|
|
[0x0d] = INAT_VARIANT,
|
|
[0x0e] = INAT_VARIANT,
|
|
[0x0f] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x14] = INAT_VARIANT,
|
|
[0x15] = INAT_VARIANT,
|
|
[0x16] = INAT_VARIANT,
|
|
[0x17] = INAT_VARIANT,
|
|
[0x18] = INAT_VARIANT,
|
|
[0x19] = INAT_VARIANT,
|
|
[0x1d] = INAT_VARIANT,
|
|
[0x20] = INAT_VARIANT,
|
|
[0x21] = INAT_VARIANT,
|
|
[0x22] = INAT_VARIANT,
|
|
[0x38] = INAT_VARIANT,
|
|
[0x39] = INAT_VARIANT,
|
|
[0x40] = INAT_VARIANT,
|
|
[0x41] = INAT_VARIANT,
|
|
[0x42] = INAT_VARIANT,
|
|
[0x44] = INAT_VARIANT,
|
|
[0x46] = INAT_VARIANT,
|
|
[0x4a] = INAT_VARIANT,
|
|
[0x4b] = INAT_VARIANT,
|
|
[0x4c] = INAT_VARIANT,
|
|
[0x60] = INAT_VARIANT,
|
|
[0x61] = INAT_VARIANT,
|
|
[0x62] = INAT_VARIANT,
|
|
[0x63] = INAT_VARIANT,
|
|
[0xdf] = INAT_VARIANT,
|
|
[0xf0] = INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_escape_table_3_1[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0x00] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x01] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x02] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x04] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x05] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x06] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x08] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x09] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x0a] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x0b] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x0c] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x0d] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x0e] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x0f] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x14] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x15] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x16] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x17] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x18] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x19] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x1d] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x20] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x21] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x22] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x38] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x39] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x40] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x41] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x42] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x44] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x46] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x4a] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x4b] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x4c] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x60] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x61] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x62] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x63] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0xdf] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
};
|
|
const insn_attr_t inat_escape_table_3_3[INAT_OPCODE_TABLE_SIZE] = {
|
|
[0xf0] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
};
|
|
|
|
/* GrpTable: Grp1 */
|
|
|
|
/* GrpTable: Grp1A */
|
|
|
|
/* GrpTable: Grp2 */
|
|
|
|
/* GrpTable: Grp3_1 */
|
|
const insn_attr_t inat_group_table_6[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM,
|
|
[0x2] = INAT_MODRM,
|
|
[0x3] = INAT_MODRM,
|
|
[0x4] = INAT_MODRM,
|
|
[0x5] = INAT_MODRM,
|
|
[0x6] = INAT_MODRM,
|
|
[0x7] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp3_2 */
|
|
const insn_attr_t inat_group_table_7[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_MODRM,
|
|
[0x2] = INAT_MODRM,
|
|
[0x3] = INAT_MODRM,
|
|
[0x4] = INAT_MODRM,
|
|
[0x5] = INAT_MODRM,
|
|
[0x6] = INAT_MODRM,
|
|
[0x7] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp4 */
|
|
const insn_attr_t inat_group_table_8[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MODRM,
|
|
[0x1] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp5 */
|
|
const insn_attr_t inat_group_table_9[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MODRM,
|
|
[0x1] = INAT_MODRM,
|
|
[0x2] = INAT_MODRM | INAT_FORCE64,
|
|
[0x3] = INAT_MODRM,
|
|
[0x4] = INAT_MODRM | INAT_FORCE64,
|
|
[0x5] = INAT_MODRM,
|
|
[0x6] = INAT_MODRM | INAT_FORCE64,
|
|
};
|
|
|
|
/* GrpTable: Grp6 */
|
|
const insn_attr_t inat_group_table_10[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MODRM,
|
|
[0x1] = INAT_MODRM,
|
|
[0x2] = INAT_MODRM,
|
|
[0x3] = INAT_MODRM,
|
|
[0x4] = INAT_MODRM,
|
|
[0x5] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp7 */
|
|
const insn_attr_t inat_group_table_11[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MODRM,
|
|
[0x1] = INAT_MODRM,
|
|
[0x2] = INAT_MODRM,
|
|
[0x3] = INAT_MODRM,
|
|
[0x4] = INAT_MODRM,
|
|
[0x6] = INAT_MODRM,
|
|
[0x7] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp8 */
|
|
|
|
/* GrpTable: Grp9 */
|
|
const insn_attr_t inat_group_table_22[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x1] = INAT_MODRM,
|
|
[0x6] = INAT_MODRM | INAT_MODRM | INAT_VARIANT,
|
|
[0x7] = INAT_MODRM | INAT_MODRM | INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_group_table_22_1[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x6] = INAT_MODRM,
|
|
};
|
|
const insn_attr_t inat_group_table_22_2[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x6] = INAT_MODRM,
|
|
[0x7] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp10 */
|
|
|
|
/* GrpTable: Grp11A */
|
|
const insn_attr_t inat_group_table_4[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM,
|
|
[0x7] = INAT_MAKE_IMM(INAT_IMM_BYTE),
|
|
};
|
|
|
|
/* GrpTable: Grp11B */
|
|
const insn_attr_t inat_group_table_5[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MAKE_IMM(INAT_IMM_VWORD32) | INAT_MODRM,
|
|
[0x7] = INAT_MAKE_IMM(INAT_IMM_VWORD32),
|
|
};
|
|
|
|
/* GrpTable: Grp12 */
|
|
const insn_attr_t inat_group_table_14[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x4] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_group_table_14_1[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x4] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
};
|
|
|
|
/* GrpTable: Grp13 */
|
|
const insn_attr_t inat_group_table_15[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x4] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_group_table_15_1[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x4] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
};
|
|
|
|
/* GrpTable: Grp14 */
|
|
const insn_attr_t inat_group_table_16[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x3] = INAT_VARIANT,
|
|
[0x6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VARIANT,
|
|
[0x7] = INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_group_table_16_1[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x2] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x3] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x6] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
[0x7] = INAT_MAKE_IMM(INAT_IMM_BYTE) | INAT_MODRM | INAT_VEXOK,
|
|
};
|
|
|
|
/* GrpTable: Grp15 */
|
|
const insn_attr_t inat_group_table_19[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_VARIANT,
|
|
[0x1] = INAT_VARIANT,
|
|
[0x2] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
[0x3] = INAT_MODRM | INAT_VEXOK | INAT_VARIANT,
|
|
};
|
|
const insn_attr_t inat_group_table_19_2[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MODRM,
|
|
[0x1] = INAT_MODRM,
|
|
[0x2] = INAT_MODRM,
|
|
[0x3] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp16 */
|
|
const insn_attr_t inat_group_table_13[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x0] = INAT_MODRM,
|
|
[0x1] = INAT_MODRM,
|
|
[0x2] = INAT_MODRM,
|
|
[0x3] = INAT_MODRM,
|
|
};
|
|
|
|
/* GrpTable: Grp17 */
|
|
const insn_attr_t inat_group_table_23[INAT_GROUP_TABLE_SIZE] = {
|
|
[0x1] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x2] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
[0x3] = INAT_MODRM | INAT_VEXOK | INAT_VEXONLY,
|
|
};
|
|
|
|
/* GrpTable: GrpP */
|
|
|
|
/* GrpTable: GrpPDLK */
|
|
|
|
/* GrpTable: GrpRNG */
|
|
|
|
/* Escape opcode map array */
|
|
const insn_attr_t * const inat_escape_tables[INAT_ESC_MAX + 1][INAT_LSTPFX_MAX + 1] = {
|
|
[1][0] = inat_escape_table_1,
|
|
[1][1] = inat_escape_table_1_1,
|
|
[1][2] = inat_escape_table_1_2,
|
|
[1][3] = inat_escape_table_1_3,
|
|
[2][0] = inat_escape_table_2,
|
|
[2][1] = inat_escape_table_2_1,
|
|
[2][2] = inat_escape_table_2_2,
|
|
[2][3] = inat_escape_table_2_3,
|
|
[3][0] = inat_escape_table_3,
|
|
[3][1] = inat_escape_table_3_1,
|
|
[3][3] = inat_escape_table_3_3,
|
|
};
|
|
|
|
/* Group opcode map array */
|
|
const insn_attr_t * const inat_group_tables[INAT_GRP_MAX + 1][INAT_LSTPFX_MAX + 1] = {
|
|
[4][0] = inat_group_table_4,
|
|
[5][0] = inat_group_table_5,
|
|
[6][0] = inat_group_table_6,
|
|
[7][0] = inat_group_table_7,
|
|
[8][0] = inat_group_table_8,
|
|
[9][0] = inat_group_table_9,
|
|
[10][0] = inat_group_table_10,
|
|
[11][0] = inat_group_table_11,
|
|
[13][0] = inat_group_table_13,
|
|
[14][0] = inat_group_table_14,
|
|
[14][1] = inat_group_table_14_1,
|
|
[15][0] = inat_group_table_15,
|
|
[15][1] = inat_group_table_15_1,
|
|
[16][0] = inat_group_table_16,
|
|
[16][1] = inat_group_table_16_1,
|
|
[19][0] = inat_group_table_19,
|
|
[19][2] = inat_group_table_19_2,
|
|
[22][0] = inat_group_table_22,
|
|
[22][1] = inat_group_table_22_1,
|
|
[22][2] = inat_group_table_22_2,
|
|
[23][0] = inat_group_table_23,
|
|
};
|
|
|
|
/* AVX opcode map array */
|
|
const insn_attr_t * const inat_avx_tables[X86_VEX_M_MAX + 1][INAT_LSTPFX_MAX + 1] = {
|
|
[1][0] = inat_escape_table_1,
|
|
[1][1] = inat_escape_table_1_1,
|
|
[1][2] = inat_escape_table_1_2,
|
|
[1][3] = inat_escape_table_1_3,
|
|
[2][0] = inat_escape_table_2,
|
|
[2][1] = inat_escape_table_2_1,
|
|
[2][2] = inat_escape_table_2_2,
|
|
[2][3] = inat_escape_table_2_3,
|
|
[3][0] = inat_escape_table_3,
|
|
[3][1] = inat_escape_table_3_1,
|
|
[3][3] = inat_escape_table_3_3,
|
|
};
|