x86: consistently use scalar_mode for AVX512-FP16 scalar insns
[binutils-gdb.git] / opcodes / i386-dis-evex.h
index 5de4cc56b19fa95bfdd377bf12a6dc2b7b6836d7..fe39026a87171ef78d796d4bae5267502d8f3e53 100644 (file)
@@ -23,11 +23,11 @@ static const struct dis386 evex_table[][256] = {
     { PREFIX_TABLE (PREFIX_EVEX_0F10) },
     { PREFIX_TABLE (PREFIX_EVEX_0F11) },
     { PREFIX_TABLE (PREFIX_EVEX_0F12) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F13) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F14) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F15) },
+    { MOD_TABLE (MOD_EVEX_0F13) },
+    { "vunpcklpX",     { XM, Vex, EXx }, PREFIX_OPCODE },
+    { "vunpckhpX",     { XM, Vex, EXx }, PREFIX_OPCODE },
     { PREFIX_TABLE (PREFIX_EVEX_0F16) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F17) },
+    { MOD_TABLE (MOD_EVEX_0F17) },
     /* 18 */
     { Bad_Opcode },
     { Bad_Opcode },
@@ -47,14 +47,14 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     /* 28 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F28) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F29) },
+    { "vmovapX",       { XM, EXx }, PREFIX_OPCODE },
+    { "vmovapX",       { EXxS, XM }, PREFIX_OPCODE },
     { PREFIX_TABLE (PREFIX_EVEX_0F2A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F2B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F2C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F2D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F2E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F2F) },
+    { MOD_TABLE (MOD_EVEX_0F2B) },
+    { PREFIX_TABLE (PREFIX_VEX_0F2C) },
+    { PREFIX_TABLE (PREFIX_VEX_0F2D) },
+    { PREFIX_TABLE (PREFIX_VEX_0F2E) },
+    { PREFIX_TABLE (PREFIX_VEX_0F2F) },
     /* 30 */
     { Bad_Opcode },
     { Bad_Opcode },
@@ -96,10 +96,10 @@ static const struct dis386 evex_table[][256] = {
     { PREFIX_TABLE (PREFIX_EVEX_0F51) },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F54) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F55) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F56) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F57) },
+    { "vandpX",        { XM, Vex, EXx }, PREFIX_OPCODE },
+    { "vandnpX",       { XM, Vex, EXx }, PREFIX_OPCODE },
+    { "vorpX", { XM, Vex, EXx }, PREFIX_OPCODE },
+    { "vxorpX",        { XM, Vex, EXx }, PREFIX_OPCODE },
     /* 58 */
     { PREFIX_TABLE (PREFIX_EVEX_0F58) },
     { PREFIX_TABLE (PREFIX_EVEX_0F59) },
@@ -110,31 +110,31 @@ static const struct dis386 evex_table[][256] = {
     { PREFIX_TABLE (PREFIX_EVEX_0F5E) },
     { PREFIX_TABLE (PREFIX_EVEX_0F5F) },
     /* 60 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F60) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F61) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F62) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F63) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F64) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F65) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F66) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F67) },
+    { "vpunpcklbw",    { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpunpcklwd",    { XM, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0F62) },
+    { "vpacksswb",     { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpcmpgtb",      { MaskG, Vex, EXx }, PREFIX_DATA },
+    { "vpcmpgtw",      { MaskG, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0F66) },
+    { "vpackuswb",     { XM, Vex, EXx }, PREFIX_DATA },
     /* 68 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F68) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F69) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F6A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F6B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F6C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F6D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F6E) },
+    { "vpunpckhbw",    { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpunpckhwd",    { XM, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0F6A) },
+    { VEX_W_TABLE (EVEX_W_0F6B) },
+    { VEX_W_TABLE (EVEX_W_0F6C) },
+    { VEX_W_TABLE (EVEX_W_0F6D) },
+    { VEX_LEN_TABLE (VEX_LEN_0F6E) },
     { PREFIX_TABLE (PREFIX_EVEX_0F6F) },
     /* 70 */
     { PREFIX_TABLE (PREFIX_EVEX_0F70) },
     { REG_TABLE (REG_EVEX_0F71) },
     { REG_TABLE (REG_EVEX_0F72) },
     { REG_TABLE (REG_EVEX_0F73) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F74) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F75) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F76) },
+    { "vpcmpeqb",      { MaskG, Vex, EXx }, PREFIX_DATA },
+    { "vpcmpeqw",      { MaskG, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0F76) },
     { Bad_Opcode },
     /* 78 */
     { PREFIX_TABLE (PREFIX_EVEX_0F78) },
