1 #ifdef NEED_OPCODE_TABLE
3 static const struct dis386 evex_table[][256] = {
25 { PREFIX_TABLE (PREFIX_EVEX_0F10) },
26 { PREFIX_TABLE (PREFIX_EVEX_0F11) },
27 { PREFIX_TABLE (PREFIX_EVEX_0F12) },
28 { PREFIX_TABLE (PREFIX_EVEX_0F13) },
29 { PREFIX_TABLE (PREFIX_EVEX_0F14) },
30 { PREFIX_TABLE (PREFIX_EVEX_0F15) },
31 { PREFIX_TABLE (PREFIX_EVEX_0F16) },
32 { PREFIX_TABLE (PREFIX_EVEX_0F17) },
52 { PREFIX_TABLE (PREFIX_EVEX_0F28) },
53 { PREFIX_TABLE (PREFIX_EVEX_0F29) },
54 { PREFIX_TABLE (PREFIX_EVEX_0F2A) },
55 { PREFIX_TABLE (PREFIX_EVEX_0F2B) },
56 { PREFIX_TABLE (PREFIX_EVEX_0F2C) },
57 { PREFIX_TABLE (PREFIX_EVEX_0F2D) },
58 { PREFIX_TABLE (PREFIX_EVEX_0F2E) },
59 { PREFIX_TABLE (PREFIX_EVEX_0F2F) },
98 { PREFIX_TABLE (PREFIX_EVEX_0F51) },
101 { PREFIX_TABLE (PREFIX_EVEX_0F54) },
102 { PREFIX_TABLE (PREFIX_EVEX_0F55) },
103 { PREFIX_TABLE (PREFIX_EVEX_0F56) },
104 { PREFIX_TABLE (PREFIX_EVEX_0F57) },
106 { PREFIX_TABLE (PREFIX_EVEX_0F58) },
107 { PREFIX_TABLE (PREFIX_EVEX_0F59) },
108 { PREFIX_TABLE (PREFIX_EVEX_0F5A) },
109 { PREFIX_TABLE (PREFIX_EVEX_0F5B) },
110 { PREFIX_TABLE (PREFIX_EVEX_0F5C) },
111 { PREFIX_TABLE (PREFIX_EVEX_0F5D) },
112 { PREFIX_TABLE (PREFIX_EVEX_0F5E) },
113 { PREFIX_TABLE (PREFIX_EVEX_0F5F) },
115 { PREFIX_TABLE (PREFIX_EVEX_0F60) },
116 { PREFIX_TABLE (PREFIX_EVEX_0F61) },
117 { PREFIX_TABLE (PREFIX_EVEX_0F62) },
118 { PREFIX_TABLE (PREFIX_EVEX_0F63) },
119 { PREFIX_TABLE (PREFIX_EVEX_0F64) },
120 { PREFIX_TABLE (PREFIX_EVEX_0F65) },
121 { PREFIX_TABLE (PREFIX_EVEX_0F66) },
122 { PREFIX_TABLE (PREFIX_EVEX_0F67) },
124 { PREFIX_TABLE (PREFIX_EVEX_0F68) },
125 { PREFIX_TABLE (PREFIX_EVEX_0F69) },
126 { PREFIX_TABLE (PREFIX_EVEX_0F6A) },
127 { PREFIX_TABLE (PREFIX_EVEX_0F6B) },
128 { PREFIX_TABLE (PREFIX_EVEX_0F6C) },
129 { PREFIX_TABLE (PREFIX_EVEX_0F6D) },
130 { PREFIX_TABLE (PREFIX_EVEX_0F6E) },
131 { PREFIX_TABLE (PREFIX_EVEX_0F6F) },
133 { PREFIX_TABLE (PREFIX_EVEX_0F70) },
134 { REG_TABLE (REG_EVEX_0F71) },
135 { REG_TABLE (REG_EVEX_0F72) },
136 { REG_TABLE (REG_EVEX_0F73) },
137 { PREFIX_TABLE (PREFIX_EVEX_0F74) },
138 { PREFIX_TABLE (PREFIX_EVEX_0F75) },
139 { PREFIX_TABLE (PREFIX_EVEX_0F76) },
142 { PREFIX_TABLE (PREFIX_EVEX_0F78) },
143 { PREFIX_TABLE (PREFIX_EVEX_0F79) },
144 { PREFIX_TABLE (PREFIX_EVEX_0F7A) },
145 { PREFIX_TABLE (PREFIX_EVEX_0F7B) },
148 { PREFIX_TABLE (PREFIX_EVEX_0F7E) },
149 { PREFIX_TABLE (PREFIX_EVEX_0F7F) },
225 { PREFIX_TABLE (PREFIX_EVEX_0FC2) },
227 { PREFIX_TABLE (PREFIX_EVEX_0FC4) },
228 { PREFIX_TABLE (PREFIX_EVEX_0FC5) },
229 { PREFIX_TABLE (PREFIX_EVEX_0FC6) },
242 { PREFIX_TABLE (PREFIX_EVEX_0FD1) },
243 { PREFIX_TABLE (PREFIX_EVEX_0FD2) },
244 { PREFIX_TABLE (PREFIX_EVEX_0FD3) },
245 { PREFIX_TABLE (PREFIX_EVEX_0FD4) },
246 { PREFIX_TABLE (PREFIX_EVEX_0FD5) },
247 { PREFIX_TABLE (PREFIX_EVEX_0FD6) },
250 { PREFIX_TABLE (PREFIX_EVEX_0FD8) },
251 { PREFIX_TABLE (PREFIX_EVEX_0FD9) },
252 { PREFIX_TABLE (PREFIX_EVEX_0FDA) },
253 { PREFIX_TABLE (PREFIX_EVEX_0FDB) },
254 { PREFIX_TABLE (PREFIX_EVEX_0FDC) },
255 { PREFIX_TABLE (PREFIX_EVEX_0FDD) },
256 { PREFIX_TABLE (PREFIX_EVEX_0FDE) },
257 { PREFIX_TABLE (PREFIX_EVEX_0FDF) },
259 { PREFIX_TABLE (PREFIX_EVEX_0FE0) },
260 { PREFIX_TABLE (PREFIX_EVEX_0FE1) },
261 { PREFIX_TABLE (PREFIX_EVEX_0FE2) },
262 { PREFIX_TABLE (PREFIX_EVEX_0FE3) },
263 { PREFIX_TABLE (PREFIX_EVEX_0FE4) },
264 { PREFIX_TABLE (PREFIX_EVEX_0FE5) },
265 { PREFIX_TABLE (PREFIX_EVEX_0FE6) },
266 { PREFIX_TABLE (PREFIX_EVEX_0FE7) },
268 { PREFIX_TABLE (PREFIX_EVEX_0FE8) },
269 { PREFIX_TABLE (PREFIX_EVEX_0FE9) },
270 { PREFIX_TABLE (PREFIX_EVEX_0FEA) },
271 { PREFIX_TABLE (PREFIX_EVEX_0FEB) },
272 { PREFIX_TABLE (PREFIX_EVEX_0FEC) },
273 { PREFIX_TABLE (PREFIX_EVEX_0FED) },
274 { PREFIX_TABLE (PREFIX_EVEX_0FEE) },
275 { PREFIX_TABLE (PREFIX_EVEX_0FEF) },
278 { PREFIX_TABLE (PREFIX_EVEX_0FF1) },
279 { PREFIX_TABLE (PREFIX_EVEX_0FF2) },
280 { PREFIX_TABLE (PREFIX_EVEX_0FF3) },
281 { PREFIX_TABLE (PREFIX_EVEX_0FF4) },
282 { PREFIX_TABLE (PREFIX_EVEX_0FF5) },
283 { PREFIX_TABLE (PREFIX_EVEX_0FF6) },
286 { PREFIX_TABLE (PREFIX_EVEX_0FF8) },
287 { PREFIX_TABLE (PREFIX_EVEX_0FF9) },
288 { PREFIX_TABLE (PREFIX_EVEX_0FFA) },
289 { PREFIX_TABLE (PREFIX_EVEX_0FFB) },
290 { PREFIX_TABLE (PREFIX_EVEX_0FFC) },
291 { PREFIX_TABLE (PREFIX_EVEX_0FFD) },
292 { PREFIX_TABLE (PREFIX_EVEX_0FFE) },
298 { PREFIX_TABLE (PREFIX_EVEX_0F3800) },
302 { PREFIX_TABLE (PREFIX_EVEX_0F3804) },
310 { PREFIX_TABLE (PREFIX_EVEX_0F380B) },
311 { PREFIX_TABLE (PREFIX_EVEX_0F380C) },
312 { PREFIX_TABLE (PREFIX_EVEX_0F380D) },
316 { PREFIX_TABLE (PREFIX_EVEX_0F3810) },
317 { PREFIX_TABLE (PREFIX_EVEX_0F3811) },
318 { PREFIX_TABLE (PREFIX_EVEX_0F3812) },
319 { PREFIX_TABLE (PREFIX_EVEX_0F3813) },
320 { PREFIX_TABLE (PREFIX_EVEX_0F3814) },
321 { PREFIX_TABLE (PREFIX_EVEX_0F3815) },
322 { PREFIX_TABLE (PREFIX_EVEX_0F3816) },
325 { PREFIX_TABLE (PREFIX_EVEX_0F3818) },
326 { PREFIX_TABLE (PREFIX_EVEX_0F3819) },
327 { PREFIX_TABLE (PREFIX_EVEX_0F381A) },
328 { PREFIX_TABLE (PREFIX_EVEX_0F381B) },
329 { PREFIX_TABLE (PREFIX_EVEX_0F381C) },
330 { PREFIX_TABLE (PREFIX_EVEX_0F381D) },
331 { PREFIX_TABLE (PREFIX_EVEX_0F381E) },
332 { PREFIX_TABLE (PREFIX_EVEX_0F381F) },
334 { PREFIX_TABLE (PREFIX_EVEX_0F3820) },
335 { PREFIX_TABLE (PREFIX_EVEX_0F3821) },
336 { PREFIX_TABLE (PREFIX_EVEX_0F3822) },
337 { PREFIX_TABLE (PREFIX_EVEX_0F3823) },
338 { PREFIX_TABLE (PREFIX_EVEX_0F3824) },
339 { PREFIX_TABLE (PREFIX_EVEX_0F3825) },
340 { PREFIX_TABLE (PREFIX_EVEX_0F3826) },
341 { PREFIX_TABLE (PREFIX_EVEX_0F3827) },
343 { PREFIX_TABLE (PREFIX_EVEX_0F3828) },
344 { PREFIX_TABLE (PREFIX_EVEX_0F3829) },
345 { PREFIX_TABLE (PREFIX_EVEX_0F382A) },
346 { PREFIX_TABLE (PREFIX_EVEX_0F382B) },
347 { PREFIX_TABLE (PREFIX_EVEX_0F382C) },
348 { PREFIX_TABLE (PREFIX_EVEX_0F382D) },
352 { PREFIX_TABLE (PREFIX_EVEX_0F3830) },
353 { PREFIX_TABLE (PREFIX_EVEX_0F3831) },
354 { PREFIX_TABLE (PREFIX_EVEX_0F3832) },
355 { PREFIX_TABLE (PREFIX_EVEX_0F3833) },
356 { PREFIX_TABLE (PREFIX_EVEX_0F3834) },
357 { PREFIX_TABLE (PREFIX_EVEX_0F3835) },
358 { PREFIX_TABLE (PREFIX_EVEX_0F3836) },
359 { PREFIX_TABLE (PREFIX_EVEX_0F3837) },
361 { PREFIX_TABLE (PREFIX_EVEX_0F3838) },
362 { PREFIX_TABLE (PREFIX_EVEX_0F3839) },
363 { PREFIX_TABLE (PREFIX_EVEX_0F383A) },
364 { PREFIX_TABLE (PREFIX_EVEX_0F383B) },
365 { PREFIX_TABLE (PREFIX_EVEX_0F383C) },
366 { PREFIX_TABLE (PREFIX_EVEX_0F383D) },
367 { PREFIX_TABLE (PREFIX_EVEX_0F383E) },
368 { PREFIX_TABLE (PREFIX_EVEX_0F383F) },
370 { PREFIX_TABLE (PREFIX_EVEX_0F3840) },
372 { PREFIX_TABLE (PREFIX_EVEX_0F3842) },
373 { PREFIX_TABLE (PREFIX_EVEX_0F3843) },
374 { PREFIX_TABLE (PREFIX_EVEX_0F3844) },
375 { PREFIX_TABLE (PREFIX_EVEX_0F3845) },
376 { PREFIX_TABLE (PREFIX_EVEX_0F3846) },
377 { PREFIX_TABLE (PREFIX_EVEX_0F3847) },
383 { PREFIX_TABLE (PREFIX_EVEX_0F384C) },
384 { PREFIX_TABLE (PREFIX_EVEX_0F384D) },
385 { PREFIX_TABLE (PREFIX_EVEX_0F384E) },
386 { PREFIX_TABLE (PREFIX_EVEX_0F384F) },
397 { PREFIX_TABLE (PREFIX_EVEX_0F3858) },
398 { PREFIX_TABLE (PREFIX_EVEX_0F3859) },
399 { PREFIX_TABLE (PREFIX_EVEX_0F385A) },
400 { PREFIX_TABLE (PREFIX_EVEX_0F385B) },
410 { PREFIX_TABLE (PREFIX_EVEX_0F3864) },
411 { PREFIX_TABLE (PREFIX_EVEX_0F3865) },
412 { PREFIX_TABLE (PREFIX_EVEX_0F3866) },
429 { PREFIX_TABLE (PREFIX_EVEX_0F3875) },
430 { PREFIX_TABLE (PREFIX_EVEX_0F3876) },
431 { PREFIX_TABLE (PREFIX_EVEX_0F3877) },
433 { PREFIX_TABLE (PREFIX_EVEX_0F3878) },
434 { PREFIX_TABLE (PREFIX_EVEX_0F3879) },
435 { PREFIX_TABLE (PREFIX_EVEX_0F387A) },
436 { PREFIX_TABLE (PREFIX_EVEX_0F387B) },
437 { PREFIX_TABLE (PREFIX_EVEX_0F387C) },
438 { PREFIX_TABLE (PREFIX_EVEX_0F387D) },
439 { PREFIX_TABLE (PREFIX_EVEX_0F387E) },
440 { PREFIX_TABLE (PREFIX_EVEX_0F387F) },
451 { PREFIX_TABLE (PREFIX_EVEX_0F3888) },
452 { PREFIX_TABLE (PREFIX_EVEX_0F3889) },
453 { PREFIX_TABLE (PREFIX_EVEX_0F388A) },
454 { PREFIX_TABLE (PREFIX_EVEX_0F388B) },
456 { PREFIX_TABLE (PREFIX_EVEX_0F388D) },
460 { PREFIX_TABLE (PREFIX_EVEX_0F3890) },
461 { PREFIX_TABLE (PREFIX_EVEX_0F3891) },
462 { PREFIX_TABLE (PREFIX_EVEX_0F3892) },
463 { PREFIX_TABLE (PREFIX_EVEX_0F3893) },
466 { PREFIX_TABLE (PREFIX_EVEX_0F3896) },
467 { PREFIX_TABLE (PREFIX_EVEX_0F3897) },
469 { PREFIX_TABLE (PREFIX_EVEX_0F3898) },
470 { PREFIX_TABLE (PREFIX_EVEX_0F3899) },
471 { PREFIX_TABLE (PREFIX_EVEX_0F389A) },
472 { PREFIX_TABLE (PREFIX_EVEX_0F389B) },
473 { PREFIX_TABLE (PREFIX_EVEX_0F389C) },
474 { PREFIX_TABLE (PREFIX_EVEX_0F389D) },
475 { PREFIX_TABLE (PREFIX_EVEX_0F389E) },
476 { PREFIX_TABLE (PREFIX_EVEX_0F389F) },
478 { PREFIX_TABLE (PREFIX_EVEX_0F38A0) },
479 { PREFIX_TABLE (PREFIX_EVEX_0F38A1) },
480 { PREFIX_TABLE (PREFIX_EVEX_0F38A2) },
481 { PREFIX_TABLE (PREFIX_EVEX_0F38A3) },
484 { PREFIX_TABLE (PREFIX_EVEX_0F38A6) },
485 { PREFIX_TABLE (PREFIX_EVEX_0F38A7) },
487 { PREFIX_TABLE (PREFIX_EVEX_0F38A8) },
488 { PREFIX_TABLE (PREFIX_EVEX_0F38A9) },
489 { PREFIX_TABLE (PREFIX_EVEX_0F38AA) },
490 { PREFIX_TABLE (PREFIX_EVEX_0F38AB) },
491 { PREFIX_TABLE (PREFIX_EVEX_0F38AC) },
492 { PREFIX_TABLE (PREFIX_EVEX_0F38AD) },
493 { PREFIX_TABLE (PREFIX_EVEX_0F38AE) },
494 { PREFIX_TABLE (PREFIX_EVEX_0F38AF) },
502 { PREFIX_TABLE (PREFIX_EVEX_0F38B6) },
503 { PREFIX_TABLE (PREFIX_EVEX_0F38B7) },
505 { PREFIX_TABLE (PREFIX_EVEX_0F38B8) },
506 { PREFIX_TABLE (PREFIX_EVEX_0F38B9) },
507 { PREFIX_TABLE (PREFIX_EVEX_0F38BA) },
508 { PREFIX_TABLE (PREFIX_EVEX_0F38BB) },
509 { PREFIX_TABLE (PREFIX_EVEX_0F38BC) },
510 { PREFIX_TABLE (PREFIX_EVEX_0F38BD) },
511 { PREFIX_TABLE (PREFIX_EVEX_0F38BE) },
512 { PREFIX_TABLE (PREFIX_EVEX_0F38BF) },
518 { PREFIX_TABLE (PREFIX_EVEX_0F38C4) },
520 { REG_TABLE (REG_EVEX_0F38C6) },
521 { REG_TABLE (REG_EVEX_0F38C7) },
523 { PREFIX_TABLE (PREFIX_EVEX_0F38C8) },
525 { PREFIX_TABLE (PREFIX_EVEX_0F38CA) },
526 { PREFIX_TABLE (PREFIX_EVEX_0F38CB) },
527 { PREFIX_TABLE (PREFIX_EVEX_0F38CC) },
528 { PREFIX_TABLE (PREFIX_EVEX_0F38CD) },
589 { PREFIX_TABLE (PREFIX_EVEX_0F3A00) },
590 { PREFIX_TABLE (PREFIX_EVEX_0F3A01) },
592 { PREFIX_TABLE (PREFIX_EVEX_0F3A03) },
593 { PREFIX_TABLE (PREFIX_EVEX_0F3A04) },
594 { PREFIX_TABLE (PREFIX_EVEX_0F3A05) },
598 { PREFIX_TABLE (PREFIX_EVEX_0F3A08) },
599 { PREFIX_TABLE (PREFIX_EVEX_0F3A09) },
600 { PREFIX_TABLE (PREFIX_EVEX_0F3A0A) },
601 { PREFIX_TABLE (PREFIX_EVEX_0F3A0B) },
605 { PREFIX_TABLE (PREFIX_EVEX_0F3A0F) },
611 { PREFIX_TABLE (PREFIX_EVEX_0F3A14) },
612 { PREFIX_TABLE (PREFIX_EVEX_0F3A15) },
613 { PREFIX_TABLE (PREFIX_EVEX_0F3A16) },
614 { PREFIX_TABLE (PREFIX_EVEX_0F3A17) },
616 { PREFIX_TABLE (PREFIX_EVEX_0F3A18) },
617 { PREFIX_TABLE (PREFIX_EVEX_0F3A19) },
618 { PREFIX_TABLE (PREFIX_EVEX_0F3A1A) },
619 { PREFIX_TABLE (PREFIX_EVEX_0F3A1B) },
621 { PREFIX_TABLE (PREFIX_EVEX_0F3A1D) },
622 { PREFIX_TABLE (PREFIX_EVEX_0F3A1E) },
623 { PREFIX_TABLE (PREFIX_EVEX_0F3A1F) },
625 { PREFIX_TABLE (PREFIX_EVEX_0F3A20) },
626 { PREFIX_TABLE (PREFIX_EVEX_0F3A21) },
627 { PREFIX_TABLE (PREFIX_EVEX_0F3A22) },
628 { PREFIX_TABLE (PREFIX_EVEX_0F3A23) },
630 { PREFIX_TABLE (PREFIX_EVEX_0F3A25) },
631 { PREFIX_TABLE (PREFIX_EVEX_0F3A26) },
632 { PREFIX_TABLE (PREFIX_EVEX_0F3A27) },
652 { PREFIX_TABLE (PREFIX_EVEX_0F3A38) },
653 { PREFIX_TABLE (PREFIX_EVEX_0F3A39) },
654 { PREFIX_TABLE (PREFIX_EVEX_0F3A3A) },
655 { PREFIX_TABLE (PREFIX_EVEX_0F3A3B) },
658 { PREFIX_TABLE (PREFIX_EVEX_0F3A3E) },
659 { PREFIX_TABLE (PREFIX_EVEX_0F3A3F) },
663 { PREFIX_TABLE (PREFIX_EVEX_0F3A42) },
664 { PREFIX_TABLE (PREFIX_EVEX_0F3A43) },
679 { PREFIX_TABLE (PREFIX_EVEX_0F3A50) },
680 { PREFIX_TABLE (PREFIX_EVEX_0F3A51) },
683 { PREFIX_TABLE (PREFIX_EVEX_0F3A54) },
684 { PREFIX_TABLE (PREFIX_EVEX_0F3A55) },
685 { PREFIX_TABLE (PREFIX_EVEX_0F3A56) },
686 { PREFIX_TABLE (PREFIX_EVEX_0F3A57) },
703 { PREFIX_TABLE (PREFIX_EVEX_0F3A66) },
704 { PREFIX_TABLE (PREFIX_EVEX_0F3A67) },
878 #endif /* NEED_OPCODE_TABLE */
880 #ifdef NEED_REG_TABLE
885 { PREFIX_TABLE (PREFIX_EVEX_0F71_REG_2) },
887 { PREFIX_TABLE (PREFIX_EVEX_0F71_REG_4) },
889 { PREFIX_TABLE (PREFIX_EVEX_0F71_REG_6) },
893 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_0) },
894 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_1) },
895 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_2) },
897 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_4) },
899 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_6) },
905 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_2) },
906 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_3) },
909 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_6) },
910 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_7) },
912 /* REG_EVEX_0F38C6 */
915 { MOD_TABLE (MOD_EVEX_0F38C6_REG_1) },
916 { MOD_TABLE (MOD_EVEX_0F38C6_REG_2) },
919 { MOD_TABLE (MOD_EVEX_0F38C6_REG_5) },
920 { MOD_TABLE (MOD_EVEX_0F38C6_REG_6) },
922 /* REG_EVEX_0F38C7 */
925 { MOD_TABLE (MOD_EVEX_0F38C7_REG_1) },
926 { MOD_TABLE (MOD_EVEX_0F38C7_REG_2) },
929 { MOD_TABLE (MOD_EVEX_0F38C7_REG_5) },
930 { MOD_TABLE (MOD_EVEX_0F38C7_REG_6) },
932 #endif /* NEED_REG_TABLE */
934 #ifdef NEED_PREFIX_TABLE
935 /* PREFIX_EVEX_0F10 */
937 { VEX_W_TABLE (EVEX_W_0F10_P_0) },
938 { MOD_TABLE (MOD_EVEX_0F10_PREFIX_1) },
939 { VEX_W_TABLE (EVEX_W_0F10_P_2) },
940 { MOD_TABLE (MOD_EVEX_0F10_PREFIX_3) },
942 /* PREFIX_EVEX_0F11 */
944 { VEX_W_TABLE (EVEX_W_0F11_P_0) },
945 { MOD_TABLE (MOD_EVEX_0F11_PREFIX_1) },
946 { VEX_W_TABLE (EVEX_W_0F11_P_2) },
947 { MOD_TABLE (MOD_EVEX_0F11_PREFIX_3) },
949 /* PREFIX_EVEX_0F12 */
951 { MOD_TABLE (MOD_EVEX_0F12_PREFIX_0) },
952 { VEX_W_TABLE (EVEX_W_0F12_P_1) },
953 { VEX_W_TABLE (EVEX_W_0F12_P_2) },
954 { VEX_W_TABLE (EVEX_W_0F12_P_3) },
956 /* PREFIX_EVEX_0F13 */
958 { VEX_W_TABLE (EVEX_W_0F13_P_0) },
960 { VEX_W_TABLE (EVEX_W_0F13_P_2) },
962 /* PREFIX_EVEX_0F14 */
964 { VEX_W_TABLE (EVEX_W_0F14_P_0) },
966 { VEX_W_TABLE (EVEX_W_0F14_P_2) },
968 /* PREFIX_EVEX_0F15 */
970 { VEX_W_TABLE (EVEX_W_0F15_P_0) },
972 { VEX_W_TABLE (EVEX_W_0F15_P_2) },
974 /* PREFIX_EVEX_0F16 */
976 { MOD_TABLE (MOD_EVEX_0F16_PREFIX_0) },
977 { VEX_W_TABLE (EVEX_W_0F16_P_1) },
978 { VEX_W_TABLE (EVEX_W_0F16_P_2) },
980 /* PREFIX_EVEX_0F17 */
982 { VEX_W_TABLE (EVEX_W_0F17_P_0) },
984 { VEX_W_TABLE (EVEX_W_0F17_P_2) },
986 /* PREFIX_EVEX_0F28 */
988 { VEX_W_TABLE (EVEX_W_0F28_P_0) },
990 { VEX_W_TABLE (EVEX_W_0F28_P_2) },
992 /* PREFIX_EVEX_0F29 */
994 { VEX_W_TABLE (EVEX_W_0F29_P_0) },
996 { VEX_W_TABLE (EVEX_W_0F29_P_2) },
998 /* PREFIX_EVEX_0F2A */
1001 { VEX_W_TABLE (EVEX_W_0F2A_P_1) },
1003 { VEX_W_TABLE (EVEX_W_0F2A_P_3) },
1005 /* PREFIX_EVEX_0F2B */
1007 { VEX_W_TABLE (EVEX_W_0F2B_P_0) },
1009 { VEX_W_TABLE (EVEX_W_0F2B_P_2) },
1011 /* PREFIX_EVEX_0F2C */
1014 { "vcvttss2si", { Gdq, EXxmm_md, EXxEVexS } },
1016 { "vcvttsd2si", { Gdq, EXxmm_mq, EXxEVexS } },
1018 /* PREFIX_EVEX_0F2D */
1021 { "vcvtss2si", { Gdq, EXxmm_md, EXxEVexR } },
1023 { "vcvtsd2si", { Gdq, EXxmm_mq, EXxEVexR } },
1025 /* PREFIX_EVEX_0F2E */
1027 { VEX_W_TABLE (EVEX_W_0F2E_P_0) },
1029 { VEX_W_TABLE (EVEX_W_0F2E_P_2) },
1031 /* PREFIX_EVEX_0F2F */
1033 { VEX_W_TABLE (EVEX_W_0F2F_P_0) },
1035 { VEX_W_TABLE (EVEX_W_0F2F_P_2) },
1037 /* PREFIX_EVEX_0F51 */
1039 { VEX_W_TABLE (EVEX_W_0F51_P_0) },
1040 { VEX_W_TABLE (EVEX_W_0F51_P_1) },
1041 { VEX_W_TABLE (EVEX_W_0F51_P_2) },
1042 { VEX_W_TABLE (EVEX_W_0F51_P_3) },
1044 /* PREFIX_EVEX_0F54 */
1046 { VEX_W_TABLE (EVEX_W_0F54_P_0) },
1048 { VEX_W_TABLE (EVEX_W_0F54_P_2) },
1050 /* PREFIX_EVEX_0F55 */
1052 { VEX_W_TABLE (EVEX_W_0F55_P_0) },
1054 { VEX_W_TABLE (EVEX_W_0F55_P_2) },
1056 /* PREFIX_EVEX_0F56 */
1058 { VEX_W_TABLE (EVEX_W_0F56_P_0) },
1060 { VEX_W_TABLE (EVEX_W_0F56_P_2) },
1062 /* PREFIX_EVEX_0F57 */
1064 { VEX_W_TABLE (EVEX_W_0F57_P_0) },
1066 { VEX_W_TABLE (EVEX_W_0F57_P_2) },
1068 /* PREFIX_EVEX_0F58 */
1070 { VEX_W_TABLE (EVEX_W_0F58_P_0) },
1071 { VEX_W_TABLE (EVEX_W_0F58_P_1) },
1072 { VEX_W_TABLE (EVEX_W_0F58_P_2) },
1073 { VEX_W_TABLE (EVEX_W_0F58_P_3) },
1075 /* PREFIX_EVEX_0F59 */
1077 { VEX_W_TABLE (EVEX_W_0F59_P_0) },
1078 { VEX_W_TABLE (EVEX_W_0F59_P_1) },
1079 { VEX_W_TABLE (EVEX_W_0F59_P_2) },
1080 { VEX_W_TABLE (EVEX_W_0F59_P_3) },
1082 /* PREFIX_EVEX_0F5A */
1084 { VEX_W_TABLE (EVEX_W_0F5A_P_0) },
1085 { VEX_W_TABLE (EVEX_W_0F5A_P_1) },
1086 { VEX_W_TABLE (EVEX_W_0F5A_P_2) },
1087 { VEX_W_TABLE (EVEX_W_0F5A_P_3) },
1089 /* PREFIX_EVEX_0F5B */
1091 { VEX_W_TABLE (EVEX_W_0F5B_P_0) },
1092 { VEX_W_TABLE (EVEX_W_0F5B_P_1) },
1093 { VEX_W_TABLE (EVEX_W_0F5B_P_2) },
1095 /* PREFIX_EVEX_0F5C */
1097 { VEX_W_TABLE (EVEX_W_0F5C_P_0) },
1098 { VEX_W_TABLE (EVEX_W_0F5C_P_1) },
1099 { VEX_W_TABLE (EVEX_W_0F5C_P_2) },
1100 { VEX_W_TABLE (EVEX_W_0F5C_P_3) },
1102 /* PREFIX_EVEX_0F5D */
1104 { VEX_W_TABLE (EVEX_W_0F5D_P_0) },
1105 { VEX_W_TABLE (EVEX_W_0F5D_P_1) },
1106 { VEX_W_TABLE (EVEX_W_0F5D_P_2) },
1107 { VEX_W_TABLE (EVEX_W_0F5D_P_3) },
1109 /* PREFIX_EVEX_0F5E */
1111 { VEX_W_TABLE (EVEX_W_0F5E_P_0) },
1112 { VEX_W_TABLE (EVEX_W_0F5E_P_1) },
1113 { VEX_W_TABLE (EVEX_W_0F5E_P_2) },
1114 { VEX_W_TABLE (EVEX_W_0F5E_P_3) },
1116 /* PREFIX_EVEX_0F5F */
1118 { VEX_W_TABLE (EVEX_W_0F5F_P_0) },
1119 { VEX_W_TABLE (EVEX_W_0F5F_P_1) },
1120 { VEX_W_TABLE (EVEX_W_0F5F_P_2) },
1121 { VEX_W_TABLE (EVEX_W_0F5F_P_3) },
1123 /* PREFIX_EVEX_0F60 */
1127 { "vpunpcklbw", { XM, Vex, EXx } },
1129 /* PREFIX_EVEX_0F61 */
1133 { "vpunpcklwd", { XM, Vex, EXx } },
1135 /* PREFIX_EVEX_0F62 */
1139 { VEX_W_TABLE (EVEX_W_0F62_P_2) },
1141 /* PREFIX_EVEX_0F63 */
1145 { "vpacksswb", { XM, Vex, EXx } },
1147 /* PREFIX_EVEX_0F64 */
1151 { "vpcmpgtb", { XMask, Vex, EXx } },
1153 /* PREFIX_EVEX_0F65 */
1157 { "vpcmpgtw", { XMask, Vex, EXx } },
1159 /* PREFIX_EVEX_0F66 */
1163 { VEX_W_TABLE (EVEX_W_0F66_P_2) },
1165 /* PREFIX_EVEX_0F67 */
1169 { "vpackuswb", { XM, Vex, EXx } },
1171 /* PREFIX_EVEX_0F68 */
1175 { "vpunpckhbw", { XM, Vex, EXx } },
1177 /* PREFIX_EVEX_0F69 */
1181 { "vpunpckhwd", { XM, Vex, EXx } },
1183 /* PREFIX_EVEX_0F6A */
1187 { VEX_W_TABLE (EVEX_W_0F6A_P_2) },
1189 /* PREFIX_EVEX_0F6B */
1193 { VEX_W_TABLE (EVEX_W_0F6B_P_2) },
1195 /* PREFIX_EVEX_0F6C */
1199 { VEX_W_TABLE (EVEX_W_0F6C_P_2) },
1201 /* PREFIX_EVEX_0F6D */
1205 { VEX_W_TABLE (EVEX_W_0F6D_P_2) },
1207 /* PREFIX_EVEX_0F6E */
1211 { VEX_W_TABLE (EVEX_W_0F6E_P_2) },
1213 /* PREFIX_EVEX_0F6F */
1216 { VEX_W_TABLE (EVEX_W_0F6F_P_1) },
1217 { VEX_W_TABLE (EVEX_W_0F6F_P_2) },
1218 { VEX_W_TABLE (EVEX_W_0F6F_P_3) },
1220 /* PREFIX_EVEX_0F70 */
1223 { "vpshufhw", { XM, EXx, Ib } },
1224 { VEX_W_TABLE (EVEX_W_0F70_P_2) },
1225 { "vpshuflw", { XM, EXx, Ib } },
1227 /* PREFIX_EVEX_0F71_REG_2 */
1231 { "vpsrlw", { Vex, EXx, Ib } },
1233 /* PREFIX_EVEX_0F71_REG_4 */
1237 { "vpsraw", { Vex, EXx, Ib } },
1239 /* PREFIX_EVEX_0F71_REG_6 */
1243 { "vpsllw", { Vex, EXx, Ib } },
1245 /* PREFIX_EVEX_0F72_REG_0 */
1249 { "vpror%LW", { Vex, EXx, Ib } },
1251 /* PREFIX_EVEX_0F72_REG_1 */
1255 { "vprol%LW", { Vex, EXx, Ib } },
1257 /* PREFIX_EVEX_0F72_REG_2 */
1261 { VEX_W_TABLE (EVEX_W_0F72_R_2_P_2) },
1263 /* PREFIX_EVEX_0F72_REG_4 */
1267 { "vpsra%LW", { Vex, EXx, Ib } },
1269 /* PREFIX_EVEX_0F72_REG_6 */
1273 { VEX_W_TABLE (EVEX_W_0F72_R_6_P_2) },
1275 /* PREFIX_EVEX_0F73_REG_2 */
1279 { VEX_W_TABLE (EVEX_W_0F73_R_2_P_2) },
1281 /* PREFIX_EVEX_0F73_REG_3 */
1285 { "vpsrldq", { Vex, EXx, Ib } },
1287 /* PREFIX_EVEX_0F73_REG_6 */
1291 { VEX_W_TABLE (EVEX_W_0F73_R_6_P_2) },
1293 /* PREFIX_EVEX_0F73_REG_7 */
1297 { "vpslldq", { Vex, EXx, Ib } },
1299 /* PREFIX_EVEX_0F74 */
1303 { "vpcmpeqb", { XMask, Vex, EXx } },
1305 /* PREFIX_EVEX_0F75 */
1309 { "vpcmpeqw", { XMask, Vex, EXx } },
1311 /* PREFIX_EVEX_0F76 */
1315 { VEX_W_TABLE (EVEX_W_0F76_P_2) },
1317 /* PREFIX_EVEX_0F78 */
1319 { VEX_W_TABLE (EVEX_W_0F78_P_0) },
1320 { "vcvttss2usi", { Gdq, EXxmm_md, EXxEVexS } },
1321 { VEX_W_TABLE (EVEX_W_0F78_P_2) },
1322 { "vcvttsd2usi", { Gdq, EXxmm_mq, EXxEVexS } },
1324 /* PREFIX_EVEX_0F79 */
1326 { VEX_W_TABLE (EVEX_W_0F79_P_0) },
1327 { "vcvtss2usi", { Gdq, EXxmm_md, EXxEVexR } },
1328 { VEX_W_TABLE (EVEX_W_0F79_P_2) },
1329 { "vcvtsd2usi", { Gdq, EXxmm_mq, EXxEVexR } },
1331 /* PREFIX_EVEX_0F7A */
1334 { VEX_W_TABLE (EVEX_W_0F7A_P_1) },
1335 { VEX_W_TABLE (EVEX_W_0F7A_P_2) },
1336 { VEX_W_TABLE (EVEX_W_0F7A_P_3) },
1338 /* PREFIX_EVEX_0F7B */
1341 { VEX_W_TABLE (EVEX_W_0F7B_P_1) },
1342 { VEX_W_TABLE (EVEX_W_0F7B_P_2) },
1343 { VEX_W_TABLE (EVEX_W_0F7B_P_3) },
1345 /* PREFIX_EVEX_0F7E */
1348 { VEX_W_TABLE (EVEX_W_0F7E_P_1) },
1349 { VEX_W_TABLE (EVEX_W_0F7E_P_2) },
1351 /* PREFIX_EVEX_0F7F */
1354 { VEX_W_TABLE (EVEX_W_0F7F_P_1) },
1355 { VEX_W_TABLE (EVEX_W_0F7F_P_2) },
1356 { VEX_W_TABLE (EVEX_W_0F7F_P_3) },
1358 /* PREFIX_EVEX_0FC2 */
1360 { VEX_W_TABLE (EVEX_W_0FC2_P_0) },
1361 { VEX_W_TABLE (EVEX_W_0FC2_P_1) },
1362 { VEX_W_TABLE (EVEX_W_0FC2_P_2) },
1363 { VEX_W_TABLE (EVEX_W_0FC2_P_3) },
1365 /* PREFIX_EVEX_0FC4 */
1369 { "vpinsrw", { XM, Vex128, Edw, Ib } },
1371 /* PREFIX_EVEX_0FC5 */
1375 { "vpextrw", { Gdq, XS, Ib } },
1377 /* PREFIX_EVEX_0FC6 */
1379 { VEX_W_TABLE (EVEX_W_0FC6_P_0) },
1381 { VEX_W_TABLE (EVEX_W_0FC6_P_2) },
1383 /* PREFIX_EVEX_0FD1 */
1387 { "vpsrlw", { XM, Vex, EXxmm } },
1389 /* PREFIX_EVEX_0FD2 */
1393 { VEX_W_TABLE (EVEX_W_0FD2_P_2) },
1395 /* PREFIX_EVEX_0FD3 */
1399 { VEX_W_TABLE (EVEX_W_0FD3_P_2) },
1401 /* PREFIX_EVEX_0FD4 */
1405 { VEX_W_TABLE (EVEX_W_0FD4_P_2) },
1407 /* PREFIX_EVEX_0FD5 */
1411 { "vpmullw", { XM, Vex, EXx } },
1413 /* PREFIX_EVEX_0FD6 */
1417 { VEX_W_TABLE (EVEX_W_0FD6_P_2) },
1419 /* PREFIX_EVEX_0FD8 */
1423 { "vpsubusb", { XM, Vex, EXx } },
1425 /* PREFIX_EVEX_0FD9 */
1429 { "vpsubusw", { XM, Vex, EXx } },
1431 /* PREFIX_EVEX_0FDA */
1435 { "vpminub", { XM, Vex, EXx } },
1437 /* PREFIX_EVEX_0FDB */
1441 { "vpand%LW", { XM, Vex, EXx } },
1443 /* PREFIX_EVEX_0FDC */
1447 { "vpaddusb", { XM, Vex, EXx } },
1449 /* PREFIX_EVEX_0FDD */
1453 { "vpaddusw", { XM, Vex, EXx } },
1455 /* PREFIX_EVEX_0FDE */
1459 { "vpmaxub", { XM, Vex, EXx } },
1461 /* PREFIX_EVEX_0FDF */
1465 { "vpandn%LW", { XM, Vex, EXx } },
1467 /* PREFIX_EVEX_0FE0 */
1471 { "vpavgb", { XM, Vex, EXx } },
1473 /* PREFIX_EVEX_0FE1 */
1477 { "vpsraw", { XM, Vex, EXxmm } },
1479 /* PREFIX_EVEX_0FE2 */
1483 { "vpsra%LW", { XM, Vex, EXxmm } },
1485 /* PREFIX_EVEX_0FE3 */
1489 { "vpavgw", { XM, Vex, EXx } },
1491 /* PREFIX_EVEX_0FE4 */
1495 { "vpmulhuw", { XM, Vex, EXx } },
1497 /* PREFIX_EVEX_0FE5 */
1501 { "vpmulhw", { XM, Vex, EXx } },
1503 /* PREFIX_EVEX_0FE6 */
1506 { VEX_W_TABLE (EVEX_W_0FE6_P_1) },
1507 { VEX_W_TABLE (EVEX_W_0FE6_P_2) },
1508 { VEX_W_TABLE (EVEX_W_0FE6_P_3) },
1510 /* PREFIX_EVEX_0FE7 */
1514 { VEX_W_TABLE (EVEX_W_0FE7_P_2) },
1516 /* PREFIX_EVEX_0FE8 */
1520 { "vpsubsb", { XM, Vex, EXx } },
1522 /* PREFIX_EVEX_0FE9 */
1526 { "vpsubsw", { XM, Vex, EXx } },
1528 /* PREFIX_EVEX_0FEA */
1532 { "vpminsw", { XM, Vex, EXx } },
1534 /* PREFIX_EVEX_0FEB */
1538 { "vpor%LW", { XM, Vex, EXx } },
1540 /* PREFIX_EVEX_0FEC */
1544 { "vpaddsb", { XM, Vex, EXx } },
1546 /* PREFIX_EVEX_0FED */
1550 { "vpaddsw", { XM, Vex, EXx } },
1552 /* PREFIX_EVEX_0FEE */
1556 { "vpmaxsw", { XM, Vex, EXx } },
1558 /* PREFIX_EVEX_0FEF */
1562 { "vpxor%LW", { XM, Vex, EXx } },
1564 /* PREFIX_EVEX_0FF1 */
1568 { "vpsllw", { XM, Vex, EXxmm } },
1570 /* PREFIX_EVEX_0FF2 */
1574 { VEX_W_TABLE (EVEX_W_0FF2_P_2) },
1576 /* PREFIX_EVEX_0FF3 */
1580 { VEX_W_TABLE (EVEX_W_0FF3_P_2) },
1582 /* PREFIX_EVEX_0FF4 */
1586 { VEX_W_TABLE (EVEX_W_0FF4_P_2) },
1588 /* PREFIX_EVEX_0FF5 */
1592 { "vpmaddwd", { XM, Vex, EXx } },
1594 /* PREFIX_EVEX_0FF6 */
1598 { "vpsadbw", { XM, Vex, EXx } },
1600 /* PREFIX_EVEX_0FF8 */
1604 { "vpsubb", { XM, Vex, EXx } },
1606 /* PREFIX_EVEX_0FF9 */
1610 { "vpsubw", { XM, Vex, EXx } },
1612 /* PREFIX_EVEX_0FFA */
1616 { VEX_W_TABLE (EVEX_W_0FFA_P_2) },
1618 /* PREFIX_EVEX_0FFB */
1622 { VEX_W_TABLE (EVEX_W_0FFB_P_2) },
1624 /* PREFIX_EVEX_0FFC */
1628 { "vpaddb", { XM, Vex, EXx } },
1630 /* PREFIX_EVEX_0FFD */
1634 { "vpaddw", { XM, Vex, EXx } },
1636 /* PREFIX_EVEX_0FFE */
1640 { VEX_W_TABLE (EVEX_W_0FFE_P_2) },
1642 /* PREFIX_EVEX_0F3800 */
1646 { "vpshufb", { XM, Vex, EXx } },
1648 /* PREFIX_EVEX_0F3804 */
1652 { "vpmaddubsw", { XM, Vex, EXx } },
1654 /* PREFIX_EVEX_0F380B */
1658 { "vpmulhrsw", { XM, Vex, EXx } },
1660 /* PREFIX_EVEX_0F380C */
1664 { VEX_W_TABLE (EVEX_W_0F380C_P_2) },
1666 /* PREFIX_EVEX_0F380D */
1670 { VEX_W_TABLE (EVEX_W_0F380D_P_2) },
1672 /* PREFIX_EVEX_0F3810 */
1675 { VEX_W_TABLE (EVEX_W_0F3810_P_1) },
1676 { VEX_W_TABLE (EVEX_W_0F3810_P_2) },
1678 /* PREFIX_EVEX_0F3811 */
1681 { VEX_W_TABLE (EVEX_W_0F3811_P_1) },
1682 { VEX_W_TABLE (EVEX_W_0F3811_P_2) },
1684 /* PREFIX_EVEX_0F3812 */
1687 { VEX_W_TABLE (EVEX_W_0F3812_P_1) },
1688 { VEX_W_TABLE (EVEX_W_0F3812_P_2) },
1690 /* PREFIX_EVEX_0F3813 */
1693 { VEX_W_TABLE (EVEX_W_0F3813_P_1) },
1694 { VEX_W_TABLE (EVEX_W_0F3813_P_2) },
1696 /* PREFIX_EVEX_0F3814 */
1699 { VEX_W_TABLE (EVEX_W_0F3814_P_1) },
1700 { "vprorv%LW", { XM, Vex, EXx } },
1702 /* PREFIX_EVEX_0F3815 */
1705 { VEX_W_TABLE (EVEX_W_0F3815_P_1) },
1706 { "vprolv%LW", { XM, Vex, EXx } },
1708 /* PREFIX_EVEX_0F3816 */
1712 { "vpermp%XW", { XM, Vex, EXx } },
1714 /* PREFIX_EVEX_0F3818 */
1718 { VEX_W_TABLE (EVEX_W_0F3818_P_2) },
1720 /* PREFIX_EVEX_0F3819 */
1724 { VEX_W_TABLE (EVEX_W_0F3819_P_2) },
1726 /* PREFIX_EVEX_0F381A */
1730 { VEX_W_TABLE (EVEX_W_0F381A_P_2) },
1732 /* PREFIX_EVEX_0F381B */
1736 { VEX_W_TABLE (EVEX_W_0F381B_P_2) },
1738 /* PREFIX_EVEX_0F381C */
1742 { "vpabsb", { XM, EXx } },
1744 /* PREFIX_EVEX_0F381D */
1748 { "vpabsw", { XM, EXx } },
1750 /* PREFIX_EVEX_0F381E */
1754 { VEX_W_TABLE (EVEX_W_0F381E_P_2) },
1756 /* PREFIX_EVEX_0F381F */
1760 { VEX_W_TABLE (EVEX_W_0F381F_P_2) },
1762 /* PREFIX_EVEX_0F3820 */
1765 { VEX_W_TABLE (EVEX_W_0F3820_P_1) },
1766 { "vpmovsxbw", { XM, EXxmmq } },
1768 /* PREFIX_EVEX_0F3821 */
1771 { VEX_W_TABLE (EVEX_W_0F3821_P_1) },
1772 { "vpmovsxbd", { XM, EXxmmqd } },
1774 /* PREFIX_EVEX_0F3822 */
1777 { VEX_W_TABLE (EVEX_W_0F3822_P_1) },
1778 { "vpmovsxbq", { XM, EXxmmdw } },
1780 /* PREFIX_EVEX_0F3823 */
1783 { VEX_W_TABLE (EVEX_W_0F3823_P_1) },
1784 { "vpmovsxwd", { XM, EXxmmq } },
1786 /* PREFIX_EVEX_0F3824 */
1789 { VEX_W_TABLE (EVEX_W_0F3824_P_1) },
1790 { "vpmovsxwq", { XM, EXxmmqd } },
1792 /* PREFIX_EVEX_0F3825 */
1795 { VEX_W_TABLE (EVEX_W_0F3825_P_1) },
1796 { VEX_W_TABLE (EVEX_W_0F3825_P_2) },
1798 /* PREFIX_EVEX_0F3826 */
1801 { VEX_W_TABLE (EVEX_W_0F3826_P_1) },
1802 { VEX_W_TABLE (EVEX_W_0F3826_P_2) },
1804 /* PREFIX_EVEX_0F3827 */
1807 { "vptestnm%LW", { XMask, Vex, EXx } },
1808 { "vptestm%LW", { XMask, Vex, EXx } },
1810 /* PREFIX_EVEX_0F3828 */
1813 { VEX_W_TABLE (EVEX_W_0F3828_P_1) },
1814 { VEX_W_TABLE (EVEX_W_0F3828_P_2) },
1816 /* PREFIX_EVEX_0F3829 */
1819 { VEX_W_TABLE (EVEX_W_0F3829_P_1) },
1820 { VEX_W_TABLE (EVEX_W_0F3829_P_2) },
1822 /* PREFIX_EVEX_0F382A */
1825 { VEX_W_TABLE (EVEX_W_0F382A_P_1) },
1826 { VEX_W_TABLE (EVEX_W_0F382A_P_2) },
1828 /* PREFIX_EVEX_0F382B */
1832 { VEX_W_TABLE (EVEX_W_0F382B_P_2) },
1834 /* PREFIX_EVEX_0F382C */
1838 { "vscalefp%XW", { XM, Vex, EXx, EXxEVexR } },
1840 /* PREFIX_EVEX_0F382D */
1844 { "vscalefs%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
1846 /* PREFIX_EVEX_0F3830 */
1849 { VEX_W_TABLE (EVEX_W_0F3830_P_1) },
1850 { "vpmovzxbw", { XM, EXxmmq } },
1852 /* PREFIX_EVEX_0F3831 */
1855 { VEX_W_TABLE (EVEX_W_0F3831_P_1) },
1856 { "vpmovzxbd", { XM, EXxmmqd } },
1858 /* PREFIX_EVEX_0F3832 */
1861 { VEX_W_TABLE (EVEX_W_0F3832_P_1) },
1862 { "vpmovzxbq", { XM, EXxmmdw } },
1864 /* PREFIX_EVEX_0F3833 */
1867 { VEX_W_TABLE (EVEX_W_0F3833_P_1) },
1868 { "vpmovzxwd", { XM, EXxmmq } },
1870 /* PREFIX_EVEX_0F3834 */
1873 { VEX_W_TABLE (EVEX_W_0F3834_P_1) },
1874 { "vpmovzxwq", { XM, EXxmmqd } },
1876 /* PREFIX_EVEX_0F3835 */
1879 { VEX_W_TABLE (EVEX_W_0F3835_P_1) },
1880 { VEX_W_TABLE (EVEX_W_0F3835_P_2) },
1882 /* PREFIX_EVEX_0F3836 */
1886 { "vperm%LW", { XM, Vex, EXx } },
1888 /* PREFIX_EVEX_0F3837 */
1892 { VEX_W_TABLE (EVEX_W_0F3837_P_2) },
1894 /* PREFIX_EVEX_0F3838 */
1897 { VEX_W_TABLE (EVEX_W_0F3838_P_1) },
1898 { "vpminsb", { XM, Vex, EXx } },
1900 /* PREFIX_EVEX_0F3839 */
1903 { VEX_W_TABLE (EVEX_W_0F3839_P_1) },
1904 { "vpmins%LW", { XM, Vex, EXx } },
1906 /* PREFIX_EVEX_0F383A */
1909 { VEX_W_TABLE (EVEX_W_0F383A_P_1) },
1910 { "vpminuw", { XM, Vex, EXx } },
1912 /* PREFIX_EVEX_0F383B */
1916 { "vpminu%LW", { XM, Vex, EXx } },
1918 /* PREFIX_EVEX_0F383C */
1922 { "vpmaxsb", { XM, Vex, EXx } },
1924 /* PREFIX_EVEX_0F383D */
1928 { "vpmaxs%LW", { XM, Vex, EXx } },
1930 /* PREFIX_EVEX_0F383E */
1934 { "vpmaxuw", { XM, Vex, EXx } },
1936 /* PREFIX_EVEX_0F383F */
1940 { "vpmaxu%LW", { XM, Vex, EXx } },
1942 /* PREFIX_EVEX_0F3840 */
1946 { VEX_W_TABLE (EVEX_W_0F3840_P_2) },
1948 /* PREFIX_EVEX_0F3842 */
1952 { "vgetexpp%XW", { XM, EXx, EXxEVexS } },
1954 /* PREFIX_EVEX_0F3843 */
1958 { "vgetexps%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS } },
1960 /* PREFIX_EVEX_0F3844 */
1964 { "vplzcnt%LW", { XM, EXx } },
1966 /* PREFIX_EVEX_0F3845 */
1970 { "vpsrlv%LW", { XM, Vex, EXx } },
1972 /* PREFIX_EVEX_0F3846 */
1976 { "vpsrav%LW", { XM, Vex, EXx } },
1978 /* PREFIX_EVEX_0F3847 */
1982 { "vpsllv%LW", { XM, Vex, EXx } },
1984 /* PREFIX_EVEX_0F384C */
1988 { "vrcp14p%XW", { XM, EXx } },
1990 /* PREFIX_EVEX_0F384D */
1994 { "vrcp14s%XW", { XMScalar, VexScalar, EXxmm_mdq } },
1996 /* PREFIX_EVEX_0F384E */
2000 { "vrsqrt14p%XW", { XM, EXx } },
2002 /* PREFIX_EVEX_0F384F */
2006 { "vrsqrt14s%XW", { XMScalar, VexScalar, EXxmm_mdq } },
2008 /* PREFIX_EVEX_0F3858 */
2012 { VEX_W_TABLE (EVEX_W_0F3858_P_2) },
2014 /* PREFIX_EVEX_0F3859 */
2018 { VEX_W_TABLE (EVEX_W_0F3859_P_2) },
2020 /* PREFIX_EVEX_0F385A */
2024 { VEX_W_TABLE (EVEX_W_0F385A_P_2) },
2026 /* PREFIX_EVEX_0F385B */
2030 { VEX_W_TABLE (EVEX_W_0F385B_P_2) },
2032 /* PREFIX_EVEX_0F3864 */
2036 { "vpblendm%LW", { XM, Vex, EXx } },
2038 /* PREFIX_EVEX_0F3865 */
2042 { "vblendmp%XW", { XM, Vex, EXx } },
2044 /* PREFIX_EVEX_0F3866 */
2048 { VEX_W_TABLE (EVEX_W_0F3866_P_2) },
2050 /* PREFIX_EVEX_0F3875 */
2054 { VEX_W_TABLE (EVEX_W_0F3875_P_2) },
2056 /* PREFIX_EVEX_0F3876 */
2060 { "vpermi2%LW", { XM, Vex, EXx } },
2062 /* PREFIX_EVEX_0F3877 */
2066 { "vpermi2p%XW", { XM, Vex, EXx } },
2068 /* PREFIX_EVEX_0F3878 */
2072 { VEX_W_TABLE (EVEX_W_0F3878_P_2) },
2074 /* PREFIX_EVEX_0F3879 */
2078 { VEX_W_TABLE (EVEX_W_0F3879_P_2) },
2080 /* PREFIX_EVEX_0F387A */
2084 { VEX_W_TABLE (EVEX_W_0F387A_P_2) },
2086 /* PREFIX_EVEX_0F387B */
2090 { VEX_W_TABLE (EVEX_W_0F387B_P_2) },
2092 /* PREFIX_EVEX_0F387C */
2096 { "vpbroadcast%LW", { XM, Rdq } },
2098 /* PREFIX_EVEX_0F387D */
2102 { VEX_W_TABLE (EVEX_W_0F387D_P_2) },
2104 /* PREFIX_EVEX_0F387E */
2108 { "vpermt2%LW", { XM, Vex, EXx } },
2110 /* PREFIX_EVEX_0F387F */
2114 { "vpermt2p%XW", { XM, Vex, EXx } },
2116 /* PREFIX_EVEX_0F3888 */
2120 { "vexpandp%XW", { XM, EXEvexXGscat } },
2122 /* PREFIX_EVEX_0F3889 */
2126 { "vpexpand%LW", { XM, EXEvexXGscat } },
2128 /* PREFIX_EVEX_0F388A */
2132 { "vcompressp%XW", { EXEvexXGscat, XM } },
2134 /* PREFIX_EVEX_0F388B */
2138 { "vpcompress%LW", { EXEvexXGscat, XM } },
2140 /* PREFIX_EVEX_0F388D */
2144 { VEX_W_TABLE (EVEX_W_0F388D_P_2) },
2146 /* PREFIX_EVEX_0F3890 */
2150 { "vpgatherd%LW", { XM, MVexVSIBDWpX } },
2152 /* PREFIX_EVEX_0F3891 */
2156 { VEX_W_TABLE (EVEX_W_0F3891_P_2) },
2158 /* PREFIX_EVEX_0F3892 */
2162 { "vgatherdp%XW", { XM, MVexVSIBDWpX} },
2164 /* PREFIX_EVEX_0F3893 */
2168 { VEX_W_TABLE (EVEX_W_0F3893_P_2) },
2170 /* PREFIX_EVEX_0F3896 */
2174 { "vfmaddsub132p%XW", { XM, Vex, EXx, EXxEVexR } },
2176 /* PREFIX_EVEX_0F3897 */
2180 { "vfmsubadd132p%XW", { XM, Vex, EXx, EXxEVexR } },
2182 /* PREFIX_EVEX_0F3898 */
2186 { "vfmadd132p%XW", { XM, Vex, EXx, EXxEVexR } },
2188 /* PREFIX_EVEX_0F3899 */
2192 { "vfmadd132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2194 /* PREFIX_EVEX_0F389A */
2198 { "vfmsub132p%XW", { XM, Vex, EXx, EXxEVexR } },
2200 /* PREFIX_EVEX_0F389B */
2204 { "vfmsub132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2206 /* PREFIX_EVEX_0F389C */
2210 { "vfnmadd132p%XW", { XM, Vex, EXx, EXxEVexR } },
2212 /* PREFIX_EVEX_0F389D */
2216 { "vfnmadd132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2218 /* PREFIX_EVEX_0F389E */
2222 { "vfnmsub132p%XW", { XM, Vex, EXx, EXxEVexR } },
2224 /* PREFIX_EVEX_0F389F */
2228 { "vfnmsub132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2230 /* PREFIX_EVEX_0F38A0 */
2234 { "vpscatterd%LW", { MVexVSIBDWpX, XM } },
2236 /* PREFIX_EVEX_0F38A1 */
2240 { VEX_W_TABLE (EVEX_W_0F38A1_P_2) },
2242 /* PREFIX_EVEX_0F38A2 */
2246 { "vscatterdp%XW", { MVexVSIBDWpX, XM } },
2248 /* PREFIX_EVEX_0F38A3 */
2252 { VEX_W_TABLE (EVEX_W_0F38A3_P_2) },
2254 /* PREFIX_EVEX_0F38A6 */
2258 { "vfmaddsub213p%XW", { XM, Vex, EXx, EXxEVexR } },
2260 /* PREFIX_EVEX_0F38A7 */
2264 { "vfmsubadd213p%XW", { XM, Vex, EXx, EXxEVexR } },
2266 /* PREFIX_EVEX_0F38A8 */
2270 { "vfmadd213p%XW", { XM, Vex, EXx, EXxEVexR } },
2272 /* PREFIX_EVEX_0F38A9 */
2276 { "vfmadd213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2278 /* PREFIX_EVEX_0F38AA */
2282 { "vfmsub213p%XW", { XM, Vex, EXx, EXxEVexR } },
2284 /* PREFIX_EVEX_0F38AB */
2288 { "vfmsub213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2290 /* PREFIX_EVEX_0F38AC */
2294 { "vfnmadd213p%XW", { XM, Vex, EXx, EXxEVexR } },
2296 /* PREFIX_EVEX_0F38AD */
2300 { "vfnmadd213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2302 /* PREFIX_EVEX_0F38AE */
2306 { "vfnmsub213p%XW", { XM, Vex, EXx, EXxEVexR } },
2308 /* PREFIX_EVEX_0F38AF */
2312 { "vfnmsub213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2314 /* PREFIX_EVEX_0F38B6 */
2318 { "vfmaddsub231p%XW", { XM, Vex, EXx, EXxEVexR } },
2320 /* PREFIX_EVEX_0F38B7 */
2324 { "vfmsubadd231p%XW", { XM, Vex, EXx, EXxEVexR } },
2326 /* PREFIX_EVEX_0F38B8 */
2330 { "vfmadd231p%XW", { XM, Vex, EXx, EXxEVexR } },
2332 /* PREFIX_EVEX_0F38B9 */
2336 { "vfmadd231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2338 /* PREFIX_EVEX_0F38BA */
2342 { "vfmsub231p%XW", { XM, Vex, EXx, EXxEVexR } },
2344 /* PREFIX_EVEX_0F38BB */
2348 { "vfmsub231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2350 /* PREFIX_EVEX_0F38BC */
2354 { "vfnmadd231p%XW", { XM, Vex, EXx, EXxEVexR } },
2356 /* PREFIX_EVEX_0F38BD */
2360 { "vfnmadd231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2362 /* PREFIX_EVEX_0F38BE */
2366 { "vfnmsub231p%XW", { XM, Vex, EXx, EXxEVexR } },
2368 /* PREFIX_EVEX_0F38BF */
2372 { "vfnmsub231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2374 /* PREFIX_EVEX_0F38C4 */
2378 { "vpconflict%LW", { XM, EXx } },
2380 /* PREFIX_EVEX_0F38C6_REG_1 */
2384 { "vgatherpf0dp%XW", { MVexVSIBDWpX } },
2386 /* PREFIX_EVEX_0F38C6_REG_2 */
2390 { "vgatherpf1dp%XW", { MVexVSIBDWpX } },
2392 /* PREFIX_EVEX_0F38C6_REG_5 */
2396 { "vscatterpf0dp%XW", { MVexVSIBDWpX } },
2398 /* PREFIX_EVEX_0F38C6_REG_6 */
2402 { "vscatterpf1dp%XW", { MVexVSIBDWpX } },
2404 /* PREFIX_EVEX_0F38C7_REG_1 */
2408 { VEX_W_TABLE (EVEX_W_0F38C7_R_1_P_2) },
2410 /* PREFIX_EVEX_0F38C7_REG_2 */
2414 { VEX_W_TABLE (EVEX_W_0F38C7_R_2_P_2) },
2416 /* PREFIX_EVEX_0F38C7_REG_5 */
2420 { VEX_W_TABLE (EVEX_W_0F38C7_R_5_P_2) },
2422 /* PREFIX_EVEX_0F38C7_REG_6 */
2426 { VEX_W_TABLE (EVEX_W_0F38C7_R_6_P_2) },
2428 /* PREFIX_EVEX_0F38C8 */
2432 { "vexp2p%XW", { XM, EXx, EXxEVexS } },
2434 /* PREFIX_EVEX_0F38CA */
2438 { "vrcp28p%XW", { XM, EXx, EXxEVexS } },
2440 /* PREFIX_EVEX_0F38CB */
2444 { "vrcp28s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS } },
2446 /* PREFIX_EVEX_0F38CC */
2450 { "vrsqrt28p%XW", { XM, EXx, EXxEVexS } },
2452 /* PREFIX_EVEX_0F38CD */
2456 { "vrsqrt28s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS } },
2458 /* PREFIX_EVEX_0F3A00 */
2462 { VEX_W_TABLE (EVEX_W_0F3A00_P_2) },
2464 /* PREFIX_EVEX_0F3A01 */
2468 { VEX_W_TABLE (EVEX_W_0F3A01_P_2) },
2470 /* PREFIX_EVEX_0F3A03 */
2474 { "valign%LW", { XM, Vex, EXx, Ib } },
2476 /* PREFIX_EVEX_0F3A04 */
2480 { VEX_W_TABLE (EVEX_W_0F3A04_P_2) },
2482 /* PREFIX_EVEX_0F3A05 */
2486 { VEX_W_TABLE (EVEX_W_0F3A05_P_2) },
2488 /* PREFIX_EVEX_0F3A08 */
2492 { VEX_W_TABLE (EVEX_W_0F3A08_P_2) },
2494 /* PREFIX_EVEX_0F3A09 */
2498 { VEX_W_TABLE (EVEX_W_0F3A09_P_2) },
2500 /* PREFIX_EVEX_0F3A0A */
2504 { VEX_W_TABLE (EVEX_W_0F3A0A_P_2) },
2506 /* PREFIX_EVEX_0F3A0B */
2510 { VEX_W_TABLE (EVEX_W_0F3A0B_P_2) },
2512 /* PREFIX_EVEX_0F3A0F */
2516 { "vpalignr", { XM, Vex, EXx, Ib } },
2518 /* PREFIX_EVEX_0F3A14 */
2522 { "vpextrb", { Edqb, XM, Ib } },
2524 /* PREFIX_EVEX_0F3A15 */
2528 { "vpextrw", { EdqwS, XM, Ib } },
2530 /* PREFIX_EVEX_0F3A16 */
2534 { VEX_W_TABLE (EVEX_W_0F3A16_P_2) },
2536 /* PREFIX_EVEX_0F3A17 */
2540 { "vextractps", { Edqd, XMM, Ib } },
2542 /* PREFIX_EVEX_0F3A18 */
2546 { VEX_W_TABLE (EVEX_W_0F3A18_P_2) },
2548 /* PREFIX_EVEX_0F3A19 */
2552 { VEX_W_TABLE (EVEX_W_0F3A19_P_2) },
2554 /* PREFIX_EVEX_0F3A1A */
2558 { VEX_W_TABLE (EVEX_W_0F3A1A_P_2) },
2560 /* PREFIX_EVEX_0F3A1B */
2564 { VEX_W_TABLE (EVEX_W_0F3A1B_P_2) },
2566 /* PREFIX_EVEX_0F3A1D */
2570 { VEX_W_TABLE (EVEX_W_0F3A1D_P_2) },
2572 /* PREFIX_EVEX_0F3A1E */
2576 { "vpcmpu%LW", { XMask, Vex, EXx, VPCMP } },
2578 /* PREFIX_EVEX_0F3A1F */
2582 { "vpcmp%LW", { XMask, Vex, EXx, VPCMP } },
2584 /* PREFIX_EVEX_0F3A20 */
2588 { "vpinsrb", { XM, Vex128, Edb, Ib } },
2590 /* PREFIX_EVEX_0F3A21 */
2594 { VEX_W_TABLE (EVEX_W_0F3A21_P_2) },
2596 /* PREFIX_EVEX_0F3A22 */
2600 { VEX_W_TABLE (EVEX_W_0F3A22_P_2) },
2602 /* PREFIX_EVEX_0F3A23 */
2606 { VEX_W_TABLE (EVEX_W_0F3A23_P_2) },
2608 /* PREFIX_EVEX_0F3A25 */
2612 { "vpternlog%LW", { XM, Vex, EXx, Ib } },
2614 /* PREFIX_EVEX_0F3A26 */
2618 { "vgetmantp%XW", { XM, EXx, EXxEVexS, Ib } },
2620 /* PREFIX_EVEX_0F3A27 */
2624 { "vgetmants%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS, Ib } },
2626 /* PREFIX_EVEX_0F3A38 */
2630 { VEX_W_TABLE (EVEX_W_0F3A38_P_2) },
2632 /* PREFIX_EVEX_0F3A39 */
2636 { VEX_W_TABLE (EVEX_W_0F3A39_P_2) },
2638 /* PREFIX_EVEX_0F3A3A */
2642 { VEX_W_TABLE (EVEX_W_0F3A3A_P_2) },
2644 /* PREFIX_EVEX_0F3A3B */
2648 { VEX_W_TABLE (EVEX_W_0F3A3B_P_2) },
2650 /* PREFIX_EVEX_0F3A3E */
2654 { VEX_W_TABLE (EVEX_W_0F3A3E_P_2) },
2656 /* PREFIX_EVEX_0F3A3F */
2660 { VEX_W_TABLE (EVEX_W_0F3A3F_P_2) },
2662 /* PREFIX_EVEX_0F3A42 */
2666 { VEX_W_TABLE (EVEX_W_0F3A42_P_2) },
2668 /* PREFIX_EVEX_0F3A43 */
2672 { VEX_W_TABLE (EVEX_W_0F3A43_P_2) },
2674 /* PREFIX_EVEX_0F3A50 */
2678 { VEX_W_TABLE (EVEX_W_0F3A50_P_2) },
2680 /* PREFIX_EVEX_0F3A51 */
2684 { VEX_W_TABLE (EVEX_W_0F3A51_P_2) },
2686 /* PREFIX_EVEX_0F3A54 */
2690 { "vfixupimmp%XW", { XM, Vex, EXx, EXxEVexS, Ib } },
2692 /* PREFIX_EVEX_0F3A55 */
2696 { "vfixupimms%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS, Ib } },
2698 /* PREFIX_EVEX_0F3A56 */
2702 { VEX_W_TABLE (EVEX_W_0F3A56_P_2) },
2704 /* PREFIX_EVEX_0F3A57 */
2708 { VEX_W_TABLE (EVEX_W_0F3A57_P_2) },
2710 /* PREFIX_EVEX_0F3A66 */
2714 { VEX_W_TABLE (EVEX_W_0F3A66_P_2) },
2716 /* PREFIX_EVEX_0F3A67 */
2720 { VEX_W_TABLE (EVEX_W_0F3A67_P_2) },
2722 #endif /* NEED_PREFIX_TABLE */
2724 #ifdef NEED_VEX_W_TABLE
2725 /* EVEX_W_0F10_P_0 */
2727 { "vmovups", { XM, EXEvexXNoBcst } },
2729 /* EVEX_W_0F10_P_1_M_0 */
2731 { "vmovss", { XMScalar, EXdScalar } },
2733 /* EVEX_W_0F10_P_1_M_1 */
2735 { "vmovss", { XMScalar, VexScalar, EXxmm_md } },
2737 /* EVEX_W_0F10_P_2 */
2740 { "vmovupd", { XM, EXEvexXNoBcst } },
2742 /* EVEX_W_0F10_P_3_M_0 */
2745 { "vmovsd", { XMScalar, EXqScalar } },
2747 /* EVEX_W_0F10_P_3_M_1 */
2750 { "vmovsd", { XMScalar, VexScalar, EXxmm_mq } },
2752 /* EVEX_W_0F11_P_0 */
2754 { "vmovups", { EXxS, XM } },
2756 /* EVEX_W_0F11_P_1_M_0 */
2758 { "vmovss", { EXdScalarS, XMScalar } },
2760 /* EVEX_W_0F11_P_1_M_1 */
2762 { "vmovss", { EXxS, Vex, XMScalar } },
2764 /* EVEX_W_0F11_P_2 */
2767 { "vmovupd", { EXxS, XM } },
2769 /* EVEX_W_0F11_P_3_M_0 */
2772 { "vmovsd", { EXqScalarS, XMScalar } },
2774 /* EVEX_W_0F11_P_3_M_1 */
2777 { "vmovsd", { EXxS, Vex, XMScalar } },
2779 /* EVEX_W_0F12_P_0_M_0 */
2781 { "vmovlps", { XMM, Vex, EXxmm_mq } },
2783 /* EVEX_W_0F12_P_0_M_1 */
2785 { "vmovhlps", { XMM, Vex, EXxmm_mq } },
2787 /* EVEX_W_0F12_P_1 */
2789 { "vmovsldup", { XM, EXEvexXNoBcst } },
2791 /* EVEX_W_0F12_P_2 */
2794 { "vmovlpd", { XMM, Vex, EXxmm_mq } },
2796 /* EVEX_W_0F12_P_3 */
2799 { "vmovddup", { XM, EXymmq } },
2801 /* EVEX_W_0F13_P_0 */
2803 { "vmovlps", { EXxmm_mq, XMM } },
2805 /* EVEX_W_0F13_P_2 */
2808 { "vmovlpd", { EXxmm_mq, XMM } },
2810 /* EVEX_W_0F14_P_0 */
2812 { "vunpcklps", { XM, Vex, EXx } },
2814 /* EVEX_W_0F14_P_2 */
2817 { "vunpcklpd", { XM, Vex, EXx } },
2819 /* EVEX_W_0F15_P_0 */
2821 { "vunpckhps", { XM, Vex, EXx } },
2823 /* EVEX_W_0F15_P_2 */
2826 { "vunpckhpd", { XM, Vex, EXx } },
2828 /* EVEX_W_0F16_P_0_M_0 */
2830 { "vmovhps", { XMM, Vex, EXxmm_mq } },
2832 /* EVEX_W_0F16_P_0_M_1 */
2834 { "vmovlhps", { XMM, Vex, EXx } },
2836 /* EVEX_W_0F16_P_1 */
2838 { "vmovshdup", { XM, EXx } },
2840 /* EVEX_W_0F16_P_2 */
2843 { "vmovhpd", { XMM, Vex, EXxmm_mq } },
2845 /* EVEX_W_0F17_P_0 */
2847 { "vmovhps", { EXxmm_mq, XMM } },
2849 /* EVEX_W_0F17_P_2 */
2852 { "vmovhpd", { EXxmm_mq, XMM } },
2854 /* EVEX_W_0F28_P_0 */
2856 { "vmovaps", { XM, EXx } },
2858 /* EVEX_W_0F28_P_2 */
2861 { "vmovapd", { XM, EXx } },
2863 /* EVEX_W_0F29_P_0 */
2865 { "vmovaps", { EXxS, XM } },
2867 /* EVEX_W_0F29_P_2 */
2870 { "vmovapd", { EXxS, XM } },
2872 /* EVEX_W_0F2A_P_1 */
2874 { "vcvtsi2ss", { XMScalar, VexScalar, EXxEVexR, Ed } },
2875 { "vcvtsi2ss", { XMScalar, VexScalar, EXxEVexR, Eq } },
2877 /* EVEX_W_0F2A_P_3 */
2879 { "vcvtsi2sd", { XMScalar, VexScalar, Ed } },
2880 { "vcvtsi2sd", { XMScalar, VexScalar, EXxEVexR, Eq } },
2882 /* EVEX_W_0F2B_P_0 */
2884 { "vmovntps", { EXx, XM } },
2886 /* EVEX_W_0F2B_P_2 */
2889 { "vmovntpd", { EXx, XM } },
2891 /* EVEX_W_0F2E_P_0 */
2893 { "vucomiss", { XMScalar, EXxmm_md, EXxEVexS } },
2895 /* EVEX_W_0F2E_P_2 */
2898 { "vucomisd", { XMScalar, EXxmm_mq, EXxEVexS } },
2900 /* EVEX_W_0F2F_P_0 */
2902 { "vcomiss", { XMScalar, EXxmm_md, EXxEVexS } },
2904 /* EVEX_W_0F2F_P_2 */
2907 { "vcomisd", { XMScalar, EXxmm_mq, EXxEVexS } },
2909 /* EVEX_W_0F51_P_0 */
2911 { "vsqrtps", { XM, EXx, EXxEVexR } },
2913 /* EVEX_W_0F51_P_1 */
2915 { "vsqrtss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2917 /* EVEX_W_0F51_P_2 */
2920 { "vsqrtpd", { XM, EXx, EXxEVexR } },
2922 /* EVEX_W_0F51_P_3 */
2925 { "vsqrtsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2927 /* EVEX_W_0F54_P_0 */
2929 { "vandps", { XM, Vex, EXx } },
2931 /* EVEX_W_0F54_P_2 */
2934 { "vandpd", { XM, Vex, EXx } },
2936 /* EVEX_W_0F55_P_0 */
2938 { "vandnps", { XM, Vex, EXx } },
2940 /* EVEX_W_0F55_P_2 */
2943 { "vandnpd", { XM, Vex, EXx } },
2945 /* EVEX_W_0F56_P_0 */
2947 { "vorps", { XM, Vex, EXx } },
2949 /* EVEX_W_0F56_P_2 */
2952 { "vorpd", { XM, Vex, EXx } },
2954 /* EVEX_W_0F57_P_0 */
2956 { "vxorps", { XM, Vex, EXx } },
2958 /* EVEX_W_0F57_P_2 */
2961 { "vxorpd", { XM, Vex, EXx } },
2963 /* EVEX_W_0F58_P_0 */
2965 { "vaddps", { XM, Vex, EXx, EXxEVexR } },
2967 /* EVEX_W_0F58_P_1 */
2969 { "vaddss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2971 /* EVEX_W_0F58_P_2 */
2974 { "vaddpd", { XM, Vex, EXx, EXxEVexR } },
2976 /* EVEX_W_0F58_P_3 */
2979 { "vaddsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2981 /* EVEX_W_0F59_P_0 */
2983 { "vmulps", { XM, Vex, EXx, EXxEVexR } },
2985 /* EVEX_W_0F59_P_1 */
2987 { "vmulss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2989 /* EVEX_W_0F59_P_2 */
2992 { "vmulpd", { XM, Vex, EXx, EXxEVexR } },
2994 /* EVEX_W_0F59_P_3 */
2997 { "vmulsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2999 /* EVEX_W_0F5A_P_0 */
3001 { "vcvtps2pd", { XM, EXEvexHalfBcstXmmq, EXxEVexS } },
3003 /* EVEX_W_0F5A_P_1 */
3005 { "vcvtss2sd", { XMScalar, VexScalar, EXxmm_md, EXxEVexS } },
3007 /* EVEX_W_0F5A_P_2 */
3010 { "vcvtpd2ps", { XMxmmq, EXx, EXxEVexR } },
3012 /* EVEX_W_0F5A_P_3 */
3015 { "vcvtsd2ss", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
3017 /* EVEX_W_0F5B_P_0 */
3019 { "vcvtdq2ps", { XM, EXx, EXxEVexR } },
3020 { "vcvtqq2ps", { XMxmmq, EXx, EXxEVexR } },
3022 /* EVEX_W_0F5B_P_1 */
3024 { "vcvttps2dq", { XM, EXx, EXxEVexS } },
3026 /* EVEX_W_0F5B_P_2 */
3028 { "vcvtps2dq", { XM, EXx, EXxEVexR } },
3030 /* EVEX_W_0F5C_P_0 */
3032 { "vsubps", { XM, Vex, EXx, EXxEVexR } },
3034 /* EVEX_W_0F5C_P_1 */
3036 { "vsubss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
3038 /* EVEX_W_0F5C_P_2 */
3041 { "vsubpd", { XM, Vex, EXx, EXxEVexR } },
3043 /* EVEX_W_0F5C_P_3 */
3046 { "vsubsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
3048 /* EVEX_W_0F5D_P_0 */
3050 { "vminps", { XM, Vex, EXx, EXxEVexS } },
3052 /* EVEX_W_0F5D_P_1 */
3054 { "vminss", { XMScalar, VexScalar, EXxmm_md, EXxEVexS } },
3056 /* EVEX_W_0F5D_P_2 */
3059 { "vminpd", { XM, Vex, EXx, EXxEVexS } },
3061 /* EVEX_W_0F5D_P_3 */
3064 { "vminsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS } },
3066 /* EVEX_W_0F5E_P_0 */
3068 { "vdivps", { XM, Vex, EXx, EXxEVexR } },
3070 /* EVEX_W_0F5E_P_1 */
3072 { "vdivss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
3074 /* EVEX_W_0F5E_P_2 */
3077 { "vdivpd", { XM, Vex, EXx, EXxEVexR } },
3079 /* EVEX_W_0F5E_P_3 */
3082 { "vdivsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
3084 /* EVEX_W_0F5F_P_0 */
3086 { "vmaxps", { XM, Vex, EXx, EXxEVexS } },
3088 /* EVEX_W_0F5F_P_1 */
3090 { "vmaxss", { XMScalar, VexScalar, EXxmm_md, EXxEVexS } },
3092 /* EVEX_W_0F5F_P_2 */
3095 { "vmaxpd", { XM, Vex, EXx, EXxEVexS } },
3097 /* EVEX_W_0F5F_P_3 */
3100 { "vmaxsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS } },
3102 /* EVEX_W_0F62_P_2 */
3104 { "vpunpckldq", { XM, Vex, EXx } },
3106 /* EVEX_W_0F66_P_2 */
3108 { "vpcmpgtd", { XMask, Vex, EXx } },
3110 /* EVEX_W_0F6A_P_2 */
3112 { "vpunpckhdq", { XM, Vex, EXx } },
3114 /* EVEX_W_0F6B_P_2 */
3116 { "vpackssdw", { XM, Vex, EXx } },
3118 /* EVEX_W_0F6C_P_2 */
3121 { "vpunpcklqdq", { XM, Vex, EXx } },
3123 /* EVEX_W_0F6D_P_2 */
3126 { "vpunpckhqdq", { XM, Vex, EXx } },
3128 /* EVEX_W_0F6E_P_2 */
3130 { "vmovd", { XMScalar, Ed } },
3131 { "vmovq", { XMScalar, Eq } },
3133 /* EVEX_W_0F6F_P_1 */
3135 { "vmovdqu32", { XM, EXEvexXNoBcst } },
3136 { "vmovdqu64", { XM, EXEvexXNoBcst } },
3138 /* EVEX_W_0F6F_P_2 */
3140 { "vmovdqa32", { XM, EXEvexXNoBcst } },
3141 { "vmovdqa64", { XM, EXEvexXNoBcst } },
3143 /* EVEX_W_0F6F_P_3 */
3145 { "vmovdqu8", { XM, EXx } },
3146 { "vmovdqu16", { XM, EXx } },
3148 /* EVEX_W_0F70_P_2 */
3150 { "vpshufd", { XM, EXx, Ib } },
3152 /* EVEX_W_0F72_R_2_P_2 */
3154 { "vpsrld", { Vex, EXx, Ib } },
3156 /* EVEX_W_0F72_R_6_P_2 */
3158 { "vpslld", { Vex, EXx, Ib } },
3160 /* EVEX_W_0F73_R_2_P_2 */
3163 { "vpsrlq", { Vex, EXx, Ib } },
3165 /* EVEX_W_0F73_R_6_P_2 */
3168 { "vpsllq", { Vex, EXx, Ib } },
3170 /* EVEX_W_0F76_P_2 */
3172 { "vpcmpeqd", { XMask, Vex, EXx } },
3174 /* EVEX_W_0F78_P_0 */
3176 { "vcvttps2udq", { XM, EXx, EXxEVexS } },
3177 { "vcvttpd2udq", { XMxmmq, EXx, EXxEVexS } },
3179 /* EVEX_W_0F78_P_2 */
3181 { "vcvttps2uqq", { XM, EXxmmq, EXxEVexS } },
3182 { "vcvttpd2uqq", { XM, EXx, EXxEVexS } },
3184 /* EVEX_W_0F79_P_0 */
3186 { "vcvtps2udq", { XM, EXx, EXxEVexR } },
3187 { "vcvtpd2udq", { XMxmmq, EXx, EXxEVexR } },
3189 /* EVEX_W_0F79_P_2 */
3191 { "vcvtps2uqq", { XM, EXxmmq, EXxEVexR } },
3192 { "vcvtpd2uqq", { XM, EXx, EXxEVexR } },
3194 /* EVEX_W_0F7A_P_1 */
3196 { "vcvtudq2pd", { XM, EXEvexHalfBcstXmmq } },
3197 { "vcvtuqq2pd", { XM, EXx, EXxEVexR } },
3199 /* EVEX_W_0F7A_P_2 */
3201 { "vcvttps2qq", { XM, EXxmmq, EXxEVexS } },
3202 { "vcvttpd2qq", { XM, EXx, EXxEVexS } },
3204 /* EVEX_W_0F7A_P_3 */
3206 { "vcvtudq2ps", { XM, EXx, EXxEVexR } },
3207 { "vcvtuqq2ps", { XMxmmq, EXx, EXxEVexR } },
3209 /* EVEX_W_0F7B_P_1 */
3211 { "vcvtusi2ss", { XMScalar, VexScalar, EXxEVexR, Ed } },
3212 { "vcvtusi2ss", { XMScalar, VexScalar, EXxEVexR, Eq } },
3214 /* EVEX_W_0F7B_P_2 */
3216 { "vcvtps2qq", { XM, EXxmmq, EXxEVexR } },
3217 { "vcvtpd2qq", { XM, EXx, EXxEVexR } },
3219 /* EVEX_W_0F7B_P_3 */
3221 { "vcvtusi2sd", { XMScalar, VexScalar, Ed } },
3222 { "vcvtusi2sd", { XMScalar, VexScalar, EXxEVexR, Eq } },
3224 /* EVEX_W_0F7E_P_1 */
3227 { "vmovq", { XMScalar, EXxmm_mq } },
3229 /* EVEX_W_0F7E_P_2 */
3231 { "vmovd", { Ed, XMScalar } },
3232 { "vmovq", { Eq, XMScalar } },
3234 /* EVEX_W_0F7F_P_1 */
3236 { "vmovdqu32", { EXxS, XM } },
3237 { "vmovdqu64", { EXxS, XM } },
3239 /* EVEX_W_0F7F_P_2 */
3241 { "vmovdqa32", { EXxS, XM } },
3242 { "vmovdqa64", { EXxS, XM } },
3244 /* EVEX_W_0F7F_P_3 */
3246 { "vmovdqu8", { EXxS, XM } },
3247 { "vmovdqu16", { EXxS, XM } },
3249 /* EVEX_W_0FC2_P_0 */
3251 { "vcmpps", { XMask, Vex, EXx, EXxEVexS, VCMP } },
3253 /* EVEX_W_0FC2_P_1 */
3255 { "vcmpss", { XMask, VexScalar, EXxmm_md, EXxEVexS, VCMP } },
3257 /* EVEX_W_0FC2_P_2 */
3260 { "vcmppd", { XMask, Vex, EXx, EXxEVexS, VCMP } },
3262 /* EVEX_W_0FC2_P_3 */
3265 { "vcmpsd", { XMask, VexScalar, EXxmm_mq, EXxEVexS, VCMP } },
3267 /* EVEX_W_0FC6_P_0 */
3269 { "vshufps", { XM, Vex, EXx, Ib } },
3271 /* EVEX_W_0FC6_P_2 */
3274 { "vshufpd", { XM, Vex, EXx, Ib } },
3276 /* EVEX_W_0FD2_P_2 */
3278 { "vpsrld", { XM, Vex, EXxmm } },
3280 /* EVEX_W_0FD3_P_2 */
3283 { "vpsrlq", { XM, Vex, EXxmm } },
3285 /* EVEX_W_0FD4_P_2 */
3288 { "vpaddq", { XM, Vex, EXx } },
3290 /* EVEX_W_0FD6_P_2 */
3293 { "vmovq", { EXxmm_mq, XMScalar } },
3295 /* EVEX_W_0FE6_P_1 */
3297 { "vcvtdq2pd", { XM, EXEvexHalfBcstXmmq } },
3298 { "vcvtqq2pd", { XM, EXx, EXxEVexR } },
3300 /* EVEX_W_0FE6_P_2 */
3303 { "vcvttpd2dq", { XMxmmq, EXx, EXxEVexS } },
3305 /* EVEX_W_0FE6_P_3 */
3308 { "vcvtpd2dq", { XMxmmq, EXx, EXxEVexR } },
3310 /* EVEX_W_0FE7_P_2 */
3312 { "vmovntdq", { EXEvexXNoBcst, XM } },
3314 /* EVEX_W_0FF2_P_2 */
3316 { "vpslld", { XM, Vex, EXxmm } },
3318 /* EVEX_W_0FF3_P_2 */
3321 { "vpsllq", { XM, Vex, EXxmm } },
3323 /* EVEX_W_0FF4_P_2 */
3326 { "vpmuludq", { XM, Vex, EXx } },
3328 /* EVEX_W_0FFA_P_2 */
3330 { "vpsubd", { XM, Vex, EXx } },
3332 /* EVEX_W_0FFB_P_2 */
3335 { "vpsubq", { XM, Vex, EXx } },
3337 /* EVEX_W_0FFE_P_2 */
3339 { "vpaddd", { XM, Vex, EXx } },
3341 /* EVEX_W_0F380C_P_2 */
3343 { "vpermilps", { XM, Vex, EXx } },
3345 /* EVEX_W_0F380D_P_2 */
3348 { "vpermilpd", { XM, Vex, EXx } },
3350 /* EVEX_W_0F3810_P_1 */
3352 { "vpmovuswb", { EXxmmq, XM } },
3354 /* EVEX_W_0F3810_P_2 */
3357 { "vpsrlvw", { XM, Vex, EXx } },
3359 /* EVEX_W_0F3811_P_1 */
3361 { "vpmovusdb", { EXxmmqd, XM } },
3363 /* EVEX_W_0F3811_P_2 */
3366 { "vpsravw", { XM, Vex, EXx } },
3368 /* EVEX_W_0F3812_P_1 */
3370 { "vpmovusqb", { EXxmmdw, XM } },
3372 /* EVEX_W_0F3812_P_2 */
3375 { "vpsllvw", { XM, Vex, EXx } },
3377 /* EVEX_W_0F3813_P_1 */
3379 { "vpmovusdw", { EXxmmq, XM } },
3381 /* EVEX_W_0F3813_P_2 */
3383 { "vcvtph2ps", { XM, EXxmmq, EXxEVexS } },
3385 /* EVEX_W_0F3814_P_1 */
3387 { "vpmovusqw", { EXxmmqd, XM } },
3389 /* EVEX_W_0F3815_P_1 */
3391 { "vpmovusqd", { EXxmmq, XM } },
3393 /* EVEX_W_0F3818_P_2 */
3395 { "vbroadcastss", { XM, EXxmm_md } },
3397 /* EVEX_W_0F3819_P_2 */
3399 { "vbroadcastf32x2", { XM, EXxmm_mq } },
3400 { "vbroadcastsd", { XM, EXxmm_mq } },
3402 /* EVEX_W_0F381A_P_2 */
3404 { "vbroadcastf32x4", { XM, EXxmm } },
3405 { "vbroadcastf64x2", { XM, EXxmm } },
3407 /* EVEX_W_0F381B_P_2 */
3409 { "vbroadcastf32x8", { XM, EXxmmq } },
3410 { "vbroadcastf64x4", { XM, EXymm } },
3412 /* EVEX_W_0F381E_P_2 */
3414 { "vpabsd", { XM, EXx } },
3416 /* EVEX_W_0F381F_P_2 */
3419 { "vpabsq", { XM, EXx } },
3421 /* EVEX_W_0F3820_P_1 */
3423 { "vpmovswb", { EXxmmq, XM } },
3425 /* EVEX_W_0F3821_P_1 */
3427 { "vpmovsdb", { EXxmmqd, XM } },
3429 /* EVEX_W_0F3822_P_1 */
3431 { "vpmovsqb", { EXxmmdw, XM } },
3433 /* EVEX_W_0F3823_P_1 */
3435 { "vpmovsdw", { EXxmmq, XM } },
3437 /* EVEX_W_0F3824_P_1 */
3439 { "vpmovsqw", { EXxmmqd, XM } },
3441 /* EVEX_W_0F3825_P_1 */
3443 { "vpmovsqd", { EXxmmq, XM } },
3445 /* EVEX_W_0F3825_P_2 */
3447 { "vpmovsxdq", { XM, EXxmmq } },
3449 /* EVEX_W_0F3826_P_1 */
3451 { "vptestnmb", { XMask, Vex, EXx } },
3452 { "vptestnmw", { XMask, Vex, EXx } },
3454 /* EVEX_W_0F3826_P_2 */
3456 { "vptestmb", { XMask, Vex, EXx } },
3457 { "vptestmw", { XMask, Vex, EXx } },
3459 /* EVEX_W_0F3828_P_1 */
3461 { "vpmovm2b", { XM, MaskR } },
3462 { "vpmovm2w", { XM, MaskR } },
3464 /* EVEX_W_0F3828_P_2 */
3467 { "vpmuldq", { XM, Vex, EXx } },
3469 /* EVEX_W_0F3829_P_1 */
3471 { "vpmovb2m", { XMask, EXx } },
3472 { "vpmovw2m", { XMask, EXx } },
3474 /* EVEX_W_0F3829_P_2 */
3477 { "vpcmpeqq", { XMask, Vex, EXx } },
3479 /* EVEX_W_0F382A_P_1 */
3482 { "vpbroadcastmb2q", { XM, MaskR } },
3484 /* EVEX_W_0F382A_P_2 */
3486 { "vmovntdqa", { XM, EXEvexXNoBcst } },
3488 /* EVEX_W_0F382B_P_2 */
3490 { "vpackusdw", { XM, Vex, EXx } },
3492 /* EVEX_W_0F3830_P_1 */
3494 { "vpmovwb", { EXxmmq, XM } },
3496 /* EVEX_W_0F3831_P_1 */
3498 { "vpmovdb", { EXxmmqd, XM } },
3500 /* EVEX_W_0F3832_P_1 */
3502 { "vpmovqb", { EXxmmdw, XM } },
3504 /* EVEX_W_0F3833_P_1 */
3506 { "vpmovdw", { EXxmmq, XM } },
3508 /* EVEX_W_0F3834_P_1 */
3510 { "vpmovqw", { EXxmmqd, XM } },
3512 /* EVEX_W_0F3835_P_1 */
3514 { "vpmovqd", { EXxmmq, XM } },
3516 /* EVEX_W_0F3835_P_2 */
3518 { "vpmovzxdq", { XM, EXxmmq } },
3520 /* EVEX_W_0F3837_P_2 */
3523 { "vpcmpgtq", { XMask, Vex, EXx } },
3525 /* EVEX_W_0F3838_P_1 */
3527 { "vpmovm2d", { XM, MaskR } },
3528 { "vpmovm2q", { XM, MaskR } },
3530 /* EVEX_W_0F3839_P_1 */
3532 { "vpmovd2m", { XMask, EXx } },
3533 { "vpmovq2m", { XMask, EXx } },
3535 /* EVEX_W_0F383A_P_1 */
3537 { "vpbroadcastmw2d", { XM, MaskR } },
3539 /* EVEX_W_0F3840_P_2 */
3541 { "vpmulld", { XM, Vex, EXx } },
3542 { "vpmullq", { XM, Vex, EXx } },
3544 /* EVEX_W_0F3858_P_2 */
3546 { "vpbroadcastd", { XM, EXxmm_md } },
3548 /* EVEX_W_0F3859_P_2 */
3550 { "vbroadcasti32x2", { XM, EXxmm_mq } },
3551 { "vpbroadcastq", { XM, EXxmm_mq } },
3553 /* EVEX_W_0F385A_P_2 */
3555 { "vbroadcasti32x4", { XM, EXxmm } },
3556 { "vbroadcasti64x2", { XM, EXxmm } },
3558 /* EVEX_W_0F385B_P_2 */
3560 { "vbroadcasti32x8", { XM, EXxmmq } },
3561 { "vbroadcasti64x4", { XM, EXymm } },
3563 /* EVEX_W_0F3866_P_2 */
3565 { "vpblendmb", { XM, Vex, EXx } },
3566 { "vpblendmw", { XM, Vex, EXx } },
3568 /* EVEX_W_0F3875_P_2 */
3571 { "vpermi2w", { XM, Vex, EXx } },
3573 /* EVEX_W_0F3878_P_2 */
3575 { "vpbroadcastb", { XM, EXxmm_mb } },
3577 /* EVEX_W_0F3879_P_2 */
3579 { "vpbroadcastw", { XM, EXxmm_mw } },
3581 /* EVEX_W_0F387A_P_2 */
3583 { "vpbroadcastb", { XM, Rd } },
3585 /* EVEX_W_0F387B_P_2 */
3587 { "vpbroadcastw", { XM, Rd } },
3589 /* EVEX_W_0F387D_P_2 */
3592 { "vpermt2w", { XM, Vex, EXx } },
3594 /* EVEX_W_0F388D_P_2 */
3597 { "vpermw", { XM, Vex, EXx } },
3599 /* EVEX_W_0F3891_P_2 */
3601 { "vpgatherqd", { XMxmmq, MVexVSIBQDWpX } },
3602 { "vpgatherqq", { XM, MVexVSIBQWpX } },
3604 /* EVEX_W_0F3893_P_2 */
3606 { "vgatherqps", { XMxmmq, MVexVSIBQDWpX } },
3607 { "vgatherqpd", { XM, MVexVSIBQWpX } },
3609 /* EVEX_W_0F38A1_P_2 */
3611 { "vpscatterqd", { MVexVSIBQDWpX, XMxmmq } },
3612 { "vpscatterqq", { MVexVSIBQWpX, XM } },
3614 /* EVEX_W_0F38A3_P_2 */
3616 { "vscatterqps", { MVexVSIBQDWpX, XMxmmq } },
3617 { "vscatterqpd", { MVexVSIBQWpX, XM } },
3619 /* EVEX_W_0F38C7_R_1_P_2 */
3621 { "vgatherpf0qps", { MVexVSIBDQWpX } },
3622 { "vgatherpf0qpd", { MVexVSIBQWpX } },
3624 /* EVEX_W_0F38C7_R_2_P_2 */
3626 { "vgatherpf1qps", { MVexVSIBDQWpX } },
3627 { "vgatherpf1qpd", { MVexVSIBQWpX } },
3629 /* EVEX_W_0F38C7_R_5_P_2 */
3631 { "vscatterpf0qps", { MVexVSIBDQWpX } },
3632 { "vscatterpf0qpd", { MVexVSIBQWpX } },
3634 /* EVEX_W_0F38C7_R_6_P_2 */
3636 { "vscatterpf1qps", { MVexVSIBDQWpX } },
3637 { "vscatterpf1qpd", { MVexVSIBQWpX } },
3639 /* EVEX_W_0F3A00_P_2 */
3642 { "vpermq", { XM, EXx, Ib } },
3644 /* EVEX_W_0F3A01_P_2 */
3647 { "vpermpd", { XM, EXx, Ib } },
3649 /* EVEX_W_0F3A04_P_2 */
3651 { "vpermilps", { XM, EXx, Ib } },
3653 /* EVEX_W_0F3A05_P_2 */
3656 { "vpermilpd", { XM, EXx, Ib } },
3658 /* EVEX_W_0F3A08_P_2 */
3660 { "vrndscaleps", { XM, EXx, EXxEVexS, Ib } },
3662 /* EVEX_W_0F3A09_P_2 */
3665 { "vrndscalepd", { XM, EXx, EXxEVexS, Ib } },
3667 /* EVEX_W_0F3A0A_P_2 */
3669 { "vrndscaless", { XMScalar, VexScalar, EXxmm_md, EXxEVexS, Ib } },
3671 /* EVEX_W_0F3A0B_P_2 */
3674 { "vrndscalesd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS, Ib } },
3676 /* EVEX_W_0F3A16_P_2 */
3678 { "vpextrd", { Edqd, XM, Ib } },
3679 { "vpextrq", { Eq, XM, Ib } },
3681 /* EVEX_W_0F3A18_P_2 */
3683 { "vinsertf32x4", { XM, Vex, EXxmm, Ib } },
3684 { "vinsertf64x2", { XM, Vex, EXxmm, Ib } },
3686 /* EVEX_W_0F3A19_P_2 */
3688 { "vextractf32x4", { EXxmm, XM, Ib } },
3689 { "vextractf64x2", { EXxmm, XM, Ib } },
3691 /* EVEX_W_0F3A1A_P_2 */
3693 { "vinsertf32x8", { XM, Vex, EXxmmq, Ib } },
3694 { "vinsertf64x4", { XM, Vex, EXxmmq, Ib } },
3696 /* EVEX_W_0F3A1B_P_2 */
3698 { "vextractf32x8", { EXxmmq, XM, Ib } },
3699 { "vextractf64x4", { EXxmmq, XM, Ib } },
3701 /* EVEX_W_0F3A1D_P_2 */
3703 { "vcvtps2ph", { EXxmmq, XM, EXxEVexS, Ib } },
3705 /* EVEX_W_0F3A21_P_2 */
3707 { "vinsertps", { XMM, Vex, EXxmm_md, Ib } },
3709 /* EVEX_W_0F3A22_P_2 */
3711 { "vpinsrd", { XM, Vex128, Edqd, Ib } },
3712 { "vpinsrq", { XM, Vex128, Eq, Ib } },
3714 /* EVEX_W_0F3A23_P_2 */
3716 { "vshuff32x4", { XM, Vex, EXx, Ib } },
3717 { "vshuff64x2", { XM, Vex, EXx, Ib } },
3719 /* EVEX_W_0F3A38_P_2 */
3721 { "vinserti32x4", { XM, Vex, EXxmm, Ib } },
3722 { "vinserti64x2", { XM, Vex, EXxmm, Ib } },
3724 /* EVEX_W_0F3A39_P_2 */
3726 { "vextracti32x4", { EXxmm, XM, Ib } },
3727 { "vextracti64x2", { EXxmm, XM, Ib } },
3729 /* EVEX_W_0F3A3A_P_2 */
3731 { "vinserti32x8", { XM, Vex, EXxmmq, Ib } },
3732 { "vinserti64x4", { XM, Vex, EXxmmq, Ib } },
3734 /* EVEX_W_0F3A3B_P_2 */
3736 { "vextracti32x8", { EXxmmq, XM, Ib } },
3737 { "vextracti64x4", { EXxmmq, XM, Ib } },
3739 /* EVEX_W_0F3A3E_P_2 */
3741 { "vpcmpub", { XMask, Vex, EXx, Ib } },
3742 { "vpcmpuw", { XMask, Vex, EXx, Ib } },
3744 /* EVEX_W_0F3A3F_P_2 */
3746 { "vpcmpb", { XMask, Vex, EXx, Ib } },
3747 { "vpcmpw", { XMask, Vex, EXx, Ib } },
3749 /* EVEX_W_0F3A42_P_2 */
3751 { "vdbpsadbw", { XM, Vex, EXx, Ib } },
3753 /* EVEX_W_0F3A43_P_2 */
3755 { "vshufi32x4", { XM, Vex, EXx, Ib } },
3756 { "vshufi64x2", { XM, Vex, EXx, Ib } },
3758 /* EVEX_W_0F3A50_P_2 */
3760 { "vrangeps", { XM, Vex, EXx, EXxEVexS, Ib } },
3761 { "vrangepd", { XM, Vex, EXx, EXxEVexS, Ib } },
3763 /* EVEX_W_0F3A51_P_2 */
3765 { "vrangess", { XMScalar, VexScalar, EXxmm_md, EXxEVexS, Ib } },
3766 { "vrangesd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS, Ib } },
3768 /* EVEX_W_0F3A56_P_2 */
3770 { "vreduceps", { XM, EXx, EXxEVexS, Ib } },
3771 { "vreducepd", { XM, EXx, EXxEVexS, Ib } },
3773 /* EVEX_W_0F3A57_P_2 */
3775 { "vreducess", { XMScalar, VexScalar, EXxmm_md, EXxEVexS, Ib } },
3776 { "vreducesd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS, Ib } },
3778 /* EVEX_W_0F3A66_P_2 */
3780 { "vfpclassps", { XMask, EXx, Ib } },
3781 { "vfpclasspd", { XMask, EXx, Ib } },
3783 /* EVEX_W_0F3A67_P_2 */
3785 { "vfpclassss", { XMask, EXxmm_md, Ib } },
3786 { "vfpclasssd", { XMask, EXxmm_mq, Ib } },
3788 #endif /* NEED_VEX_W_TABLE */
3789 #ifdef NEED_MOD_TABLE
3791 /* MOD_EVEX_0F10_PREFIX_1 */
3792 { VEX_W_TABLE (EVEX_W_0F10_P_1_M_0) },
3793 { VEX_W_TABLE (EVEX_W_0F10_P_1_M_1) },
3796 /* MOD_EVEX_0F10_PREFIX_3 */
3797 { VEX_W_TABLE (EVEX_W_0F10_P_3_M_0) },
3798 { VEX_W_TABLE (EVEX_W_0F10_P_3_M_1) },
3801 /* MOD_EVEX_0F11_PREFIX_1 */
3802 { VEX_W_TABLE (EVEX_W_0F11_P_1_M_0) },
3803 { VEX_W_TABLE (EVEX_W_0F11_P_1_M_1) },
3806 /* MOD_EVEX_0F11_PREFIX_3 */
3807 { VEX_W_TABLE (EVEX_W_0F11_P_3_M_0) },
3808 { VEX_W_TABLE (EVEX_W_0F11_P_3_M_1) },
3811 /* MOD_EVEX_0F12_PREFIX_0 */
3812 { VEX_W_TABLE (EVEX_W_0F12_P_0_M_0) },
3813 { VEX_W_TABLE (EVEX_W_0F12_P_0_M_1) },
3816 /* MOD_EVEX_0F16_PREFIX_0 */
3817 { VEX_W_TABLE (EVEX_W_0F16_P_0_M_0) },
3818 { VEX_W_TABLE (EVEX_W_0F16_P_0_M_1) },
3821 /* MOD_EVEX_0F38C6_REG_1 */
3822 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_1) },
3825 /* MOD_EVEX_0F38C6_REG_2 */
3826 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_2) },
3829 /* MOD_EVEX_0F38C6_REG_5 */
3830 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_5) },
3833 /* MOD_EVEX_0F38C6_REG_6 */
3834 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_6) },
3837 /* MOD_EVEX_0F38C7_REG_1 */
3838 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_1) },
3841 /* MOD_EVEX_0F38C7_REG_2 */
3842 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_2) },
3845 /* MOD_EVEX_0F38C7_REG_5 */
3846 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_5) },
3849 /* MOD_EVEX_0F38C7_REG_6 */
3850 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_6) },
3852 #endif /* NEED_MOD_TABLE */