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> 2020-07-14 Jan Beulich <jbeulich@suse.com>
* testsuite/gas/i386/x86-64-avx-intel.d, * 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]+: 26 9b es fwait
[ ]*[a-f0-9]+: 9b 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]+: 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]+: 66 f2 0f 38 17 \(bad\)
[ ]*[a-f0-9]+: f2 66 0f 54 repnz \(bad\) [ ]*[a-f0-9]+: f2 66 0f 54 \(bad\)
[ ]*[a-f0-9]+: f2 0f 54 repnz \(bad\) [ ]*[a-f0-9]+: f2 0f 54 \(bad\)
[ ]*[a-f0-9]+: f2 66 0f 11 22 data16 movsd %xmm4,\(%edx\) [ ]*[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 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\) [ ]*[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]+: 90 nop
[ ]*[a-f0-9]+: f2 0f c7 \(bad\) [ ]*[a-f0-9]+: f2 0f c7 \(bad\)
[ ]*[a-f0-9]+: f0 90 lock nop [ ]*[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]+: ff cc dec %esp
[ ]*[a-f0-9]+: c5 fa 28 \(bad\) * [ ]*[a-f0-9]+: c5 fa 28 \(bad\) *
[ ]*[a-f0-9]+: ff cc dec %esp [ ]*[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> 2020-07-14 Jan Beulich <jbeulich@suse.com>
* i386-dis.c (PREFIX_EVEX_0F2C, PREFIX_EVEX_0F2D, * i386-dis.c (PREFIX_EVEX_0F2C, PREFIX_EVEX_0F2D,

View file

@ -1,7 +1,7 @@
static const struct dis386 evex_len_table[][3] = { 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 */ /* EVEX_LEN_0F7E_P_1 */
@ -14,61 +14,61 @@ static const struct dis386 evex_len_table[][3] = {
{ "vmovK", { Edq, XMScalar }, 0 }, { "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 }, { Bad_Opcode },
{ "vpermp%XW", { XM, Vex, EXx }, 0 }, { "vpermp%XW", { XM, Vex, EXx }, PREFIX_DATA },
{ "vpermp%XW", { XM, Vex, EXx }, 0 }, { "vpermp%XW", { XM, Vex, EXx }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3819_P_2_W_0 */ /* EVEX_LEN_0F3819_W_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vbroadcastf32x2", { XM, EXxmm_mq }, 0 }, { "vbroadcastf32x2", { XM, EXxmm_mq }, PREFIX_DATA },
{ "vbroadcastf32x2", { XM, EXxmm_mq }, 0 }, { "vbroadcastf32x2", { XM, EXxmm_mq }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3819_P_2_W_1 */ /* EVEX_LEN_0F3819_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vbroadcastsd", { XM, EXxmm_mq }, 0 }, { "vbroadcastsd", { XM, EXxmm_mq }, PREFIX_DATA },
{ "vbroadcastsd", { XM, EXxmm_mq }, 0 }, { "vbroadcastsd", { XM, EXxmm_mq }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F381A_P_2_W_0_M_0 */ /* EVEX_LEN_0F381A_W_0_M_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vbroadcastf32x4", { XM, EXxmm }, 0 }, { "vbroadcastf32x4", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcastf32x4", { XM, EXxmm }, 0 }, { "vbroadcastf32x4", { XM, EXxmm }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F381A_P_2_W_1_M_0 */ /* EVEX_LEN_0F381A_W_1_M_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vbroadcastf64x2", { XM, EXxmm }, 0 }, { "vbroadcastf64x2", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcastf64x2", { XM, EXxmm }, 0 }, { "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 },
{ Bad_Opcode }, { Bad_Opcode },
{ "vbroadcastf32x8", { XM, EXymm }, 0 }, { "vbroadcastf32x8", { XM, EXymm }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F381B_P_2_W_1_M_0 */ /* 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 }, { "vbroadcastf64x4", { XM, EXymm }, 0 },
}, },
/* EVEX_LEN_0F3836_P_2 */ /* EVEX_LEN_0F3836 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vperm%DQ", { XM, Vex, EXx }, 0 }, { "vperm%DQ", { XM, Vex, EXx }, PREFIX_DATA },
{ "vperm%DQ", { XM, Vex, EXx }, 0 }, { "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 }, { Bad_Opcode },
{ "vbroadcasti32x4", { XM, EXxmm }, 0 }, { "vbroadcasti32x4", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcasti32x4", { XM, EXxmm }, 0 }, { "vbroadcasti32x4", { XM, EXxmm }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F385A_P_2_W_1_M_0 */ /* EVEX_LEN_0F385A_W_1_M_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vbroadcasti64x2", { XM, EXxmm }, 0 }, { "vbroadcasti64x2", { XM, EXxmm }, PREFIX_DATA },
{ "vbroadcasti64x2", { XM, EXxmm }, 0 }, { "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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 },
{ 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 }, { Bad_Opcode },
{ "vpermq", { XM, EXx, Ib }, 0 }, { "vpermq", { XM, EXx, Ib }, PREFIX_DATA },
{ "vpermq", { XM, EXx, Ib }, 0 }, { "vpermq", { XM, EXx, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A01_P_2_W_1 */ /* EVEX_LEN_0F3A01_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vpermpd", { XM, EXx, Ib }, 0 }, { "vpermpd", { XM, EXx, Ib }, PREFIX_DATA },
{ "vpermpd", { XM, EXx, Ib }, 0 }, { "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 }, { Bad_Opcode },
{ "vinsertf32x4", { XM, Vex, EXxmm, Ib }, 0 }, { "vinsertf32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinsertf32x4", { XM, Vex, EXxmm, Ib }, 0 }, { "vinsertf32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A18_P_2_W_1 */ /* EVEX_LEN_0F3A18_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vinsertf64x2", { XM, Vex, EXxmm, Ib }, 0 }, { "vinsertf64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinsertf64x2", { XM, Vex, EXxmm, Ib }, 0 }, { "vinsertf64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A19_P_2_W_0 */ /* EVEX_LEN_0F3A19_W_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vextractf32x4", { EXxmm, XM, Ib }, 0 }, { "vextractf32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextractf32x4", { EXxmm, XM, Ib }, 0 }, { "vextractf32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A19_P_2_W_1 */ /* EVEX_LEN_0F3A19_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vextractf64x2", { EXxmm, XM, Ib }, 0 }, { "vextractf64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextractf64x2", { EXxmm, XM, Ib }, 0 }, { "vextractf64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A1A_P_2_W_0 */ /* EVEX_LEN_0F3A1A_W_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ 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 },
{ 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 },
{ 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 },
{ 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 }, { Bad_Opcode },
{ "vshuff32x4", { XM, Vex, EXx, Ib }, 0 }, { "vshuff32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshuff32x4", { XM, Vex, EXx, Ib }, 0 }, { "vshuff32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A23_P_2_W_1 */ /* EVEX_LEN_0F3A23_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vshuff64x2", { XM, Vex, EXx, Ib }, 0 }, { "vshuff64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshuff64x2", { XM, Vex, EXx, Ib }, 0 }, { "vshuff64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A38_P_2_W_0 */ /* EVEX_LEN_0F3A38_W_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vinserti32x4", { XM, Vex, EXxmm, Ib }, 0 }, { "vinserti32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinserti32x4", { XM, Vex, EXxmm, Ib }, 0 }, { "vinserti32x4", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A38_P_2_W_1 */ /* EVEX_LEN_0F3A38_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vinserti64x2", { XM, Vex, EXxmm, Ib }, 0 }, { "vinserti64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
{ "vinserti64x2", { XM, Vex, EXxmm, Ib }, 0 }, { "vinserti64x2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A39_P_2_W_0 */ /* EVEX_LEN_0F3A39_W_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vextracti32x4", { EXxmm, XM, Ib }, 0 }, { "vextracti32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextracti32x4", { EXxmm, XM, Ib }, 0 }, { "vextracti32x4", { EXxmm, XM, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A39_P_2_W_1 */ /* EVEX_LEN_0F3A39_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vextracti64x2", { EXxmm, XM, Ib }, 0 }, { "vextracti64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
{ "vextracti64x2", { EXxmm, XM, Ib }, 0 }, { "vextracti64x2", { EXxmm, XM, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A3A_P_2_W_0 */ /* EVEX_LEN_0F3A3A_W_0 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ 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 },
{ 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 },
{ 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 },
{ 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 }, { Bad_Opcode },
{ "vshufi32x4", { XM, Vex, EXx, Ib }, 0 }, { "vshufi32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshufi32x4", { XM, Vex, EXx, Ib }, 0 }, { "vshufi32x4", { XM, Vex, EXx, Ib }, PREFIX_DATA },
}, },
/* EVEX_LEN_0F3A43_P_2_W_1 */ /* EVEX_LEN_0F3A43_W_1 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ "vshufi64x2", { XM, Vex, EXx, Ib }, 0 }, { "vshufi64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
{ "vshufi64x2", { XM, Vex, EXx, Ib }, 0 }, { "vshufi64x2", { XM, Vex, EXx, Ib }, PREFIX_DATA },
}, },
}; };

View file

@ -28,67 +28,67 @@
/* MOD_EVEX_0F2B */ /* MOD_EVEX_0F2B */
{ "vmovntpX", { EXx, XM }, PREFIX_OPCODE }, { "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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 */ /* 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 }, { "vmaxpX", { XM, Vex, EXx, EXxEVexS }, PREFIX_OPCODE },
{ VEX_W_TABLE (EVEX_W_0F5F_P_3) }, { 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 */ /* PREFIX_EVEX_0F6F */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -132,96 +108,6 @@
{ VEX_W_TABLE (EVEX_W_0F70_P_2) }, { VEX_W_TABLE (EVEX_W_0F70_P_2) },
{ "vpshuflw", { XM, EXx, Ib }, 0 }, { "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 */ /* PREFIX_EVEX_0F78 */
{ {
{ VEX_W_TABLE (EVEX_W_0F78_P_0) }, { VEX_W_TABLE (EVEX_W_0F78_P_0) },
@ -270,42 +156,6 @@
{ "vcmppX", { XMask, Vex, EXx, EXxEVexS, CMP }, PREFIX_OPCODE }, { "vcmppX", { XMask, Vex, EXx, EXxEVexS, CMP }, PREFIX_OPCODE },
{ VEX_W_TABLE (EVEX_W_0FC2_P_3) }, { 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 */ /* PREFIX_EVEX_0FE6 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -313,30 +163,6 @@
{ VEX_W_TABLE (EVEX_W_0FE6_P_2) }, { VEX_W_TABLE (EVEX_W_0FE6_P_2) },
{ VEX_W_TABLE (EVEX_W_0FE6_P_3) }, { 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 */ /* PREFIX_EVEX_0F3810 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -373,42 +199,6 @@
{ VEX_W_TABLE (EVEX_W_0F3815_P_1) }, { VEX_W_TABLE (EVEX_W_0F3815_P_1) },
{ "vprolv%DQ", { XM, Vex, EXx }, 0 }, { "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 */ /* PREFIX_EVEX_0F3820 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -475,18 +265,6 @@
{ VEX_W_TABLE (EVEX_W_0F382A_P_1) }, { VEX_W_TABLE (EVEX_W_0F382A_P_1) },
{ VEX_W_TABLE (EVEX_W_0F382A_P_2) }, { 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 */ /* PREFIX_EVEX_0F3830 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -523,18 +301,6 @@
{ VEX_W_TABLE (EVEX_W_0F3835_P_1) }, { VEX_W_TABLE (EVEX_W_0F3835_P_1) },
{ VEX_W_TABLE (EVEX_W_0F3835_P_2) }, { 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 */ /* PREFIX_EVEX_0F3838 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -553,102 +319,6 @@
{ VEX_W_TABLE (EVEX_W_0F383A_P_1) }, { VEX_W_TABLE (EVEX_W_0F383A_P_1) },
{ "vpminuw", { XM, Vex, EXx }, 0 }, { "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 */ /* PREFIX_EVEX_0F3852 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -663,66 +333,6 @@
{ "vpdpwssds", { XM, Vex, EXx }, 0 }, { "vpdpwssds", { XM, Vex, EXx }, 0 },
{ "vp4dpwssds", { XM, Vex, EXxmm }, 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 */ /* PREFIX_EVEX_0F3868 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -730,18 +340,6 @@
{ Bad_Opcode }, { Bad_Opcode },
{ "vp2intersect%DQ", { XMask, Vex, EXx, EXxEVexS }, 0 }, { "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 */ /* PREFIX_EVEX_0F3872 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -749,132 +347,6 @@
{ VEX_W_TABLE (EVEX_W_0F3872_P_2) }, { VEX_W_TABLE (EVEX_W_0F3872_P_2) },
{ VEX_W_TABLE (EVEX_W_0F3872_P_3) }, { 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 */ /* PREFIX_EVEX_0F389A */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -889,30 +361,6 @@
{ "vfmsub132s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, 0 }, { "vfmsub132s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, 0 },
{ "v4fmaddss", { XMScalar, VexScalar, Mxmm }, 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 */ /* PREFIX_EVEX_0F38AA */
{ {
{ Bad_Opcode }, { Bad_Opcode },
@ -927,369 +375,3 @@
{ "vfmsub213s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, 0 }, { "vfmsub213s%XW", { XMScalar, VexScalar, EXVexWdqScalar, EXxEVexR }, 0 },
{ "v4fnmaddss", { XMScalar, VexScalar, Mxmm }, 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 },
{ Bad_Opcode }, { Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F71_REG_2) }, { "vpsrlw", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode }, { Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F71_REG_4) }, { "vpsraw", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode }, { Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F71_REG_6) }, { "vpsllw", { Vex, EXx, Ib }, PREFIX_DATA },
}, },
/* REG_EVEX_0F72 */ /* REG_EVEX_0F72 */
{ {
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_0) }, { "vpror%DQ", { Vex, EXx, Ib }, PREFIX_DATA },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_1) }, { "vprol%DQ", { Vex, EXx, Ib }, PREFIX_DATA },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_2) }, { VEX_W_TABLE (EVEX_W_0F72_R_2) },
{ Bad_Opcode }, { Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_4) }, { "vpsra%DQ", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode }, { Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F72_REG_6) }, { VEX_W_TABLE (EVEX_W_0F72_R_6) },
}, },
/* REG_EVEX_0F73 */ /* REG_EVEX_0F73 */
{ {
{ Bad_Opcode }, { Bad_Opcode },
{ Bad_Opcode }, { Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_2) }, { VEX_W_TABLE (EVEX_W_0F73_R_2) },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_3) }, { "vpsrldq", { Vex, EXx, Ib }, PREFIX_DATA },
{ Bad_Opcode }, { Bad_Opcode },
{ Bad_Opcode }, { Bad_Opcode },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_6) }, { VEX_W_TABLE (EVEX_W_0F73_R_6) },
{ PREFIX_TABLE (PREFIX_EVEX_0F73_REG_7) }, { "vpslldq", { Vex, EXx, Ib }, PREFIX_DATA },
}, },
/* REG_EVEX_0F38C6 */ /* REG_EVEX_0F38C6 */
{ {

View file

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

File diff suppressed because it is too large Load diff