@@ -222,9 +222,9 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { PREFIX_TABLE (PREFIX_EVEX_0FC2) },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0FC4) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FC5) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FC6) },
+    { VEX_LEN_TABLE (VEX_LEN_0FC4) },
+    { VEX_LEN_TABLE (VEX_LEN_0FC5) },
+    { "vshufpX",       { XM, Vex, EXx, Ib }, PREFIX_OPCODE },
     { Bad_Opcode },
     /* C8 */
     { Bad_Opcode },
@@ -237,67 +237,67 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     /* D0 */
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0FD1) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FD2) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FD3) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FD4) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FD5) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FD6) },
+    { "vpsrlw",                { XM, Vex, EXxmm }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0FD2) },
+    { VEX_W_TABLE (EVEX_W_0FD3) },
+    { VEX_W_TABLE (EVEX_W_0FD4) },
+    { "vpmullw",       { XM, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0FD6) },
     { Bad_Opcode },
     /* D8 */
-    { PREFIX_TABLE (PREFIX_EVEX_0FD8) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FD9) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FDA) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FDB) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FDC) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FDD) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FDE) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FDF) },
+    { "vpsubusb",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpsubusw",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpminub",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpand%DQ",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpaddusb",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpaddusw",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmaxub",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpandn%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
     /* E0 */
-    { PREFIX_TABLE (PREFIX_EVEX_0FE0) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FE1) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FE2) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FE3) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FE4) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FE5) },
+    { "vpavgb",                { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpsraw",                { XM, Vex, EXxmm }, PREFIX_DATA },
+    { "vpsra%DQ",      { XM, Vex, EXxmm }, PREFIX_DATA },
+    { "vpavgw",                { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmulhuw",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmulhw",       { XM, Vex, EXx }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0FE6) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FE7) },
+    { VEX_W_TABLE (EVEX_W_0FE7) },
     /* E8 */
-    { PREFIX_TABLE (PREFIX_EVEX_0FE8) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FE9) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FEA) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FEB) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FEC) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FED) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FEE) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FEF) },
+    { "vpsubsb",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpsubsw",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpminsw",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpor%DQ",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpaddsb",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpaddsw",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmaxsw",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpxor%DQ",      { XM, Vex, EXx }, PREFIX_DATA },
     /* F0 */
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0FF1) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FF2) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FF3) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FF4) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FF5) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FF6) },
+    { "vpsllw",                { XM, Vex, EXxmm }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0FF2) },
+    { VEX_W_TABLE (EVEX_W_0FF3) },
+    { VEX_W_TABLE (EVEX_W_0FF4) },
+    { "vpmaddwd",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpsadbw",       { XM, Vex, EXx }, PREFIX_DATA },
     { Bad_Opcode },
     /* F8 */
-    { PREFIX_TABLE (PREFIX_EVEX_0FF8) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FF9) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FFA) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FFB) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FFC) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FFD) },
-    { PREFIX_TABLE (PREFIX_EVEX_0FFE) },
+    { "vpsubb",                { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpsubw",                { XM, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0FFA) },
+    { VEX_W_TABLE (EVEX_W_0FFB) },
+    { "vpaddb",                { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpaddw",                { XM, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0FFE) },
     { Bad_Opcode },
   },
   /* EVEX_0F38 */
   {
     /* 00 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3800) },
+    { "vpshufb",       { XM, Vex, EXx }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3804) },
+    { "vpmaddubsw",    { XM, Vex, EXx }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
@@ -305,9 +305,9 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F380B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F380C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F380D) },
+    { "vpmulhrsw",     { XM, Vex, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (VEX_W_0F380C) },
+    { "vpermilp%XD", { XM, Vex, EXx }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     /* 10 */
@@ -317,17 +317,17 @@ static const struct dis386 evex_table[][256] = {
     { PREFIX_TABLE (PREFIX_EVEX_0F3813) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3814) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3815) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3816) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3816) },
     { Bad_Opcode },
     /* 18 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3818) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3819) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F381A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F381B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F381C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F381D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F381E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F381F) },
+    { VEX_W_TABLE (VEX_W_0F3818) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3819) },
+    { MOD_TABLE (MOD_EVEX_0F381A) },
+    { MOD_TABLE (MOD_EVEX_0F381B) },
+    { "vpabsb",                { XM, EXx }, PREFIX_DATA },
+    { "vpabsw",                { XM, EXx }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0F381E) },
+    { VEX_W_TABLE (EVEX_W_0F381F) },
     /* 20 */
     { PREFIX_TABLE (PREFIX_EVEX_0F3820) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3821) },
