x86: simplify decode of opcodes valid with (embedded) 66 prefix only

The only valid (embedded or explicit) prefix being the data size one
(which is a fairly common pattern), avoid going through prefix_table[].
Instead extend the "required prefix" logic to also handle PREFIX_DATA
alone in a table entry, now used to identify this case. This requires
moving the (adjusted) ->prefix_requirement logic ahead of the printing
of stray prefixes, as the latter needs to observe the new setting of
PREFIX_DATA in used_prefixes.

Also add PREFIX_OPCODE on related entries when previously there was
mistakenly no decode step through prefix_table[].
This commit is contained in:
Jan Beulich 2020-07-14 10:33:40 +02:00
parent 17d3c7eccd
commit 7531c61332
10 changed files with 1650 additions and 4912 deletions

View File

@ -1,3 +1,7 @@
2020-07-14 Jan Beulich <jbeulich@suse.com>
* testsuite/gas/i386/prefix.d: Adjust expectations.
2020-07-14 Jan Beulich <jbeulich@suse.com>
* testsuite/gas/i386/x86-64-avx-intel.d,

View File

@ -14,9 +14,9 @@ Disassembly of section .text:
[ ]*[a-f0-9]+: 26 9b es fwait
[ ]*[a-f0-9]+: 9b fwait
[ ]*[a-f0-9]+: 65 c7 05 00 00 00 00 00 00 00 00 movl \$0x0,%gs:0x0
[ ]*[a-f0-9]+: 66 f2 0f 38 17 data16 \(bad\)
[ ]*[a-f0-9]+: f2 66 0f 54 repnz \(bad\)
[ ]*[a-f0-9]+: f2 0f 54 repnz \(bad\)
[ ]*[a-f0-9]+: 66 f2 0f 38 17 \(bad\)
[ ]*[a-f0-9]+: f2 66 0f 54 \(bad\)
[ ]*[a-f0-9]+: f2 0f 54 \(bad\)
[ ]*[a-f0-9]+: f2 66 0f 11 22 data16 movsd %xmm4,\(%edx\)
[ ]*[a-f0-9]+: f2 67 66 0f 11 22 data16 movsd %xmm4,\(%bp,%si\)
[ ]*[a-f0-9]+: f2 67 f0 66 0f 11 22 lock data16 movsd %xmm4,\(%bp,%si\)
@ -72,7 +72,7 @@ Disassembly of section .text:
[ ]*[a-f0-9]+: 90 nop
[ ]*[a-f0-9]+: f2 0f c7 \(bad\)
[ ]*[a-f0-9]+: f0 90 lock nop
[ ]*[a-f0-9]+: f3 0f 28 repz \(bad\) *
[ ]*[a-f0-9]+: f3 0f 28 \(bad\) *
[ ]*[a-f0-9]+: ff cc dec %esp
[ ]*[a-f0-9]+: c5 fa 28 \(bad\) *
[ ]*[a-f0-9]+: ff cc dec %esp

View File

