/* 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, };