@@ -341,9 +341,9 @@ static const struct dis386 evex_table[][256] = {
     { PREFIX_TABLE (PREFIX_EVEX_0F3828) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3829) },
     { PREFIX_TABLE (PREFIX_EVEX_0F382A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F382B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F382C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F382D) },
+    { VEX_W_TABLE (EVEX_W_0F382B) },
+    { "vscalefp%XW",   { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vscalefs%XW",   { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     /* 30 */
@@ -353,49 +353,49 @@ static const struct dis386 evex_table[][256] = {
     { PREFIX_TABLE (PREFIX_EVEX_0F3833) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3834) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3835) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3836) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3837) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3836) },
+    { VEX_W_TABLE (EVEX_W_0F3837) },
     /* 38 */
     { PREFIX_TABLE (PREFIX_EVEX_0F3838) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3839) },
     { PREFIX_TABLE (PREFIX_EVEX_0F383A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F383B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F383C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F383D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F383E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F383F) },
+    { "vpminu%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmaxsb",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmaxs%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmaxuw",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmaxu%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
     /* 40 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3840) },
-    { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3842) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3843) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3844) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3845) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3846) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3847) },
+    { "vpmull%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
+    { Bad_Opcode },
+    { "vgetexpp%XW",   { XM, EXx, EXxEVexS }, PREFIX_DATA },
+    { "vgetexps%XW",   { XMScalar, VexScalar, EXdq, EXxEVexS }, PREFIX_DATA },
+    { "vplzcnt%DQ",    { XM, EXx }, PREFIX_DATA },
+    { "vpsrlv%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpsrav%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpsllv%DQ",     { XM, Vex, EXx }, PREFIX_DATA },
     /* 48 */
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F384C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F384D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F384E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F384F) },
+    { "vrcp14p%XW",    { XM, EXx }, PREFIX_DATA },
+    { "vrcp14s%XW",    { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
+    { "vrsqrt14p%XW",  { XM, EXx }, 0 },
+    { "vrsqrt14s%XW",  { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
     /* 50 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3850) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3851) },
+    { "vpdpbusd",      { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpdpbusds",     { XM, Vex, EXx }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0F3852) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3853) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3854) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3855) },
+    { "vpopcnt%BW",    { XM, EXx }, PREFIX_DATA },
+    { "vpopcnt%DQ",    { XM, EXx }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     /* 58 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3858) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3859) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F385A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F385B) },
+    { VEX_W_TABLE (VEX_W_0F3858) },
+    { VEX_W_TABLE (EVEX_W_0F3859) },
+    { MOD_TABLE (MOD_EVEX_0F385A) },
+    { MOD_TABLE (MOD_EVEX_0F385B) },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
@@ -403,11 +403,11 @@ static const struct dis386 evex_table[][256] = {
     /* 60 */
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3862) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3863) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3864) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3865) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3866) },
+    { "vpexpand%BW",   { XM, EXbwUnit }, PREFIX_DATA },
+    { "vpcompress%BW", { EXbwUnit, XM }, PREFIX_DATA },
+    { "vpblendm%DQ",   { XM, Vex, EXx }, PREFIX_DATA },
+    { "vblendmp%XW",   { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpblendm%BW",   { XM, Vex, EXx }, PREFIX_DATA },
     { Bad_Opcode },
     /* 68 */
     { PREFIX_TABLE (PREFIX_EVEX_0F3868) },
@@ -419,113 +419,113 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     /* 70 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3870) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3871) },
+    { VEX_W_TABLE (EVEX_W_0F3870) },
+    { "vpshldv%DQ",  { XM, Vex, EXx }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0F3872) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3873) },
+    { "vpshrdv%DQ",  { XM, Vex, EXx }, PREFIX_DATA },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3875) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3876) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3877) },
+    { "vpermi2%BW",    { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpermi2%DQ",    { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpermi2p%XW",   { XM, Vex, EXx }, PREFIX_DATA },
     /* 78 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3878) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3879) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F387A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F387B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F387C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F387D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F387E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F387F) },
+    { VEX_W_TABLE (VEX_W_0F3878) },
+    { VEX_W_TABLE (VEX_W_0F3879) },
+    { VEX_W_TABLE (EVEX_W_0F387A) },
+    { VEX_W_TABLE (EVEX_W_0F387B) },
+    { MOD_TABLE (MOD_EVEX_0F387C) },
+    { "vpermt2%BW",    { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpermt2%DQ",    { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpermt2p%XW",   { XM, Vex, EXx }, PREFIX_DATA },
     /* 80 */
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3883) },
+    { VEX_W_TABLE (EVEX_W_0F3883) },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
     /* 88 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3888) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3889) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F388A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F388B) },
+    { "vexpandp%XW",   { XM, EXEvexXGscat }, PREFIX_DATA },
+    { "vpexpand%DQ",   { XM, EXEvexXGscat }, PREFIX_DATA },
+    { "vcompressp%XW", { EXEvexXGscat, XM }, PREFIX_DATA },
+    { "vpcompress%DQ", { EXEvexXGscat, XM }, PREFIX_DATA },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F388D) },
+    { "vperm%BW",      { XM, Vex, EXx }, PREFIX_DATA },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F388F) },
+    { "vpshufbitqmb",  { MaskG, Vex, EXx }, PREFIX_DATA },
     /* 90 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3890) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3891) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3892) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3893) },
+    { "vpgatherd%DQ",  { XMGatherD, MVexVSIBDWpX }, PREFIX_DATA },
+    { "vpgatherq%DQ",  { XMGatherQ, MVexVSIBQWpX }, PREFIX_DATA },
+    { "vgatherdp%XW",  { XMGatherD, MVexVSIBDWpX }, PREFIX_DATA },
+    { "vgatherqp%XW",  { XMGatherQ, MVexVSIBQWpX }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3896) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3897) },
+    { "vfmaddsub132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfmsubadd132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
     /* 98 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3898) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3899) },
+    { "vfmadd132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfmadd132s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0F389A) },
     { PREFIX_TABLE (PREFIX_EVEX_0F389B) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F389C) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F389D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F389E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F389F) },
+    { "vfnmadd132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd132s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub132p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub132s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
     /* A0 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A0) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A1) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A2) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A3) },
+    { "vpscatterd%DQ", { MVexVSIBDWpX, XM }, PREFIX_DATA },
+    { "vpscatterq%DQ", { MVexVSIBQWpX, XMGatherQ }, PREFIX_DATA },
+    { "vscatterdp%XW", { MVexVSIBDWpX, XM }, PREFIX_DATA },
+    { "vscatterqp%XW", { MVexVSIBQWpX, XMGatherQ }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A6) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A7) },
+    { "vfmaddsub213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfmsubadd213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
     /* A8 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A8) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38A9) },
+    { "vfmadd213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfmadd213s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0F38AA) },
     { PREFIX_TABLE (PREFIX_EVEX_0F38AB) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38AC) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38AD) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38AE) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38AF) },
+    { "vfnmadd213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd213s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub213p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub213s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
     /* B0 */
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38B4) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38B5) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38B6) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38B7) },
+    { "vpmadd52luq",   { XM, Vex, EXx }, PREFIX_DATA },
+    { "vpmadd52huq",   { XM, Vex, EXx }, PREFIX_DATA },
+    { "vfmaddsub231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfmsubadd231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
     /* B8 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F38B8) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38B9) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38BA) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38BB) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38BC) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38BD) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38BE) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38BF) },
+    { "vfmadd231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfmadd231s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub231s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd231s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub231p%XW", { XM, Vex, EXx, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub231s%XW", { XMScalar, VexScalar, EXdq, EXxEVexR }, PREFIX_DATA },
     /* C0 */
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38C4) },
+    { "vpconflict%DQ", { XM, EXx }, PREFIX_DATA },
     { Bad_Opcode },