@ -1,3 +1,341 @@
2020-07-14 Jan Beulich <jbeulich@suse.com>
* i386-dis.c (PREFIX_0F6C, PREFIX_0F6D, PREFIX_0F73_REG_3,
PREFIX_0F73_REG_7, PREFIX_0F3810, PREFIX_0F3814, PREFIX_0F3815,
PREFIX_0F3817, PREFIX_0F3820, PREFIX_0F3821, PREFIX_0F3822,
PREFIX_0F3823, PREFIX_0F3824, PREFIX_0F3825, PREFIX_0F3828,
PREFIX_0F3829, PREFIX_0F382A, PREFIX_0F382B, PREFIX_0F3830,
PREFIX_0F3831, PREFIX_0F3832, PREFIX_0F3833, PREFIX_0F3834,
PREFIX_0F3835, PREFIX_0F3837, PREFIX_0F3838, PREFIX_0F3839,
PREFIX_0F383A, PREFIX_0F383B, PREFIX_0F383C, PREFIX_0F383D,
PREFIX_0F383E, PREFIX_0F383F, PREFIX_0F3840, PREFIX_0F3841,
PREFIX_0F3880, PREFIX_0F3881, PREFIX_0F3882, PREFIX_0F38CF,
PREFIX_0F38DB, PREFIX_0F38DC, PREFIX_0F38DD, PREFIX_0F38DE,
PREFIX_0F38DF, PREFIX_0F38F5, PREFIX_0F3A08, PREFIX_0F3A09,
PREFIX_0F3A0A, PREFIX_0F3A0B, PREFIX_0F3A0C, PREFIX_0F3A0D,
PREFIX_0F3A0E, PREFIX_0F3A14, PREFIX_0F3A15, PREFIX_0F3A16,
PREFIX_0F3A17, PREFIX_0F3A20, PREFIX_0F3A21, PREFIX_0F3A22,
PREFIX_0F3A40, PREFIX_0F3A41, PREFIX_0F3A42, PREFIX_0F3A44,
PREFIX_0F3A60, PREFIX_0F3A61, PREFIX_0F3A62, PREFIX_0F3A63,
PREFIX_0F3ACE, PREFIX_0F3ACF, PREFIX_0F3ADF, PREFIX_VEX_0F60,
PREFIX_VEX_0F61, PREFIX_VEX_0F62, PREFIX_VEX_0F63,
PREFIX_VEX_0F64, PREFIX_VEX_0F65, PREFIX_VEX_0F66,
PREFIX_VEX_0F67, PREFIX_VEX_0F68, PREFIX_VEX_0F69,
PREFIX_VEX_0F6A, PREFIX_VEX_0F6B, PREFIX_VEX_0F6C,
PREFIX_VEX_0F6D, PREFIX_VEX_0F6E, PREFIX_VEX_0F71_REG_2,
PREFIX_VEX_0F71_REG_4, PREFIX_VEX_0F71_REG_6,
PREFIX_VEX_0F72_REG_2, PREFIX_VEX_0F72_REG_4,
PREFIX_VEX_0F72_REG_6, PREFIX_VEX_0F73_REG_2,
PREFIX_VEX_0F73_REG_3, PREFIX_VEX_0F73_REG_6,
PREFIX_VEX_0F73_REG_7, PREFIX_VEX_0F74,
PREFIX_VEX_0F75, PREFIX_VEX_0F76, PREFIX_VEX_0FC4,
PREFIX_VEX_0FC5, PREFIX_VEX_0FD1, PREFIX_VEX_0FD2,
PREFIX_VEX_0FD3, PREFIX_VEX_0FD4, PREFIX_VEX_0FD5,
PREFIX_VEX_0FD6, PREFIX_VEX_0FD7, PREFIX_VEX_0FD8,
PREFIX_VEX_0FD9, PREFIX_VEX_0FDA, PREFIX_VEX_0FDB,
PREFIX_VEX_0FDC, PREFIX_VEX_0FDD, PREFIX_VEX_0FDE,
PREFIX_VEX_0FDF, PREFIX_VEX_0FE0, PREFIX_VEX_0FE1,
PREFIX_VEX_0FE2, PREFIX_VEX_0FE3, PREFIX_VEX_0FE4,
PREFIX_VEX_0FE5, PREFIX_VEX_0FE7, PREFIX_VEX_0FE8,
PREFIX_VEX_0FE9, PREFIX_VEX_0FEA, PREFIX_VEX_0FEB,
PREFIX_VEX_0FEC, PREFIX_VEX_0FED, PREFIX_VEX_0FEE,
PREFIX_VEX_0FEF, PREFIX_VEX_0FF1, PREFIX_VEX_0FF2,
PREFIX_VEX_0FF3, PREFIX_VEX_0FF4, PREFIX_VEX_0FF5,
PREFIX_VEX_0FF6, PREFIX_VEX_0FF7, PREFIX_VEX_0FF8,
PREFIX_VEX_0FF9, PREFIX_VEX_0FFA, PREFIX_VEX_0FFB,
PREFIX_VEX_0FFC, PREFIX_VEX_0FFD, PREFIX_VEX_0FFE,
PREFIX_VEX_0F3800, PREFIX_VEX_0F3801, PREFIX_VEX_0F3802,
PREFIX_VEX_0F3803, PREFIX_VEX_0F3804, PREFIX_VEX_0F3805,
PREFIX_VEX_0F3806, PREFIX_VEX_0F3807, PREFIX_VEX_0F3808,
PREFIX_VEX_0F3809, PREFIX_VEX_0F380A, PREFIX_VEX_0F380B,
PREFIX_VEX_0F380C, PREFIX_VEX_0F380D, PREFIX_VEX_0F380E,
PREFIX_VEX_0F380F, PREFIX_VEX_0F3813, PREFIX_VEX_0F3816,
PREFIX_VEX_0F3817, PREFIX_VEX_0F3818, PREFIX_VEX_0F3819,
PREFIX_VEX_0F381A, PREFIX_VEX_0F381C, PREFIX_VEX_0F381D,
PREFIX_VEX_0F381E, PREFIX_VEX_0F3820, PREFIX_VEX_0F3821,
PREFIX_VEX_0F3822, PREFIX_VEX_0F3823, PREFIX_VEX_0F3824,
PREFIX_VEX_0F3825, PREFIX_VEX_0F3828, PREFIX_VEX_0F3829,
PREFIX_VEX_0F382A, PREFIX_VEX_0F382B, PREFIX_VEX_0F382C,
PREFIX_VEX_0F382D, PREFIX_VEX_0F382E, PREFIX_VEX_0F382F,
PREFIX_VEX_0F3830, PREFIX_VEX_0F3831, PREFIX_VEX_0F3832,
PREFIX_VEX_0F3833, PREFIX_VEX_0F3834, PREFIX_VEX_0F3835,
PREFIX_VEX_0F3836, PREFIX_VEX_0F3837, PREFIX_VEX_0F3838,
PREFIX_VEX_0F3839, PREFIX_VEX_0F383A, PREFIX_VEX_0F383B,
PREFIX_VEX_0F383C, PREFIX_VEX_0F383D, PREFIX_VEX_0F383E,
PREFIX_VEX_0F383F, PREFIX_VEX_0F3840, PREFIX_VEX_0F3841,
PREFIX_VEX_0F3845, PREFIX_VEX_0F3846, PREFIX_VEX_0F3847,
PREFIX_VEX_0F3858, PREFIX_VEX_0F3859, PREFIX_VEX_0F385A,
PREFIX_VEX_0F3878, PREFIX_VEX_0F3879, PREFIX_VEX_0F388C,
PREFIX_VEX_0F388E, PREFIX_VEX_0F3890, PREFIX_VEX_0F3891,
PREFIX_VEX_0F3892, PREFIX_VEX_0F3893, PREFIX_VEX_0F3896,
PREFIX_VEX_0F3897, PREFIX_VEX_0F3898, PREFIX_VEX_0F3899,
PREFIX_VEX_0F389A, PREFIX_VEX_0F389B, PREFIX_VEX_0F389C,
PREFIX_VEX_0F389D, PREFIX_VEX_0F389E, PREFIX_VEX_0F389F,
PREFIX_VEX_0F38A6, PREFIX_VEX_0F38A7, PREFIX_VEX_0F38A8,
PREFIX_VEX_0F38A9, PREFIX_VEX_0F38AA, PREFIX_VEX_0F38AB,
PREFIX_VEX_0F38AC, PREFIX_VEX_0F38AD, PREFIX_VEX_0F38AE,
PREFIX_VEX_0F38AF, PREFIX_VEX_0F38B6, PREFIX_VEX_0F38B7,
PREFIX_VEX_0F38B8, PREFIX_VEX_0F38B9, PREFIX_VEX_0F38BA,
PREFIX_VEX_0F38BB, PREFIX_VEX_0F38BC, PREFIX_VEX_0F38BD,
PREFIX_VEX_0F38BE, PREFIX_VEX_0F38BF, PREFIX_VEX_0F38CF,
PREFIX_VEX_0F38DB, PREFIX_VEX_0F38DC, PREFIX_VEX_0F38DD,
PREFIX_VEX_0F38DE, PREFIX_VEX_0F38DF, PREFIX_VEX_0F3A00,
PREFIX_VEX_0F3A01, PREFIX_VEX_0F3A02, PREFIX_VEX_0F3A04,
PREFIX_VEX_0F3A05, PREFIX_VEX_0F3A06, PREFIX_VEX_0F3A08,
PREFIX_VEX_0F3A09, PREFIX_VEX_0F3A0A, PREFIX_VEX_0F3A0B,
PREFIX_VEX_0F3A0C, PREFIX_VEX_0F3A0D, PREFIX_VEX_0F3A0E,
PREFIX_VEX_0F3A0F, PREFIX_VEX_0F3A14, PREFIX_VEX_0F3A15,
PREFIX_VEX_0F3A16, PREFIX_VEX_0F3A17, PREFIX_VEX_0F3A18,
PREFIX_VEX_0F3A19, PREFIX_VEX_0F3A1D, PREFIX_VEX_0F3A20,
PREFIX_VEX_0F3A21, PREFIX_VEX_0F3A22, PREFIX_VEX_0F3A30,
PREFIX_VEX_0F3A31, PREFIX_VEX_0F3A32, PREFIX_VEX_0F3A33,
PREFIX_VEX_0F3A38, PREFIX_VEX_0F3A39, PREFIX_VEX_0F3A40,
PREFIX_VEX_0F3A41, PREFIX_VEX_0F3A42, PREFIX_VEX_0F3A44,
PREFIX_VEX_0F3A46, PREFIX_VEX_0F3A48, PREFIX_VEX_0F3A49,
PREFIX_VEX_0F3A4A, PREFIX_VEX_0F3A4B, PREFIX_VEX_0F3A4C,
PREFIX_VEX_0F3A5C, PREFIX_VEX_0F3A5D, PREFIX_VEX_0F3A5E,
PREFIX_VEX_0F3A5F, PREFIX_VEX_0F3A60, PREFIX_VEX_0F3A61,
PREFIX_VEX_0F3A62, PREFIX_VEX_0F3A63, PREFIX_VEX_0F3A68,
PREFIX_VEX_0F3A69, PREFIX_VEX_0F3A6A, PREFIX_VEX_0F3A6B,
PREFIX_VEX_0F3A6C, PREFIX_VEX_0F3A6D, PREFIX_VEX_0F3A6E,
PREFIX_VEX_0F3A6F, PREFIX_VEX_0F3A78, PREFIX_VEX_0F3A79,
PREFIX_VEX_0F3A7A, PREFIX_VEX_0F3A7B, PREFIX_VEX_0F3A7C,
PREFIX_VEX_0F3A7D, PREFIX_VEX_0F3A7E, PREFIX_VEX_0F3A7F,
PREFIX_VEX_0F3ACE, PREFIX_VEX_0F3ACF, PREFIX_VEX_0F3ADF,
PREFIX_EVEX_0F64, PREFIX_EVEX_0F65, PREFIX_EVEX_0F66,
PREFIX_EVEX_0F6E, PREFIX_EVEX_0F71_REG_2,
PREFIX_EVEX_0F71_REG_4, PREFIX_EVEX_0F71_REG_6,
PREFIX_EVEX_0F72_REG_0, PREFIX_EVEX_0F72_REG_1,
PREFIX_EVEX_0F72_REG_2, PREFIX_EVEX_0F72_REG_4,
PREFIX_EVEX_0F72_REG_6, PREFIX_EVEX_0F73_REG_2,
PREFIX_EVEX_0F73_REG_3, PREFIX_EVEX_0F73_REG_6,
PREFIX_EVEX_0F73_REG_7, PREFIX_EVEX_0F74, PREFIX_EVEX_0F75,
PREFIX_EVEX_0F76, PREFIX_EVEX_0FC4, PREFIX_EVEX_0FC5,
PREFIX_EVEX_0FD6, PREFIX_EVEX_0FDB, PREFIX_EVEX_0FDF,
PREFIX_EVEX_0FE2, PREFIX_EVEX_0FE7, PREFIX_EVEX_0FEB,
PREFIX_EVEX_0FEF, PREFIX_EVEX_0F380D, PREFIX_EVEX_0F3816,
PREFIX_EVEX_0F3819, PREFIX_EVEX_0F381A, PREFIX_EVEX_0F381B,
PREFIX_EVEX_0F381E, PREFIX_EVEX_0F381F, PREFIX_EVEX_0F382C,
PREFIX_EVEX_0F382D, PREFIX_EVEX_0F3836, PREFIX_EVEX_0F3837,
PREFIX_EVEX_0F383B, PREFIX_EVEX_0F383D, PREFIX_EVEX_0F383F,
PREFIX_EVEX_0F3840, PREFIX_EVEX_0F3842, PREFIX_EVEX_0F3843,
PREFIX_EVEX_0F3844, PREFIX_EVEX_0F3845, PREFIX_EVEX_0F3846,
PREFIX_EVEX_0F3847, PREFIX_EVEX_0F384C, PREFIX_EVEX_0F384D,
PREFIX_EVEX_0F384E, PREFIX_EVEX_0F384F, PREFIX_EVEX_0F3850,
PREFIX_EVEX_0F3851, PREFIX_EVEX_0F3854, PREFIX_EVEX_0F3855,
PREFIX_EVEX_0F3859, PREFIX_EVEX_0F385A, PREFIX_EVEX_0F385B,
PREFIX_EVEX_0F3862, PREFIX_EVEX_0F3863, PREFIX_EVEX_0F3864,
PREFIX_EVEX_0F3865, PREFIX_EVEX_0F3866, PREFIX_EVEX_0F3870,
PREFIX_EVEX_0F3871, PREFIX_EVEX_0F3873, PREFIX_EVEX_0F3875,
PREFIX_EVEX_0F3876, PREFIX_EVEX_0F3877, PREFIX_EVEX_0F387A,
PREFIX_EVEX_0F387B, PREFIX_EVEX_0F387C, PREFIX_EVEX_0F387D,
PREFIX_EVEX_0F387E, PREFIX_EVEX_0F387F, PREFIX_EVEX_0F3883,
PREFIX_EVEX_0F3888, PREFIX_EVEX_0F3889, PREFIX_EVEX_0F388A,
PREFIX_EVEX_0F388B, PREFIX_EVEX_0F388D, PREFIX_EVEX_0F388F,
PREFIX_EVEX_0F3890, PREFIX_EVEX_0F3891, PREFIX_EVEX_0F3892,
PREFIX_EVEX_0F3893, PREFIX_EVEX_0F38A0, PREFIX_EVEX_0F38A1,
PREFIX_EVEX_0F38A2, PREFIX_EVEX_0F38A3, PREFIX_EVEX_0F38B4,
PREFIX_EVEX_0F38B5, PREFIX_EVEX_0F38C4,
PREFIX_EVEX_0F38C6_REG_1, PREFIX_EVEX_0F38C6_REG_2,
PREFIX_EVEX_0F38C6_REG_5, PREFIX_EVEX_0F38C6_REG_6,
PREFIX_EVEX_0F38C7_REG_1, PREFIX_EVEX_0F38C7_REG_2,
PREFIX_EVEX_0F38C7_REG_5, PREFIX_EVEX_0F38C7_REG_6,
PREFIX_EVEX_0F38C8, PREFIX_EVEX_0F38CA, PREFIX_EVEX_0F38CB,
PREFIX_EVEX_0F38CC, PREFIX_EVEX_0F38CD, PREFIX_EVEX_0F3A00,
PREFIX_EVEX_0F3A01, PREFIX_EVEX_0F3A03, PREFIX_EVEX_0F3A05,
PREFIX_EVEX_0F3A08, PREFIX_EVEX_0F3A09, PREFIX_EVEX_0F3A0A,
PREFIX_EVEX_0F3A0B, PREFIX_EVEX_0F3A14, PREFIX_EVEX_0F3A15,
PREFIX_EVEX_0F3A16, PREFIX_EVEX_0F3A17, PREFIX_EVEX_0F3A18,
PREFIX_EVEX_0F3A19, PREFIX_EVEX_0F3A1A, PREFIX_EVEX_0F3A1B,
PREFIX_EVEX_0F3A1E, PREFIX_EVEX_0F3A1F, PREFIX_EVEX_0F3A20,
PREFIX_EVEX_0F3A21, PREFIX_EVEX_0F3A22, PREFIX_EVEX_0F3A23,
PREFIX_EVEX_0F3A25, PREFIX_EVEX_0F3A26, PREFIX_EVEX_0F3A27,
PREFIX_EVEX_0F3A38, PREFIX_EVEX_0F3A39, PREFIX_EVEX_0F3A3A,
PREFIX_EVEX_0F3A3B, PREFIX_EVEX_0F3A3E, PREFIX_EVEX_0F3A3F,
PREFIX_EVEX_0F3A42, PREFIX_EVEX_0F3A43, PREFIX_EVEX_0F3A50,
PREFIX_EVEX_0F3A51, PREFIX_EVEX_0F3A54, PREFIX_EVEX_0F3A55,
PREFIX_EVEX_0F3A56, PREFIX_EVEX_0F3A57, PREFIX_EVEX_0F3A66,
PREFIX_EVEX_0F3A67, PREFIX_EVEX_0F3A70, PREFIX_EVEX_0F3A71,
PREFIX_EVEX_0F3A72, PREFIX_EVEX_0F3A73): Delete.
(MOD_0F382A_PREFIX_2, MOD_0F38F5_PREFIX_2,
MOD_VEX_0FD7_PREFIX_2, MOD_VEX_0FE7_PREFIX_2,
MOD_VEX_0F381A_PREFIX_2, MOD_VEX_0F382A_PREFIX_2,
MOD_VEX_0F382C_PREFIX_2, MOD_VEX_0F382D_PREFIX_2,
MOD_VEX_0F382E_PREFIX_2, MOD_VEX_0F382F_PREFIX_2,
MOD_VEX_0F385A_PREFIX_2, MOD_VEX_0F388C_PREFIX_2,
MOD_VEX_0F388E_PREFIX_2, MOD_VEX_W_0_0F3A30_P_2_LEN_0,
MOD_VEX_W_1_0F3A30_P_2_LEN_0, MOD_VEX_W_0_0F3A31_P_2_LEN_0,
MOD_VEX_W_1_0F3A31_P_2_LEN_0, MOD_VEX_W_0_0F3A32_P_2_LEN_0,
MOD_VEX_W_1_0F3A32_P_2_LEN_0, MOD_VEX_W_0_0F3A33_P_2_LEN_0,
MOD_VEX_W_1_0F3A33_P_2_LEN_0, MOD_EVEX_0F381A_P_2_W_0,
MOD_EVEX_0F381A_P_2_W_1, MOD_EVEX_0F381B_P_2_W_0,
MOD_EVEX_0F381B_P_2_W_1, MOD_EVEX_0F385A_P_2_W_0,
MOD_EVEX_0F385A_P_2_W_1, MOD_EVEX_0F385B_P_2_W_0,
MOD_EVEX_0F385B_P_2_W_1, VEX_LEN_0F6E_P_2,
VEX_LEN_0FC4_P_2, VEX_LEN_0FC5_P_2, VEX_LEN_0FD6_P_2,
VEX_LEN_0FF7_P_2, VEX_LEN_0F3816_P_2, VEX_LEN_0F3819_P_2,
VEX_LEN_0F381A_P_2_M_0, VEX_LEN_0F3836_P_2,
VEX_LEN_0F3841_P_2, VEX_LEN_0F385A_P_2_M_0,
VEX_LEN_0F38DB_P_2, VEX_LEN_0F3A00_P_2, VEX_LEN_0F3A01_P_2,
VEX_LEN_0F3A06_P_2, VEX_LEN_0F3A14_P_2, VEX_LEN_0F3A15_P_2,
VEX_LEN_0F3A16_P_2, VEX_LEN_0F3A17_P_2, VEX_LEN_0F3A18_P_2,
VEX_LEN_0F3A19_P_2, VEX_LEN_0F3A20_P_2, VEX_LEN_0F3A21_P_2,
VEX_LEN_0F3A22_P_2, VEX_LEN_0F3A30_P_2, VEX_LEN_0F3A31_P_2,
VEX_LEN_0F3A32_P_2, VEX_LEN_0F3A33_P_2, VEX_LEN_0F3A38_P_2,
VEX_LEN_0F3A39_P_2, VEX_LEN_0F3A41_P_2, VEX_LEN_0F3A46_P_2,
VEX_LEN_0F3A60_P_2, VEX_LEN_0F3A61_P_2, VEX_LEN_0F3A62_P_2,
VEX_LEN_0F3A63_P_2, VEX_LEN_0F3ADF_P_2, EVEX_LEN_0F6E_P_2,
EVEX_LEN_0FC4_P_2, EVEX_LEN_0FC5_P_2, EVEX_LEN_0FD6_P_2,
EVEX_LEN_0F3816_P_2, EVEX_LEN_0F3819_P_2_W_0,
EVEX_LEN_0F3819_P_2_W_1, EVEX_LEN_0F381A_P_2_W_0_M_0,
EVEX_LEN_0F381A_P_2_W_1_M_0, EVEX_LEN_0F381B_P_2_W_0_M_0,
EVEX_LEN_0F381B_P_2_W_1_M_0, EVEX_LEN_0F3836_P_2,
EVEX_LEN_0F385A_P_2_W_0_M_0, EVEX_LEN_0F385A_P_2_W_1_M_0,
EVEX_LEN_0F385B_P_2_W_0_M_0, EVEX_LEN_0F385B_P_2_W_1_M_0,
EVEX_LEN_0F38C6_REG_1_PREFIX_2, EVEX_LEN_0F38C6_REG_2_PREFIX_2,
EVEX_LEN_0F38C6_REG_5_PREFIX_2, EVEX_LEN_0F38C6_REG_6_PREFIX_2,
EVEX_LEN_0F38C7_R_1_P_2_W_0, EVEX_LEN_0F38C7_R_1_P_2_W_1,
EVEX_LEN_0F38C7_R_2_P_2_W_0, EVEX_LEN_0F38C7_R_2_P_2_W_1,
EVEX_LEN_0F38C7_R_5_P_2_W_0, EVEX_LEN_0F38C7_R_5_P_2_W_1,
EVEX_LEN_0F38C7_R_6_P_2_W_0, EVEX_LEN_0F38C7_R_6_P_2_W_1,
EVEX_LEN_0F3A00_P_2_W_1, EVEX_LEN_0F3A01_P_2_W_1,
EVEX_LEN_0F3A14_P_2, EVEX_LEN_0F3A15_P_2, EVEX_LEN_0F3A16_P_2,
EVEX_LEN_0F3A17_P_2, EVEX_LEN_0F3A18_P_2_W_0,
EVEX_LEN_0F3A18_P_2_W_1, EVEX_LEN_0F3A19_P_2_W_0,
EVEX_LEN_0F3A19_P_2_W_1, EVEX_LEN_0F3A1A_P_2_W_0,
EVEX_LEN_0F3A1A_P_2_W_1, EVEX_LEN_0F3A1B_P_2_W_0,
EVEX_LEN_0F3A1B_P_2_W_1, EVEX_LEN_0F3A20_P_2,
EVEX_LEN_0F3A21_P_2_W_0, EVEX_LEN_0F3A22_P_2,
EVEX_LEN_0F3A23_P_2_W_0, EVEX_LEN_0F3A23_P_2_W_1,
EVEX_LEN_0F3A38_P_2_W_0, EVEX_LEN_0F3A38_P_2_W_1,
EVEX_LEN_0F3A39_P_2_W_0, EVEX_LEN_0F3A39_P_2_W_1,
EVEX_LEN_0F3A3A_P_2_W_0, EVEX_LEN_0F3A3A_P_2_W_1,
EVEX_LEN_0F3A3B_P_2_W_0, EVEX_LEN_0F3A3B_P_2_W_1,
EVEX_LEN_0F3A43_P_2_W_0, EVEX_LEN_0F3A43_P_2_W_1
VEX_W_0F380C_P_2, VEX_W_0F380D_P_2, VEX_W_0F380E_P_2,
VEX_W_0F380F_P_2, VEX_W_0F3813_P_2, VEX_W_0F3816_P_2,
VEX_W_0F3818_P_2, VEX_W_0F3819_P_2,
VEX_W_0F381A_P_2_M_0_L_0, VEX_W_0F382C_P_2_M_0,
VEX_W_0F382D_P_2_M_0, VEX_W_0F382E_P_2_M_0,
VEX_W_0F382F_P_2_M_0, VEX_W_0F3836_P_2,
VEX_W_0F3846_P_2, VEX_W_0F3858_P_2, VEX_W_0F3859_P_2,
VEX_W_0F385A_P_2_M_0_L_0, VEX_W_0F3878_P_2,
VEX_W_0F3879_P_2, VEX_W_0F38CF_P_2, VEX_W_0F3A00_P_2,
VEX_W_0F3A01_P_2, VEX_W_0F3A02_P_2, VEX_W_0F3A04_P_2,
VEX_W_0F3A05_P_2, VEX_W_0F3A06_P_2_L_0,
VEX_W_0F3A18_P_2_L_0, VEX_W_0F3A19_P_2_L_0,
VEX_W_0F3A1D_P_2, VEX_W_0F3A30_P_2_LEN_0,
VEX_W_0F3A31_P_2_LEN_0, VEX_W_0F3A32_P_2_LEN_0,
VEX_W_0F3A33_P_2_LEN_0, VEX_W_0F3A38_P_2_L_0,
VEX_W_0F3A39_P_2_L_0, VEX_W_0F3A46_P_2_L_0,
VEX_W_0F3A4A_P_2, VEX_W_0F3A4B_P_2, VEX_W_0F3A4C_P_2,
VEX_W_0F3ACE_P_2, VEX_W_0F3ACF_P_2, EVEX_W_0F66_P_2,
EVEX_W_0F72_R_2_P_2, EVEX_W_0F72_R_6_P_2,
EVEX_W_0F73_R_2_P_2, EVEX_W_0F73_R_6_P_2,
EVEX_W_0F76_P_2, EVEX_W_0FD6_P_2, EVEX_W_0FE7_P_2,
EVEX_W_0F380D_P_2, EVEX_W_0F3819_P_2,
EVEX_W_0F381A_P_2, EVEX_W_0F381B_P_2,
EVEX_W_0F381E_P_2, EVEX_W_0F381F_P_2,
EVEX_W_0F3837_P_2, EVEX_W_0F3859_P_2,
EVEX_W_0F385A_P_2, EVEX_W_0F385B_P_2,
EVEX_W_0F3870_P_2, EVEX_W_0F387A_P_2,
EVEX_W_0F387B_P_2, EVEX_W_0F3883_P_2,
EVEX_W_0F3891_P_2, EVEX_W_0F3893_P_2,
EVEX_W_0F38A1_P_2, EVEX_W_0F38A3_P_2,
EVEX_W_0F38C7_R_1_P_2, EVEX_W_0F38C7_R_2_P_2,
EVEX_W_0F38C7_R_5_P_2, EVEX_W_0F38C7_R_6_P_2,
EVEX_W_0F3A00_P_2, EVEX_W_0F3A01_P_2,
EVEX_W_0F3A05_P_2, EVEX_W_0F3A08_P_2,
EVEX_W_0F3A09_P_2, EVEX_W_0F3A0A_P_2,
EVEX_W_0F3A0B_P_2, EVEX_W_0F3A18_P_2,
EVEX_W_0F3A19_P_2, EVEX_W_0F3A1A_P_2,
EVEX_W_0F3A1B_P_2, EVEX_W_0F3A21_P_2,
EVEX_W_0F3A23_P_2, EVEX_W_0F3A38_P_2,
EVEX_W_0F3A39_P_2, EVEX_W_0F3A3A_P_2,
EVEX_W_0F3A3B_P_2, EVEX_W_0F3A42_P_2,
EVEX_W_0F3A43_P_2, EVEX_W_0F3A70_P_2,
EVEX_W_0F3A72_P_2): Rename to ...
(MOD_0F382A, MOD_0F38F5, MOD_VEX_0FD7, MOD_VEX_0FE7,
MOD_VEX_0F381A, MOD_VEX_0F382A, MOD_VEX_0F382C, MOD_VEX_0F382D,
MOD_VEX_0F382E, MOD_VEX_0F382F, MOD_VEX_0F385A, MOD_VEX_0F388C,
MOD_VEX_0F388E, MOD_VEX_0F3A30_L_0_W_0,
MOD_VEX_0F3A30_L_0_W_1, MOD_VEX_0F3A31_L_0_W_0,
MOD_VEX_0F3A31_L_0_W_1, MOD_VEX_0F3A32_L_0_W_0,
MOD_VEX_0F3A32_L_0_W_1, MOD_VEX_0F3A33_L_0_W_0,
MOD_VEX_0F3A33_L_0_W_1, MOD_EVEX_0F381A_W_0,
MOD_EVEX_0F381A_W_1, MOD_EVEX_0F381B_W_0, MOD_EVEX_0F381B_W_1,
MOD_EVEX_0F385A_W_0, MOD_EVEX_0F385A_W_1, MOD_EVEX_0F385B_W_0,
MOD_EVEX_0F385B_W_1, VEX_LEN_0F6E, VEX_LEN_0FC4, VEX_LEN_0FC5,
VEX_LEN_0FD6, VEX_LEN_0FF7, VEX_LEN_0F3816, VEX_LEN_0F3819,
VEX_LEN_0F381A_M_0, VEX_LEN_0F3836, VEX_LEN_0F3841,
VEX_LEN_0F385A_M_0, VEX_LEN_0F38DB, VEX_LEN_0F3A00,
VEX_LEN_0F3A01, VEX_LEN_0F3A06, VEX_LEN_0F3A14, VEX_LEN_0F3A15,
VEX_LEN_0F3A16, VEX_LEN_0F3A17, VEX_LEN_0F3A18, VEX_LEN_0F3A19,
VEX_LEN_0F3A20, VEX_LEN_0F3A21, VEX_LEN_0F3A22, VEX_LEN_0F3A30,
VEX_LEN_0F3A31, VEX_LEN_0F3A32, VEX_LEN_0F3A33, VEX_LEN_0F3A38,
VEX_LEN_0F3A39, VEX_LEN_0F3A41, VEX_LEN_0F3A46, VEX_LEN_0F3A60,
VEX_LEN_0F3A61, VEX_LEN_0F3A62, VEX_LEN_0F3A63, VEX_LEN_0F3ADF,
EVEX_LEN_0F6E, EVEX_LEN_0FC4, EVEX_LEN_0FC5, EVEX_LEN_0FD6,
EVEX_LEN_0F3816, EVEX_LEN_0F3819_W_0, EVEX_LEN_0F3819_W_1,
EVEX_LEN_0F381A_W_0_M_0, EVEX_LEN_0F381A_W_1_M_0,
EVEX_LEN_0F381B_W_0_M_0, EVEX_LEN_0F381B_W_1_M_0,
EVEX_LEN_0F3836, EVEX_LEN_0F385A_W_0_M_0,
EVEX_LEN_0F385A_W_1_M_0, EVEX_LEN_0F385B_W_0_M_0,
EVEX_LEN_0F385B_W_1_M_0, EVEX_LEN_0F38C6_R_1_M_0,
EVEX_LEN_0F38C6_R_2_M_0, EVEX_LEN_0F38C6_R_5_M_0,
EVEX_LEN_0F38C6_R_6_M_0, EVEX_LEN_0F38C7_R_1_M_0_W_0,
EVEX_LEN_0F38C7_R_1_M_0_W_1, EVEX_LEN_0F38C7_R_2_M_0_W_0,
EVEX_LEN_0F38C7_R_2_M_0_W_1, EVEX_LEN_0F38C7_R_5_M_0_W_0,
EVEX_LEN_0F38C7_R_5_M_0_W_1, EVEX_LEN_0F38C7_R_6_M_0_W_0,
EVEX_LEN_0F38C7_R_6_M_0_W_1, EVEX_LEN_0F3A00_W_1,
EVEX_LEN_0F3A01_W_1, EVEX_LEN_0F3A14, EVEX_LEN_0F3A15,
EVEX_LEN_0F3A16, EVEX_LEN_0F3A17, EVEX_LEN_0F3A18_W_0,
EVEX_LEN_0F3A18_W_1, EVEX_LEN_0F3A19_W_0,
EVEX_LEN_0F3A19_W_1, EVEX_LEN_0F3A1A_W_0,
EVEX_LEN_0F3A1A_W_1, EVEX_LEN_0F3A1B_W_0,
EVEX_LEN_0F3A1B_W_1, EVEX_LEN_0F3A20, EVEX_LEN_0F3A21_W_0,
EVEX_LEN_0F3A22, EVEX_LEN_0F3A23_W_0, EVEX_LEN_0F3A23_W_1,
EVEX_LEN_0F3A38_W_0, EVEX_LEN_0F3A38_W_1,
EVEX_LEN_0F3A39_W_0, EVEX_LEN_0F3A39_W_1,
EVEX_LEN_0F3A3A_W_0, EVEX_LEN_0F3A3A_W_1,
EVEX_LEN_0F3A3B_W_0, EVEX_LEN_0F3A3B_W_1,
EVEX_LEN_0F3A43_W_0, EVEX_LEN_0F3A43_W_1
VEX_W_0F380C, VEX_W_0F380D, VEX_W_0F380E, VEX_W_0F380F,
VEX_W_0F3813, VEX_W_0F3816_L_1, VEX_W_0F3818,
VEX_W_0F3819_L_1, VEX_W_0F381A_M_0_L_1, VEX_W_0F382C_M_0,
VEX_W_0F382D_M_0, VEX_W_0F382E_M_0, VEX_W_0F382F_M_0,
VEX_W_0F3836, VEX_W_0F3846, VEX_W_0F3858, VEX_W_0F3859,
VEX_W_0F385A_M_0_L_0, VEX_W_0F3878, VEX_W_0F3879,
VEX_W_0F38CF, VEX_W_0F3A00_L_1, VEX_W_0F3A01_L_1,
VEX_W_0F3A02, VEX_W_0F3A04, VEX_W_0F3A05, VEX_W_0F3A06_L_1,
VEX_W_0F3A18_L_1, VEX_W_0F3A19_L_1, VEX_W_0F3A1D,
VEX_W_0F3A30_L_0, VEX_W_0F3A31_L_0, VEX_W_0F3A32_L_0,
VEX_W_0F3A33_L_0, VEX_W_0F3A38_L_1, VEX_W_0F3A39_L_1,
VEX_W_0F3A46_L_1, VEX_W_0F3A4A, VEX_W_0F3A4B, VEX_W_0F3A4C,
VEX_W_0F3ACE, VEX_W_0F3ACF, EVEX_W_0F66, EVEX_W_0F72_R_2,
EVEX_W_0F72_R_6, EVEX_W_0F73_R_2, EVEX_W_0F73_R_6,
EVEX_W_0F76, EVEX_W_0FD6_L_0, EVEX_W_0FE7, EVEX_W_0F380D,
EVEX_W_0F3819, EVEX_W_0F381A, EVEX_W_0F381B, EVEX_W_0F381E,
EVEX_W_0F381F, EVEX_W_0F3837, EVEX_W_0F3859, EVEX_W_0F385A,
EVEX_W_0F385B, EVEX_W_0F3870, EVEX_W_0F387A, EVEX_W_0F387B,
EVEX_W_0F3883, EVEX_W_0F3891, EVEX_W_0F3893, EVEX_W_0F38A1,
EVEX_W_0F38A3, EVEX_W_0F38C7_R_1_M_0,
EVEX_W_0F38C7_R_2_M_0, EVEX_W_0F38C7_R_5_M_0,
EVEX_W_0F38C7_R_6_M_0, EVEX_W_0F3A00, EVEX_W_0F3A01,
EVEX_W_0F3A05, EVEX_W_0F3A08, EVEX_W_0F3A09, EVEX_W_0F3A0A,
EVEX_W_0F3A0B, EVEX_W_0F3A18, EVEX_W_0F3A19, EVEX_W_0F3A1A,
EVEX_W_0F3A1B, EVEX_W_0F3A21, EVEX_W_0F3A23, EVEX_W_0F3A38,
EVEX_W_0F3A39, EVEX_W_0F3A3A, EVEX_W_0F3A3B, EVEX_W_0F3A42,
EVEX_W_0F3A43, EVEX_W_0F3A70, EVEX_W_0F3A72): ... these
respectively.
(dis386_twobyte, three_byte_table, vex_table, vex_len_table,
vex_w_table, mod_table): Replace / remove respective entries.
(print_insn): Move up dp->prefix_requirement handling. Handle
PREFIX_DATA.
* i386-dis-evex.h, i386-dis-evex-len.h, i386-dis-evex-mod.h,
i386-dis-evex-prefix.h, i386-dis-evex-reg.h, i386-dis-evex-w.h:
Replace / remove respective entries.
2020-07-14 Jan Beulich <jbeulich@suse.com>
* i386-dis.c (PREFIX_EVEX_0F2C, PREFIX_EVEX_0F2D,

View File

@ -1,7 +1,7 @@
static const struct dis386 evex_len_table[][3] = {
/* EVEX_LEN_0F6E_P_2 */
/* EVEX_LEN_0F6E */
{
{ "vmovK", { XMScalar, Edq }, 0 },
{ "vmovK", { XMScalar, Edq }, PREFIX_DATA },
},
/* EVEX_LEN_0F7E_P_1 */
@ -14,61 +14,61 @@ static const struct dis386 evex_len_table[][3] = {
{ "vmovK", { Edq, XMScalar }, 0 },
},
/* EVEX_LEN_0FC4_P_2 */
/* EVEX_LEN_0FC4 */
{
{ "vpinsrw", { XM, Vex, Edqw, Ib }, 0 },
{ "vpinsrw", { XM, Vex, Edqw, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0FC5_P_2 */
/* EVEX_LEN_0FC5 */
{
{ "vpextrw", { Gdq, XS, Ib }, 0 },
{ "vpextrw", { Gdq, XS, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0FD6_P_2 */
/* EVEX_LEN_0FD6 */
{
{ VEX_W_TABLE (EVEX_W_0FD6_P_2) },
{ VEX_W_TABLE (EVEX_W_0FD6_L_0) },
},
/* EVEX_LEN_0F3816_P_2 */
/* EVEX_LEN_0F3816 */
{
{ Bad_Opcode },
{ "vpermp%XW", { XM, Vex, EXx }, 0 },
{ "vpermp%XW", { XM, Vex, EXx }, 0 },
{ "vpermp%XW", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpermp%XW", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_LEN_0F3819_P_2_W_0 */
/* EVEX_LEN_0F3819_W_0 */
{
{ Bad_Opcode },
{ "vbroadcastf32x2", { XM, EXxmm_mq }, 0 },
{ "vbroadcastf32x2", { XM, EXxmm_mq }, 0 },
{ "vbroadcastf32x2", { XM, EXxmm_mq }, PREFIX_DATA },
{ "vbroadcastf32x2", { XM, EXxmm_mq }, PREFIX_DATA },
},
/* EVEX_LEN_0F3819_P_2_W_1 */
/* EVEX_LEN_0F3819_W_1 */
{
{ Bad_Opcode },
{ "vbroadcastsd", { XM, EXxmm_mq }, 0 },
{ "vbroadcastsd", { XM, EXxmm_mq }, 0 },
{ "vbroadcastsd", { XM, EXxmm_mq }, PREFIX_DATA },
{ "vbroadcastsd", { XM, EXxmm_mq }, PREFIX_DATA },
},
/* EVEX_LEN_0F381A_P_2_W_0_M_0 */
/* EVEX_LEN_0F381A_W_0_M_0 */
{
{ Bad_Opcode },
{ "vbroadcastf32x4", { XM, EXxmm }, 0 },
{ "vbroadcastf32x4", { XM, EXxmm }, 0 },
{ "vbroadcastf32x4", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcastf32x4", { XM, EXxmm }, PREFIX_DATA },
},
/* EVEX_LEN_0F381A_P_2_W_1_M_0 */
/* EVEX_LEN_0F381A_W_1_M_0 */
{
{ Bad_Opcode },
{ "vbroadcastf64x2", { XM, EXxmm }, 0 },
{ "vbroadcastf64x2", { XM, EXxmm }, 0 },
{ "vbroadcastf64x2", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcastf64x2", { XM, EXxmm }, PREFIX_DATA },
},
/* EVEX_LEN_0F381B_P_2_W_0_M_0 */
/* EVEX_LEN_0F381B_W_0_M_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vbroadcastf32x8", { XM, EXymm }, 0 },
{ "vbroadcastf32x8", { XM, EXymm }, PREFIX_DATA },
},
/* EVEX_LEN_0F381B_P_2_W_1_M_0 */
@ -78,311 +78,311 @@ static const struct dis386 evex_len_table[][3] = {
{ "vbroadcastf64x4", { XM, EXymm }, 0 },
},
/* EVEX_LEN_0F3836_P_2 */
/* EVEX_LEN_0F3836 */
{
{ Bad_Opcode },
{ "vperm%DQ", { XM, Vex, EXx }, 0 },
{ "vperm%DQ", { XM, Vex, EXx }, 0 },
{ "vperm%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vperm%DQ", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_LEN_0F385A_P_2_W_0_M_0 */
/* EVEX_LEN_0F385A_W_0_M_0 */
{
{ Bad_Opcode },
{ "vbroadcasti32x4", { XM, EXxmm }, 0 },
{ "vbroadcasti32x4", { XM, EXxmm }, 0 },
{ "vbroadcasti32x4", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcasti32x4", { XM, EXxmm }, PREFIX_DATA },
},
/* EVEX_LEN_0F385A_P_2_W_1_M_0 */
/* EVEX_LEN_0F385A_W_1_M_0 */
{
{ Bad_Opcode },
{ "vbroadcasti64x2", { XM, EXxmm }, 0 },
{ "vbroadcasti64x2", { XM, EXxmm }, 0 },
{ "vbroadcasti64x2", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcasti64x2", { XM, EXxmm }, PREFIX_DATA },
},
/* EVEX_LEN_0F385B_P_2_W_0_M_0 */
/* EVEX_LEN_0F385B_W_0_M_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vbroadcasti32x8", { XM, EXymm }, 0 },
{ "vbroadcasti32x8", { XM, EXymm }, PREFIX_DATA },
},
/* EVEX_LEN_0F385B_P_2_W_1_M_0 */
/* EVEX_LEN_0F385B_W_1_M_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vbroadcasti64x4", { XM, EXymm }, 0 },
{ "vbroadcasti64x4", { XM, EXymm }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C6_REG_1_PREFIX_2 */
/* EVEX_LEN_0F38C6_R_1_M_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgatherpf0dp%XW", { MVexVSIBDWpX }, 0 },
{ "vgatherpf0dp%XW", { MVexVSIBDWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C6_REG_2_PREFIX_2 */
/* EVEX_LEN_0F38C6_R_2_M_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgatherpf1dp%XW", { MVexVSIBDWpX }, 0 },
{ "vgatherpf1dp%XW", { MVexVSIBDWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C6_REG_5_PREFIX_2 */
/* EVEX_LEN_0F38C6_R_5_M_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscatterpf0dp%XW", { MVexVSIBDWpX }, 0 },
{ "vscatterpf0dp%XW", { MVexVSIBDWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C6_REG_6_PREFIX_2 */
/* EVEX_LEN_0F38C6_R_6_M_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscatterpf1dp%XW", { MVexVSIBDWpX }, 0 },
{ "vscatterpf1dp%XW", { MVexVSIBDWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_1_P_2_W_0 */
/* EVEX_LEN_0F38C7_R_1_M_0_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgatherpf0qps", { MVexVSIBDQWpX }, 0 },
{ "vgatherpf0qps", { MVexVSIBDQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_1_P_2_W_1 */
/* EVEX_LEN_0F38C7_R_1_M_0_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgatherpf0qpd", { MVexVSIBQWpX }, 0 },
{ "vgatherpf0qpd", { MVexVSIBQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_2_P_2_W_0 */
/* EVEX_LEN_0F38C7_R_2_M_0_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgatherpf1qps", { MVexVSIBDQWpX }, 0 },
{ "vgatherpf1qps", { MVexVSIBDQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_2_P_2_W_1 */
/* EVEX_LEN_0F38C7_R_2_M_0_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgatherpf1qpd", { MVexVSIBQWpX }, 0 },
{ "vgatherpf1qpd", { MVexVSIBQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_5_P_2_W_0 */
/* EVEX_LEN_0F38C7_R_5_M_0_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscatterpf0qps", { MVexVSIBDQWpX }, 0 },
{ "vscatterpf0qps", { MVexVSIBDQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_5_P_2_W_1 */
/* EVEX_LEN_0F38C7_R_5_M_0_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscatterpf0qpd", { MVexVSIBQWpX }, 0 },
{ "vscatterpf0qpd", { MVexVSIBQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_6_P_2_W_0 */
/* EVEX_LEN_0F38C7_R_6_M_0_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscatterpf1qps", { MVexVSIBDQWpX }, 0 },
{ "vscatterpf1qps", { MVexVSIBDQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F38C7_R_6_P_2_W_1 */
/* EVEX_LEN_0F38C7_R_6_M_0_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscatterpf1qpd", { MVexVSIBQWpX }, 0 },
{ "vscatterpf1qpd", { MVexVSIBQWpX }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A00_P_2_W_1 */
/* EVEX_LEN_0F3A00_W_1 */
{
{ Bad_Opcode },
{ "vpermq", { XM, EXx, Ib }, 0 },
{ "vpermq", { XM, EXx, Ib }, 0 },
{ "vpermq", { XM, EXx, Ib }, PREFIX_DATA },
{ "vpermq", { XM, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A01_P_2_W_1 */
/* EVEX_LEN_0F3A01_W_1 */
{
{ Bad_Opcode },
{ "vpermpd", { XM, EXx, Ib }, 0 },
{ "vpermpd", { XM, EXx, Ib }, 0 },
{ "vpermpd", { XM, EXx, Ib }, PREFIX_DATA },
{ "vpermpd", { XM, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A14_P_2 */
/* EVEX_LEN_0F3A14 */
{
{ "vpextrb", { Edqb, XM, Ib }, 0 },
{ "vpextrb", { Edqb, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A15_P_2 */
/* EVEX_LEN_0F3A15 */
{
{ "vpextrw", { Edqw, XM, Ib }, 0 },
{ "vpextrw", { Edqw, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A16_P_2 */
/* EVEX_LEN_0F3A16 */
{
{ "vpextrK", { Edq, XM, Ib }, 0 },
{ "vpextrK", { Edq, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A17_P_2 */
/* EVEX_LEN_0F3A17 */
{
{ "vextractps", { Edqd, XMM, Ib }, 0 },
{ "vextractps", { Edqd, XMM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A18_P_2_W_0 */
/* EVEX_LEN_0F3A18_W_0 */
{
{ Bad_Opcode },
{ "vinsertf32x4", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinsertf32x4", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinsertf32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinsertf32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A18_P_2_W_1 */
/* EVEX_LEN_0F3A18_W_1 */
{
{ Bad_Opcode },
{ "vinsertf64x2", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinsertf64x2", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinsertf64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinsertf64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A19_P_2_W_0 */
/* EVEX_LEN_0F3A19_W_0 */
{
{ Bad_Opcode },
{ "vextractf32x4", { EXxmm, XM, Ib }, 0 },
{ "vextractf32x4", { EXxmm, XM, Ib }, 0 },
{ "vextractf32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextractf32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A19_P_2_W_1 */
/* EVEX_LEN_0F3A19_W_1 */
{
{ Bad_Opcode },
{ "vextractf64x2", { EXxmm, XM, Ib }, 0 },
{ "vextractf64x2", { EXxmm, XM, Ib }, 0 },
{ "vextractf64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextractf64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A1A_P_2_W_0 */
/* EVEX_LEN_0F3A1A_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vinsertf32x8", { XM, Vex, EXymm, Ib }, 0 },
{ "vinsertf32x8", { XM, Vex, EXymm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A1A_P_2_W_1 */
/* EVEX_LEN_0F3A1A_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vinsertf64x4", { XM, Vex, EXymm, Ib }, 0 },
{ "vinsertf64x4", { XM, Vex, EXymm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A1B_P_2_W_0 */
/* EVEX_LEN_0F3A1B_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vextractf32x8", { EXymm, XM, Ib }, 0 },
{ "vextractf32x8", { EXymm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A1B_P_2_W_1 */
/* EVEX_LEN_0F3A1B_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vextractf64x4", { EXymm, XM, Ib }, 0 },
{ "vextractf64x4", { EXymm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A20_P_2 */
/* EVEX_LEN_0F3A20 */
{
{ "vpinsrb", { XM, Vex, Edqb, Ib }, 0 },
{ "vpinsrb", { XM, Vex, Edqb, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A21_P_2_W_0 */
/* EVEX_LEN_0F3A21_W_0 */
{
{ "vinsertps", { XMM, Vex, EXxmm_md, Ib }, 0 },
{ "vinsertps", { XMM, Vex, EXxmm_md, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A22_P_2 */
/* EVEX_LEN_0F3A22 */
{
{ "vpinsrK", { XM, Vex, Edq, Ib }, 0 },
{ "vpinsrK", { XM, Vex, Edq, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A23_P_2_W_0 */
/* EVEX_LEN_0F3A23_W_0 */
{
{ Bad_Opcode },
{ "vshuff32x4", { XM, Vex, EXx, Ib }, 0 },
{ "vshuff32x4", { XM, Vex, EXx, Ib }, 0 },
{ "vshuff32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshuff32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A23_P_2_W_1 */
/* EVEX_LEN_0F3A23_W_1 */
{
{ Bad_Opcode },
{ "vshuff64x2", { XM, Vex, EXx, Ib }, 0 },
{ "vshuff64x2", { XM, Vex, EXx, Ib }, 0 },
{ "vshuff64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshuff64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A38_P_2_W_0 */
/* EVEX_LEN_0F3A38_W_0 */
{
{ Bad_Opcode },
{ "vinserti32x4", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinserti32x4", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinserti32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinserti32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A38_P_2_W_1 */
/* EVEX_LEN_0F3A38_W_1 */
{
{ Bad_Opcode },
{ "vinserti64x2", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinserti64x2", { XM, Vex, EXxmm, Ib }, 0 },
{ "vinserti64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinserti64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A39_P_2_W_0 */
/* EVEX_LEN_0F3A39_W_0 */
{
{ Bad_Opcode },
{ "vextracti32x4", { EXxmm, XM, Ib }, 0 },
{ "vextracti32x4", { EXxmm, XM, Ib }, 0 },
{ "vextracti32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextracti32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A39_P_2_W_1 */
/* EVEX_LEN_0F3A39_W_1 */
{
{ Bad_Opcode },
{ "vextracti64x2", { EXxmm, XM, Ib }, 0 },
{ "vextracti64x2", { EXxmm, XM, Ib }, 0 },
{ "vextracti64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextracti64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A3A_P_2_W_0 */
/* EVEX_LEN_0F3A3A_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vinserti32x8", { XM, Vex, EXymm, Ib }, 0 },
{ "vinserti32x8", { XM, Vex, EXymm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A3A_P_2_W_1 */
/* EVEX_LEN_0F3A3A_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vinserti64x4", { XM, Vex, EXymm, Ib }, 0 },
{ "vinserti64x4", { XM, Vex, EXymm, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A3B_P_2_W_0 */
/* EVEX_LEN_0F3A3B_W_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vextracti32x8", { EXymm, XM, Ib }, 0 },
{ "vextracti32x8", { EXymm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A3B_P_2_W_1 */
/* EVEX_LEN_0F3A3B_W_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vextracti64x4", { EXymm, XM, Ib }, 0 },
{ "vextracti64x4", { EXymm, XM, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A43_P_2_W_0 */
/* EVEX_LEN_0F3A43_W_0 */
{
{ Bad_Opcode },
{ "vshufi32x4", { XM, Vex, EXx, Ib }, 0 },
{ "vshufi32x4", { XM, Vex, EXx, Ib }, 0 },
{ "vshufi32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshufi32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_LEN_0F3A43_P_2_W_1 */
/* EVEX_LEN_0F3A43_W_1 */
{
{ Bad_Opcode },
{ "vshufi64x2", { XM, Vex, EXx, Ib }, 0 },
{ "vshufi64x2", { XM, Vex, EXx, Ib }, 0 },
{ "vshufi64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshufi64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
},
};

View File

@ -28,67 +28,67 @@
/* MOD_EVEX_0F2B */
{ "vmovntpX", { EXx, XM }, PREFIX_OPCODE },
},
/* MOD_EVEX_0F381A_P_2_W_0 */
/* MOD_EVEX_0F381A_W_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F381A_P_2_W_0_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F381A_W_0_M_0) },
},
/* MOD_EVEX_0F381A_P_2_W_1 */
/* MOD_EVEX_0F381A_W_1 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F381A_P_2_W_1_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F381A_W_1_M_0) },
},
/* MOD_EVEX_0F381B_P_2_W_0 */
/* MOD_EVEX_0F381B_W_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F381B_P_2_W_0_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F381B_W_0_M_0) },
},
/* MOD_EVEX_0F381B_P_2_W_1 */
/* MOD_EVEX_0F381B_W_1 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F381B_P_2_W_1_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F381B_W_1_M_0) },
},
/* MOD_EVEX_0F385A_P_2_W_0 */
/* MOD_EVEX_0F385A_W_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F385A_P_2_W_0_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F385A_W_0_M_0) },
},
/* MOD_EVEX_0F385A_P_2_W_1 */
/* MOD_EVEX_0F385A_W_1 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F385A_P_2_W_1_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F385A_W_1_M_0) },
},
/* MOD_EVEX_0F385B_P_2_W_0 */
/* MOD_EVEX_0F385B_W_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F385B_P_2_W_0_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F385B_W_0_M_0) },
},
/* MOD_EVEX_0F385B_P_2_W_1 */
/* MOD_EVEX_0F385B_W_1 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F385B_P_2_W_1_M_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F385B_W_1_M_0) },
},
{
/* MOD_EVEX_0F38C6_REG_1 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_R_1_M_0) },
},
{
/* MOD_EVEX_0F38C6_REG_2 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_2) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_R_2_M_0) },
},
{
/* MOD_EVEX_0F38C6_REG_5 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_5) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_R_5_M_0) },
},
{
/* MOD_EVEX_0F38C6_REG_6 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_6) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_R_6_M_0) },
},
{
/* MOD_EVEX_0F38C7_REG_1 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_1) },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_1_M_0) },
},
{
/* MOD_EVEX_0F38C7_REG_2 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_2) },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_2_M_0) },
},
{
/* MOD_EVEX_0F38C7_REG_5 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_5) },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_5_M_0) },
},
{
/* MOD_EVEX_0F38C7_REG_6 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_6) },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_6_M_0) },
},

View File

@ -94,30 +94,6 @@
{ "vmaxpX", { XM, Vex, EXx, EXxEVexS }, PREFIX_OPCODE },
{ VEX_W_TABLE (EVEX_W_0F5F_P_3) },
},
/* PREFIX_EVEX_0F64 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmpgtb", { XMask, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F65 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmpgtw", { XMask, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F66 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F66_P_2) },
},
/* PREFIX_EVEX_0F6E */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F6E_P_2) },
},
/* PREFIX_EVEX_0F6F */
{
{ Bad_Opcode },
@ -132,96 +108,6 @@
{ VEX_W_TABLE (EVEX_W_0F70_P_2) },
{ "vpshuflw", { XM, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F71_REG_2 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsrlw", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F71_REG_4 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsraw", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F71_REG_6 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsllw", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F72_REG_0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpror%DQ", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F72_REG_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vprol%DQ", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F72_REG_2 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F72_R_2_P_2) },
},
/* PREFIX_EVEX_0F72_REG_4 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsra%DQ", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F72_REG_6 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F72_R_6_P_2) },
},
/* PREFIX_EVEX_0F73_REG_2 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F73_R_2_P_2) },
},
/* PREFIX_EVEX_0F73_REG_3 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsrldq", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F73_REG_6 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F73_R_6_P_2) },
},
/* PREFIX_EVEX_0F73_REG_7 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpslldq", { Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F74 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmpeqb", { XMask, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F75 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmpeqw", { XMask, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F76 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F76_P_2) },
},
/* PREFIX_EVEX_0F78 */
{
{ VEX_W_TABLE (EVEX_W_0F78_P_0) },
@ -270,42 +156,6 @@
{ "vcmppX", { XMask, Vex, EXx, EXxEVexS, CMP }, PREFIX_OPCODE },
{ VEX_W_TABLE (EVEX_W_0FC2_P_3) },
},
/* PREFIX_EVEX_0FC4 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0FC4_P_2) },
},
/* PREFIX_EVEX_0FC5 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0FC5_P_2) },
},
/* PREFIX_EVEX_0FD6 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0FD6_P_2) },
},
/* PREFIX_EVEX_0FDB */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpand%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0FDF */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpandn%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0FE2 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsra%DQ", { XM, Vex, EXxmm }, 0 },
},
/* PREFIX_EVEX_0FE6 */
{
{ Bad_Opcode },
@ -313,30 +163,6 @@
{ VEX_W_TABLE (EVEX_W_0FE6_P_2) },
{ VEX_W_TABLE (EVEX_W_0FE6_P_3) },
},
/* PREFIX_EVEX_0FE7 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0FE7_P_2) },
},
/* PREFIX_EVEX_0FEB */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpor%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0FEF */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpxor%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F380D */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F380D_P_2) },
},
/* PREFIX_EVEX_0F3810 */
{
{ Bad_Opcode },
@ -373,42 +199,6 @@
{ VEX_W_TABLE (EVEX_W_0F3815_P_1) },
{ "vprolv%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3816 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3816_P_2) },
},
/* PREFIX_EVEX_0F3819 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3819_P_2) },
},
/* PREFIX_EVEX_0F381A */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F381A_P_2) },
},
/* PREFIX_EVEX_0F381B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F381B_P_2) },
},
/* PREFIX_EVEX_0F381E */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F381E_P_2) },
},
/* PREFIX_EVEX_0F381F */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F381F_P_2) },
},
/* PREFIX_EVEX_0F3820 */
{
{ Bad_Opcode },
@ -475,18 +265,6 @@
{ VEX_W_TABLE (EVEX_W_0F382A_P_1) },
{ VEX_W_TABLE (EVEX_W_0F382A_P_2) },
},
/* PREFIX_EVEX_0F382C */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscalefp%XW", { XM, Vex, EXx, EXxEVexR }, 0 },
},
/* PREFIX_EVEX_0F382D */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscalefs%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, 0 },
},
/* PREFIX_EVEX_0F3830 */
{
{ Bad_Opcode },
@ -523,18 +301,6 @@
{ VEX_W_TABLE (EVEX_W_0F3835_P_1) },
{ VEX_W_TABLE (EVEX_W_0F3835_P_2) },
},
/* PREFIX_EVEX_0F3836 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3836_P_2) },
},
/* PREFIX_EVEX_0F3837 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3837_P_2) },
},
/* PREFIX_EVEX_0F3838 */
{
{ Bad_Opcode },
@ -553,102 +319,6 @@
{ VEX_W_TABLE (EVEX_W_0F383A_P_1) },
{ "vpminuw", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F383B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpminu%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F383D */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpmaxs%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F383F */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpmaxu%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3840 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpmull%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3842 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgetexpp%XW", { XM, EXx, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F3843 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgetexps%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F3844 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vplzcnt%DQ", { XM, EXx }, 0 },
},
/* PREFIX_EVEX_0F3845 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsrlv%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3846 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsrav%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3847 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpsllv%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F384C */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrcp14p%XW", { XM, EXx }, 0 },
},
/* PREFIX_EVEX_0F384D */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrcp14s%XW", { XMScalar, VexScalar, EXVexWdqScalar }, 0 },
},
/* PREFIX_EVEX_0F384E */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrsqrt14p%XW", { XM, EXx }, 0 },
},
/* PREFIX_EVEX_0F384F */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrsqrt14s%XW", { XMScalar, VexScalar, EXVexWdqScalar }, 0 },
},
/* PREFIX_EVEX_0F3850 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpdpbusd", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3851 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpdpbusds", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3852 */
{
{ Bad_Opcode },
@ -663,66 +333,6 @@
{ "vpdpwssds", { XM, Vex, EXx }, 0 },
{ "vp4dpwssds", { XM, Vex, EXxmm }, 0 },
},
/* PREFIX_EVEX_0F3854 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpopcnt%BW", { XM, EXx }, 0 },
},
/* PREFIX_EVEX_0F3855 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpopcnt%DQ", { XM, EXx }, 0 },
},
/* PREFIX_EVEX_0F3859 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3859_P_2) },
},
/* PREFIX_EVEX_0F385A */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F385A_P_2) },
},
/* PREFIX_EVEX_0F385B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F385B_P_2) },
},
/* PREFIX_EVEX_0F3862 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpexpand%BW", { XM, EXbwUnit }, 0 },
},
/* PREFIX_EVEX_0F3863 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcompress%BW", { EXbwUnit, XM }, 0 },
},
/* PREFIX_EVEX_0F3864 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpblendm%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3865 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vblendmp%XW", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3866 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpblendm%BW", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3868 */
{
{ Bad_Opcode },
@ -730,18 +340,6 @@
{ Bad_Opcode },
{ "vp2intersect%DQ", { XMask, Vex, EXx, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F3870 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3870_P_2) },
},
/* PREFIX_EVEX_0F3871 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpshldv%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3872 */
{
{ Bad_Opcode },
@ -749,132 +347,6 @@
{ VEX_W_TABLE (EVEX_W_0F3872_P_2) },
{ VEX_W_TABLE (EVEX_W_0F3872_P_3) },
},
/* PREFIX_EVEX_0F3873 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpshrdv%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3875 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpermi2%BW", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3876 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpermi2%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3877 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpermi2p%XW", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F387A */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F387A_P_2) },
},
/* PREFIX_EVEX_0F387B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F387B_P_2) },
},
/* PREFIX_EVEX_0F387C */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpbroadcastK", { XM, Rdq }, 0 },
},
/* PREFIX_EVEX_0F387D */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpermt2%BW", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F387E */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpermt2%DQ", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F387F */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpermt2p%XW", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3883 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3883_P_2) },
},
/* PREFIX_EVEX_0F3888 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vexpandp%XW", { XM, EXEvexXGscat }, 0 },
},
/* PREFIX_EVEX_0F3889 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpexpand%DQ", { XM, EXEvexXGscat }, 0 },
},
/* PREFIX_EVEX_0F388A */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vcompressp%XW", { EXEvexXGscat, XM }, 0 },
},
/* PREFIX_EVEX_0F388B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcompress%DQ", { EXEvexXGscat, XM }, 0 },
},
/* PREFIX_EVEX_0F388D */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vperm%BW", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F388F */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpshufbitqmb", { XMask, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F3890 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpgatherd%DQ", { XM, MVexVSIBDWpX }, 0 },
},
/* PREFIX_EVEX_0F3891 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3891_P_2) },
},
/* PREFIX_EVEX_0F3892 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgatherdp%XW", { XM, MVexVSIBDWpX}, 0 },
},
/* PREFIX_EVEX_0F3893 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3893_P_2) },
},
/* PREFIX_EVEX_0F389A */
{
{ Bad_Opcode },
@ -889,30 +361,6 @@
{ "vfmsub132s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, 0 },
{ "v4fmaddss", { XMScalar, VexScalar, Mxmm }, 0 },
},
/* PREFIX_EVEX_0F38A0 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpscatterd%DQ", { MVexVSIBDWpX, XM }, 0 },
},
/* PREFIX_EVEX_0F38A1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F38A1_P_2) },
},
/* PREFIX_EVEX_0F38A2 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vscatterdp%XW", { MVexVSIBDWpX, XM }, 0 },
},
/* PREFIX_EVEX_0F38A3 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F38A3_P_2) },
},
/* PREFIX_EVEX_0F38AA */
{
{ Bad_Opcode },
@ -927,369 +375,3 @@
{ "vfmsub213s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, 0 },
{ "v4fnmaddss", { XMScalar, VexScalar, Mxmm }, 0 },
},
/* PREFIX_EVEX_0F38B4 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpmadd52luq", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F38B5 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpmadd52huq", { XM, Vex, EXx }, 0 },
},
/* PREFIX_EVEX_0F38C4 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpconflict%DQ", { XM, EXx }, 0 },
},
/* PREFIX_EVEX_0F38C6_REG_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_REG_1_PREFIX_2) },
},
/* PREFIX_EVEX_0F38C6_REG_2 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_REG_2_PREFIX_2) },
},
/* PREFIX_EVEX_0F38C6_REG_5 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_REG_5_PREFIX_2) },
},
/* PREFIX_EVEX_0F38C6_REG_6 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C6_REG_6_PREFIX_2) },
},
/* PREFIX_EVEX_0F38C7_REG_1 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_1_P_2) },
},
/* PREFIX_EVEX_0F38C7_REG_2 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_2_P_2) },
},
/* PREFIX_EVEX_0F38C7_REG_5 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_5_P_2) },
},
/* PREFIX_EVEX_0F38C7_REG_6 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F38C7_R_6_P_2) },
},
/* PREFIX_EVEX_0F38C8 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vexp2p%XW", { XM, EXx, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F38CA */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrcp28p%XW", { XM, EXx, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F38CB */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrcp28s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F38CC */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrsqrt28p%XW", { XM, EXx, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F38CD */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrsqrt28s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS }, 0 },
},
/* PREFIX_EVEX_0F3A00 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A00_P_2) },
},
/* PREFIX_EVEX_0F3A01 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A01_P_2) },
},
/* PREFIX_EVEX_0F3A03 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "valign%DQ", { XM, Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A05 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A05_P_2) },
},
/* PREFIX_EVEX_0F3A08 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A08_P_2) },
},
/* PREFIX_EVEX_0F3A09 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A09_P_2) },
},
/* PREFIX_EVEX_0F3A0A */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A0A_P_2) },
},
/* PREFIX_EVEX_0F3A0B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A0B_P_2) },
},
/* PREFIX_EVEX_0F3A14 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A14_P_2) },
},
/* PREFIX_EVEX_0F3A15 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A15_P_2) },
},
/* PREFIX_EVEX_0F3A16 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A16_P_2) },
},
/* PREFIX_EVEX_0F3A17 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A17_P_2) },
},
/* PREFIX_EVEX_0F3A18 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A18_P_2) },
},
/* PREFIX_EVEX_0F3A19 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A19_P_2) },
},
/* PREFIX_EVEX_0F3A1A */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A1A_P_2) },
},
/* PREFIX_EVEX_0F3A1B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A1B_P_2) },
},
/* PREFIX_EVEX_0F3A1E */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmpu%DQ", { XMask, Vex, EXx, VPCMP }, 0 },
},
/* PREFIX_EVEX_0F3A1F */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmp%DQ", { XMask, Vex, EXx, VPCMP }, 0 },
},
/* PREFIX_EVEX_0F3A20 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A20_P_2) },
},
/* PREFIX_EVEX_0F3A21 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A21_P_2) },
},
/* PREFIX_EVEX_0F3A22 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A22_P_2) },
},
/* PREFIX_EVEX_0F3A23 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A23_P_2) },
},
/* PREFIX_EVEX_0F3A25 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpternlog%DQ", { XM, Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A26 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgetmantp%XW", { XM, EXx, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A27 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vgetmants%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A38 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A38_P_2) },
},
/* PREFIX_EVEX_0F3A39 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A39_P_2) },
},
/* PREFIX_EVEX_0F3A3A */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A3A_P_2) },
},
/* PREFIX_EVEX_0F3A3B */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A3B_P_2) },
},
/* PREFIX_EVEX_0F3A3E */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmpu%BW", { XMask, Vex, EXx, VPCMP }, 0 },
},
/* PREFIX_EVEX_0F3A3F */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpcmp%BW", { XMask, Vex, EXx, VPCMP }, 0 },
},
/* PREFIX_EVEX_0F3A42 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A42_P_2) },
},
/* PREFIX_EVEX_0F3A43 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A43_P_2) },
},
/* PREFIX_EVEX_0F3A50 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vrangep%XW", { XM, Vex, EXx, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A51 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vranges%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A54 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vfixupimmp%XW", { XM, Vex, EXx, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A55 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vfixupimms%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A56 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vreducep%XW", { XM, EXx, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A57 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vreduces%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A66 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vfpclassp%XW%XZ", { XMask, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A67 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vfpclasss%XW", { XMask, EXVexWdqScalar, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A70 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A70_P_2) },
},
/* PREFIX_EVEX_0F3A71 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpshld%DQ", { XM, Vex, EXx, Ib }, 0 },
},
/* PREFIX_EVEX_0F3A72 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ VEX_W_TABLE (EVEX_W_0F3A72_P_2) },
},
/* PREFIX_EVEX_0F3A73 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ "vpshrd%DQ", { XM, Vex, EXx, Ib }, 0 },
},

View File

@ -2,32 +2,32 @@
{
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F71_REG_2) },
{ "vpsrlw", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F71_REG_4) },
{ "vpsraw", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F71_REG_6) },
{ "vpsllw", { Vex, EXx, Ib }, PREFIX_DATA },
},
/* REG_EVEX_0F72 */
{
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_0) },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_1) },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_2) },
{ "vpror%DQ", { Vex, EXx, Ib }, PREFIX_DATA },
{ "vprol%DQ", { Vex, EXx, Ib }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F72_R_2) },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_4) },
{ "vpsra%DQ", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_6) },
{ VEX_W_TABLE (EVEX_W_0F72_R_6) },
},
/* REG_EVEX_0F73 */
{
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_2) },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_3) },
{ VEX_W_TABLE (EVEX_W_0F73_R_2) },
{ "vpsrldq", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_6) },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_7) },
{ VEX_W_TABLE (EVEX_W_0F73_R_6) },
{ "vpslldq", { Vex, EXx, Ib }, PREFIX_DATA },
},
/* REG_EVEX_0F38C6 */
{

View File

@ -138,29 +138,29 @@
},
/* EVEX_W_0F62 */
{
{ PREFIX_TABLE (PREFIX_VEX_0F62) },
{ "vpunpckldq", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F66_P_2 */
/* EVEX_W_0F66 */
{
{ "vpcmpgtd", { XMask, Vex, EXx }, 0 },
{ "vpcmpgtd", { XMask, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F6A */
{
{ PREFIX_TABLE (PREFIX_VEX_0F6A) },
{ "vpunpckhdq", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F6B */
{
{ PREFIX_TABLE (PREFIX_VEX_0F6B) },
{ "vpackssdw", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F6C */
{
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F6C) },
{ "vpunpcklqdq", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F6D */
{
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F6D) },
{ "vpunpckhqdq", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F6F_P_1 */
{
@ -181,27 +181,27 @@
{
{ "vpshufd", { XM, EXx, Ib }, 0 },
},
/* EVEX_W_0F72_R_2_P_2 */
/* EVEX_W_0F72_R_2 */
{
{ "vpsrld", { Vex, EXx, Ib }, 0 },
{ "vpsrld", { Vex, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F72_R_6_P_2 */
/* EVEX_W_0F72_R_6 */
{
{ "vpslld", { Vex, EXx, Ib }, 0 },
{ "vpslld", { Vex, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F73_R_2_P_2 */
/* EVEX_W_0F73_R_2 */
{
{ Bad_Opcode },
{ "vpsrlq", { Vex, EXx, Ib }, 0 },
{ "vpsrlq", { Vex, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F73_R_6_P_2 */
/* EVEX_W_0F73_R_6 */
{
{ Bad_Opcode },
{ "vpsllq", { Vex, EXx, Ib }, 0 },
{ "vpsllq", { Vex, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F76_P_2 */
/* EVEX_W_0F76 */
{
{ "vpcmpeqd", { XMask, Vex, EXx }, 0 },
{ "vpcmpeqd", { XMask, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F78_P_0 */
{
@ -279,22 +279,22 @@
},
/* EVEX_W_0FD2 */
{
{ PREFIX_TABLE (PREFIX_VEX_0FD2) },
{ "vpsrld", { XM, Vex, EXxmm }, PREFIX_DATA },
},
/* EVEX_W_0FD3 */
{
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0FD3) },
{ "vpsrlq", { XM, Vex, EXxmm }, PREFIX_DATA },
},
/* EVEX_W_0FD4 */
{
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0FD4) },
{ "vpaddq", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0FD6_P_2 */
/* EVEX_W_0FD6_L_0 */
{
{ Bad_Opcode },
{ "vmovq", { EXqS, XMScalar }, 0 },
{ "vmovq", { EXqS, XMScalar }, PREFIX_DATA },
},
/* EVEX_W_0FE6_P_1 */
{
@ -311,41 +311,41 @@
{ Bad_Opcode },
{ "vcvtpd2dq%XY", { XMxmmq, EXx, EXxEVexR }, 0 },
},
/* EVEX_W_0FE7_P_2 */
/* EVEX_W_0FE7 */
{
{ "vmovntdq", { EXEvexXNoBcst, XM }, 0 },
{ "vmovntdq", { EXEvexXNoBcst, XM }, PREFIX_DATA },
},
/* EVEX_W_0FF2 */
{
{ PREFIX_TABLE (PREFIX_VEX_0FF2) },
{ "vpslld", { XM, Vex, EXxmm }, PREFIX_DATA },
},
/* EVEX_W_0FF3 */
{
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0FF3) },
{ "vpsllq", { XM, Vex, EXxmm }, PREFIX_DATA },
},
/* EVEX_W_0FF4 */
{
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0FF4) },
{ "vpmuludq", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0FFA */
{
{ PREFIX_TABLE (PREFIX_VEX_0FFA) },
{ "vpsubd", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0FFB */
{
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0FFB) },
{ "vpsubq", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0FFE */
{
{ PREFIX_TABLE (PREFIX_VEX_0FFE) },
{ "vpaddd", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F380D_P_2 */
/* EVEX_W_0F380D */
{
{ Bad_Opcode },
{ "vpermilpd", { XM, Vex, EXx }, 0 },
{ "vpermilpd", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F3810_P_1 */
{
@ -390,29 +390,29 @@
{
{ "vpmovusqd", { EXxmmq, XM }, 0 },
},
/* EVEX_W_0F3819_P_2 */
/* EVEX_W_0F3819 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3819_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3819_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3819_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3819_W_1) },
},
/* EVEX_W_0F381A_P_2 */
/* EVEX_W_0F381A */
{
{ MOD_TABLE (MOD_EVEX_0F381A_P_2_W_0) },
{ MOD_TABLE (MOD_EVEX_0F381A_P_2_W_1) },
{ MOD_TABLE (MOD_EVEX_0F381A_W_0) },
{ MOD_TABLE (MOD_EVEX_0F381A_W_1) },
},
/* EVEX_W_0F381B_P_2 */
/* EVEX_W_0F381B */
{
{ MOD_TABLE (MOD_EVEX_0F381B_P_2_W_0) },
{ MOD_TABLE (MOD_EVEX_0F381B_P_2_W_1) },
{ MOD_TABLE (MOD_EVEX_0F381B_W_0) },
{ MOD_TABLE (MOD_EVEX_0F381B_W_1) },
},
/* EVEX_W_0F381E_P_2 */
/* EVEX_W_0F381E */
{
{ "vpabsd", { XM, EXx }, 0 },
{ "vpabsd", { XM, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F381F_P_2 */
/* EVEX_W_0F381F */
{
{ Bad_Opcode },
{ "vpabsq", { XM, EXx }, 0 },
{ "vpabsq", { XM, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F3820_P_1 */
{
@ -463,7 +463,7 @@
},
/* EVEX_W_0F382B */
{
{ PREFIX_TABLE (PREFIX_VEX_0F382B) },
{ "vpackusdw", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F3830_P_1 */
{
@ -493,10 +493,10 @@
{
{ "vpmovzxdq", { XM, EXxmmq }, 0 },
},
/* EVEX_W_0F3837_P_2 */
/* EVEX_W_0F3837 */
{
{ Bad_Opcode },
{ "vpcmpgtq", { XMask, Vex, EXx }, 0 },
{ "vpcmpgtq", { XMask, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F383A_P_1 */
{
@ -507,25 +507,25 @@
{ "vdpbf16ps", { XM, Vex, EXx }, 0 },
{ Bad_Opcode },
},
/* EVEX_W_0F3859_P_2 */
/* EVEX_W_0F3859 */
{
{ "vbroadcasti32x2", { XM, EXxmm_mq }, 0 },
{ "vpbroadcastq", { XM, EXxmm_mq }, 0 },
{ "vbroadcasti32x2", { XM, EXxmm_mq }, PREFIX_DATA },
{ "vpbroadcastq", { XM, EXxmm_mq }, PREFIX_DATA },
},
/* EVEX_W_0F385A_P_2 */
/* EVEX_W_0F385A */
{
{ MOD_TABLE (MOD_EVEX_0F385A_P_2_W_0) },
{ MOD_TABLE (MOD_EVEX_0F385A_P_2_W_1) },
{ MOD_TABLE (MOD_EVEX_0F385A_W_0) },
{ MOD_TABLE (MOD_EVEX_0F385A_W_1) },
},
/* EVEX_W_0F385B_P_2 */
/* EVEX_W_0F385B */
{
{ MOD_TABLE (MOD_EVEX_0F385B_P_2_W_0) },
{ MOD_TABLE (MOD_EVEX_0F385B_P_2_W_1) },
{ MOD_TABLE (MOD_EVEX_0F385B_W_0) },
{ MOD_TABLE (MOD_EVEX_0F385B_W_1) },
},
/* EVEX_W_0F3870_P_2 */
/* EVEX_W_0F3870 */
{
{ Bad_Opcode },
{ "vpshldvw", { XM, Vex, EXx }, 0 },
{ "vpshldvw", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F3872_P_1 */
{
@ -542,156 +542,156 @@
{ "vcvtne2ps2bf16", { XM, Vex, EXx}, 0 },
{ Bad_Opcode },
},
/* EVEX_W_0F387A_P_2 */
/* EVEX_W_0F387A */
{
{ "vpbroadcastb", { XM, Rd }, 0 },
{ "vpbroadcastb", { XM, Rd }, PREFIX_DATA },
},
/* EVEX_W_0F387B_P_2 */
/* EVEX_W_0F387B */
{
{ "vpbroadcastw", { XM, Rd }, 0 },
{ "vpbroadcastw", { XM, Rd }, PREFIX_DATA },
},
/* EVEX_W_0F3883_P_2 */
/* EVEX_W_0F3883 */
{
{ Bad_Opcode },
{ "vpmultishiftqb", { XM, Vex, EXx }, 0 },
{ "vpmultishiftqb", { XM, Vex, EXx }, PREFIX_DATA },
},
/* EVEX_W_0F3891_P_2 */
/* EVEX_W_0F3891 */
{
{ "vpgatherqd", { XMxmmq, MVexVSIBQDWpX }, 0 },
{ "vpgatherqd", { XMxmmq, MVexVSIBQDWpX }, PREFIX_DATA },
{ "vpgatherqq", { XM, MVexVSIBQWpX }, 0 },
},
/* EVEX_W_0F3893_P_2 */
/* EVEX_W_0F3893 */
{
{ "vgatherqps", { XMxmmq, MVexVSIBQDWpX }, 0 },
{ "vgatherqps", { XMxmmq, MVexVSIBQDWpX }, PREFIX_DATA },
{ "vgatherqpd", { XM, MVexVSIBQWpX }, 0 },
},
/* EVEX_W_0F38A1_P_2 */
/* EVEX_W_0F38A1 */
{
{ "vpscatterqd", { MVexVSIBQDWpX, XMxmmq }, 0 },
{ "vpscatterqd", { MVexVSIBQDWpX, XMxmmq }, PREFIX_DATA },
{ "vpscatterqq", { MVexVSIBQWpX, XM }, 0 },
},
/* EVEX_W_0F38A3_P_2 */
/* EVEX_W_0F38A3 */
{
{ "vscatterqps", { MVexVSIBQDWpX, XMxmmq }, 0 },
{ "vscatterqps", { MVexVSIBQDWpX, XMxmmq }, PREFIX_DATA },
{ "vscatterqpd", { MVexVSIBQWpX, XM }, 0 },
},
/* EVEX_W_0F38C7_R_1_P_2 */
/* EVEX_W_0F38C7_R_1_M_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_1_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_1_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_1_M_0_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_1_M_0_W_1) },
},
/* EVEX_W_0F38C7_R_2_P_2 */
/* EVEX_W_0F38C7_R_2_M_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_2_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_2_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_2_M_0_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_2_M_0_W_1) },
},
/* EVEX_W_0F38C7_R_5_P_2 */
/* EVEX_W_0F38C7_R_5_M_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_5_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_5_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_5_M_0_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_5_M_0_W_1) },
},
/* EVEX_W_0F38C7_R_6_P_2 */
/* EVEX_W_0F38C7_R_6_M_0 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_6_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_6_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_6_M_0_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F38C7_R_6_M_0_W_1) },
},
/* EVEX_W_0F3A00_P_2 */
/* EVEX_W_0F3A00 */
{
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A00_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A00_W_1) },
},
/* EVEX_W_0F3A01_P_2 */
/* EVEX_W_0F3A01 */
{
{ Bad_Opcode },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A01_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A01_W_1) },
},
/* EVEX_W_0F3A05_P_2 */
/* EVEX_W_0F3A05 */
{
{ Bad_Opcode },
{ "vpermilpd", { XM, EXx, Ib }, 0 },
{ "vpermilpd", { XM, EXx, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F3A08_P_2 */
/* EVEX_W_0F3A08 */
{
{ "vrndscaleps", { XM, EXx, EXxEVexS, Ib }, 0 },
{ "vrndscaleps", { XM, EXx, EXxEVexS, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F3A09_P_2 */
/* EVEX_W_0F3A09 */
{
{ Bad_Opcode },
{ "vrndscalepd", { XM, EXx, EXxEVexS, Ib }, 0 },
{ "vrndscalepd", { XM, EXx, EXxEVexS, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F3A0A_P_2 */
/* EVEX_W_0F3A0A */
{
{ "vrndscaless", { XMScalar, VexScalar, EXxmm_md, EXxEVexS, Ib }, 0 },
{ "vrndscaless", { XMScalar, VexScalar, EXxmm_md, EXxEVexS, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F3A0B_P_2 */
/* EVEX_W_0F3A0B */
{
{ Bad_Opcode },
{ "vrndscalesd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS, Ib }, 0 },
{ "vrndscalesd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS, Ib }, PREFIX_DATA },
},
/* EVEX_W_0F3A18_P_2 */
/* EVEX_W_0F3A18 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A18_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A18_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A18_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A18_W_1) },
},
/* EVEX_W_0F3A19_P_2 */
/* EVEX_W_0F3A19 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A19_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A19_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A19_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A19_W_1) },
},
/* EVEX_W_0F3A1A_P_2 */
/* EVEX_W_0F3A1A */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1A_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1A_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1A_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1A_W_1) },
},
/* EVEX_W_0F3A1B_P_2 */
/* EVEX_W_0F3A1B */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1B_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1B_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1B_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A1B_W_1) },
},
/* EVEX_W_0F3A21_P_2 */
/* EVEX_W_0F3A21 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A21_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A21_W_0) },
},
/* EVEX_W_0F3A23_P_2 */
/* EVEX_W_0F3A23 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A23_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A23_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A23_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A23_W_1) },
},
/* EVEX_W_0F3A38_P_2 */
/* EVEX_W_0F3A38 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A38_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A38_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A38_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A38_W_1) },
},
/* EVEX_W_0F3A39_P_2 */
/* EVEX_W_0F3A39 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A39_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A39_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A39_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A39_W_1) },
},
/* EVEX_W_0F3A3A_P_2 */
/* EVEX_W_0F3A3A */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3A_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3A_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3A_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3A_W_1) },
},
/* EVEX_W_0F3A3B_P_2 */
/* EVEX_W_0F3A3B */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3B_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3B_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3B_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A3B_W_1) },
},
/* EVEX_W_0F3A42_P_2 */
/* EVEX_W_0F3A42 */
{
{ "vdbpsadbw", { XM, Vex, EXx, Ib }, 0 },
},
/* EVEX_W_0F3A43_P_2 */
/* EVEX_W_0F3A43 */
{
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A43_P_2_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A43_P_2_W_1) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A43_W_0) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A43_W_1) },
},
/* EVEX_W_0F3A70_P_2 */
/* EVEX_W_0F3A70 */
{
{ Bad_Opcode },
{ "vpshldw", { XM, Vex, EXx, Ib }, 0 },
},
/* EVEX_W_0F3A72_P_2 */
/* EVEX_W_0F3A72 */
{
{ Bad_Opcode },
{ "vpshrdw", { XM, Vex, EXx, Ib }, 0 },

View File

@ -110,31 +110,31 @@ static const struct dis386 evex_table[][256] = {
{ PREFIX_TABLE (PREFIX_EVEX_0F5E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F5F) },
/* 60 */
{ PREFIX_TABLE (PREFIX_VEX_0F60) },
{ PREFIX_TABLE (PREFIX_VEX_0F61) },
{ "vpunpcklbw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpunpcklwd", { XM, Vex, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F62) },
{ PREFIX_TABLE (PREFIX_VEX_0F63) },
{ PREFIX_TABLE (PREFIX_EVEX_0F64) },
{ PREFIX_TABLE (PREFIX_EVEX_0F65) },
{ PREFIX_TABLE (PREFIX_EVEX_0F66) },
{ PREFIX_TABLE (PREFIX_VEX_0F67) },
{ "vpacksswb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpcmpgtb", { XMask, Vex, EXx }, PREFIX_DATA },
{ "vpcmpgtw", { XMask, Vex, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F66) },
{ "vpackuswb", { XM, Vex, EXx }, PREFIX_DATA },
/* 68 */
{ PREFIX_TABLE (PREFIX_VEX_0F68) },
{ PREFIX_TABLE (PREFIX_VEX_0F69) },
{ "vpunpckhbw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpunpckhwd", { XM, Vex, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F6A) },
{ VEX_W_TABLE (EVEX_W_0F6B) },
{ VEX_W_TABLE (EVEX_W_0F6C) },
{ VEX_W_TABLE (EVEX_W_0F6D) },
{ PREFIX_TABLE (PREFIX_EVEX_0F6E) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F6E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F6F) },
/* 70 */
{ PREFIX_TABLE (PREFIX_EVEX_0F70) },
{ REG_TABLE (REG_EVEX_0F71) },
{ REG_TABLE (REG_EVEX_0F72) },
{ REG_TABLE (REG_EVEX_0F73) },
{ PREFIX_TABLE (PREFIX_EVEX_0F74) },
{ PREFIX_TABLE (PREFIX_EVEX_0F75) },
{ PREFIX_TABLE (PREFIX_EVEX_0F76) },
{ "vpcmpeqb", { XMask, Vex, EXx }, PREFIX_DATA },
{ "vpcmpeqw", { XMask, Vex, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F76) },
{ Bad_Opcode },
/* 78 */
{ PREFIX_TABLE (PREFIX_EVEX_0F78) },
@ -222,8 +222,8 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0FC2) },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0FC4) },
{ PREFIX_TABLE (PREFIX_EVEX_0FC5) },
{ EVEX_LEN_TABLE (EVEX_LEN_0FC4) },
{ EVEX_LEN_TABLE (EVEX_LEN_0FC5) },
{ "vshufpX", { XM, Vex, EXx, Ib }, PREFIX_OPCODE },
{ Bad_Opcode },
/* C8 */
@ -237,67 +237,67 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
/* D0 */
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0FD1) },
{ "vpsrlw", { XM, Vex, EXxmm }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0FD2) },
{ VEX_W_TABLE (EVEX_W_0FD3) },
{ VEX_W_TABLE (EVEX_W_0FD4) },
{ PREFIX_TABLE (PREFIX_VEX_0FD5) },
{ PREFIX_TABLE (PREFIX_EVEX_0FD6) },
{ "vpmullw", { XM, Vex, EXx }, PREFIX_DATA },
{ EVEX_LEN_TABLE (EVEX_LEN_0FD6) },
{ Bad_Opcode },
/* D8 */
{ PREFIX_TABLE (PREFIX_VEX_0FD8) },
{ PREFIX_TABLE (PREFIX_VEX_0FD9) },
{ PREFIX_TABLE (PREFIX_VEX_0FDA) },
{ PREFIX_TABLE (PREFIX_EVEX_0FDB) },
{ PREFIX_TABLE (PREFIX_VEX_0FDC) },
{ PREFIX_TABLE (PREFIX_VEX_0FDD) },
{ PREFIX_TABLE (PREFIX_VEX_0FDE) },
{ PREFIX_TABLE (PREFIX_EVEX_0FDF) },
{ "vpsubusb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpsubusw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpminub", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpand%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpaddusb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpaddusw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmaxub", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpandn%DQ", { XM, Vex, EXx }, PREFIX_DATA },
/* E0 */
{ PREFIX_TABLE (PREFIX_VEX_0FE0) },
{ PREFIX_TABLE (PREFIX_VEX_0FE1) },
{ PREFIX_TABLE (PREFIX_EVEX_0FE2) },
{ PREFIX_TABLE (PREFIX_VEX_0FE3) },
{ PREFIX_TABLE (PREFIX_VEX_0FE4) },
{ PREFIX_TABLE (PREFIX_VEX_0FE5) },
{ "vpavgb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpsraw", { XM, Vex, EXxmm }, PREFIX_DATA },
{ "vpsra%DQ", { XM, Vex, EXxmm }, PREFIX_DATA },
{ "vpavgw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmulhuw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmulhw", { XM, Vex, EXx }, PREFIX_DATA },
{ PREFIX_TABLE (PREFIX_EVEX_0FE6) },
{ PREFIX_TABLE (PREFIX_EVEX_0FE7) },
{ VEX_W_TABLE (EVEX_W_0FE7) },
/* E8 */
{ PREFIX_TABLE (PREFIX_VEX_0FE8) },
{ PREFIX_TABLE (PREFIX_VEX_0FE9) },
{ PREFIX_TABLE (PREFIX_VEX_0FEA) },
{ PREFIX_TABLE (PREFIX_EVEX_0FEB) },
{ PREFIX_TABLE (PREFIX_VEX_0FEC) },
{ PREFIX_TABLE (PREFIX_VEX_0FED) },
{ PREFIX_TABLE (PREFIX_VEX_0FEE) },
{ PREFIX_TABLE (PREFIX_EVEX_0FEF) },
{ "vpsubsb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpsubsw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpminsw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpor%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpaddsb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpaddsw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmaxsw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpxor%DQ", { XM, Vex, EXx }, PREFIX_DATA },
/* F0 */
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0FF1) },
{ "vpsllw", { XM, Vex, EXxmm }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0FF2) },
{ VEX_W_TABLE (EVEX_W_0FF3) },
{ VEX_W_TABLE (EVEX_W_0FF4) },
{ PREFIX_TABLE (PREFIX_VEX_0FF5) },
{ PREFIX_TABLE (PREFIX_VEX_0FF6) },
{ "vpmaddwd", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpsadbw", { XM, Vex, EXx }, PREFIX_DATA },
{ Bad_Opcode },
/* F8 */
{ PREFIX_TABLE (PREFIX_VEX_0FF8) },
{ PREFIX_TABLE (PREFIX_VEX_0FF9) },
{ "vpsubb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpsubw", { XM, Vex, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0FFA) },
{ VEX_W_TABLE (EVEX_W_0FFB) },
{ PREFIX_TABLE (PREFIX_VEX_0FFC) },
{ PREFIX_TABLE (PREFIX_VEX_0FFD) },
{ "vpaddb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpaddw", { XM, Vex, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0FFE) },
{ Bad_Opcode },
},
/* EVEX_0F38 */
{
/* 00 */
{ PREFIX_TABLE (PREFIX_VEX_0F3800) },
{ "vpshufb", { XM, Vex, EXx }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F3804) },
{ "vpmaddubsw", { XM, Vex, EXx }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
@ -305,9 +305,9 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F380B) },
{ PREFIX_TABLE (PREFIX_VEX_0F380C) },
{ PREFIX_TABLE (PREFIX_EVEX_0F380D) },
{ "vpmulhrsw", { XM, Vex, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (VEX_W_0F380C) },
{ VEX_W_TABLE (EVEX_W_0F380D) },
{ Bad_Opcode },
{ Bad_Opcode },
/* 10 */
@ -317,17 +317,17 @@ static const struct dis386 evex_table[][256] = {
{ PREFIX_TABLE (PREFIX_EVEX_0F3813) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3814) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3815) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3816) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3816) },
{ Bad_Opcode },
/* 18 */
{ PREFIX_TABLE (PREFIX_VEX_0F3818) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3819) },
{ PREFIX_TABLE (PREFIX_EVEX_0F381A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F381B) },
{ PREFIX_TABLE (PREFIX_VEX_0F381C) },
{ PREFIX_TABLE (PREFIX_VEX_0F381D) },
{ PREFIX_TABLE (PREFIX_EVEX_0F381E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F381F) },
{ VEX_W_TABLE (VEX_W_0F3818) },
{ VEX_W_TABLE (EVEX_W_0F3819) },
{ VEX_W_TABLE (EVEX_W_0F381A) },
{ VEX_W_TABLE (EVEX_W_0F381B) },
{ "vpabsb", { XM, EXx }, PREFIX_DATA },
{ "vpabsw", { XM, EXx }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F381E) },
{ VEX_W_TABLE (EVEX_W_0F381F) },
/* 20 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3820) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3821) },
@ -342,8 +342,8 @@ static const struct dis386 evex_table[][256] = {
{ PREFIX_TABLE (PREFIX_EVEX_0F3829) },
{ PREFIX_TABLE (PREFIX_EVEX_0F382A) },
{ VEX_W_TABLE (EVEX_W_0F382B) },
{ PREFIX_TABLE (PREFIX_EVEX_0F382C) },
{ PREFIX_TABLE (PREFIX_EVEX_0F382D) },
{ "vscalefp%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vscalefs%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
/* 30 */
@ -353,49 +353,49 @@ static const struct dis386 evex_table[][256] = {
{ PREFIX_TABLE (PREFIX_EVEX_0F3833) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3834) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3835) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3836) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3837) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3836) },
{ VEX_W_TABLE (EVEX_W_0F3837) },
/* 38 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3838) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3839) },
{ PREFIX_TABLE (PREFIX_EVEX_0F383A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F383B) },
{ PREFIX_TABLE (PREFIX_VEX_0F383C) },
{ PREFIX_TABLE (PREFIX_EVEX_0F383D) },
{ PREFIX_TABLE (PREFIX_VEX_0F383E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F383F) },
{ "vpminu%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmaxsb", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmaxs%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmaxuw", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmaxu%DQ", { XM, Vex, EXx }, PREFIX_DATA },
/* 40 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3840) },
{ "vpmull%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3842) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3843) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3844) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3845) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3846) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3847) },
{ "vgetexpp%XW", { XM, EXx, EXxEVexS }, PREFIX_DATA },
{ "vgetexps%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS }, PREFIX_DATA },
{ "vplzcnt%DQ", { XM, EXx }, PREFIX_DATA },
{ "vpsrlv%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpsrav%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpsllv%DQ", { XM, Vex, EXx }, PREFIX_DATA },
/* 48 */
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F384C) },
{ PREFIX_TABLE (PREFIX_EVEX_0F384D) },
{ PREFIX_TABLE (PREFIX_EVEX_0F384E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F384F) },
{ "vrcp14p%XW", { XM, EXx }, PREFIX_DATA },
{ "vrcp14s%XW", { XMScalar, VexScalar, EXVexWdqScalar }, PREFIX_DATA },
{ "vrsqrt14p%XW", { XM, EXx }, 0 },
{ "vrsqrt14s%XW", { XMScalar, VexScalar, EXVexWdqScalar }, PREFIX_DATA },
/* 50 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3850) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3851) },
{ "vpdpbusd", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpdpbusds", { XM, Vex, EXx }, PREFIX_DATA },
{ PREFIX_TABLE (PREFIX_EVEX_0F3852) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3853) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3854) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3855) },
{ "vpopcnt%BW", { XM, EXx }, PREFIX_DATA },
{ "vpopcnt%DQ", { XM, EXx }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
/* 58 */
{ PREFIX_TABLE (PREFIX_VEX_0F3858) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3859) },
{ PREFIX_TABLE (PREFIX_EVEX_0F385A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F385B) },
{ VEX_W_TABLE (VEX_W_0F3858) },
{ VEX_W_TABLE (EVEX_W_0F3859) },
{ VEX_W_TABLE (EVEX_W_0F385A) },
{ VEX_W_TABLE (EVEX_W_0F385B) },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
@ -403,11 +403,11 @@ static const struct dis386 evex_table[][256] = {
/* 60 */
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3862) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3863) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3864) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3865) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3866) },
{ "vpexpand%BW", { XM, EXbwUnit }, PREFIX_DATA },
{ "vpcompress%BW", { EXbwUnit, XM }, PREFIX_DATA },
{ "vpblendm%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vblendmp%XW", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpblendm%BW", { XM, Vex, EXx }, PREFIX_DATA },
{ Bad_Opcode },
/* 68 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3868) },
@ -419,113 +419,113 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
/* 70 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3870) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3871) },
{ VEX_W_TABLE (EVEX_W_0F3870) },
{ "vpshldv%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ PREFIX_TABLE (PREFIX_EVEX_0F3872) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3873) },
{ "vpshrdv%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3875) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3876) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3877) },
{ "vpermi2%BW", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpermi2%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpermi2p%XW", { XM, Vex, EXx }, PREFIX_DATA },
/* 78 */
{ PREFIX_TABLE (PREFIX_VEX_0F3878) },
{ PREFIX_TABLE (PREFIX_VEX_0F3879) },
{ PREFIX_TABLE (PREFIX_EVEX_0F387A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F387B) },
{ PREFIX_TABLE (PREFIX_EVEX_0F387C) },
{ PREFIX_TABLE (PREFIX_EVEX_0F387D) },
{ PREFIX_TABLE (PREFIX_EVEX_0F387E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F387F) },
{ VEX_W_TABLE (VEX_W_0F3878) },
{ VEX_W_TABLE (VEX_W_0F3879) },
{ VEX_W_TABLE (EVEX_W_0F387A) },
{ VEX_W_TABLE (EVEX_W_0F387B) },
{ "vpbroadcastK", { XM, Rdq }, PREFIX_DATA },
{ "vpermt2%BW", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpermt2%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpermt2p%XW", { XM, Vex, EXx }, PREFIX_DATA },
/* 80 */
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3883) },
{ VEX_W_TABLE (EVEX_W_0F3883) },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
/* 88 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3888) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3889) },
{ PREFIX_TABLE (PREFIX_EVEX_0F388A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F388B) },
{ "vexpandp%XW", { XM, EXEvexXGscat }, PREFIX_DATA },
{ "vpexpand%DQ", { XM, EXEvexXGscat }, PREFIX_DATA },
{ "vcompressp%XW", { EXEvexXGscat, XM }, PREFIX_DATA },
{ "vpcompress%DQ", { EXEvexXGscat, XM }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F388D) },
{ "vperm%BW", { XM, Vex, EXx }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F388F) },
{ "vpshufbitqmb", { XMask, Vex, EXx }, PREFIX_DATA },
/* 90 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3890) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3891) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3892) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3893) },
{ "vpgatherd%DQ", { XM, MVexVSIBDWpX }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F3891) },
{ "vgatherdp%XW", { XM, MVexVSIBDWpX}, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F3893) },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F3896) },
{ PREFIX_TABLE (PREFIX_VEX_0F3897) },
{ "vfmaddsub132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfmsubadd132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
/* 98 */
{ PREFIX_TABLE (PREFIX_VEX_0F3898) },
{ PREFIX_TABLE (PREFIX_VEX_0F3899) },
{ "vfmadd132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfmadd132s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ PREFIX_TABLE (PREFIX_EVEX_0F389A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F389B) },
{ PREFIX_TABLE (PREFIX_VEX_0F389C) },
{ PREFIX_TABLE (PREFIX_VEX_0F389D) },
{ PREFIX_TABLE (PREFIX_VEX_0F389E) },
{ PREFIX_TABLE (PREFIX_VEX_0F389F) },
{ "vfnmadd132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfnmadd132s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ "vfnmsub132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfnmsub132s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
/* A0 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38A0) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38A1) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38A2) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38A3) },
{ "vpscatterd%DQ", { MVexVSIBDWpX, XM }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F38A1) },
{ "vscatterdp%XW", { MVexVSIBDWpX, XM }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F38A3) },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F38A6) },
{ PREFIX_TABLE (PREFIX_VEX_0F38A7) },
{ "vfmaddsub213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfmsubadd213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
/* A8 */
{ PREFIX_TABLE (PREFIX_VEX_0F38A8) },
{ PREFIX_TABLE (PREFIX_VEX_0F38A9) },
{ "vfmadd213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfmadd213s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ PREFIX_TABLE (PREFIX_EVEX_0F38AA) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38AB) },
{ PREFIX_TABLE (PREFIX_VEX_0F38AC) },
{ PREFIX_TABLE (PREFIX_VEX_0F38AD) },
{ PREFIX_TABLE (PREFIX_VEX_0F38AE) },
{ PREFIX_TABLE (PREFIX_VEX_0F38AF) },
{ "vfnmadd213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfnmadd213s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ "vfnmsub213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfnmsub213s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
/* B0 */
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F38B4) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38B5) },
{ PREFIX_TABLE (PREFIX_VEX_0F38B6) },
{ PREFIX_TABLE (PREFIX_VEX_0F38B7) },
{ "vpmadd52luq", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpmadd52huq", { XM, Vex, EXx }, PREFIX_DATA },
{ "vfmaddsub231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfmsubadd231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
/* B8 */
{ PREFIX_TABLE (PREFIX_VEX_0F38B8) },
{ PREFIX_TABLE (PREFIX_VEX_0F38B9) },
{ PREFIX_TABLE (PREFIX_VEX_0F38BA) },
{ PREFIX_TABLE (PREFIX_VEX_0F38BB) },
{ PREFIX_TABLE (PREFIX_VEX_0F38BC) },
{ PREFIX_TABLE (PREFIX_VEX_0F38BD) },
{ PREFIX_TABLE (PREFIX_VEX_0F38BE) },
{ PREFIX_TABLE (PREFIX_VEX_0F38BF) },
{ "vfmadd231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfmadd231s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ "vfmsub231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfmsub231s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ "vfnmadd231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfnmadd231s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
{ "vfnmsub231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
{ "vfnmsub231s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, PREFIX_DATA },
/* C0 */
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F38C4) },
{ "vpconflict%DQ", { XM, EXx }, PREFIX_DATA },
{ Bad_Opcode },
{ REG_TABLE (REG_EVEX_0F38C6) },
{ REG_TABLE (REG_EVEX_0F38C7) },
/* C8 */
{ PREFIX_TABLE (PREFIX_EVEX_0F38C8) },
{ "vexp2p%XW", { XM, EXx, EXxEVexS }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F38CA) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38CB) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38CC) },
{ PREFIX_TABLE (PREFIX_EVEX_0F38CD) },
{ "vrcp28p%XW", { XM, EXx, EXxEVexS }, PREFIX_DATA },
{ "vrcp28s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS }, PREFIX_DATA },
{ "vrsqrt28p%XW", { XM, EXx, EXxEVexS }, PREFIX_DATA },
{ "vrsqrt28s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS }, PREFIX_DATA },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F38CF) },
{ VEX_W_TABLE (VEX_W_0F38CF) },
/* D0 */
{ Bad_Opcode },
{ Bad_Opcode },
@ -540,10 +540,10 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F38DC) },
{ PREFIX_TABLE (PREFIX_VEX_0F38DD) },
{ PREFIX_TABLE (PREFIX_VEX_0F38DE) },
{ PREFIX_TABLE (PREFIX_VEX_0F38DF) },
{ "vaesenc", { XM, Vex, EXx }, PREFIX_DATA },
{ "vaesenclast", { XM, Vex, EXx }, PREFIX_DATA },
{ "vaesdec", { XM, Vex, EXx }, PREFIX_DATA },
{ "vaesdeclast", { XM, Vex, EXx }, PREFIX_DATA },
/* E0 */
{ Bad_Opcode },
{ Bad_Opcode },
@ -584,50 +584,50 @@ static const struct dis386 evex_table[][256] = {
/* EVEX_0F3A */
{
/* 00 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3A00) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A01) },
{ VEX_W_TABLE (EVEX_W_0F3A00) },
{ VEX_W_TABLE (EVEX_W_0F3A01) },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A03) },
{ PREFIX_TABLE (PREFIX_VEX_0F3A04) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A05) },
{ "valign%DQ", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ VEX_W_TABLE (VEX_W_0F3A04) },
{ VEX_W_TABLE (EVEX_W_0F3A05) },
{ Bad_Opcode },
{ Bad_Opcode },
/* 08 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3A08) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A09) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A0A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A0B) },
{ VEX_W_TABLE (EVEX_W_0F3A08) },
{ VEX_W_TABLE (EVEX_W_0F3A09) },
{ VEX_W_TABLE (EVEX_W_0F3A0A) },
{ VEX_W_TABLE (EVEX_W_0F3A0B) },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F3A0F) },
{ "vpalignr", { XM, Vex, EXx, Ib }, PREFIX_DATA },
/* 10 */
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A14) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A15) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A16) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A17) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A14) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A15) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A16) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A17) },
/* 18 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3A18) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A19) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A1A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A1B) },
{ VEX_W_TABLE (EVEX_W_0F3A18) },
{ VEX_W_TABLE (EVEX_W_0F3A19) },
{ VEX_W_TABLE (EVEX_W_0F3A1A) },
{ VEX_W_TABLE (EVEX_W_0F3A1B) },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F3A1D) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A1E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A1F) },
{ VEX_W_TABLE (VEX_W_0F3A1D) },
{ "vpcmpu%DQ", { XMask, Vex, EXx, VPCMP }, PREFIX_DATA },
{ "vpcmp%DQ", { XMask, Vex, EXx, VPCMP }, PREFIX_DATA },
/* 20 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3A20) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A21) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A22) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A23) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A20) },
{ VEX_W_TABLE (EVEX_W_0F3A21) },
{ EVEX_LEN_TABLE (EVEX_LEN_0F3A22) },
{ VEX_W_TABLE (EVEX_W_0F3A23) },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A25) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A26) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A27) },
{ "vpternlog%DQ", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vgetmantp%XW", { XM, EXx, EXxEVexS, Ib }, PREFIX_DATA },
{ "vgetmants%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, PREFIX_DATA },
/* 28 */
{ Bad_Opcode },
{ Bad_Opcode },
@ -647,20 +647,20 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
/* 38 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3A38) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A39) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A3A) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A3B) },
{ VEX_W_TABLE (EVEX_W_0F3A38) },
{ VEX_W_TABLE (EVEX_W_0F3A39) },
{ VEX_W_TABLE (EVEX_W_0F3A3A) },
{ VEX_W_TABLE (EVEX_W_0F3A3B) },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A3E) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A3F) },
{ "vpcmpu%BW", { XMask, Vex, EXx, VPCMP }, PREFIX_DATA },
{ "vpcmp%BW", { XMask, Vex, EXx, VPCMP }, PREFIX_DATA },
/* 40 */
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A42) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A43) },
{ PREFIX_TABLE (PREFIX_VEX_0F3A44) },
{ VEX_W_TABLE (EVEX_W_0F3A42) },
{ VEX_W_TABLE (EVEX_W_0F3A43) },
{ "vpclmulqdq", { XM, Vex, EXx, PCLMUL }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
@ -674,14 +674,14 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
/* 50 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3A50) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A51) },
{ "vrangep%XW", { XM, Vex, EXx, EXxEVexS, Ib }, PREFIX_DATA },
{ "vranges%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A54) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A55) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A56) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A57) },
{ "vfixupimmp%XW", { XM, Vex, EXx, EXxEVexS, Ib }, PREFIX_DATA },
{ "vfixupimms%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, PREFIX_DATA },
{ "vreducep%XW", { XM, EXx, EXxEVexS, Ib }, PREFIX_DATA },
{ "vreduces%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexS, Ib }, PREFIX_DATA },
/* 58 */
{ Bad_Opcode },
{ Bad_Opcode },
@ -698,8 +698,8 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A66) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A67) },
{ "vfpclassp%XW%XZ", { XMask, EXx, Ib }, PREFIX_DATA },
{ "vfpclasss%XW", { XMask, EXVexWdqScalar, Ib }, PREFIX_DATA },
/* 68 */
{ Bad_Opcode },
{ Bad_Opcode },
@ -710,10 +710,10 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
/* 70 */
{ PREFIX_TABLE (PREFIX_EVEX_0F3A70) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A71) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A72) },
{ PREFIX_TABLE (PREFIX_EVEX_0F3A73) },
{ VEX_W_TABLE (EVEX_W_0F3A70) },
{ "vpshld%DQ", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ VEX_W_TABLE (EVEX_W_0F3A72) },
{ "vpshrd%DQ", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
@ -815,8 +815,8 @@ static const struct dis386 evex_table[][256] = {
{ Bad_Opcode },
{ Bad_Opcode },
{ Bad_Opcode },
{ PREFIX_TABLE (PREFIX_VEX_0F3ACE) },
{ PREFIX_TABLE (PREFIX_VEX_0F3ACF) },
{ VEX_W_TABLE (VEX_W_0F3ACE) },
{ VEX_W_TABLE (VEX_W_0F3ACF) },
/* D0 */
{ Bad_Opcode },
{ Bad_Opcode },

File diff suppressed because it is too large Load Diff