-    { REG_TABLE (REG_EVEX_0F38C6) },
-    { REG_TABLE (REG_EVEX_0F38C7) },
+    { MOD_TABLE (MOD_EVEX_0F38C6) },
+    { MOD_TABLE (MOD_EVEX_0F38C7) },
     /* C8 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F38C8) },
+    { "vexp2p%XW",     { XM, EXx, EXxEVexS }, PREFIX_DATA },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38CA) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38CB) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38CC) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38CD) },
+    { "vrcp28p%XW",    { XM, EXx, EXxEVexS }, PREFIX_DATA },
+    { "vrcp28s%XW",    { XMScalar, VexScalar, EXdq, EXxEVexS }, PREFIX_DATA },
+    { "vrsqrt28p%XW",  { XM, EXx, EXxEVexS }, PREFIX_DATA },
+    { "vrsqrt28s%XW",  { XMScalar, VexScalar, EXdq, EXxEVexS }, PREFIX_DATA },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38CF) },
+    { VEX_W_TABLE (VEX_W_0F38CF) },
     /* D0 */
     { Bad_Opcode },
     { Bad_Opcode },
@@ -540,10 +540,10 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38DC) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38DD) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38DE) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F38DF) },
+    { "vaesenc",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vaesenclast",   { XM, Vex, EXx }, PREFIX_DATA },
+    { "vaesdec",       { XM, Vex, EXx }, PREFIX_DATA },
+    { "vaesdeclast",   { XM, Vex, EXx }, PREFIX_DATA },
     /* E0 */
     { Bad_Opcode },
     { Bad_Opcode },
@@ -584,48 +584,48 @@ static const struct dis386 evex_table[][256] = {
   /* EVEX_0F3A */
   {
     /* 00 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A00) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A01) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A00) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A01) },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A03) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A04) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A05) },
+    { "valign%DQ",     { XM, Vex, EXx, Ib }, PREFIX_DATA },
+    { VEX_W_TABLE (VEX_W_0F3A04) },
+    { "vpermilp%XD", { XM, EXx, Ib }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     /* 08 */
     { PREFIX_TABLE (PREFIX_EVEX_0F3A08) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A09) },
+    { "vrndscalep%XD", { XM, EXx, EXxEVexS, Ib }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0F3A0A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A0B) },
+    { "vrndscales%XD", { XMScalar, VexScalar, EXq, EXxEVexS, Ib }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A0F) },
+    { "vpalignr",      { XM, Vex, EXx, Ib }, PREFIX_DATA },
     /* 10 */
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A14) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A15) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A16) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A17) },
+    { VEX_LEN_TABLE (VEX_LEN_0F3A14) },
+    { VEX_LEN_TABLE (VEX_LEN_0F3A15) },
+    { VEX_LEN_TABLE (VEX_LEN_0F3A16) },
+    { VEX_LEN_TABLE (VEX_LEN_0F3A17) },
     /* 18 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A18) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A19) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A1A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A1B) },
-    { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A1D) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A1E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A1F) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A18) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A19) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A1A) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A1B) },
+    { Bad_Opcode },
+    { VEX_W_TABLE (VEX_W_0F3A1D) },
+    { "vpcmpu%DQ",     { MaskG, Vex, EXx, VPCMP }, PREFIX_DATA },
+    { "vpcmp%DQ",      { MaskG, Vex, EXx, VPCMP }, PREFIX_DATA },
     /* 20 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A20) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A21) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A22) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A23) },
+    { VEX_LEN_TABLE (VEX_LEN_0F3A20) },
+    { VEX_W_TABLE (EVEX_W_0F3A21) },
+    { VEX_LEN_TABLE (VEX_LEN_0F3A22) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A23) },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A25) },
+    { "vpternlog%DQ",  { XM, Vex, EXx, Ib }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0F3A26) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3A27) },
     /* 28 */
@@ -647,20 +647,20 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     /* 38 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A38) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A39) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A3A) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A3B) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A38) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A39) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A3A) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A3B) },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A3E) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A3F) },
+    { "vpcmpu%BW",     { MaskG, Vex, EXx, VPCMP }, PREFIX_DATA },
+    { "vpcmp%BW",      { MaskG, Vex, EXx, VPCMP }, PREFIX_DATA },
     /* 40 */
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A42) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A43) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A44) },
+    { VEX_W_TABLE (EVEX_W_0F3A42) },
+    { EVEX_LEN_TABLE (EVEX_LEN_0F3A43) },
+    { "vpclmulqdq",    { XM, Vex, EXx, PCLMUL }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
@@ -674,12 +674,12 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     /* 50 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A50) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A51) },
+    { "vrangep%XW",    { XM, Vex, EXx, EXxEVexS, Ib }, PREFIX_DATA },
+    { "vranges%XW",    { XMScalar, VexScalar, EXdq, EXxEVexS, Ib }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A54) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A55) },
+    { "vfixupimmp%XW", { XM, Vex, EXx, EXxEVexS, Ib }, PREFIX_DATA },
+    { "vfixupimms%XW", { XMScalar, VexScalar, EXdq, EXxEVexS, Ib }, PREFIX_DATA },
     { PREFIX_TABLE (PREFIX_EVEX_0F3A56) },
     { PREFIX_TABLE (PREFIX_EVEX_0F3A57) },
     /* 58 */
@@ -710,10 +710,10 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     /* 70 */
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A70) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A71) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A72) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3A73) },
+    { VEX_W_TABLE (EVEX_W_0F3A70) },
+    { "vpshld%DQ",   { XM, Vex, EXx, Ib }, PREFIX_DATA },
+    { VEX_W_TABLE (EVEX_W_0F3A72) },
+    { "vpshrd%DQ",   { XM, Vex, EXx, Ib }, PREFIX_DATA },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
@@ -802,6 +802,297 @@ static const struct dis386 evex_table[][256] = {
     /* C0 */
     { Bad_Opcode },
     { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_0F3AC2) },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* C8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { VEX_W_TABLE (VEX_W_0F3ACE) },
+    { VEX_W_TABLE (VEX_W_0F3ACF) },
+    /* D0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* D8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* E0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* E8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* F0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* F8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+  },
+  /* EVEX_MAP5_ */
+  {
+    /* 00 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 08 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 10 */
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_10) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_11) },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 18 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_1D) },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 20 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 28 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_2A) },
+    { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_2C) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_2D) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_2E) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_2F) },
+    /* 30 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 38 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 40 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 48 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 50 */
+    { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_51) },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 58 */
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_58) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_59) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_5A) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_5B) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_5C) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_5D) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_5E) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_5F) },
+    /* 60 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 68 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { "vmovw", { XMScalar, Edw }, PREFIX_DATA },
+    { Bad_Opcode },
+    /* 70 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 78 */
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_78) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_79) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_7A) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_7B) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_7C) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP5_7D) },
+    { "vmovw",   { Edw, XMScalar }, PREFIX_DATA },
+    { Bad_Opcode },
+    /* 80 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 88 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 90 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 98 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* A0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* A8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* B0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* B8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* C0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
@@ -815,8 +1106,8 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
     { Bad_Opcode },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3ACE) },
-    { PREFIX_TABLE (PREFIX_EVEX_0F3ACF) },
+    { Bad_Opcode },
+    { Bad_Opcode },
     /* D0 */
     { Bad_Opcode },
     { Bad_Opcode },
@@ -872,4 +1163,295 @@ static const struct dis386 evex_table[][256] = {
     { Bad_Opcode },
     { Bad_Opcode },
   },
+  /* EVEX_MAP6_ */
+  {
+    /* 00 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 08 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 10 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP6_13) },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 18 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 20 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 28 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { "vscalefp%XH",      { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vscalefs%XH",      { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 30 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 38 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 40 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { "vgetexpp%XH",      { XM, EXxh, EXxEVexS }, PREFIX_DATA },
+    { "vgetexps%XH",      { XMScalar, VexScalar, EXw, EXxEVexS }, PREFIX_DATA },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 48 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { "vrcpp%XH",        { XM, EXxh }, PREFIX_DATA },
+    { "vrcps%XH",        { XMScalar, VexScalar, EXw }, PREFIX_DATA },
+    { "vrsqrtp%XH",       { XM, EXxh }, PREFIX_DATA },
+    { "vrsqrts%XH",       { XMScalar, VexScalar, EXw }, PREFIX_DATA },
+    /* 50 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP6_56) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP6_57) },
+    /* 58 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 60 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 68 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 70 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 78 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 80 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 88 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* 90 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { "vfmaddsub132p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmsubadd132p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    /* 98 */
+    { "vfmadd132p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmadd132s%XH",  { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub132p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub132s%XH",  { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd132p%XH", { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd132s%XH", { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub132p%XH", { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub132s%XH", { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    /* A0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { "vfmaddsub213p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmsubadd213p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    /* A8 */
+    { "vfmadd213p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmadd213s%XH",  { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub213p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub213s%XH",  { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd213p%XH", { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd213s%XH", { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub213p%XH", { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub213s%XH", { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    /* B0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { "vfmaddsub231p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmsubadd231p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    /* B8 */
+    { "vfmadd231p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmadd231s%XH",  { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub231p%XH",  { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfmsub231s%XH",  { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd231p%XH", { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfnmadd231s%XH", { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub231p%XH", { XM, Vex, EXxh, EXxEVexR }, PREFIX_DATA },
+    { "vfnmsub231s%XH", { XMScalar, VexScalar, EXw, EXxEVexR }, PREFIX_DATA },
+    /* C0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* C8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* D0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP6_D6) },
+    { PREFIX_TABLE (PREFIX_EVEX_MAP6_D7) },
+    /* D8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* E0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* E8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* F0 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    /* F8 */
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+    { Bad_Opcode },
+  },
 };