Add support for AVX512BW instructions and their AVX512VL versions.
[deliverable/binutils-gdb.git] / opcodes / i386-dis-evex.h
CommitLineData
43234a1e
L
1#ifdef NEED_OPCODE_TABLE
2
3static const struct dis386 evex_table[][256] = {
4 /* EVEX_0F */
5 {
6 /* 00 */
7 { Bad_Opcode },
8 { Bad_Opcode },
9 { Bad_Opcode },
10 { Bad_Opcode },
11 { Bad_Opcode },
12 { Bad_Opcode },
13 { Bad_Opcode },
14 { Bad_Opcode },
15 /* 08 */
16 { Bad_Opcode },
17 { Bad_Opcode },
18 { Bad_Opcode },
19 { Bad_Opcode },
20 { Bad_Opcode },
21 { Bad_Opcode },
22 { Bad_Opcode },
23 { Bad_Opcode },
24 /* 10 */
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) },
33 /* 18 */
34 { Bad_Opcode },
35 { Bad_Opcode },
36 { Bad_Opcode },
37 { Bad_Opcode },
38 { Bad_Opcode },
39 { Bad_Opcode },
40 { Bad_Opcode },
41 { Bad_Opcode },
42 /* 20 */
43 { Bad_Opcode },
44 { Bad_Opcode },
45 { Bad_Opcode },
46 { Bad_Opcode },
47 { Bad_Opcode },
48 { Bad_Opcode },
49 { Bad_Opcode },
50 { Bad_Opcode },
51 /* 28 */
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) },
60 /* 30 */
61 { Bad_Opcode },
62 { Bad_Opcode },
63 { Bad_Opcode },
64 { Bad_Opcode },
65 { Bad_Opcode },
66 { Bad_Opcode },
67 { Bad_Opcode },
68 { Bad_Opcode },
69 /* 38 */
70 { Bad_Opcode },
71 { Bad_Opcode },
72 { Bad_Opcode },
73 { Bad_Opcode },
74 { Bad_Opcode },
75 { Bad_Opcode },
76 { Bad_Opcode },
77 { Bad_Opcode },
78 /* 40 */
79 { Bad_Opcode },
80 { Bad_Opcode },
81 { Bad_Opcode },
82 { Bad_Opcode },
83 { Bad_Opcode },
84 { Bad_Opcode },
85 { Bad_Opcode },
86 { Bad_Opcode },
87 /* 48 */
88 { Bad_Opcode },
89 { Bad_Opcode },
90 { Bad_Opcode },
91 { Bad_Opcode },
92 { Bad_Opcode },
93 { Bad_Opcode },
94 { Bad_Opcode },
95 { Bad_Opcode },
96 /* 50 */
97 { Bad_Opcode },
98 { PREFIX_TABLE (PREFIX_EVEX_0F51) },
99 { Bad_Opcode },
100 { Bad_Opcode },
101 { Bad_Opcode },
102 { Bad_Opcode },
103 { Bad_Opcode },
104 { Bad_Opcode },
105 /* 58 */
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) },
114 /* 60 */
1ba585e8
IT
115 { PREFIX_TABLE (PREFIX_EVEX_0F60) },
116 { PREFIX_TABLE (PREFIX_EVEX_0F61) },
43234a1e 117 { PREFIX_TABLE (PREFIX_EVEX_0F62) },
1ba585e8
IT
118 { PREFIX_TABLE (PREFIX_EVEX_0F63) },
119 { PREFIX_TABLE (PREFIX_EVEX_0F64) },
120 { PREFIX_TABLE (PREFIX_EVEX_0F65) },
43234a1e 121 { PREFIX_TABLE (PREFIX_EVEX_0F66) },
1ba585e8 122 { PREFIX_TABLE (PREFIX_EVEX_0F67) },
43234a1e 123 /* 68 */
1ba585e8
IT
124 { PREFIX_TABLE (PREFIX_EVEX_0F68) },
125 { PREFIX_TABLE (PREFIX_EVEX_0F69) },
43234a1e 126 { PREFIX_TABLE (PREFIX_EVEX_0F6A) },
1ba585e8 127 { PREFIX_TABLE (PREFIX_EVEX_0F6B) },
43234a1e
L
128 { PREFIX_TABLE (PREFIX_EVEX_0F6C) },
129 { PREFIX_TABLE (PREFIX_EVEX_0F6D) },
130 { PREFIX_TABLE (PREFIX_EVEX_0F6E) },
131 { PREFIX_TABLE (PREFIX_EVEX_0F6F) },
132 /* 70 */
133 { PREFIX_TABLE (PREFIX_EVEX_0F70) },
1ba585e8 134 { REG_TABLE (REG_EVEX_0F71) },
43234a1e
L
135 { REG_TABLE (REG_EVEX_0F72) },
136 { REG_TABLE (REG_EVEX_0F73) },
1ba585e8
IT
137 { PREFIX_TABLE (PREFIX_EVEX_0F74) },
138 { PREFIX_TABLE (PREFIX_EVEX_0F75) },
43234a1e
L
139 { PREFIX_TABLE (PREFIX_EVEX_0F76) },
140 { Bad_Opcode },
141 /* 78 */
142 { PREFIX_TABLE (PREFIX_EVEX_0F78) },
143 { PREFIX_TABLE (PREFIX_EVEX_0F79) },
144 { PREFIX_TABLE (PREFIX_EVEX_0F7A) },
145 { PREFIX_TABLE (PREFIX_EVEX_0F7B) },
146 { Bad_Opcode },
147 { Bad_Opcode },
148 { PREFIX_TABLE (PREFIX_EVEX_0F7E) },
149 { PREFIX_TABLE (PREFIX_EVEX_0F7F) },
150 /* 80 */
151 { Bad_Opcode },
152 { Bad_Opcode },
153 { Bad_Opcode },
154 { Bad_Opcode },
155 { Bad_Opcode },
156 { Bad_Opcode },
157 { Bad_Opcode },
158 { Bad_Opcode },
159 /* 88 */
160 { Bad_Opcode },
161 { Bad_Opcode },
162 { Bad_Opcode },
163 { Bad_Opcode },
164 { Bad_Opcode },
165 { Bad_Opcode },
166 { Bad_Opcode },
167 { Bad_Opcode },
168 /* 90 */
169 { Bad_Opcode },
170 { Bad_Opcode },
171 { Bad_Opcode },
172 { Bad_Opcode },
173 { Bad_Opcode },
174 { Bad_Opcode },
175 { Bad_Opcode },
176 { Bad_Opcode },
177 /* 98 */
178 { Bad_Opcode },
179 { Bad_Opcode },
180 { Bad_Opcode },
181 { Bad_Opcode },
182 { Bad_Opcode },
183 { Bad_Opcode },
184 { Bad_Opcode },
185 { Bad_Opcode },
186 /* A0 */
187 { Bad_Opcode },
188 { Bad_Opcode },
189 { Bad_Opcode },
190 { Bad_Opcode },
191 { Bad_Opcode },
192 { Bad_Opcode },
193 { Bad_Opcode },
194 { Bad_Opcode },
195 /* A8 */
196 { Bad_Opcode },
197 { Bad_Opcode },
198 { Bad_Opcode },
199 { Bad_Opcode },
200 { Bad_Opcode },
201 { Bad_Opcode },
202 { Bad_Opcode },
203 { Bad_Opcode },
204 /* B0 */
205 { Bad_Opcode },
206 { Bad_Opcode },
207 { Bad_Opcode },
208 { Bad_Opcode },
209 { Bad_Opcode },
210 { Bad_Opcode },
211 { Bad_Opcode },
212 { Bad_Opcode },
213 /* B8 */
214 { Bad_Opcode },
215 { Bad_Opcode },
216 { Bad_Opcode },
217 { Bad_Opcode },
218 { Bad_Opcode },
219 { Bad_Opcode },
220 { Bad_Opcode },
221 { Bad_Opcode },
222 /* C0 */
223 { Bad_Opcode },
224 { Bad_Opcode },
225 { PREFIX_TABLE (PREFIX_EVEX_0FC2) },
226 { Bad_Opcode },
1ba585e8
IT
227 { PREFIX_TABLE (PREFIX_EVEX_0FC4) },
228 { PREFIX_TABLE (PREFIX_EVEX_0FC5) },
43234a1e
L
229 { PREFIX_TABLE (PREFIX_EVEX_0FC6) },
230 { Bad_Opcode },
231 /* C8 */
232 { Bad_Opcode },
233 { Bad_Opcode },
234 { Bad_Opcode },
235 { Bad_Opcode },
236 { Bad_Opcode },
237 { Bad_Opcode },
238 { Bad_Opcode },
239 { Bad_Opcode },
240 /* D0 */
241 { Bad_Opcode },
1ba585e8 242 { PREFIX_TABLE (PREFIX_EVEX_0FD1) },
43234a1e
L
243 { PREFIX_TABLE (PREFIX_EVEX_0FD2) },
244 { PREFIX_TABLE (PREFIX_EVEX_0FD3) },
245 { PREFIX_TABLE (PREFIX_EVEX_0FD4) },
1ba585e8 246 { PREFIX_TABLE (PREFIX_EVEX_0FD5) },
43234a1e
L
247 { PREFIX_TABLE (PREFIX_EVEX_0FD6) },
248 { Bad_Opcode },
249 /* D8 */
1ba585e8
IT
250 { PREFIX_TABLE (PREFIX_EVEX_0FD8) },
251 { PREFIX_TABLE (PREFIX_EVEX_0FD9) },
252 { PREFIX_TABLE (PREFIX_EVEX_0FDA) },
43234a1e 253 { PREFIX_TABLE (PREFIX_EVEX_0FDB) },
1ba585e8
IT
254 { PREFIX_TABLE (PREFIX_EVEX_0FDC) },
255 { PREFIX_TABLE (PREFIX_EVEX_0FDD) },
256 { PREFIX_TABLE (PREFIX_EVEX_0FDE) },
43234a1e
L
257 { PREFIX_TABLE (PREFIX_EVEX_0FDF) },
258 /* E0 */
1ba585e8
IT
259 { PREFIX_TABLE (PREFIX_EVEX_0FE0) },
260 { PREFIX_TABLE (PREFIX_EVEX_0FE1) },
43234a1e 261 { PREFIX_TABLE (PREFIX_EVEX_0FE2) },
1ba585e8
IT
262 { PREFIX_TABLE (PREFIX_EVEX_0FE3) },
263 { PREFIX_TABLE (PREFIX_EVEX_0FE4) },
264 { PREFIX_TABLE (PREFIX_EVEX_0FE5) },
43234a1e
L
265 { PREFIX_TABLE (PREFIX_EVEX_0FE6) },
266 { PREFIX_TABLE (PREFIX_EVEX_0FE7) },
267 /* E8 */
1ba585e8
IT
268 { PREFIX_TABLE (PREFIX_EVEX_0FE8) },
269 { PREFIX_TABLE (PREFIX_EVEX_0FE9) },
270 { PREFIX_TABLE (PREFIX_EVEX_0FEA) },
43234a1e 271 { PREFIX_TABLE (PREFIX_EVEX_0FEB) },
1ba585e8
IT
272 { PREFIX_TABLE (PREFIX_EVEX_0FEC) },
273 { PREFIX_TABLE (PREFIX_EVEX_0FED) },
274 { PREFIX_TABLE (PREFIX_EVEX_0FEE) },
43234a1e
L
275 { PREFIX_TABLE (PREFIX_EVEX_0FEF) },
276 /* F0 */
277 { Bad_Opcode },
1ba585e8 278 { PREFIX_TABLE (PREFIX_EVEX_0FF1) },
43234a1e
L
279 { PREFIX_TABLE (PREFIX_EVEX_0FF2) },
280 { PREFIX_TABLE (PREFIX_EVEX_0FF3) },
281 { PREFIX_TABLE (PREFIX_EVEX_0FF4) },
1ba585e8
IT
282 { PREFIX_TABLE (PREFIX_EVEX_0FF5) },
283 { PREFIX_TABLE (PREFIX_EVEX_0FF6) },
43234a1e
L
284 { Bad_Opcode },
285 /* F8 */
1ba585e8
IT
286 { PREFIX_TABLE (PREFIX_EVEX_0FF8) },
287 { PREFIX_TABLE (PREFIX_EVEX_0FF9) },
43234a1e
L
288 { PREFIX_TABLE (PREFIX_EVEX_0FFA) },
289 { PREFIX_TABLE (PREFIX_EVEX_0FFB) },
1ba585e8
IT
290 { PREFIX_TABLE (PREFIX_EVEX_0FFC) },
291 { PREFIX_TABLE (PREFIX_EVEX_0FFD) },
43234a1e
L
292 { PREFIX_TABLE (PREFIX_EVEX_0FFE) },
293 { Bad_Opcode },
294 },
295 /* EVEX_0F38 */
296 {
297 /* 00 */
1ba585e8 298 { PREFIX_TABLE (PREFIX_EVEX_0F3800) },
43234a1e
L
299 { Bad_Opcode },
300 { Bad_Opcode },
301 { Bad_Opcode },
1ba585e8 302 { PREFIX_TABLE (PREFIX_EVEX_0F3804) },
43234a1e
L
303 { Bad_Opcode },
304 { Bad_Opcode },
305 { Bad_Opcode },
306 /* 08 */
307 { Bad_Opcode },
308 { Bad_Opcode },
309 { Bad_Opcode },
1ba585e8 310 { PREFIX_TABLE (PREFIX_EVEX_0F380B) },
43234a1e
L
311 { PREFIX_TABLE (PREFIX_EVEX_0F380C) },
312 { PREFIX_TABLE (PREFIX_EVEX_0F380D) },
313 { Bad_Opcode },
314 { Bad_Opcode },
315 /* 10 */
1ba585e8 316 { PREFIX_TABLE (PREFIX_EVEX_0F3810) },
43234a1e
L
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) },
323 { Bad_Opcode },
324 /* 18 */
325 { PREFIX_TABLE (PREFIX_EVEX_0F3818) },
326 { PREFIX_TABLE (PREFIX_EVEX_0F3819) },
327 { PREFIX_TABLE (PREFIX_EVEX_0F381A) },
328 { PREFIX_TABLE (PREFIX_EVEX_0F381B) },
1ba585e8
IT
329 { PREFIX_TABLE (PREFIX_EVEX_0F381C) },
330 { PREFIX_TABLE (PREFIX_EVEX_0F381D) },
43234a1e
L
331 { PREFIX_TABLE (PREFIX_EVEX_0F381E) },
332 { PREFIX_TABLE (PREFIX_EVEX_0F381F) },
333 /* 20 */
1ba585e8 334 { PREFIX_TABLE (PREFIX_EVEX_0F3820) },
43234a1e
L
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) },
1ba585e8 340 { PREFIX_TABLE (PREFIX_EVEX_0F3826) },
43234a1e
L
341 { PREFIX_TABLE (PREFIX_EVEX_0F3827) },
342 /* 28 */
343 { PREFIX_TABLE (PREFIX_EVEX_0F3828) },
344 { PREFIX_TABLE (PREFIX_EVEX_0F3829) },
345 { PREFIX_TABLE (PREFIX_EVEX_0F382A) },
1ba585e8 346 { PREFIX_TABLE (PREFIX_EVEX_0F382B) },
43234a1e
L
347 { PREFIX_TABLE (PREFIX_EVEX_0F382C) },
348 { PREFIX_TABLE (PREFIX_EVEX_0F382D) },
349 { Bad_Opcode },
350 { Bad_Opcode },
351 /* 30 */
1ba585e8 352 { PREFIX_TABLE (PREFIX_EVEX_0F3830) },
43234a1e
L
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) },
360 /* 38 */
1ba585e8 361 { PREFIX_TABLE (PREFIX_EVEX_0F3838) },
43234a1e
L
362 { PREFIX_TABLE (PREFIX_EVEX_0F3839) },
363 { PREFIX_TABLE (PREFIX_EVEX_0F383A) },
364 { PREFIX_TABLE (PREFIX_EVEX_0F383B) },
1ba585e8 365 { PREFIX_TABLE (PREFIX_EVEX_0F383C) },
43234a1e 366 { PREFIX_TABLE (PREFIX_EVEX_0F383D) },
1ba585e8 367 { PREFIX_TABLE (PREFIX_EVEX_0F383E) },
43234a1e
L
368 { PREFIX_TABLE (PREFIX_EVEX_0F383F) },
369 /* 40 */
370 { PREFIX_TABLE (PREFIX_EVEX_0F3840) },
371 { Bad_Opcode },
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) },
378 /* 48 */
379 { Bad_Opcode },
380 { Bad_Opcode },
381 { Bad_Opcode },
382 { Bad_Opcode },
383 { PREFIX_TABLE (PREFIX_EVEX_0F384C) },
384 { PREFIX_TABLE (PREFIX_EVEX_0F384D) },
385 { PREFIX_TABLE (PREFIX_EVEX_0F384E) },
386 { PREFIX_TABLE (PREFIX_EVEX_0F384F) },
387 /* 50 */
388 { Bad_Opcode },
389 { Bad_Opcode },
390 { Bad_Opcode },
391 { Bad_Opcode },
392 { Bad_Opcode },
393 { Bad_Opcode },
394 { Bad_Opcode },
395 { Bad_Opcode },
396 /* 58 */
397 { PREFIX_TABLE (PREFIX_EVEX_0F3858) },
398 { PREFIX_TABLE (PREFIX_EVEX_0F3859) },
399 { PREFIX_TABLE (PREFIX_EVEX_0F385A) },
400 { PREFIX_TABLE (PREFIX_EVEX_0F385B) },
401 { Bad_Opcode },
402 { Bad_Opcode },
403 { Bad_Opcode },
404 { Bad_Opcode },
405 /* 60 */
406 { Bad_Opcode },
407 { Bad_Opcode },
408 { Bad_Opcode },
409 { Bad_Opcode },
410 { PREFIX_TABLE (PREFIX_EVEX_0F3864) },
411 { PREFIX_TABLE (PREFIX_EVEX_0F3865) },
1ba585e8 412 { PREFIX_TABLE (PREFIX_EVEX_0F3866) },
43234a1e
L
413 { Bad_Opcode },
414 /* 68 */
415 { Bad_Opcode },
416 { Bad_Opcode },
417 { Bad_Opcode },
418 { Bad_Opcode },
419 { Bad_Opcode },
420 { Bad_Opcode },
421 { Bad_Opcode },
422 { Bad_Opcode },
423 /* 70 */
424 { Bad_Opcode },
425 { Bad_Opcode },
426 { Bad_Opcode },
427 { Bad_Opcode },
428 { Bad_Opcode },
1ba585e8 429 { PREFIX_TABLE (PREFIX_EVEX_0F3875) },
43234a1e
L
430 { PREFIX_TABLE (PREFIX_EVEX_0F3876) },
431 { PREFIX_TABLE (PREFIX_EVEX_0F3877) },
432 /* 78 */
1ba585e8
IT
433 { PREFIX_TABLE (PREFIX_EVEX_0F3878) },
434 { PREFIX_TABLE (PREFIX_EVEX_0F3879) },
435 { PREFIX_TABLE (PREFIX_EVEX_0F387A) },
436 { PREFIX_TABLE (PREFIX_EVEX_0F387B) },
43234a1e 437 { PREFIX_TABLE (PREFIX_EVEX_0F387C) },
1ba585e8 438 { PREFIX_TABLE (PREFIX_EVEX_0F387D) },
43234a1e
L
439 { PREFIX_TABLE (PREFIX_EVEX_0F387E) },
440 { PREFIX_TABLE (PREFIX_EVEX_0F387F) },
441 /* 80 */
442 { Bad_Opcode },
443 { Bad_Opcode },
444 { Bad_Opcode },
445 { Bad_Opcode },
446 { Bad_Opcode },
447 { Bad_Opcode },
448 { Bad_Opcode },
449 { Bad_Opcode },
450 /* 88 */
451 { PREFIX_TABLE (PREFIX_EVEX_0F3888) },
452 { PREFIX_TABLE (PREFIX_EVEX_0F3889) },
453 { PREFIX_TABLE (PREFIX_EVEX_0F388A) },
454 { PREFIX_TABLE (PREFIX_EVEX_0F388B) },
455 { Bad_Opcode },
1ba585e8 456 { PREFIX_TABLE (PREFIX_EVEX_0F388D) },
43234a1e
L
457 { Bad_Opcode },
458 { Bad_Opcode },
459 /* 90 */
460 { PREFIX_TABLE (PREFIX_EVEX_0F3890) },
461 { PREFIX_TABLE (PREFIX_EVEX_0F3891) },
462 { PREFIX_TABLE (PREFIX_EVEX_0F3892) },
463 { PREFIX_TABLE (PREFIX_EVEX_0F3893) },
464 { Bad_Opcode },
465 { Bad_Opcode },
466 { PREFIX_TABLE (PREFIX_EVEX_0F3896) },
467 { PREFIX_TABLE (PREFIX_EVEX_0F3897) },
468 /* 98 */
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) },
477 /* A0 */
478 { PREFIX_TABLE (PREFIX_EVEX_0F38A0) },
479 { PREFIX_TABLE (PREFIX_EVEX_0F38A1) },
480 { PREFIX_TABLE (PREFIX_EVEX_0F38A2) },
481 { PREFIX_TABLE (PREFIX_EVEX_0F38A3) },
482 { Bad_Opcode },
483 { Bad_Opcode },
484 { PREFIX_TABLE (PREFIX_EVEX_0F38A6) },
485 { PREFIX_TABLE (PREFIX_EVEX_0F38A7) },
486 /* A8 */
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) },
495 /* B0 */
496 { Bad_Opcode },
497 { Bad_Opcode },
498 { Bad_Opcode },
499 { Bad_Opcode },
500 { Bad_Opcode },
501 { Bad_Opcode },
502 { PREFIX_TABLE (PREFIX_EVEX_0F38B6) },
503 { PREFIX_TABLE (PREFIX_EVEX_0F38B7) },
504 /* B8 */
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) },
513 /* C0 */
514 { Bad_Opcode },
515 { Bad_Opcode },
516 { Bad_Opcode },
517 { Bad_Opcode },
518 { PREFIX_TABLE (PREFIX_EVEX_0F38C4) },
519 { Bad_Opcode },
520 { REG_TABLE (REG_EVEX_0F38C6) },
521 { REG_TABLE (REG_EVEX_0F38C7) },
522 /* C8 */
523 { PREFIX_TABLE (PREFIX_EVEX_0F38C8) },
524 { Bad_Opcode },
525 { PREFIX_TABLE (PREFIX_EVEX_0F38CA) },
526 { PREFIX_TABLE (PREFIX_EVEX_0F38CB) },
527 { PREFIX_TABLE (PREFIX_EVEX_0F38CC) },
528 { PREFIX_TABLE (PREFIX_EVEX_0F38CD) },
529 { Bad_Opcode },
530 { Bad_Opcode },
531 /* D0 */
532 { Bad_Opcode },
533 { Bad_Opcode },
534 { Bad_Opcode },
535 { Bad_Opcode },
536 { Bad_Opcode },
537 { Bad_Opcode },
538 { Bad_Opcode },
539 { Bad_Opcode },
540 /* D8 */
541 { Bad_Opcode },
542 { Bad_Opcode },
543 { Bad_Opcode },
544 { Bad_Opcode },
545 { Bad_Opcode },
546 { Bad_Opcode },
547 { Bad_Opcode },
548 { Bad_Opcode },
549 /* E0 */
550 { Bad_Opcode },
551 { Bad_Opcode },
552 { Bad_Opcode },
553 { Bad_Opcode },
554 { Bad_Opcode },
555 { Bad_Opcode },
556 { Bad_Opcode },
557 { Bad_Opcode },
558 /* E8 */
559 { Bad_Opcode },
560 { Bad_Opcode },
561 { Bad_Opcode },
562 { Bad_Opcode },
563 { Bad_Opcode },
564 { Bad_Opcode },
565 { Bad_Opcode },
566 { Bad_Opcode },
567 /* F0 */
568 { Bad_Opcode },
569 { Bad_Opcode },
570 { Bad_Opcode },
571 { Bad_Opcode },
572 { Bad_Opcode },
573 { Bad_Opcode },
574 { Bad_Opcode },
575 { Bad_Opcode },
576 /* F8 */
577 { Bad_Opcode },
578 { Bad_Opcode },
579 { Bad_Opcode },
580 { Bad_Opcode },
581 { Bad_Opcode },
582 { Bad_Opcode },
583 { Bad_Opcode },
584 { Bad_Opcode },
585 },
586 /* EVEX_0F3A */
587 {
588 /* 00 */
589 { PREFIX_TABLE (PREFIX_EVEX_0F3A00) },
590 { PREFIX_TABLE (PREFIX_EVEX_0F3A01) },
591 { Bad_Opcode },
592 { PREFIX_TABLE (PREFIX_EVEX_0F3A03) },
593 { PREFIX_TABLE (PREFIX_EVEX_0F3A04) },
594 { PREFIX_TABLE (PREFIX_EVEX_0F3A05) },
595 { Bad_Opcode },
596 { Bad_Opcode },
597 /* 08 */
598 { PREFIX_TABLE (PREFIX_EVEX_0F3A08) },
599 { PREFIX_TABLE (PREFIX_EVEX_0F3A09) },
600 { PREFIX_TABLE (PREFIX_EVEX_0F3A0A) },
601 { PREFIX_TABLE (PREFIX_EVEX_0F3A0B) },
602 { Bad_Opcode },
603 { Bad_Opcode },
604 { Bad_Opcode },
1ba585e8 605 { PREFIX_TABLE (PREFIX_EVEX_0F3A0F) },
43234a1e
L
606 /* 10 */
607 { Bad_Opcode },
608 { Bad_Opcode },
609 { Bad_Opcode },
610 { Bad_Opcode },
1ba585e8
IT
611 { PREFIX_TABLE (PREFIX_EVEX_0F3A14) },
612 { PREFIX_TABLE (PREFIX_EVEX_0F3A15) },
43234a1e
L
613 { Bad_Opcode },
614 { PREFIX_TABLE (PREFIX_EVEX_0F3A17) },
615 /* 18 */
616 { PREFIX_TABLE (PREFIX_EVEX_0F3A18) },
617 { PREFIX_TABLE (PREFIX_EVEX_0F3A19) },
618 { PREFIX_TABLE (PREFIX_EVEX_0F3A1A) },
619 { PREFIX_TABLE (PREFIX_EVEX_0F3A1B) },
620 { Bad_Opcode },
621 { PREFIX_TABLE (PREFIX_EVEX_0F3A1D) },
622 { PREFIX_TABLE (PREFIX_EVEX_0F3A1E) },
623 { PREFIX_TABLE (PREFIX_EVEX_0F3A1F) },
624 /* 20 */
1ba585e8 625 { PREFIX_TABLE (PREFIX_EVEX_0F3A20) },
43234a1e
L
626 { PREFIX_TABLE (PREFIX_EVEX_0F3A21) },
627 { Bad_Opcode },
628 { PREFIX_TABLE (PREFIX_EVEX_0F3A23) },
629 { Bad_Opcode },
630 { PREFIX_TABLE (PREFIX_EVEX_0F3A25) },
631 { PREFIX_TABLE (PREFIX_EVEX_0F3A26) },
632 { PREFIX_TABLE (PREFIX_EVEX_0F3A27) },
633 /* 28 */
634 { Bad_Opcode },
635 { Bad_Opcode },
636 { Bad_Opcode },
637 { Bad_Opcode },
638 { Bad_Opcode },
639 { Bad_Opcode },
640 { Bad_Opcode },
641 { Bad_Opcode },
642 /* 30 */
643 { Bad_Opcode },
644 { Bad_Opcode },
645 { Bad_Opcode },
646 { Bad_Opcode },
647 { Bad_Opcode },
648 { Bad_Opcode },
649 { Bad_Opcode },
650 { Bad_Opcode },
651 /* 38 */
652 { PREFIX_TABLE (PREFIX_EVEX_0F3A38) },
653 { PREFIX_TABLE (PREFIX_EVEX_0F3A39) },
654 { PREFIX_TABLE (PREFIX_EVEX_0F3A3A) },
655 { PREFIX_TABLE (PREFIX_EVEX_0F3A3B) },
656 { Bad_Opcode },
657 { Bad_Opcode },
1ba585e8
IT
658 { PREFIX_TABLE (PREFIX_EVEX_0F3A3E) },
659 { PREFIX_TABLE (PREFIX_EVEX_0F3A3F) },
43234a1e
L
660 /* 40 */
661 { Bad_Opcode },
662 { Bad_Opcode },
1ba585e8 663 { PREFIX_TABLE (PREFIX_EVEX_0F3A42) },
43234a1e
L
664 { PREFIX_TABLE (PREFIX_EVEX_0F3A43) },
665 { Bad_Opcode },
666 { Bad_Opcode },
667 { Bad_Opcode },
668 { Bad_Opcode },
669 /* 48 */
670 { Bad_Opcode },
671 { Bad_Opcode },
672 { Bad_Opcode },
673 { Bad_Opcode },
674 { Bad_Opcode },
675 { Bad_Opcode },
676 { Bad_Opcode },
677 { Bad_Opcode },
678 /* 50 */
679 { Bad_Opcode },
680 { Bad_Opcode },
681 { Bad_Opcode },
682 { Bad_Opcode },
683 { PREFIX_TABLE (PREFIX_EVEX_0F3A54) },
684 { PREFIX_TABLE (PREFIX_EVEX_0F3A55) },
685 { Bad_Opcode },
686 { Bad_Opcode },
687 /* 58 */
688 { Bad_Opcode },
689 { Bad_Opcode },
690 { Bad_Opcode },
691 { Bad_Opcode },
692 { Bad_Opcode },
693 { Bad_Opcode },
694 { Bad_Opcode },
695 { Bad_Opcode },
696 /* 60 */
697 { Bad_Opcode },
698 { Bad_Opcode },
699 { Bad_Opcode },
700 { Bad_Opcode },
701 { Bad_Opcode },
702 { Bad_Opcode },
703 { Bad_Opcode },
704 { Bad_Opcode },
705 /* 68 */
706 { Bad_Opcode },
707 { Bad_Opcode },
708 { Bad_Opcode },
709 { Bad_Opcode },
710 { Bad_Opcode },
711 { Bad_Opcode },
712 { Bad_Opcode },
713 { Bad_Opcode },
714 /* 70 */
715 { Bad_Opcode },
716 { Bad_Opcode },
717 { Bad_Opcode },
718 { Bad_Opcode },
719 { Bad_Opcode },
720 { Bad_Opcode },
721 { Bad_Opcode },
722 { Bad_Opcode },
723 /* 78 */
724 { Bad_Opcode },
725 { Bad_Opcode },
726 { Bad_Opcode },
727 { Bad_Opcode },
728 { Bad_Opcode },
729 { Bad_Opcode },
730 { Bad_Opcode },
731 { Bad_Opcode },
732 /* 80 */
733 { Bad_Opcode },
734 { Bad_Opcode },
735 { Bad_Opcode },
736 { Bad_Opcode },
737 { Bad_Opcode },
738 { Bad_Opcode },
739 { Bad_Opcode },
740 { Bad_Opcode },
741 /* 88 */
742 { Bad_Opcode },
743 { Bad_Opcode },
744 { Bad_Opcode },
745 { Bad_Opcode },
746 { Bad_Opcode },
747 { Bad_Opcode },
748 { Bad_Opcode },
749 { Bad_Opcode },
750 /* 90 */
751 { Bad_Opcode },
752 { Bad_Opcode },
753 { Bad_Opcode },
754 { Bad_Opcode },
755 { Bad_Opcode },
756 { Bad_Opcode },
757 { Bad_Opcode },
758 { Bad_Opcode },
759 /* 98 */
760 { Bad_Opcode },
761 { Bad_Opcode },
762 { Bad_Opcode },
763 { Bad_Opcode },
764 { Bad_Opcode },
765 { Bad_Opcode },
766 { Bad_Opcode },
767 { Bad_Opcode },
768 /* A0 */
769 { Bad_Opcode },
770 { Bad_Opcode },
771 { Bad_Opcode },
772 { Bad_Opcode },
773 { Bad_Opcode },
774 { Bad_Opcode },
775 { Bad_Opcode },
776 { Bad_Opcode },
777 /* A8 */
778 { Bad_Opcode },
779 { Bad_Opcode },
780 { Bad_Opcode },
781 { Bad_Opcode },
782 { Bad_Opcode },
783 { Bad_Opcode },
784 { Bad_Opcode },
785 { Bad_Opcode },
786 /* B0 */
787 { Bad_Opcode },
788 { Bad_Opcode },
789 { Bad_Opcode },
790 { Bad_Opcode },
791 { Bad_Opcode },
792 { Bad_Opcode },
793 { Bad_Opcode },
794 { Bad_Opcode },
795 /* B8 */
796 { Bad_Opcode },
797 { Bad_Opcode },
798 { Bad_Opcode },
799 { Bad_Opcode },
800 { Bad_Opcode },
801 { Bad_Opcode },
802 { Bad_Opcode },
803 { Bad_Opcode },
804 /* C0 */
805 { Bad_Opcode },
806 { Bad_Opcode },
807 { Bad_Opcode },
808 { Bad_Opcode },
809 { Bad_Opcode },
810 { Bad_Opcode },
811 { Bad_Opcode },
812 { Bad_Opcode },
813 /* C8 */
814 { Bad_Opcode },
815 { Bad_Opcode },
816 { Bad_Opcode },
817 { Bad_Opcode },
818 { Bad_Opcode },
819 { Bad_Opcode },
820 { Bad_Opcode },
821 { Bad_Opcode },
822 /* D0 */
823 { Bad_Opcode },
824 { Bad_Opcode },
825 { Bad_Opcode },
826 { Bad_Opcode },
827 { Bad_Opcode },
828 { Bad_Opcode },
829 { Bad_Opcode },
830 { Bad_Opcode },
831 /* D8 */
832 { Bad_Opcode },
833 { Bad_Opcode },
834 { Bad_Opcode },
835 { Bad_Opcode },
836 { Bad_Opcode },
837 { Bad_Opcode },
838 { Bad_Opcode },
839 { Bad_Opcode },
840 /* E0 */
841 { Bad_Opcode },
842 { Bad_Opcode },
843 { Bad_Opcode },
844 { Bad_Opcode },
845 { Bad_Opcode },
846 { Bad_Opcode },
847 { Bad_Opcode },
848 { Bad_Opcode },
849 /* E8 */
850 { Bad_Opcode },
851 { Bad_Opcode },
852 { Bad_Opcode },
853 { Bad_Opcode },
854 { Bad_Opcode },
855 { Bad_Opcode },
856 { Bad_Opcode },
857 { Bad_Opcode },
858 /* F0 */
859 { Bad_Opcode },
860 { Bad_Opcode },
861 { Bad_Opcode },
862 { Bad_Opcode },
863 { Bad_Opcode },
864 { Bad_Opcode },
865 { Bad_Opcode },
866 { Bad_Opcode },
867 /* F8 */
868 { Bad_Opcode },
869 { Bad_Opcode },
870 { Bad_Opcode },
871 { Bad_Opcode },
872 { Bad_Opcode },
873 { Bad_Opcode },
874 { Bad_Opcode },
875 { Bad_Opcode },
876 },
877};
878#endif /* NEED_OPCODE_TABLE */
879
880#ifdef NEED_REG_TABLE
1ba585e8
IT
881 /* REG_EVEX_0F71 */
882 {
883 { Bad_Opcode },
884 { Bad_Opcode },
885 { PREFIX_TABLE (PREFIX_EVEX_0F71_REG_2) },
886 { Bad_Opcode },
887 { PREFIX_TABLE (PREFIX_EVEX_0F71_REG_4) },
888 { Bad_Opcode },
889 { PREFIX_TABLE (PREFIX_EVEX_0F71_REG_6) },
890 },
43234a1e
L
891 /* REG_EVEX_0F72 */
892 {
893 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_0) },
894 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_1) },
895 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_2) },
896 { Bad_Opcode },
897 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_4) },
898 { Bad_Opcode },
899 { PREFIX_TABLE (PREFIX_EVEX_0F72_REG_6) },
900 },
901 /* REG_EVEX_0F73 */
902 {
903 { Bad_Opcode },
904 { Bad_Opcode },
905 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_2) },
1ba585e8 906 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_3) },
43234a1e
L
907 { Bad_Opcode },
908 { Bad_Opcode },
909 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_6) },
1ba585e8 910 { PREFIX_TABLE (PREFIX_EVEX_0F73_REG_7) },
43234a1e
L
911 },
912 /* REG_EVEX_0F38C6 */
913 {
914 { Bad_Opcode },
915 { MOD_TABLE (MOD_EVEX_0F38C6_REG_1) },
916 { MOD_TABLE (MOD_EVEX_0F38C6_REG_2) },
917 { Bad_Opcode },
918 { Bad_Opcode },
919 { MOD_TABLE (MOD_EVEX_0F38C6_REG_5) },
920 { MOD_TABLE (MOD_EVEX_0F38C6_REG_6) },
921 },
922 /* REG_EVEX_0F38C7 */
923 {
924 { Bad_Opcode },
925 { MOD_TABLE (MOD_EVEX_0F38C7_REG_1) },
926 { MOD_TABLE (MOD_EVEX_0F38C7_REG_2) },
927 { Bad_Opcode },
928 { Bad_Opcode },
929 { MOD_TABLE (MOD_EVEX_0F38C7_REG_5) },
930 { MOD_TABLE (MOD_EVEX_0F38C7_REG_6) },
931 },
932#endif /* NEED_REG_TABLE */
933
934#ifdef NEED_PREFIX_TABLE
935 /* PREFIX_EVEX_0F10 */
936 {
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) },
941 },
942 /* PREFIX_EVEX_0F11 */
943 {
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) },
948 },
949 /* PREFIX_EVEX_0F12 */
950 {
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) },
955 },
956 /* PREFIX_EVEX_0F13 */
957 {
958 { VEX_W_TABLE (EVEX_W_0F13_P_0) },
959 { Bad_Opcode },
960 { VEX_W_TABLE (EVEX_W_0F13_P_2) },
961 },
962 /* PREFIX_EVEX_0F14 */
963 {
964 { VEX_W_TABLE (EVEX_W_0F14_P_0) },
965 { Bad_Opcode },
966 { VEX_W_TABLE (EVEX_W_0F14_P_2) },
967 },
968 /* PREFIX_EVEX_0F15 */
969 {
970 { VEX_W_TABLE (EVEX_W_0F15_P_0) },
971 { Bad_Opcode },
972 { VEX_W_TABLE (EVEX_W_0F15_P_2) },
973 },
974 /* PREFIX_EVEX_0F16 */
975 {
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) },
979 },
980 /* PREFIX_EVEX_0F17 */
981 {
982 { VEX_W_TABLE (EVEX_W_0F17_P_0) },
983 { Bad_Opcode },
984 { VEX_W_TABLE (EVEX_W_0F17_P_2) },
985 },
986 /* PREFIX_EVEX_0F28 */
987 {
988 { VEX_W_TABLE (EVEX_W_0F28_P_0) },
989 { Bad_Opcode },
990 { VEX_W_TABLE (EVEX_W_0F28_P_2) },
991 },
992 /* PREFIX_EVEX_0F29 */
993 {
994 { VEX_W_TABLE (EVEX_W_0F29_P_0) },
995 { Bad_Opcode },
996 { VEX_W_TABLE (EVEX_W_0F29_P_2) },
997 },
998 /* PREFIX_EVEX_0F2A */
999 {
1000 { Bad_Opcode },
1001 { VEX_W_TABLE (EVEX_W_0F2A_P_1) },
1002 { Bad_Opcode },
1003 { VEX_W_TABLE (EVEX_W_0F2A_P_3) },
1004 },
1005 /* PREFIX_EVEX_0F2B */
1006 {
1007 { VEX_W_TABLE (EVEX_W_0F2B_P_0) },
1008 { Bad_Opcode },
1009 { VEX_W_TABLE (EVEX_W_0F2B_P_2) },
1010 },
1011 /* PREFIX_EVEX_0F2C */
1012 {
1013 { Bad_Opcode },
1014 { "vcvttss2si", { Gdq, EXxmm_md, EXxEVexS } },
1015 { Bad_Opcode },
1016 { "vcvttsd2si", { Gdq, EXxmm_mq, EXxEVexS } },
1017 },
1018 /* PREFIX_EVEX_0F2D */
1019 {
1020 { Bad_Opcode },
1021 { "vcvtss2si", { Gdq, EXxmm_md, EXxEVexR } },
1022 { Bad_Opcode },
1023 { "vcvtsd2si", { Gdq, EXxmm_mq, EXxEVexR } },
1024 },
1025 /* PREFIX_EVEX_0F2E */
1026 {
1027 { VEX_W_TABLE (EVEX_W_0F2E_P_0) },
1028 { Bad_Opcode },
1029 { VEX_W_TABLE (EVEX_W_0F2E_P_2) },
1030 },
1031 /* PREFIX_EVEX_0F2F */
1032 {
1033 { VEX_W_TABLE (EVEX_W_0F2F_P_0) },
1034 { Bad_Opcode },
1035 { VEX_W_TABLE (EVEX_W_0F2F_P_2) },
1036 },
1037 /* PREFIX_EVEX_0F51 */
1038 {
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) },
1043 },
1044 /* PREFIX_EVEX_0F58 */
1045 {
1046 { VEX_W_TABLE (EVEX_W_0F58_P_0) },
1047 { VEX_W_TABLE (EVEX_W_0F58_P_1) },
1048 { VEX_W_TABLE (EVEX_W_0F58_P_2) },
1049 { VEX_W_TABLE (EVEX_W_0F58_P_3) },
1050 },
1051 /* PREFIX_EVEX_0F59 */
1052 {
1053 { VEX_W_TABLE (EVEX_W_0F59_P_0) },
1054 { VEX_W_TABLE (EVEX_W_0F59_P_1) },
1055 { VEX_W_TABLE (EVEX_W_0F59_P_2) },
1056 { VEX_W_TABLE (EVEX_W_0F59_P_3) },
1057 },
1058 /* PREFIX_EVEX_0F5A */
1059 {
1060 { VEX_W_TABLE (EVEX_W_0F5A_P_0) },
1061 { VEX_W_TABLE (EVEX_W_0F5A_P_1) },
1062 { VEX_W_TABLE (EVEX_W_0F5A_P_2) },
1063 { VEX_W_TABLE (EVEX_W_0F5A_P_3) },
1064 },
1065 /* PREFIX_EVEX_0F5B */
1066 {
1067 { VEX_W_TABLE (EVEX_W_0F5B_P_0) },
1068 { VEX_W_TABLE (EVEX_W_0F5B_P_1) },
1069 { VEX_W_TABLE (EVEX_W_0F5B_P_2) },
1070 },
1071 /* PREFIX_EVEX_0F5C */
1072 {
1073 { VEX_W_TABLE (EVEX_W_0F5C_P_0) },
1074 { VEX_W_TABLE (EVEX_W_0F5C_P_1) },
1075 { VEX_W_TABLE (EVEX_W_0F5C_P_2) },
1076 { VEX_W_TABLE (EVEX_W_0F5C_P_3) },
1077 },
1078 /* PREFIX_EVEX_0F5D */
1079 {
1080 { VEX_W_TABLE (EVEX_W_0F5D_P_0) },
1081 { VEX_W_TABLE (EVEX_W_0F5D_P_1) },
1082 { VEX_W_TABLE (EVEX_W_0F5D_P_2) },
1083 { VEX_W_TABLE (EVEX_W_0F5D_P_3) },
1084 },
1085 /* PREFIX_EVEX_0F5E */
1086 {
1087 { VEX_W_TABLE (EVEX_W_0F5E_P_0) },
1088 { VEX_W_TABLE (EVEX_W_0F5E_P_1) },
1089 { VEX_W_TABLE (EVEX_W_0F5E_P_2) },
1090 { VEX_W_TABLE (EVEX_W_0F5E_P_3) },
1091 },
1092 /* PREFIX_EVEX_0F5F */
1093 {
1094 { VEX_W_TABLE (EVEX_W_0F5F_P_0) },
1095 { VEX_W_TABLE (EVEX_W_0F5F_P_1) },
1096 { VEX_W_TABLE (EVEX_W_0F5F_P_2) },
1097 { VEX_W_TABLE (EVEX_W_0F5F_P_3) },
1098 },
1ba585e8
IT
1099 /* PREFIX_EVEX_0F60 */
1100 {
1101 { Bad_Opcode },
1102 { Bad_Opcode },
1103 { "vpunpcklbw", { XM, Vex, EXx } },
1104 },
1105 /* PREFIX_EVEX_0F61 */
1106 {
1107 { Bad_Opcode },
1108 { Bad_Opcode },
1109 { "vpunpcklwd", { XM, Vex, EXx } },
1110 },
43234a1e
L
1111 /* PREFIX_EVEX_0F62 */
1112 {
1113 { Bad_Opcode },
1114 { Bad_Opcode },
1115 { VEX_W_TABLE (EVEX_W_0F62_P_2) },
1116 },
1ba585e8
IT
1117 /* PREFIX_EVEX_0F63 */
1118 {
1119 { Bad_Opcode },
1120 { Bad_Opcode },
1121 { "vpacksswb", { XM, Vex, EXx } },
1122 },
1123 /* PREFIX_EVEX_0F64 */
1124 {
1125 { Bad_Opcode },
1126 { Bad_Opcode },
1127 { "vpcmpgtb", { XMask, Vex, EXx } },
1128 },
1129 /* PREFIX_EVEX_0F65 */
1130 {
1131 { Bad_Opcode },
1132 { Bad_Opcode },
1133 { "vpcmpgtw", { XMask, Vex, EXx } },
1134 },
43234a1e
L
1135 /* PREFIX_EVEX_0F66 */
1136 {
1137 { Bad_Opcode },
1138 { Bad_Opcode },
1139 { VEX_W_TABLE (EVEX_W_0F66_P_2) },
1140 },
1ba585e8
IT
1141 /* PREFIX_EVEX_0F67 */
1142 {
1143 { Bad_Opcode },
1144 { Bad_Opcode },
1145 { "vpackuswb", { XM, Vex, EXx } },
1146 },
1147 /* PREFIX_EVEX_0F68 */
1148 {
1149 { Bad_Opcode },
1150 { Bad_Opcode },
1151 { "vpunpckhbw", { XM, Vex, EXx } },
1152 },
1153 /* PREFIX_EVEX_0F69 */
1154 {
1155 { Bad_Opcode },
1156 { Bad_Opcode },
1157 { "vpunpckhwd", { XM, Vex, EXx } },
1158 },
43234a1e
L
1159 /* PREFIX_EVEX_0F6A */
1160 {
1161 { Bad_Opcode },
1162 { Bad_Opcode },
1163 { VEX_W_TABLE (EVEX_W_0F6A_P_2) },
1164 },
1ba585e8
IT
1165 /* PREFIX_EVEX_0F6B */
1166 {
1167 { Bad_Opcode },
1168 { Bad_Opcode },
1169 { VEX_W_TABLE (EVEX_W_0F6B_P_2) },
1170 },
43234a1e
L
1171 /* PREFIX_EVEX_0F6C */
1172 {
1173 { Bad_Opcode },
1174 { Bad_Opcode },
1175 { VEX_W_TABLE (EVEX_W_0F6C_P_2) },
1176 },
1177 /* PREFIX_EVEX_0F6D */
1178 {
1179 { Bad_Opcode },
1180 { Bad_Opcode },
1181 { VEX_W_TABLE (EVEX_W_0F6D_P_2) },
1182 },
1183 /* PREFIX_EVEX_0F6E */
1184 {
1185 { Bad_Opcode },
1186 { Bad_Opcode },
1187 { VEX_W_TABLE (EVEX_W_0F6E_P_2) },
1188 },
1189 /* PREFIX_EVEX_0F6F */
1190 {
1191 { Bad_Opcode },
1192 { VEX_W_TABLE (EVEX_W_0F6F_P_1) },
1193 { VEX_W_TABLE (EVEX_W_0F6F_P_2) },
1ba585e8 1194 { VEX_W_TABLE (EVEX_W_0F6F_P_3) },
43234a1e
L
1195 },
1196 /* PREFIX_EVEX_0F70 */
1197 {
1198 { Bad_Opcode },
1ba585e8 1199 { "vpshufhw", { XM, EXx, Ib } },
43234a1e 1200 { VEX_W_TABLE (EVEX_W_0F70_P_2) },
1ba585e8
IT
1201 { "vpshuflw", { XM, EXx, Ib } },
1202 },
1203 /* PREFIX_EVEX_0F71_REG_2 */
1204 {
1205 { Bad_Opcode },
1206 { Bad_Opcode },
1207 { "vpsrlw", { Vex, EXx, Ib } },
1208 },
1209 /* PREFIX_EVEX_0F71_REG_4 */
1210 {
1211 { Bad_Opcode },
1212 { Bad_Opcode },
1213 { "vpsraw", { Vex, EXx, Ib } },
1214 },
1215 /* PREFIX_EVEX_0F71_REG_6 */
1216 {
1217 { Bad_Opcode },
1218 { Bad_Opcode },
1219 { "vpsllw", { Vex, EXx, Ib } },
43234a1e
L
1220 },
1221 /* PREFIX_EVEX_0F72_REG_0 */
1222 {
1223 { Bad_Opcode },
1224 { Bad_Opcode },
1225 { "vpror%LW", { Vex, EXx, Ib } },
1226 },
1227 /* PREFIX_EVEX_0F72_REG_1 */
1228 {
1229 { Bad_Opcode },
1230 { Bad_Opcode },
1231 { "vprol%LW", { Vex, EXx, Ib } },
1232 },
1233 /* PREFIX_EVEX_0F72_REG_2 */
1234 {
1235 { Bad_Opcode },
1236 { Bad_Opcode },
1237 { VEX_W_TABLE (EVEX_W_0F72_R_2_P_2) },
1238 },
1239 /* PREFIX_EVEX_0F72_REG_4 */
1240 {
1241 { Bad_Opcode },
1242 { Bad_Opcode },
1243 { "vpsra%LW", { Vex, EXx, Ib } },
1244 },
1245 /* PREFIX_EVEX_0F72_REG_6 */
1246 {
1247 { Bad_Opcode },
1248 { Bad_Opcode },
1249 { VEX_W_TABLE (EVEX_W_0F72_R_6_P_2) },
1250 },
1251 /* PREFIX_EVEX_0F73_REG_2 */
1252 {
1253 { Bad_Opcode },
1254 { Bad_Opcode },
1255 { VEX_W_TABLE (EVEX_W_0F73_R_2_P_2) },
1256 },
1ba585e8
IT
1257 /* PREFIX_EVEX_0F73_REG_3 */
1258 {
1259 { Bad_Opcode },
1260 { Bad_Opcode },
1261 { "vpsrldq", { Vex, EXx, Ib } },
1262 },
43234a1e
L
1263 /* PREFIX_EVEX_0F73_REG_6 */
1264 {
1265 { Bad_Opcode },
1266 { Bad_Opcode },
1267 { VEX_W_TABLE (EVEX_W_0F73_R_6_P_2) },
1268 },
1ba585e8
IT
1269 /* PREFIX_EVEX_0F73_REG_7 */
1270 {
1271 { Bad_Opcode },
1272 { Bad_Opcode },
1273 { "vpslldq", { Vex, EXx, Ib } },
1274 },
1275 /* PREFIX_EVEX_0F74 */
1276 {
1277 { Bad_Opcode },
1278 { Bad_Opcode },
1279 { "vpcmpeqb", { XMask, Vex, EXx } },
1280 },
1281 /* PREFIX_EVEX_0F75 */
1282 {
1283 { Bad_Opcode },
1284 { Bad_Opcode },
1285 { "vpcmpeqw", { XMask, Vex, EXx } },
1286 },
43234a1e
L
1287 /* PREFIX_EVEX_0F76 */
1288 {
1289 { Bad_Opcode },
1290 { Bad_Opcode },
1291 { VEX_W_TABLE (EVEX_W_0F76_P_2) },
1292 },
1293 /* PREFIX_EVEX_0F78 */
1294 {
1295 { VEX_W_TABLE (EVEX_W_0F78_P_0) },
1296 { "vcvttss2usi", { Gdq, EXxmm_md, EXxEVexS } },
1297 { Bad_Opcode },
1298 { "vcvttsd2usi", { Gdq, EXxmm_mq, EXxEVexS } },
1299 },
1300 /* PREFIX_EVEX_0F79 */
1301 {
1302 { VEX_W_TABLE (EVEX_W_0F79_P_0) },
1303 { "vcvtss2usi", { Gdq, EXxmm_md, EXxEVexR } },
1304 { Bad_Opcode },
1305 { "vcvtsd2usi", { Gdq, EXxmm_mq, EXxEVexR } },
1306 },
1307 /* PREFIX_EVEX_0F7A */
1308 {
1309 { Bad_Opcode },
1310 { VEX_W_TABLE (EVEX_W_0F7A_P_1) },
1311 { Bad_Opcode },
1312 { VEX_W_TABLE (EVEX_W_0F7A_P_3) },
1313 },
1314 /* PREFIX_EVEX_0F7B */
1315 {
1316 { Bad_Opcode },
1317 { VEX_W_TABLE (EVEX_W_0F7B_P_1) },
1318 { Bad_Opcode },
1319 { VEX_W_TABLE (EVEX_W_0F7B_P_3) },
1320 },
1321 /* PREFIX_EVEX_0F7E */
1322 {
1323 { Bad_Opcode },
1324 { VEX_W_TABLE (EVEX_W_0F7E_P_1) },
1325 { VEX_W_TABLE (EVEX_W_0F7E_P_2) },
1326 },
1327 /* PREFIX_EVEX_0F7F */
1328 {
1329 { Bad_Opcode },
1330 { VEX_W_TABLE (EVEX_W_0F7F_P_1) },
1331 { VEX_W_TABLE (EVEX_W_0F7F_P_2) },
1ba585e8 1332 { VEX_W_TABLE (EVEX_W_0F7F_P_3) },
43234a1e 1333 },
43234a1e
L
1334 /* PREFIX_EVEX_0FC2 */
1335 {
1336 { VEX_W_TABLE (EVEX_W_0FC2_P_0) },
1337 { VEX_W_TABLE (EVEX_W_0FC2_P_1) },
1338 { VEX_W_TABLE (EVEX_W_0FC2_P_2) },
1339 { VEX_W_TABLE (EVEX_W_0FC2_P_3) },
1340 },
1ba585e8
IT
1341 /* PREFIX_EVEX_0FC4 */
1342 {
1343 { Bad_Opcode },
1344 { Bad_Opcode },
1345 { "vpinsrw", { XM, Vex128, Edw, Ib } },
1346 },
1347 /* PREFIX_EVEX_0FC5 */
1348 {
1349 { Bad_Opcode },
1350 { Bad_Opcode },
1351 { "vpextrw", { Gdq, XS, Ib } },
1352 },
43234a1e
L
1353 /* PREFIX_EVEX_0FC6 */
1354 {
1355 { VEX_W_TABLE (EVEX_W_0FC6_P_0) },
1356 { Bad_Opcode },
1357 { VEX_W_TABLE (EVEX_W_0FC6_P_2) },
1358 },
1ba585e8
IT
1359 /* PREFIX_EVEX_0FD1 */
1360 {
1361 { Bad_Opcode },
1362 { Bad_Opcode },
1363 { "vpsrlw", { XM, Vex, EXxmm } },
1364 },
43234a1e
L
1365 /* PREFIX_EVEX_0FD2 */
1366 {
1367 { Bad_Opcode },
1368 { Bad_Opcode },
1369 { VEX_W_TABLE (EVEX_W_0FD2_P_2) },
1370 },
1371 /* PREFIX_EVEX_0FD3 */
1372 {
1373 { Bad_Opcode },
1374 { Bad_Opcode },
1375 { VEX_W_TABLE (EVEX_W_0FD3_P_2) },
1376 },
1377 /* PREFIX_EVEX_0FD4 */
1378 {
1379 { Bad_Opcode },
1380 { Bad_Opcode },
1381 { VEX_W_TABLE (EVEX_W_0FD4_P_2) },
1382 },
1ba585e8
IT
1383 /* PREFIX_EVEX_0FD5 */
1384 {
1385 { Bad_Opcode },
1386 { Bad_Opcode },
1387 { "vpmullw", { XM, Vex, EXx } },
1388 },
43234a1e
L
1389 /* PREFIX_EVEX_0FD6 */
1390 {
1391 { Bad_Opcode },
1392 { Bad_Opcode },
1393 { VEX_W_TABLE (EVEX_W_0FD6_P_2) },
1394 },
1ba585e8
IT
1395 /* PREFIX_EVEX_0FD8 */
1396 {
1397 { Bad_Opcode },
1398 { Bad_Opcode },
1399 { "vpsubusb", { XM, Vex, EXx } },
1400 },
1401 /* PREFIX_EVEX_0FD9 */
1402 {
1403 { Bad_Opcode },
1404 { Bad_Opcode },
1405 { "vpsubusw", { XM, Vex, EXx } },
1406 },
1407 /* PREFIX_EVEX_0FDA */
1408 {
1409 { Bad_Opcode },
1410 { Bad_Opcode },
1411 { "vpminub", { XM, Vex, EXx } },
1412 },
43234a1e
L
1413 /* PREFIX_EVEX_0FDB */
1414 {
1415 { Bad_Opcode },
1416 { Bad_Opcode },
1417 { "vpand%LW", { XM, Vex, EXx } },
1418 },
1ba585e8
IT
1419 /* PREFIX_EVEX_0FDC */
1420 {
1421 { Bad_Opcode },
1422 { Bad_Opcode },
1423 { "vpaddusb", { XM, Vex, EXx } },
1424 },
1425 /* PREFIX_EVEX_0FDD */
1426 {
1427 { Bad_Opcode },
1428 { Bad_Opcode },
1429 { "vpaddusw", { XM, Vex, EXx } },
1430 },
1431 /* PREFIX_EVEX_0FDE */
1432 {
1433 { Bad_Opcode },
1434 { Bad_Opcode },
1435 { "vpmaxub", { XM, Vex, EXx } },
1436 },
43234a1e
L
1437 /* PREFIX_EVEX_0FDF */
1438 {
1439 { Bad_Opcode },
1440 { Bad_Opcode },
1441 { "vpandn%LW", { XM, Vex, EXx } },
1442 },
1ba585e8
IT
1443 /* PREFIX_EVEX_0FE0 */
1444 {
1445 { Bad_Opcode },
1446 { Bad_Opcode },
1447 { "vpavgb", { XM, Vex, EXx } },
1448 },
1449 /* PREFIX_EVEX_0FE1 */
1450 {
1451 { Bad_Opcode },
1452 { Bad_Opcode },
1453 { "vpsraw", { XM, Vex, EXxmm } },
1454 },
43234a1e
L
1455 /* PREFIX_EVEX_0FE2 */
1456 {
1457 { Bad_Opcode },
1458 { Bad_Opcode },
1459 { "vpsra%LW", { XM, Vex, EXxmm } },
1460 },
1ba585e8
IT
1461 /* PREFIX_EVEX_0FE3 */
1462 {
1463 { Bad_Opcode },
1464 { Bad_Opcode },
1465 { "vpavgw", { XM, Vex, EXx } },
1466 },
1467 /* PREFIX_EVEX_0FE4 */
1468 {
1469 { Bad_Opcode },
1470 { Bad_Opcode },
1471 { "vpmulhuw", { XM, Vex, EXx } },
1472 },
1473 /* PREFIX_EVEX_0FE5 */
1474 {
1475 { Bad_Opcode },
1476 { Bad_Opcode },
1477 { "vpmulhw", { XM, Vex, EXx } },
1478 },
43234a1e
L
1479 /* PREFIX_EVEX_0FE6 */
1480 {
1481 { Bad_Opcode },
1482 { VEX_W_TABLE (EVEX_W_0FE6_P_1) },
1483 { VEX_W_TABLE (EVEX_W_0FE6_P_2) },
1484 { VEX_W_TABLE (EVEX_W_0FE6_P_3) },
1485 },
1486 /* PREFIX_EVEX_0FE7 */
1487 {
1488 { Bad_Opcode },
1489 { Bad_Opcode },
1490 { VEX_W_TABLE (EVEX_W_0FE7_P_2) },
1491 },
1ba585e8
IT
1492 /* PREFIX_EVEX_0FE8 */
1493 {
1494 { Bad_Opcode },
1495 { Bad_Opcode },
1496 { "vpsubsb", { XM, Vex, EXx } },
1497 },
1498 /* PREFIX_EVEX_0FE9 */
1499 {
1500 { Bad_Opcode },
1501 { Bad_Opcode },
1502 { "vpsubsw", { XM, Vex, EXx } },
1503 },
1504 /* PREFIX_EVEX_0FEA */
1505 {
1506 { Bad_Opcode },
1507 { Bad_Opcode },
1508 { "vpminsw", { XM, Vex, EXx } },
1509 },
43234a1e
L
1510 /* PREFIX_EVEX_0FEB */
1511 {
1512 { Bad_Opcode },
1513 { Bad_Opcode },
1514 { "vpor%LW", { XM, Vex, EXx } },
1515 },
1ba585e8
IT
1516 /* PREFIX_EVEX_0FEC */
1517 {
1518 { Bad_Opcode },
1519 { Bad_Opcode },
1520 { "vpaddsb", { XM, Vex, EXx } },
1521 },
1522 /* PREFIX_EVEX_0FED */
1523 {
1524 { Bad_Opcode },
1525 { Bad_Opcode },
1526 { "vpaddsw", { XM, Vex, EXx } },
1527 },
1528 /* PREFIX_EVEX_0FEE */
1529 {
1530 { Bad_Opcode },
1531 { Bad_Opcode },
1532 { "vpmaxsw", { XM, Vex, EXx } },
1533 },
43234a1e
L
1534 /* PREFIX_EVEX_0FEF */
1535 {
1536 { Bad_Opcode },
1537 { Bad_Opcode },
1538 { "vpxor%LW", { XM, Vex, EXx } },
1539 },
1ba585e8
IT
1540 /* PREFIX_EVEX_0FF1 */
1541 {
1542 { Bad_Opcode },
1543 { Bad_Opcode },
1544 { "vpsllw", { XM, Vex, EXxmm } },
1545 },
43234a1e
L
1546 /* PREFIX_EVEX_0FF2 */
1547 {
1548 { Bad_Opcode },
1549 { Bad_Opcode },
1550 { VEX_W_TABLE (EVEX_W_0FF2_P_2) },
1551 },
1552 /* PREFIX_EVEX_0FF3 */
1553 {
1554 { Bad_Opcode },
1555 { Bad_Opcode },
1556 { VEX_W_TABLE (EVEX_W_0FF3_P_2) },
1557 },
1558 /* PREFIX_EVEX_0FF4 */
1559 {
1560 { Bad_Opcode },
1561 { Bad_Opcode },
1562 { VEX_W_TABLE (EVEX_W_0FF4_P_2) },
1563 },
1ba585e8
IT
1564 /* PREFIX_EVEX_0FF5 */
1565 {
1566 { Bad_Opcode },
1567 { Bad_Opcode },
1568 { "vpmaddwd", { XM, Vex, EXx } },
1569 },
1570 /* PREFIX_EVEX_0FF6 */
1571 {
1572 { Bad_Opcode },
1573 { Bad_Opcode },
1574 { "vpsadbw", { XM, Vex, EXx } },
1575 },
1576 /* PREFIX_EVEX_0FF8 */
1577 {
1578 { Bad_Opcode },
1579 { Bad_Opcode },
1580 { "vpsubb", { XM, Vex, EXx } },
1581 },
1582 /* PREFIX_EVEX_0FF9 */
1583 {
1584 { Bad_Opcode },
1585 { Bad_Opcode },
1586 { "vpsubw", { XM, Vex, EXx } },
1587 },
43234a1e
L
1588 /* PREFIX_EVEX_0FFA */
1589 {
1590 { Bad_Opcode },
1591 { Bad_Opcode },
1592 { VEX_W_TABLE (EVEX_W_0FFA_P_2) },
1593 },
1594 /* PREFIX_EVEX_0FFB */
1595 {
1596 { Bad_Opcode },
1597 { Bad_Opcode },
1598 { VEX_W_TABLE (EVEX_W_0FFB_P_2) },
1599 },
1ba585e8
IT
1600 /* PREFIX_EVEX_0FFC */
1601 {
1602 { Bad_Opcode },
1603 { Bad_Opcode },
1604 { "vpaddb", { XM, Vex, EXx } },
1605 },
1606 /* PREFIX_EVEX_0FFD */
1607 {
1608 { Bad_Opcode },
1609 { Bad_Opcode },
1610 { "vpaddw", { XM, Vex, EXx } },
1611 },
43234a1e
L
1612 /* PREFIX_EVEX_0FFE */
1613 {
1614 { Bad_Opcode },
1615 { Bad_Opcode },
1616 { VEX_W_TABLE (EVEX_W_0FFE_P_2) },
1617 },
1ba585e8
IT
1618 /* PREFIX_EVEX_0F3800 */
1619 {
1620 { Bad_Opcode },
1621 { Bad_Opcode },
1622 { "vpshufb", { XM, Vex, EXx } },
1623 },
1624 /* PREFIX_EVEX_0F3804 */
1625 {
1626 { Bad_Opcode },
1627 { Bad_Opcode },
1628 { "vpmaddubsw", { XM, Vex, EXx } },
1629 },
1630 /* PREFIX_EVEX_0F380B */
1631 {
1632 { Bad_Opcode },
1633 { Bad_Opcode },
1634 { "vpmulhrsw", { XM, Vex, EXx } },
1635 },
43234a1e
L
1636 /* PREFIX_EVEX_0F380C */
1637 {
1638 { Bad_Opcode },
1639 { Bad_Opcode },
1640 { VEX_W_TABLE (EVEX_W_0F380C_P_2) },
1641 },
1642 /* PREFIX_EVEX_0F380D */
1643 {
1644 { Bad_Opcode },
1645 { Bad_Opcode },
1646 { VEX_W_TABLE (EVEX_W_0F380D_P_2) },
1647 },
1ba585e8
IT
1648 /* PREFIX_EVEX_0F3810 */
1649 {
1650 { Bad_Opcode },
1651 { VEX_W_TABLE (EVEX_W_0F3810_P_1) },
1652 { VEX_W_TABLE (EVEX_W_0F3810_P_2) },
1653 },
43234a1e
L
1654 /* PREFIX_EVEX_0F3811 */
1655 {
1656 { Bad_Opcode },
1657 { VEX_W_TABLE (EVEX_W_0F3811_P_1) },
1ba585e8 1658 { VEX_W_TABLE (EVEX_W_0F3811_P_2) },
43234a1e
L
1659 },
1660 /* PREFIX_EVEX_0F3812 */
1661 {
1662 { Bad_Opcode },
1663 { VEX_W_TABLE (EVEX_W_0F3812_P_1) },
1ba585e8 1664 { VEX_W_TABLE (EVEX_W_0F3812_P_2) },
43234a1e
L
1665 },
1666 /* PREFIX_EVEX_0F3813 */
1667 {
1668 { Bad_Opcode },
1669 { VEX_W_TABLE (EVEX_W_0F3813_P_1) },
1670 { VEX_W_TABLE (EVEX_W_0F3813_P_2) },
1671 },
1672 /* PREFIX_EVEX_0F3814 */
1673 {
1674 { Bad_Opcode },
1675 { VEX_W_TABLE (EVEX_W_0F3814_P_1) },
1676 { "vprorv%LW", { XM, Vex, EXx } },
1677 },
1678 /* PREFIX_EVEX_0F3815 */
1679 {
1680 { Bad_Opcode },
1681 { VEX_W_TABLE (EVEX_W_0F3815_P_1) },
1682 { "vprolv%LW", { XM, Vex, EXx } },
1683 },
1684 /* PREFIX_EVEX_0F3816 */
1685 {
1686 { Bad_Opcode },
1687 { Bad_Opcode },
1688 { "vpermp%XW", { XM, Vex, EXx } },
1689 },
1690 /* PREFIX_EVEX_0F3818 */
1691 {
1692 { Bad_Opcode },
1693 { Bad_Opcode },
1694 { VEX_W_TABLE (EVEX_W_0F3818_P_2) },
1695 },
1696 /* PREFIX_EVEX_0F3819 */
1697 {
1698 { Bad_Opcode },
1699 { Bad_Opcode },
1700 { VEX_W_TABLE (EVEX_W_0F3819_P_2) },
1701 },
1702 /* PREFIX_EVEX_0F381A */
1703 {
1704 { Bad_Opcode },
1705 { Bad_Opcode },
1706 { VEX_W_TABLE (EVEX_W_0F381A_P_2) },
1707 },
1708 /* PREFIX_EVEX_0F381B */
1709 {
1710 { Bad_Opcode },
1711 { Bad_Opcode },
1712 { VEX_W_TABLE (EVEX_W_0F381B_P_2) },
1713 },
1ba585e8
IT
1714 /* PREFIX_EVEX_0F381C */
1715 {
1716 { Bad_Opcode },
1717 { Bad_Opcode },
1718 { "vpabsb", { XM, EXx } },
1719 },
1720 /* PREFIX_EVEX_0F381D */
1721 {
1722 { Bad_Opcode },
1723 { Bad_Opcode },
1724 { "vpabsw", { XM, EXx } },
1725 },
43234a1e
L
1726 /* PREFIX_EVEX_0F381E */
1727 {
1728 { Bad_Opcode },
1729 { Bad_Opcode },
1730 { VEX_W_TABLE (EVEX_W_0F381E_P_2) },
1731 },
1732 /* PREFIX_EVEX_0F381F */
1733 {
1734 { Bad_Opcode },
1735 { Bad_Opcode },
1736 { VEX_W_TABLE (EVEX_W_0F381F_P_2) },
1737 },
1ba585e8
IT
1738 /* PREFIX_EVEX_0F3820 */
1739 {
1740 { Bad_Opcode },
1741 { VEX_W_TABLE (EVEX_W_0F3820_P_1) },
1742 { "vpmovsxbw", { XM, EXxmmq } },
1743 },
43234a1e
L
1744 /* PREFIX_EVEX_0F3821 */
1745 {
1746 { Bad_Opcode },
1747 { VEX_W_TABLE (EVEX_W_0F3821_P_1) },
1748 { "vpmovsxbd", { XM, EXxmmqd } },
1749 },
1750 /* PREFIX_EVEX_0F3822 */
1751 {
1752 { Bad_Opcode },
1753 { VEX_W_TABLE (EVEX_W_0F3822_P_1) },
1754 { "vpmovsxbq", { XM, EXxmmdw } },
1755 },
1756 /* PREFIX_EVEX_0F3823 */
1757 {
1758 { Bad_Opcode },
1759 { VEX_W_TABLE (EVEX_W_0F3823_P_1) },
1760 { "vpmovsxwd", { XM, EXxmmq } },
1761 },
1762 /* PREFIX_EVEX_0F3824 */
1763 {
1764 { Bad_Opcode },
1765 { VEX_W_TABLE (EVEX_W_0F3824_P_1) },
1766 { "vpmovsxwq", { XM, EXxmmqd } },
1767 },
1768 /* PREFIX_EVEX_0F3825 */
1769 {
1770 { Bad_Opcode },
1771 { VEX_W_TABLE (EVEX_W_0F3825_P_1) },
1772 { VEX_W_TABLE (EVEX_W_0F3825_P_2) },
1773 },
1ba585e8
IT
1774 /* PREFIX_EVEX_0F3826 */
1775 {
1776 { Bad_Opcode },
1777 { VEX_W_TABLE (EVEX_W_0F3826_P_1) },
1778 { VEX_W_TABLE (EVEX_W_0F3826_P_2) },
1779 },
43234a1e
L
1780 /* PREFIX_EVEX_0F3827 */
1781 {
1782 { Bad_Opcode },
1783 { "vptestnm%LW", { XMask, Vex, EXx } },
1784 { "vptestm%LW", { XMask, Vex, EXx } },
1785 },
1786 /* PREFIX_EVEX_0F3828 */
1787 {
1788 { Bad_Opcode },
1ba585e8 1789 { VEX_W_TABLE (EVEX_W_0F3828_P_1) },
43234a1e
L
1790 { VEX_W_TABLE (EVEX_W_0F3828_P_2) },
1791 },
1792 /* PREFIX_EVEX_0F3829 */
1793 {
1794 { Bad_Opcode },
1ba585e8 1795 { VEX_W_TABLE (EVEX_W_0F3829_P_1) },
43234a1e
L
1796 { VEX_W_TABLE (EVEX_W_0F3829_P_2) },
1797 },
1798 /* PREFIX_EVEX_0F382A */
1799 {
1800 { Bad_Opcode },
1801 { VEX_W_TABLE (EVEX_W_0F382A_P_1) },
1802 { VEX_W_TABLE (EVEX_W_0F382A_P_2) },
1803 },
1ba585e8
IT
1804 /* PREFIX_EVEX_0F382B */
1805 {
1806 { Bad_Opcode },
1807 { Bad_Opcode },
1808 { VEX_W_TABLE (EVEX_W_0F382B_P_2) },
1809 },
43234a1e
L
1810 /* PREFIX_EVEX_0F382C */
1811 {
1812 { Bad_Opcode },
1813 { Bad_Opcode },
1814 { "vscalefp%XW", { XM, Vex, EXx, EXxEVexR } },
1815 },
1816 /* PREFIX_EVEX_0F382D */
1817 {
1818 { Bad_Opcode },
1819 { Bad_Opcode },
1820 { "vscalefs%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
1821 },
1ba585e8
IT
1822 /* PREFIX_EVEX_0F3830 */
1823 {
1824 { Bad_Opcode },
1825 { VEX_W_TABLE (EVEX_W_0F3830_P_1) },
1826 { "vpmovzxbw", { XM, EXxmmq } },
1827 },
43234a1e
L
1828 /* PREFIX_EVEX_0F3831 */
1829 {
1830 { Bad_Opcode },
1831 { VEX_W_TABLE (EVEX_W_0F3831_P_1) },
1832 { "vpmovzxbd", { XM, EXxmmqd } },
1833 },
1834 /* PREFIX_EVEX_0F3832 */
1835 {
1836 { Bad_Opcode },
1837 { VEX_W_TABLE (EVEX_W_0F3832_P_1) },
1838 { "vpmovzxbq", { XM, EXxmmdw } },
1839 },
1840 /* PREFIX_EVEX_0F3833 */
1841 {
1842 { Bad_Opcode },
1843 { VEX_W_TABLE (EVEX_W_0F3833_P_1) },
1844 { "vpmovzxwd", { XM, EXxmmq } },
1845 },
1846 /* PREFIX_EVEX_0F3834 */
1847 {
1848 { Bad_Opcode },
1849 { VEX_W_TABLE (EVEX_W_0F3834_P_1) },
1850 { "vpmovzxwq", { XM, EXxmmqd } },
1851 },
1852 /* PREFIX_EVEX_0F3835 */
1853 {
1854 { Bad_Opcode },
1855 { VEX_W_TABLE (EVEX_W_0F3835_P_1) },
1856 { VEX_W_TABLE (EVEX_W_0F3835_P_2) },
1857 },
1858 /* PREFIX_EVEX_0F3836 */
1859 {
1860 { Bad_Opcode },
1861 { Bad_Opcode },
1862 { "vperm%LW", { XM, Vex, EXx } },
1863 },
1864 /* PREFIX_EVEX_0F3837 */
1865 {
1866 { Bad_Opcode },
1867 { Bad_Opcode },
1868 { VEX_W_TABLE (EVEX_W_0F3837_P_2) },
1869 },
1ba585e8
IT
1870 /* PREFIX_EVEX_0F3838 */
1871 {
1872 { Bad_Opcode },
1873 { Bad_Opcode },
1874 { "vpminsb", { XM, Vex, EXx } },
1875 },
43234a1e
L
1876 /* PREFIX_EVEX_0F3839 */
1877 {
1878 { Bad_Opcode },
1879 { Bad_Opcode },
1880 { "vpmins%LW", { XM, Vex, EXx } },
1881 },
1882 /* PREFIX_EVEX_0F383A */
1883 {
1884 { Bad_Opcode },
1885 { VEX_W_TABLE (EVEX_W_0F383A_P_1) },
1ba585e8 1886 { "vpminuw", { XM, Vex, EXx } },
43234a1e
L
1887 },
1888 /* PREFIX_EVEX_0F383B */
1889 {
1890 { Bad_Opcode },
1891 { Bad_Opcode },
1892 { "vpminu%LW", { XM, Vex, EXx } },
1893 },
1ba585e8
IT
1894 /* PREFIX_EVEX_0F383C */
1895 {
1896 { Bad_Opcode },
1897 { Bad_Opcode },
1898 { "vpmaxsb", { XM, Vex, EXx } },
1899 },
43234a1e
L
1900 /* PREFIX_EVEX_0F383D */
1901 {
1902 { Bad_Opcode },
1903 { Bad_Opcode },
1904 { "vpmaxs%LW", { XM, Vex, EXx } },
1905 },
1ba585e8
IT
1906 /* PREFIX_EVEX_0F383E */
1907 {
1908 { Bad_Opcode },
1909 { Bad_Opcode },
1910 { "vpmaxuw", { XM, Vex, EXx } },
1911 },
43234a1e
L
1912 /* PREFIX_EVEX_0F383F */
1913 {
1914 { Bad_Opcode },
1915 { Bad_Opcode },
1916 { "vpmaxu%LW", { XM, Vex, EXx } },
1917 },
1918 /* PREFIX_EVEX_0F3840 */
1919 {
1920 { Bad_Opcode },
1921 { Bad_Opcode },
1922 { VEX_W_TABLE (EVEX_W_0F3840_P_2) },
1923 },
1924 /* PREFIX_EVEX_0F3842 */
1925 {
1926 { Bad_Opcode },
1927 { Bad_Opcode },
1928 { "vgetexpp%XW", { XM, EXx, EXxEVexS } },
1929 },
1930 /* PREFIX_EVEX_0F3843 */
1931 {
1932 { Bad_Opcode },
1933 { Bad_Opcode },
1934 { "vgetexps%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS } },
1935 },
1936 /* PREFIX_EVEX_0F3844 */
1937 {
1938 { Bad_Opcode },
1939 { Bad_Opcode },
1940 { "vplzcnt%LW", { XM, EXx } },
1941 },
1942 /* PREFIX_EVEX_0F3845 */
1943 {
1944 { Bad_Opcode },
1945 { Bad_Opcode },
1946 { "vpsrlv%LW", { XM, Vex, EXx } },
1947 },
1948 /* PREFIX_EVEX_0F3846 */
1949 {
1950 { Bad_Opcode },
1951 { Bad_Opcode },
1952 { "vpsrav%LW", { XM, Vex, EXx } },
1953 },
1954 /* PREFIX_EVEX_0F3847 */
1955 {
1956 { Bad_Opcode },
1957 { Bad_Opcode },
1958 { "vpsllv%LW", { XM, Vex, EXx } },
1959 },
1960 /* PREFIX_EVEX_0F384C */
1961 {
1962 { Bad_Opcode },
1963 { Bad_Opcode },
1964 { "vrcp14p%XW", { XM, EXx } },
1965 },
1966 /* PREFIX_EVEX_0F384D */
1967 {
1968 { Bad_Opcode },
1969 { Bad_Opcode },
1970 { "vrcp14s%XW", { XMScalar, VexScalar, EXxmm_mdq } },
1971 },
1972 /* PREFIX_EVEX_0F384E */
1973 {
1974 { Bad_Opcode },
1975 { Bad_Opcode },
1976 { "vrsqrt14p%XW", { XM, EXx } },
1977 },
1978 /* PREFIX_EVEX_0F384F */
1979 {
1980 { Bad_Opcode },
1981 { Bad_Opcode },
1982 { "vrsqrt14s%XW", { XMScalar, VexScalar, EXxmm_mdq } },
1983 },
1984 /* PREFIX_EVEX_0F3858 */
1985 {
1986 { Bad_Opcode },
1987 { Bad_Opcode },
1988 { VEX_W_TABLE (EVEX_W_0F3858_P_2) },
1989 },
1990 /* PREFIX_EVEX_0F3859 */
1991 {
1992 { Bad_Opcode },
1993 { Bad_Opcode },
1994 { VEX_W_TABLE (EVEX_W_0F3859_P_2) },
1995 },
1996 /* PREFIX_EVEX_0F385A */
1997 {
1998 { Bad_Opcode },
1999 { Bad_Opcode },
2000 { VEX_W_TABLE (EVEX_W_0F385A_P_2) },
2001 },
2002 /* PREFIX_EVEX_0F385B */
2003 {
2004 { Bad_Opcode },
2005 { Bad_Opcode },
2006 { VEX_W_TABLE (EVEX_W_0F385B_P_2) },
2007 },
2008 /* PREFIX_EVEX_0F3864 */
2009 {
2010 { Bad_Opcode },
2011 { Bad_Opcode },
2012 { "vpblendm%LW", { XM, Vex, EXx } },
2013 },
2014 /* PREFIX_EVEX_0F3865 */
2015 {
2016 { Bad_Opcode },
2017 { Bad_Opcode },
2018 { "vblendmp%XW", { XM, Vex, EXx } },
2019 },
1ba585e8
IT
2020 /* PREFIX_EVEX_0F3866 */
2021 {
2022 { Bad_Opcode },
2023 { Bad_Opcode },
2024 { VEX_W_TABLE (EVEX_W_0F3866_P_2) },
2025 },
2026 /* PREFIX_EVEX_0F3875 */
2027 {
2028 { Bad_Opcode },
2029 { Bad_Opcode },
2030 { VEX_W_TABLE (EVEX_W_0F3875_P_2) },
2031 },
43234a1e
L
2032 /* PREFIX_EVEX_0F3876 */
2033 {
2034 { Bad_Opcode },
2035 { Bad_Opcode },
2036 { "vpermi2%LW", { XM, Vex, EXx } },
2037 },
2038 /* PREFIX_EVEX_0F3877 */
2039 {
2040 { Bad_Opcode },
2041 { Bad_Opcode },
2042 { "vpermi2p%XW", { XM, Vex, EXx } },
2043 },
1ba585e8
IT
2044 /* PREFIX_EVEX_0F3878 */
2045 {
2046 { Bad_Opcode },
2047 { Bad_Opcode },
2048 { VEX_W_TABLE (EVEX_W_0F3878_P_2) },
2049 },
2050 /* PREFIX_EVEX_0F3879 */
2051 {
2052 { Bad_Opcode },
2053 { Bad_Opcode },
2054 { VEX_W_TABLE (EVEX_W_0F3879_P_2) },
2055 },
2056 /* PREFIX_EVEX_0F387A */
2057 {
2058 { Bad_Opcode },
2059 { Bad_Opcode },
2060 { VEX_W_TABLE (EVEX_W_0F387A_P_2) },
2061 },
2062 /* PREFIX_EVEX_0F387B */
2063 {
2064 { Bad_Opcode },
2065 { Bad_Opcode },
2066 { VEX_W_TABLE (EVEX_W_0F387B_P_2) },
2067 },
43234a1e
L
2068 /* PREFIX_EVEX_0F387C */
2069 {
2070 { Bad_Opcode },
2071 { Bad_Opcode },
2072 { "vpbroadcast%LW", { XM, Rdq } },
2073 },
1ba585e8
IT
2074 /* PREFIX_EVEX_0F387D */
2075 {
2076 { Bad_Opcode },
2077 { Bad_Opcode },
2078 { VEX_W_TABLE (EVEX_W_0F387D_P_2) },
2079 },
43234a1e
L
2080 /* PREFIX_EVEX_0F387E */
2081 {
2082 { Bad_Opcode },
2083 { Bad_Opcode },
2084 { "vpermt2%LW", { XM, Vex, EXx } },
2085 },
2086 /* PREFIX_EVEX_0F387F */
2087 {
2088 { Bad_Opcode },
2089 { Bad_Opcode },
2090 { "vpermt2p%XW", { XM, Vex, EXx } },
2091 },
2092 /* PREFIX_EVEX_0F3888 */
2093 {
2094 { Bad_Opcode },
2095 { Bad_Opcode },
2096 { "vexpandp%XW", { XM, EXEvexXGscat } },
2097 },
2098 /* PREFIX_EVEX_0F3889 */
2099 {
2100 { Bad_Opcode },
2101 { Bad_Opcode },
2102 { "vpexpand%LW", { XM, EXEvexXGscat } },
2103 },
2104 /* PREFIX_EVEX_0F388A */
2105 {
2106 { Bad_Opcode },
2107 { Bad_Opcode },
2108 { "vcompressp%XW", { EXEvexXGscat, XM } },
2109 },
2110 /* PREFIX_EVEX_0F388B */
2111 {
2112 { Bad_Opcode },
2113 { Bad_Opcode },
2114 { "vpcompress%LW", { EXEvexXGscat, XM } },
2115 },
1ba585e8
IT
2116 /* PREFIX_EVEX_0F388D */
2117 {
2118 { Bad_Opcode },
2119 { Bad_Opcode },
2120 { VEX_W_TABLE (EVEX_W_0F388D_P_2) },
2121 },
43234a1e
L
2122 /* PREFIX_EVEX_0F3890 */
2123 {
2124 { Bad_Opcode },
2125 { Bad_Opcode },
2126 { "vpgatherd%LW", { XM, MVexVSIBDWpX } },
2127 },
2128 /* PREFIX_EVEX_0F3891 */
2129 {
2130 { Bad_Opcode },
2131 { Bad_Opcode },
2132 { VEX_W_TABLE (EVEX_W_0F3891_P_2) },
2133 },
2134 /* PREFIX_EVEX_0F3892 */
2135 {
2136 { Bad_Opcode },
2137 { Bad_Opcode },
2138 { "vgatherdp%XW", { XM, MVexVSIBDWpX} },
2139 },
2140 /* PREFIX_EVEX_0F3893 */
2141 {
2142 { Bad_Opcode },
2143 { Bad_Opcode },
2144 { VEX_W_TABLE (EVEX_W_0F3893_P_2) },
2145 },
2146 /* PREFIX_EVEX_0F3896 */
2147 {
2148 { Bad_Opcode },
2149 { Bad_Opcode },
2150 { "vfmaddsub132p%XW", { XM, Vex, EXx, EXxEVexR } },
2151 },
2152 /* PREFIX_EVEX_0F3897 */
2153 {
2154 { Bad_Opcode },
2155 { Bad_Opcode },
2156 { "vfmsubadd132p%XW", { XM, Vex, EXx, EXxEVexR } },
2157 },
2158 /* PREFIX_EVEX_0F3898 */
2159 {
2160 { Bad_Opcode },
2161 { Bad_Opcode },
2162 { "vfmadd132p%XW", { XM, Vex, EXx, EXxEVexR } },
2163 },
2164 /* PREFIX_EVEX_0F3899 */
2165 {
2166 { Bad_Opcode },
2167 { Bad_Opcode },
2168 { "vfmadd132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2169 },
2170 /* PREFIX_EVEX_0F389A */
2171 {
2172 { Bad_Opcode },
2173 { Bad_Opcode },
2174 { "vfmsub132p%XW", { XM, Vex, EXx, EXxEVexR } },
2175 },
2176 /* PREFIX_EVEX_0F389B */
2177 {
2178 { Bad_Opcode },
2179 { Bad_Opcode },
2180 { "vfmsub132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2181 },
2182 /* PREFIX_EVEX_0F389C */
2183 {
2184 { Bad_Opcode },
2185 { Bad_Opcode },
2186 { "vfnmadd132p%XW", { XM, Vex, EXx, EXxEVexR } },
2187 },
2188 /* PREFIX_EVEX_0F389D */
2189 {
2190 { Bad_Opcode },
2191 { Bad_Opcode },
2192 { "vfnmadd132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2193 },
2194 /* PREFIX_EVEX_0F389E */
2195 {
2196 { Bad_Opcode },
2197 { Bad_Opcode },
2198 { "vfnmsub132p%XW", { XM, Vex, EXx, EXxEVexR } },
2199 },
2200 /* PREFIX_EVEX_0F389F */
2201 {
2202 { Bad_Opcode },
2203 { Bad_Opcode },
2204 { "vfnmsub132s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2205 },
2206 /* PREFIX_EVEX_0F38A0 */
2207 {
2208 { Bad_Opcode },
2209 { Bad_Opcode },
2210 { "vpscatterd%LW", { MVexVSIBDWpX, XM } },
2211 },
2212 /* PREFIX_EVEX_0F38A1 */
2213 {
2214 { Bad_Opcode },
2215 { Bad_Opcode },
2216 { VEX_W_TABLE (EVEX_W_0F38A1_P_2) },
2217 },
2218 /* PREFIX_EVEX_0F38A2 */
2219 {
2220 { Bad_Opcode },
2221 { Bad_Opcode },
2222 { "vscatterdp%XW", { MVexVSIBDWpX, XM } },
2223 },
2224 /* PREFIX_EVEX_0F38A3 */
2225 {
2226 { Bad_Opcode },
2227 { Bad_Opcode },
2228 { VEX_W_TABLE (EVEX_W_0F38A3_P_2) },
2229 },
2230 /* PREFIX_EVEX_0F38A6 */
2231 {
2232 { Bad_Opcode },
2233 { Bad_Opcode },
2234 { "vfmaddsub213p%XW", { XM, Vex, EXx, EXxEVexR } },
2235 },
2236 /* PREFIX_EVEX_0F38A7 */
2237 {
2238 { Bad_Opcode },
2239 { Bad_Opcode },
2240 { "vfmsubadd213p%XW", { XM, Vex, EXx, EXxEVexR } },
2241 },
2242 /* PREFIX_EVEX_0F38A8 */
2243 {
2244 { Bad_Opcode },
2245 { Bad_Opcode },
2246 { "vfmadd213p%XW", { XM, Vex, EXx, EXxEVexR } },
2247 },
2248 /* PREFIX_EVEX_0F38A9 */
2249 {
2250 { Bad_Opcode },
2251 { Bad_Opcode },
2252 { "vfmadd213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2253 },
2254 /* PREFIX_EVEX_0F38AA */
2255 {
2256 { Bad_Opcode },
2257 { Bad_Opcode },
2258 { "vfmsub213p%XW", { XM, Vex, EXx, EXxEVexR } },
2259 },
2260 /* PREFIX_EVEX_0F38AB */
2261 {
2262 { Bad_Opcode },
2263 { Bad_Opcode },
2264 { "vfmsub213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2265 },
2266 /* PREFIX_EVEX_0F38AC */
2267 {
2268 { Bad_Opcode },
2269 { Bad_Opcode },
2270 { "vfnmadd213p%XW", { XM, Vex, EXx, EXxEVexR } },
2271 },
2272 /* PREFIX_EVEX_0F38AD */
2273 {
2274 { Bad_Opcode },
2275 { Bad_Opcode },
2276 { "vfnmadd213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2277 },
2278 /* PREFIX_EVEX_0F38AE */
2279 {
2280 { Bad_Opcode },
2281 { Bad_Opcode },
2282 { "vfnmsub213p%XW", { XM, Vex, EXx, EXxEVexR } },
2283 },
2284 /* PREFIX_EVEX_0F38AF */
2285 {
2286 { Bad_Opcode },
2287 { Bad_Opcode },
2288 { "vfnmsub213s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2289 },
2290 /* PREFIX_EVEX_0F38B6 */
2291 {
2292 { Bad_Opcode },
2293 { Bad_Opcode },
2294 { "vfmaddsub231p%XW", { XM, Vex, EXx, EXxEVexR } },
2295 },
2296 /* PREFIX_EVEX_0F38B7 */
2297 {
2298 { Bad_Opcode },
2299 { Bad_Opcode },
2300 { "vfmsubadd231p%XW", { XM, Vex, EXx, EXxEVexR } },
2301 },
2302 /* PREFIX_EVEX_0F38B8 */
2303 {
2304 { Bad_Opcode },
2305 { Bad_Opcode },
2306 { "vfmadd231p%XW", { XM, Vex, EXx, EXxEVexR } },
2307 },
2308 /* PREFIX_EVEX_0F38B9 */
2309 {
2310 { Bad_Opcode },
2311 { Bad_Opcode },
2312 { "vfmadd231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2313 },
2314 /* PREFIX_EVEX_0F38BA */
2315 {
2316 { Bad_Opcode },
2317 { Bad_Opcode },
2318 { "vfmsub231p%XW", { XM, Vex, EXx, EXxEVexR } },
2319 },
2320 /* PREFIX_EVEX_0F38BB */
2321 {
2322 { Bad_Opcode },
2323 { Bad_Opcode },
2324 { "vfmsub231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2325 },
2326 /* PREFIX_EVEX_0F38BC */
2327 {
2328 { Bad_Opcode },
2329 { Bad_Opcode },
2330 { "vfnmadd231p%XW", { XM, Vex, EXx, EXxEVexR } },
2331 },
2332 /* PREFIX_EVEX_0F38BD */
2333 {
2334 { Bad_Opcode },
2335 { Bad_Opcode },
2336 { "vfnmadd231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2337 },
2338 /* PREFIX_EVEX_0F38BE */
2339 {
2340 { Bad_Opcode },
2341 { Bad_Opcode },
2342 { "vfnmsub231p%XW", { XM, Vex, EXx, EXxEVexR } },
2343 },
2344 /* PREFIX_EVEX_0F38BF */
2345 {
2346 { Bad_Opcode },
2347 { Bad_Opcode },
2348 { "vfnmsub231s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexR } },
2349 },
2350 /* PREFIX_EVEX_0F38C4 */
2351 {
2352 { Bad_Opcode },
2353 { Bad_Opcode },
2354 { "vpconflict%LW", { XM, EXx } },
2355 },
2356 /* PREFIX_EVEX_0F38C6_REG_1 */
2357 {
2358 { Bad_Opcode },
2359 { Bad_Opcode },
2360 { "vgatherpf0dp%XW", { MVexVSIBDWpX } },
2361 },
2362 /* PREFIX_EVEX_0F38C6_REG_2 */
2363 {
2364 { Bad_Opcode },
2365 { Bad_Opcode },
2366 { "vgatherpf1dp%XW", { MVexVSIBDWpX } },
2367 },
2368 /* PREFIX_EVEX_0F38C6_REG_5 */
2369 {
2370 { Bad_Opcode },
2371 { Bad_Opcode },
2372 { "vscatterpf0dp%XW", { MVexVSIBDWpX } },
2373 },
2374 /* PREFIX_EVEX_0F38C6_REG_6 */
2375 {
2376 { Bad_Opcode },
2377 { Bad_Opcode },
2378 { "vscatterpf1dp%XW", { MVexVSIBDWpX } },
2379 },
2380 /* PREFIX_EVEX_0F38C7_REG_1 */
2381 {
2382 { Bad_Opcode },
2383 { Bad_Opcode },
2384 { VEX_W_TABLE (EVEX_W_0F38C7_R_1_P_2) },
2385 },
2386 /* PREFIX_EVEX_0F38C7_REG_2 */
2387 {
2388 { Bad_Opcode },
2389 { Bad_Opcode },
2390 { VEX_W_TABLE (EVEX_W_0F38C7_R_2_P_2) },
2391 },
2392 /* PREFIX_EVEX_0F38C7_REG_5 */
2393 {
2394 { Bad_Opcode },
2395 { Bad_Opcode },
2396 { VEX_W_TABLE (EVEX_W_0F38C7_R_5_P_2) },
2397 },
2398 /* PREFIX_EVEX_0F38C7_REG_6 */
2399 {
2400 { Bad_Opcode },
2401 { Bad_Opcode },
2402 { VEX_W_TABLE (EVEX_W_0F38C7_R_6_P_2) },
2403 },
2404 /* PREFIX_EVEX_0F38C8 */
2405 {
2406 { Bad_Opcode },
2407 { Bad_Opcode },
2408 { "vexp2p%XW", { XM, EXx, EXxEVexS } },
2409 },
2410 /* PREFIX_EVEX_0F38CA */
2411 {
2412 { Bad_Opcode },
2413 { Bad_Opcode },
2414 { "vrcp28p%XW", { XM, EXx, EXxEVexS } },
2415 },
2416 /* PREFIX_EVEX_0F38CB */
2417 {
2418 { Bad_Opcode },
2419 { Bad_Opcode },
2420 { "vrcp28s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS } },
2421 },
2422 /* PREFIX_EVEX_0F38CC */
2423 {
2424 { Bad_Opcode },
2425 { Bad_Opcode },
2426 { "vrsqrt28p%XW", { XM, EXx, EXxEVexS } },
2427 },
2428 /* PREFIX_EVEX_0F38CD */
2429 {
2430 { Bad_Opcode },
2431 { Bad_Opcode },
2432 { "vrsqrt28s%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS } },
2433 },
2434 /* PREFIX_EVEX_0F3A00 */
2435 {
2436 { Bad_Opcode },
2437 { Bad_Opcode },
2438 { VEX_W_TABLE (EVEX_W_0F3A00_P_2) },
2439 },
2440 /* PREFIX_EVEX_0F3A01 */
2441 {
2442 { Bad_Opcode },
2443 { Bad_Opcode },
2444 { VEX_W_TABLE (EVEX_W_0F3A01_P_2) },
2445 },
2446 /* PREFIX_EVEX_0F3A03 */
2447 {
2448 { Bad_Opcode },
2449 { Bad_Opcode },
2450 { "valign%LW", { XM, Vex, EXx, Ib } },
2451 },
2452 /* PREFIX_EVEX_0F3A04 */
2453 {
2454 { Bad_Opcode },
2455 { Bad_Opcode },
2456 { VEX_W_TABLE (EVEX_W_0F3A04_P_2) },
2457 },
2458 /* PREFIX_EVEX_0F3A05 */
2459 {
2460 { Bad_Opcode },
2461 { Bad_Opcode },
2462 { VEX_W_TABLE (EVEX_W_0F3A05_P_2) },
2463 },
2464 /* PREFIX_EVEX_0F3A08 */
2465 {
2466 { Bad_Opcode },
2467 { Bad_Opcode },
2468 { VEX_W_TABLE (EVEX_W_0F3A08_P_2) },
2469 },
2470 /* PREFIX_EVEX_0F3A09 */
2471 {
2472 { Bad_Opcode },
2473 { Bad_Opcode },
2474 { VEX_W_TABLE (EVEX_W_0F3A09_P_2) },
2475 },
2476 /* PREFIX_EVEX_0F3A0A */
2477 {
2478 { Bad_Opcode },
2479 { Bad_Opcode },
2480 { VEX_W_TABLE (EVEX_W_0F3A0A_P_2) },
2481 },
2482 /* PREFIX_EVEX_0F3A0B */
2483 {
2484 { Bad_Opcode },
2485 { Bad_Opcode },
2486 { VEX_W_TABLE (EVEX_W_0F3A0B_P_2) },
2487 },
1ba585e8
IT
2488 /* PREFIX_EVEX_0F3A0F */
2489 {
2490 { Bad_Opcode },
2491 { Bad_Opcode },
2492 { "vpalignr", { XM, Vex, EXx, Ib } },
2493 },
2494 /* PREFIX_EVEX_0F3A14 */
2495 {
2496 { Bad_Opcode },
2497 { Bad_Opcode },
2498 { "vpextrb", { Edqb, XM, Ib } },
2499 },
2500 /* PREFIX_EVEX_0F3A15 */
2501 {
2502 { Bad_Opcode },
2503 { Bad_Opcode },
2504 { "vpextrw", { EdqwS, XM, Ib } },
2505 },
43234a1e
L
2506 /* PREFIX_EVEX_0F3A17 */
2507 {
2508 { Bad_Opcode },
2509 { Bad_Opcode },
2510 { "vextractps", { Edqd, XMM, Ib } },
2511 },
2512 /* PREFIX_EVEX_0F3A18 */
2513 {
2514 { Bad_Opcode },
2515 { Bad_Opcode },
2516 { VEX_W_TABLE (EVEX_W_0F3A18_P_2) },
2517 },
2518 /* PREFIX_EVEX_0F3A19 */
2519 {
2520 { Bad_Opcode },
2521 { Bad_Opcode },
2522 { VEX_W_TABLE (EVEX_W_0F3A19_P_2) },
2523 },
2524 /* PREFIX_EVEX_0F3A1A */
2525 {
2526 { Bad_Opcode },
2527 { Bad_Opcode },
2528 { VEX_W_TABLE (EVEX_W_0F3A1A_P_2) },
2529 },
2530 /* PREFIX_EVEX_0F3A1B */
2531 {
2532 { Bad_Opcode },
2533 { Bad_Opcode },
2534 { VEX_W_TABLE (EVEX_W_0F3A1B_P_2) },
2535 },
2536 /* PREFIX_EVEX_0F3A1D */
2537 {
2538 { Bad_Opcode },
2539 { Bad_Opcode },
2540 { VEX_W_TABLE (EVEX_W_0F3A1D_P_2) },
2541 },
2542 /* PREFIX_EVEX_0F3A1E */
2543 {
2544 { Bad_Opcode },
2545 { Bad_Opcode },
2546 { "vpcmpu%LW", { XMask, Vex, EXx, VPCMP } },
2547 },
2548 /* PREFIX_EVEX_0F3A1F */
2549 {
2550 { Bad_Opcode },
2551 { Bad_Opcode },
2552 { "vpcmp%LW", { XMask, Vex, EXx, VPCMP } },
2553 },
1ba585e8
IT
2554 /* PREFIX_EVEX_0F3A20 */
2555 {
2556 { Bad_Opcode },
2557 { Bad_Opcode },
2558 { "vpinsrb", { XM, Vex128, Edb, Ib } },
2559 },
43234a1e
L
2560 /* PREFIX_EVEX_0F3A21 */
2561 {
2562 { Bad_Opcode },
2563 { Bad_Opcode },
2564 { VEX_W_TABLE (EVEX_W_0F3A21_P_2) },
2565 },
2566 /* PREFIX_EVEX_0F3A23 */
2567 {
2568 { Bad_Opcode },
2569 { Bad_Opcode },
2570 { VEX_W_TABLE (EVEX_W_0F3A23_P_2) },
2571 },
2572 /* PREFIX_EVEX_0F3A25 */
2573 {
2574 { Bad_Opcode },
2575 { Bad_Opcode },
2576 { "vpternlog%LW", { XM, Vex, EXx, Ib } },
2577 },
2578 /* PREFIX_EVEX_0F3A26 */
2579 {
2580 { Bad_Opcode },
2581 { Bad_Opcode },
2582 { "vgetmantp%XW", { XM, EXx, EXxEVexS, Ib } },
2583 },
2584 /* PREFIX_EVEX_0F3A27 */
2585 {
2586 { Bad_Opcode },
2587 { Bad_Opcode },
2588 { "vgetmants%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS, Ib } },
2589 },
2590 /* PREFIX_EVEX_0F3A38 */
2591 {
2592 { Bad_Opcode },
2593 { Bad_Opcode },
2594 { VEX_W_TABLE (EVEX_W_0F3A38_P_2) },
2595 },
2596 /* PREFIX_EVEX_0F3A39 */
2597 {
2598 { Bad_Opcode },
2599 { Bad_Opcode },
2600 { VEX_W_TABLE (EVEX_W_0F3A39_P_2) },
2601 },
2602 /* PREFIX_EVEX_0F3A3A */
2603 {
2604 { Bad_Opcode },
2605 { Bad_Opcode },
2606 { VEX_W_TABLE (EVEX_W_0F3A3A_P_2) },
2607 },
2608 /* PREFIX_EVEX_0F3A3B */
2609 {
2610 { Bad_Opcode },
2611 { Bad_Opcode },
2612 { VEX_W_TABLE (EVEX_W_0F3A3B_P_2) },
2613 },
1ba585e8
IT
2614 /* PREFIX_EVEX_0F3A3E */
2615 {
2616 { Bad_Opcode },
2617 { Bad_Opcode },
2618 { VEX_W_TABLE (EVEX_W_0F3A3E_P_2) },
2619 },
2620 /* PREFIX_EVEX_0F3A3F */
2621 {
2622 { Bad_Opcode },
2623 { Bad_Opcode },
2624 { VEX_W_TABLE (EVEX_W_0F3A3F_P_2) },
2625 },
2626 /* PREFIX_EVEX_0F3A42 */
2627 {
2628 { Bad_Opcode },
2629 { Bad_Opcode },
2630 { VEX_W_TABLE (EVEX_W_0F3A42_P_2) },
2631 },
43234a1e
L
2632 /* PREFIX_EVEX_0F3A43 */
2633 {
2634 { Bad_Opcode },
2635 { Bad_Opcode },
2636 { VEX_W_TABLE (EVEX_W_0F3A43_P_2) },
2637 },
2638 /* PREFIX_EVEX_0F3A54 */
2639 {
2640 { Bad_Opcode },
2641 { Bad_Opcode },
2642 { "vfixupimmp%XW", { XM, Vex, EXx, EXxEVexS, Ib } },
2643 },
2644 /* PREFIX_EVEX_0F3A55 */
2645 {
2646 { Bad_Opcode },
2647 { Bad_Opcode },
2648 { "vfixupimms%XW", { XMScalar, VexScalar, EXxmm_mdq, EXxEVexS, Ib } },
2649 },
2650#endif /* NEED_PREFIX_TABLE */
2651
2652#ifdef NEED_VEX_W_TABLE
2653 /* EVEX_W_0F10_P_0 */
2654 {
2655 { "vmovups", { XM, EXEvexXNoBcst } },
2656 },
2657 /* EVEX_W_0F10_P_1_M_0 */
2658 {
2659 { "vmovss", { XMScalar, EXdScalar } },
2660 },
2661 /* EVEX_W_0F10_P_1_M_1 */
2662 {
792f7758 2663 { "vmovss", { XMScalar, VexScalar, EXxmm_md } },
43234a1e
L
2664 },
2665 /* EVEX_W_0F10_P_2 */
2666 {
2667 { Bad_Opcode },
2668 { "vmovupd", { XM, EXEvexXNoBcst } },
2669 },
2670 /* EVEX_W_0F10_P_3_M_0 */
2671 {
2672 { Bad_Opcode },
2673 { "vmovsd", { XMScalar, EXqScalar } },
2674 },
2675 /* EVEX_W_0F10_P_3_M_1 */
2676 {
2677 { Bad_Opcode },
792f7758 2678 { "vmovsd", { XMScalar, VexScalar, EXxmm_mq } },
43234a1e
L
2679 },
2680 /* EVEX_W_0F11_P_0 */
2681 {
2682 { "vmovups", { EXxS, XM } },
2683 },
2684 /* EVEX_W_0F11_P_1_M_0 */
2685 {
2686 { "vmovss", { EXdScalarS, XMScalar } },
2687 },
2688 /* EVEX_W_0F11_P_1_M_1 */
2689 {
2690 { "vmovss", { EXxS, Vex, XMScalar } },
2691 },
2692 /* EVEX_W_0F11_P_2 */
2693 {
2694 { Bad_Opcode },
2695 { "vmovupd", { EXxS, XM } },
2696 },
2697 /* EVEX_W_0F11_P_3_M_0 */
2698 {
2699 { Bad_Opcode },
2700 { "vmovsd", { EXqScalarS, XMScalar } },
2701 },
2702 /* EVEX_W_0F11_P_3_M_1 */
2703 {
2704 { Bad_Opcode },
2705 { "vmovsd", { EXxS, Vex, XMScalar } },
2706 },
2707 /* EVEX_W_0F12_P_0_M_0 */
2708 {
2709 { "vmovlps", { XMM, Vex, EXxmm_mq } },
2710 },
2711 /* EVEX_W_0F12_P_0_M_1 */
2712 {
2713 { "vmovhlps", { XMM, Vex, EXxmm_mq } },
2714 },
2715 /* EVEX_W_0F12_P_1 */
2716 {
2717 { "vmovsldup", { XM, EXEvexXNoBcst } },
2718 },
2719 /* EVEX_W_0F12_P_2 */
2720 {
2721 { Bad_Opcode },
2722 { "vmovlpd", { XMM, Vex, EXxmm_mq } },
2723 },
2724 /* EVEX_W_0F12_P_3 */
2725 {
2726 { Bad_Opcode },
2727 { "vmovddup", { XM, EXymmq } },
2728 },
2729 /* EVEX_W_0F13_P_0 */
2730 {
2731 { "vmovlps", { EXxmm_mq, XMM } },
2732 },
2733 /* EVEX_W_0F13_P_2 */
2734 {
2735 { Bad_Opcode },
2736 { "vmovlpd", { EXxmm_mq, XMM } },
2737 },
2738 /* EVEX_W_0F14_P_0 */
2739 {
2740 { "vunpcklps", { XM, Vex, EXx } },
2741 },
2742 /* EVEX_W_0F14_P_2 */
2743 {
2744 { Bad_Opcode },
2745 { "vunpcklpd", { XM, Vex, EXx } },
2746 },
2747 /* EVEX_W_0F15_P_0 */
2748 {
2749 { "vunpckhps", { XM, Vex, EXx } },
2750 },
2751 /* EVEX_W_0F15_P_2 */
2752 {
2753 { Bad_Opcode },
2754 { "vunpckhpd", { XM, Vex, EXx } },
2755 },
2756 /* EVEX_W_0F16_P_0_M_0 */
2757 {
2758 { "vmovhps", { XMM, Vex, EXxmm_mq } },
2759 },
2760 /* EVEX_W_0F16_P_0_M_1 */
2761 {
2762 { "vmovlhps", { XMM, Vex, EXx } },
2763 },
2764 /* EVEX_W_0F16_P_1 */
2765 {
2766 { "vmovshdup", { XM, EXx } },
2767 },
2768 /* EVEX_W_0F16_P_2 */
2769 {
2770 { Bad_Opcode },
2771 { "vmovhpd", { XMM, Vex, EXxmm_mq } },
2772 },
2773 /* EVEX_W_0F17_P_0 */
2774 {
2775 { "vmovhps", { EXxmm_mq, XMM } },
2776 },
2777 /* EVEX_W_0F17_P_2 */
2778 {
2779 { Bad_Opcode },
2780 { "vmovhpd", { EXxmm_mq, XMM } },
2781 },
2782 /* EVEX_W_0F28_P_0 */
2783 {
2784 { "vmovaps", { XM, EXx } },
2785 },
2786 /* EVEX_W_0F28_P_2 */
2787 {
2788 { Bad_Opcode },
2789 { "vmovapd", { XM, EXx } },
2790 },
2791 /* EVEX_W_0F29_P_0 */
2792 {
2793 { "vmovaps", { EXxS, XM } },
2794 },
2795 /* EVEX_W_0F29_P_2 */
2796 {
2797 { Bad_Opcode },
2798 { "vmovapd", { EXxS, XM } },
2799 },
2800 /* EVEX_W_0F2A_P_1 */
2801 {
2802 { "vcvtsi2ss", { XMScalar, VexScalar, EXxEVexR, Ed } },
2803 { "vcvtsi2ss", { XMScalar, VexScalar, EXxEVexR, Eq } },
2804 },
2805 /* EVEX_W_0F2A_P_3 */
2806 {
2807 { "vcvtsi2sd", { XMScalar, VexScalar, Ed } },
2808 { "vcvtsi2sd", { XMScalar, VexScalar, EXxEVexR, Eq } },
2809 },
2810 /* EVEX_W_0F2B_P_0 */
2811 {
2812 { "vmovntps", { EXx, XM } },
2813 },
2814 /* EVEX_W_0F2B_P_2 */
2815 {
2816 { Bad_Opcode },
2817 { "vmovntpd", { EXx, XM } },
2818 },
2819 /* EVEX_W_0F2E_P_0 */
2820 {
2821 { "vucomiss", { XMScalar, EXxmm_md, EXxEVexS } },
2822 },
2823 /* EVEX_W_0F2E_P_2 */
2824 {
2825 { Bad_Opcode },
2826 { "vucomisd", { XMScalar, EXxmm_mq, EXxEVexS } },
2827 },
2828 /* EVEX_W_0F2F_P_0 */
2829 {
2830 { "vcomiss", { XMScalar, EXxmm_md, EXxEVexS } },
2831 },
2832 /* EVEX_W_0F2F_P_2 */
2833 {
2834 { Bad_Opcode },
2835 { "vcomisd", { XMScalar, EXxmm_mq, EXxEVexS } },
2836 },
2837 /* EVEX_W_0F51_P_0 */
2838 {
2839 { "vsqrtps", { XM, EXx, EXxEVexR } },
2840 },
2841 /* EVEX_W_0F51_P_1 */
2842 {
2843 { "vsqrtss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2844 },
2845 /* EVEX_W_0F51_P_2 */
2846 {
2847 { Bad_Opcode },
2848 { "vsqrtpd", { XM, EXx, EXxEVexR } },
2849 },
2850 /* EVEX_W_0F51_P_3 */
2851 {
2852 { Bad_Opcode },
2853 { "vsqrtsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2854 },
2855 /* EVEX_W_0F58_P_0 */
2856 {
2857 { "vaddps", { XM, Vex, EXx, EXxEVexR } },
2858 },
2859 /* EVEX_W_0F58_P_1 */
2860 {
2861 { "vaddss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2862 },
2863 /* EVEX_W_0F58_P_2 */
2864 {
2865 { Bad_Opcode },
2866 { "vaddpd", { XM, Vex, EXx, EXxEVexR } },
2867 },
2868 /* EVEX_W_0F58_P_3 */
2869 {
2870 { Bad_Opcode },
2871 { "vaddsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2872 },
2873 /* EVEX_W_0F59_P_0 */
2874 {
2875 { "vmulps", { XM, Vex, EXx, EXxEVexR } },
2876 },
2877 /* EVEX_W_0F59_P_1 */
2878 {
2879 { "vmulss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2880 },
2881 /* EVEX_W_0F59_P_2 */
2882 {
2883 { Bad_Opcode },
2884 { "vmulpd", { XM, Vex, EXx, EXxEVexR } },
2885 },
2886 /* EVEX_W_0F59_P_3 */
2887 {
2888 { Bad_Opcode },
2889 { "vmulsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2890 },
2891 /* EVEX_W_0F5A_P_0 */
2892 {
2893 { "vcvtps2pd", { XM, EXEvexHalfBcstXmmq, EXxEVexS } },
2894 },
2895 /* EVEX_W_0F5A_P_1 */
2896 {
2897 { "vcvtss2sd", { XMScalar, VexScalar, EXxmm_md, EXxEVexS } },
2898 },
2899 /* EVEX_W_0F5A_P_2 */
2900 {
2901 { Bad_Opcode },
2902 { "vcvtpd2ps", { XMxmmq, EXx, EXxEVexR } },
2903 },
2904 /* EVEX_W_0F5A_P_3 */
2905 {
2906 { Bad_Opcode },
2907 { "vcvtsd2ss", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2908 },
2909 /* EVEX_W_0F5B_P_0 */
2910 {
2911 { "vcvtdq2ps", { XM, EXx, EXxEVexR } },
2912 },
2913 /* EVEX_W_0F5B_P_1 */
2914 {
2915 { "vcvttps2dq", { XM, EXx, EXxEVexS } },
2916 },
2917 /* EVEX_W_0F5B_P_2 */
2918 {
2919 { "vcvtps2dq", { XM, EXx, EXxEVexR } },
2920 },
2921 /* EVEX_W_0F5C_P_0 */
2922 {
2923 { "vsubps", { XM, Vex, EXx, EXxEVexR } },
2924 },
2925 /* EVEX_W_0F5C_P_1 */
2926 {
2927 { "vsubss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2928 },
2929 /* EVEX_W_0F5C_P_2 */
2930 {
2931 { Bad_Opcode },
2932 { "vsubpd", { XM, Vex, EXx, EXxEVexR } },
2933 },
2934 /* EVEX_W_0F5C_P_3 */
2935 {
2936 { Bad_Opcode },
2937 { "vsubsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2938 },
2939 /* EVEX_W_0F5D_P_0 */
2940 {
2941 { "vminps", { XM, Vex, EXx, EXxEVexS } },
2942 },
2943 /* EVEX_W_0F5D_P_1 */
2944 {
2945 { "vminss", { XMScalar, VexScalar, EXxmm_md, EXxEVexS } },
2946 },
2947 /* EVEX_W_0F5D_P_2 */
2948 {
2949 { Bad_Opcode },
2950 { "vminpd", { XM, Vex, EXx, EXxEVexS } },
2951 },
2952 /* EVEX_W_0F5D_P_3 */
2953 {
2954 { Bad_Opcode },
2955 { "vminsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS } },
2956 },
2957 /* EVEX_W_0F5E_P_0 */
2958 {
2959 { "vdivps", { XM, Vex, EXx, EXxEVexR } },
2960 },
2961 /* EVEX_W_0F5E_P_1 */
2962 {
2963 { "vdivss", { XMScalar, VexScalar, EXxmm_md, EXxEVexR } },
2964 },
2965 /* EVEX_W_0F5E_P_2 */
2966 {
2967 { Bad_Opcode },
2968 { "vdivpd", { XM, Vex, EXx, EXxEVexR } },
2969 },
2970 /* EVEX_W_0F5E_P_3 */
2971 {
2972 { Bad_Opcode },
2973 { "vdivsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexR } },
2974 },
2975 /* EVEX_W_0F5F_P_0 */
2976 {
2977 { "vmaxps", { XM, Vex, EXx, EXxEVexS } },
2978 },
2979 /* EVEX_W_0F5F_P_1 */
2980 {
2981 { "vmaxss", { XMScalar, VexScalar, EXxmm_md, EXxEVexS } },
2982 },
2983 /* EVEX_W_0F5F_P_2 */
2984 {
2985 { Bad_Opcode },
2986 { "vmaxpd", { XM, Vex, EXx, EXxEVexS } },
2987 },
2988 /* EVEX_W_0F5F_P_3 */
2989 {
2990 { Bad_Opcode },
2991 { "vmaxsd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS } },
2992 },
2993 /* EVEX_W_0F62_P_2 */
2994 {
2995 { "vpunpckldq", { XM, Vex, EXx } },
2996 },
2997 /* EVEX_W_0F66_P_2 */
2998 {
2999 { "vpcmpgtd", { XMask, Vex, EXx } },
3000 },
3001 /* EVEX_W_0F6A_P_2 */
3002 {
3003 { "vpunpckhdq", { XM, Vex, EXx } },
3004 },
1ba585e8
IT
3005 /* EVEX_W_0F6B_P_2 */
3006 {
3007 { "vpackssdw", { XM, Vex, EXx } },
3008 },
43234a1e
L
3009 /* EVEX_W_0F6C_P_2 */
3010 {
3011 { Bad_Opcode },
3012 { "vpunpcklqdq", { XM, Vex, EXx } },
3013 },
3014 /* EVEX_W_0F6D_P_2 */
3015 {
3016 { Bad_Opcode },
3017 { "vpunpckhqdq", { XM, Vex, EXx } },
3018 },
3019 /* EVEX_W_0F6E_P_2 */
3020 {
3021 { "vmovd", { XMScalar, Ed } },
3022 { "vmovq", { XMScalar, Eq } },
3023 },
3024 /* EVEX_W_0F6F_P_1 */
3025 {
3026 { "vmovdqu32", { XM, EXEvexXNoBcst } },
3027 { "vmovdqu64", { XM, EXEvexXNoBcst } },
3028 },
3029 /* EVEX_W_0F6F_P_2 */
3030 {
3031 { "vmovdqa32", { XM, EXEvexXNoBcst } },
3032 { "vmovdqa64", { XM, EXEvexXNoBcst } },
3033 },
1ba585e8
IT
3034 /* EVEX_W_0F6F_P_3 */
3035 {
3036 { "vmovdqu8", { XM, EXx } },
3037 { "vmovdqu16", { XM, EXx } },
3038 },
43234a1e
L
3039 /* EVEX_W_0F70_P_2 */
3040 {
3041 { "vpshufd", { XM, EXx, Ib } },
3042 },
3043 /* EVEX_W_0F72_R_2_P_2 */
3044 {
3045 { "vpsrld", { Vex, EXx, Ib } },
3046 },
3047 /* EVEX_W_0F72_R_6_P_2 */
3048 {
3049 { "vpslld", { Vex, EXx, Ib } },
3050 },
3051 /* EVEX_W_0F73_R_2_P_2 */
3052 {
3053 { Bad_Opcode },
3054 { "vpsrlq", { Vex, EXx, Ib } },
3055 },
3056 /* EVEX_W_0F73_R_6_P_2 */
3057 {
3058 { Bad_Opcode },
3059 { "vpsllq", { Vex, EXx, Ib } },
3060 },
3061 /* EVEX_W_0F76_P_2 */
3062 {
3063 { "vpcmpeqd", { XMask, Vex, EXx } },
3064 },
3065 /* EVEX_W_0F78_P_0 */
3066 {
3067 { "vcvttps2udq", { XM, EXx, EXxEVexS } },
3068 { "vcvttpd2udq", { XMxmmq, EXx, EXxEVexS } },
3069 },
3070 /* EVEX_W_0F79_P_0 */
3071 {
3072 { "vcvtps2udq", { XM, EXx, EXxEVexR } },
3073 { "vcvtpd2udq", { XMxmmq, EXx, EXxEVexR } },
3074 },
3075 /* EVEX_W_0F7A_P_1 */
3076 {
3077 { "vcvtudq2pd", { XM, EXEvexHalfBcstXmmq } },
3078 },
3079 /* EVEX_W_0F7A_P_3 */
3080 {
3081 { "vcvtudq2ps", { XM, EXx, EXxEVexR } },
3082 },
3083 /* EVEX_W_0F7B_P_1 */
3084 {
3085 { "vcvtusi2ss", { XMScalar, VexScalar, EXxEVexR, Ed } },
3086 { "vcvtusi2ss", { XMScalar, VexScalar, EXxEVexR, Eq } },
3087 },
3088 /* EVEX_W_0F7B_P_3 */
3089 {
3090 { "vcvtusi2sd", { XMScalar, VexScalar, Ed } },
3091 { "vcvtusi2sd", { XMScalar, VexScalar, EXxEVexR, Eq } },
3092 },
3093 /* EVEX_W_0F7E_P_1 */
3094 {
3095 { Bad_Opcode },
3096 { "vmovq", { XMScalar, EXxmm_mq } },
3097 },
3098 /* EVEX_W_0F7E_P_2 */
3099 {
3100 { "vmovd", { Ed, XMScalar } },
3101 { "vmovq", { Eq, XMScalar } },
3102 },
3103 /* EVEX_W_0F7F_P_1 */
3104 {
3105 { "vmovdqu32", { EXxS, XM } },
3106 { "vmovdqu64", { EXxS, XM } },
3107 },
3108 /* EVEX_W_0F7F_P_2 */
3109 {
3110 { "vmovdqa32", { EXxS, XM } },
3111 { "vmovdqa64", { EXxS, XM } },
3112 },
1ba585e8
IT
3113 /* EVEX_W_0F7F_P_3 */
3114 {
3115 { "vmovdqu8", { EXxS, XM } },
3116 { "vmovdqu16", { EXxS, XM } },
3117 },
43234a1e
L
3118 /* EVEX_W_0FC2_P_0 */
3119 {
3120 { "vcmpps", { XMask, Vex, EXx, EXxEVexS, VCMP } },
3121 },
3122 /* EVEX_W_0FC2_P_1 */
3123 {
3124 { "vcmpss", { XMask, VexScalar, EXxmm_md, EXxEVexS, VCMP } },
3125 },
3126 /* EVEX_W_0FC2_P_2 */
3127 {
3128 { Bad_Opcode },
3129 { "vcmppd", { XMask, Vex, EXx, EXxEVexS, VCMP } },
3130 },
3131 /* EVEX_W_0FC2_P_3 */
3132 {
3133 { Bad_Opcode },
3134 { "vcmpsd", { XMask, VexScalar, EXxmm_mq, EXxEVexS, VCMP } },
3135 },
3136 /* EVEX_W_0FC6_P_0 */
3137 {
3138 { "vshufps", { XM, Vex, EXx, Ib } },
3139 },
3140 /* EVEX_W_0FC6_P_2 */
3141 {
3142 { Bad_Opcode },
3143 { "vshufpd", { XM, Vex, EXx, Ib } },
3144 },
3145 /* EVEX_W_0FD2_P_2 */
3146 {
3147 { "vpsrld", { XM, Vex, EXxmm } },
3148 },
3149 /* EVEX_W_0FD3_P_2 */
3150 {
3151 { Bad_Opcode },
3152 { "vpsrlq", { XM, Vex, EXxmm } },
3153 },
3154 /* EVEX_W_0FD4_P_2 */
3155 {
3156 { Bad_Opcode },
3157 { "vpaddq", { XM, Vex, EXx } },
3158 },
3159 /* EVEX_W_0FD6_P_2 */
3160 {
3161 { Bad_Opcode },
3162 { "vmovq", { EXxmm_mq, XMScalar } },
3163 },
3164 /* EVEX_W_0FE6_P_1 */
3165 {
3166 { "vcvtdq2pd", { XM, EXEvexHalfBcstXmmq } },
3167 },
3168 /* EVEX_W_0FE6_P_2 */
3169 {
3170 { Bad_Opcode },
3171 { "vcvttpd2dq", { XMxmmq, EXx, EXxEVexS } },
3172 },
3173 /* EVEX_W_0FE6_P_3 */
3174 {
3175 { Bad_Opcode },
3176 { "vcvtpd2dq", { XMxmmq, EXx, EXxEVexR } },
3177 },
3178 /* EVEX_W_0FE7_P_2 */
3179 {
3180 { "vmovntdq", { EXEvexXNoBcst, XM } },
3181 },
3182 /* EVEX_W_0FF2_P_2 */
3183 {
3184 { "vpslld", { XM, Vex, EXxmm } },
3185 },
3186 /* EVEX_W_0FF3_P_2 */
3187 {
3188 { Bad_Opcode },
3189 { "vpsllq", { XM, Vex, EXxmm } },
3190 },
3191 /* EVEX_W_0FF4_P_2 */
3192 {
3193 { Bad_Opcode },
3194 { "vpmuludq", { XM, Vex, EXx } },
3195 },
3196 /* EVEX_W_0FFA_P_2 */
3197 {
3198 { "vpsubd", { XM, Vex, EXx } },
3199 },
3200 /* EVEX_W_0FFB_P_2 */
3201 {
3202 { Bad_Opcode },
3203 { "vpsubq", { XM, Vex, EXx } },
3204 },
3205 /* EVEX_W_0FFE_P_2 */
3206 {
3207 { "vpaddd", { XM, Vex, EXx } },
3208 },
43234a1e
L
3209 /* EVEX_W_0F380C_P_2 */
3210 {
3211 { "vpermilps", { XM, Vex, EXx } },
3212 },
3213 /* EVEX_W_0F380D_P_2 */
3214 {
3215 { Bad_Opcode },
3216 { "vpermilpd", { XM, Vex, EXx } },
3217 },
1ba585e8
IT
3218 /* EVEX_W_0F3810_P_1 */
3219 {
3220 { "vpmovuswb", { EXxmmq, XM } },
3221 },
3222 /* EVEX_W_0F3810_P_2 */
3223 {
3224 { Bad_Opcode },
3225 { "vpsrlvw", { XM, Vex, EXx } },
3226 },
43234a1e
L
3227 /* EVEX_W_0F3811_P_1 */
3228 {
3229 { "vpmovusdb", { EXxmmqd, XM } },
3230 },
1ba585e8
IT
3231 /* EVEX_W_0F3811_P_2 */
3232 {
3233 { Bad_Opcode },
3234 { "vpsravw", { XM, Vex, EXx } },
3235 },
43234a1e
L
3236 /* EVEX_W_0F3812_P_1 */
3237 {
3238 { "vpmovusqb", { EXxmmdw, XM } },
3239 },
1ba585e8
IT
3240 /* EVEX_W_0F3812_P_2 */
3241 {
3242 { Bad_Opcode },
3243 { "vpsllvw", { XM, Vex, EXx } },
3244 },
43234a1e
L
3245 /* EVEX_W_0F3813_P_1 */
3246 {
3247 { "vpmovusdw", { EXxmmq, XM } },
3248 },
3249 /* EVEX_W_0F3813_P_2 */
3250 {
3251 { "vcvtph2ps", { XM, EXxmmq, EXxEVexS } },
3252 },
3253 /* EVEX_W_0F3814_P_1 */
3254 {
3255 { "vpmovusqw", { EXxmmqd, XM } },
3256 },
3257 /* EVEX_W_0F3815_P_1 */
3258 {
3259 { "vpmovusqd", { EXxmmq, XM } },
3260 },
3261 /* EVEX_W_0F3818_P_2 */
3262 {
3263 { "vbroadcastss", { XM, EXxmm_md } },
3264 },
3265 /* EVEX_W_0F3819_P_2 */
3266 {
3267 { Bad_Opcode },
3268 { "vbroadcastsd", { XM, EXxmm_mq } },
3269 },
3270 /* EVEX_W_0F381A_P_2 */
3271 {
3272 { "vbroadcastf32x4", { XM, EXxmm } },
3273 },
3274 /* EVEX_W_0F381B_P_2 */
3275 {
3276 { Bad_Opcode },
3277 { "vbroadcastf64x4", { XM, EXymm } },
3278 },
3279 /* EVEX_W_0F381E_P_2 */
3280 {
3281 { "vpabsd", { XM, EXx } },
3282 },
3283 /* EVEX_W_0F381F_P_2 */
3284 {
3285 { Bad_Opcode },
3286 { "vpabsq", { XM, EXx } },
3287 },
1ba585e8
IT
3288 /* EVEX_W_0F3820_P_1 */
3289 {
3290 { "vpmovswb", { EXxmmq, XM } },
3291 },
43234a1e
L
3292 /* EVEX_W_0F3821_P_1 */
3293 {
3294 { "vpmovsdb", { EXxmmqd, XM } },
3295 },
3296 /* EVEX_W_0F3822_P_1 */
3297 {
3298 { "vpmovsqb", { EXxmmdw, XM } },
3299 },
3300 /* EVEX_W_0F3823_P_1 */
3301 {
3302 { "vpmovsdw", { EXxmmq, XM } },
3303 },
3304 /* EVEX_W_0F3824_P_1 */
3305 {
3306 { "vpmovsqw", { EXxmmqd, XM } },
3307 },
3308 /* EVEX_W_0F3825_P_1 */
3309 {
3310 { "vpmovsqd", { EXxmmq, XM } },
3311 },
3312 /* EVEX_W_0F3825_P_2 */
3313 {
3314 { "vpmovsxdq", { XM, EXxmmq } },
3315 },
1ba585e8
IT
3316 /* EVEX_W_0F3826_P_1 */
3317 {
3318 { "vptestnmb", { XMask, Vex, EXx } },
3319 { "vptestnmw", { XMask, Vex, EXx } },
3320 },
3321 /* EVEX_W_0F3826_P_2 */
3322 {
3323 { "vptestmb", { XMask, Vex, EXx } },
3324 { "vptestmw", { XMask, Vex, EXx } },
3325 },
3326 /* EVEX_W_0F3828_P_1 */
3327 {
3328 { "vpmovm2b", { XM, MaskR } },
3329 { "vpmovm2w", { XM, MaskR } },
3330 },
43234a1e
L
3331 /* EVEX_W_0F3828_P_2 */
3332 {
3333 { Bad_Opcode },
3334 { "vpmuldq", { XM, Vex, EXx } },
3335 },
1ba585e8
IT
3336 /* EVEX_W_0F3829_P_1 */
3337 {
3338 { "vpmovb2m", { XMask, EXx } },
3339 { "vpmovw2m", { XMask, EXx } },
3340 },
43234a1e
L
3341 /* EVEX_W_0F3829_P_2 */
3342 {
3343 { Bad_Opcode },
3344 { "vpcmpeqq", { XMask, Vex, EXx } },
3345 },
3346 /* EVEX_W_0F382A_P_1 */
3347 {
3348 { Bad_Opcode },
3349 { "vpbroadcastmb2q", { XM, MaskR } },
3350 },
3351 /* EVEX_W_0F382A_P_2 */
3352 {
3353 { "vmovntdqa", { XM, EXEvexXNoBcst } },
3354 },
1ba585e8
IT
3355 /* EVEX_W_0F382B_P_2 */
3356 {
3357 { "vpackusdw", { XM, Vex, EXx } },
3358 },
3359 /* EVEX_W_0F3830_P_1 */
3360 {
3361 { "vpmovwb", { EXxmmq, XM } },
3362 },
43234a1e
L
3363 /* EVEX_W_0F3831_P_1 */
3364 {
3365 { "vpmovdb", { EXxmmqd, XM } },
3366 },
3367 /* EVEX_W_0F3832_P_1 */
3368 {
3369 { "vpmovqb", { EXxmmdw, XM } },
3370 },
3371 /* EVEX_W_0F3833_P_1 */
3372 {
3373 { "vpmovdw", { EXxmmq, XM } },
3374 },
3375 /* EVEX_W_0F3834_P_1 */
3376 {
3377 { "vpmovqw", { EXxmmqd, XM } },
3378 },
3379 /* EVEX_W_0F3835_P_1 */
3380 {
3381 { "vpmovqd", { EXxmmq, XM } },
3382 },
3383 /* EVEX_W_0F3835_P_2 */
3384 {
3385 { "vpmovzxdq", { XM, EXxmmq } },
3386 },
3387 /* EVEX_W_0F3837_P_2 */
3388 {
3389 { Bad_Opcode },
3390 { "vpcmpgtq", { XMask, Vex, EXx } },
3391 },
3392 /* EVEX_W_0F383A_P_1 */
3393 {
3394 { "vpbroadcastmw2d", { XM, MaskR } },
3395 },
3396 /* EVEX_W_0F3840_P_2 */
3397 {
3398 { "vpmulld", { XM, Vex, EXx } },
3399 },
3400 /* EVEX_W_0F3858_P_2 */
3401 {
3402 { "vpbroadcastd", { XM, EXxmm_md } },
3403 },
3404 /* EVEX_W_0F3859_P_2 */
3405 {
3406 { Bad_Opcode },
3407 { "vpbroadcastq", { XM, EXxmm_mq } },
3408 },
3409 /* EVEX_W_0F385A_P_2 */
3410 {
3411 { "vbroadcasti32x4", { XM, EXxmm } },
3412 },
3413 /* EVEX_W_0F385B_P_2 */
3414 {
3415 { Bad_Opcode },
3416 { "vbroadcasti64x4", { XM, EXymm } },
3417 },
1ba585e8
IT
3418 /* EVEX_W_0F3866_P_2 */
3419 {
3420 { "vpblendmb", { XM, Vex, EXx } },
3421 { "vpblendmw", { XM, Vex, EXx } },
3422 },
3423 /* EVEX_W_0F3875_P_2 */
3424 {
3425 { Bad_Opcode },
3426 { "vpermi2w", { XM, Vex, EXx } },
3427 },
3428 /* EVEX_W_0F3878_P_2 */
3429 {
3430 { "vpbroadcastb", { XM, EXxmm_mb } },
3431 },
3432 /* EVEX_W_0F3879_P_2 */
3433 {
3434 { "vpbroadcastw", { XM, EXxmm_mw } },
3435 },
3436 /* EVEX_W_0F387A_P_2 */
3437 {
3438 { "vpbroadcastb", { XM, Rd } },
3439 },
3440 /* EVEX_W_0F387B_P_2 */
3441 {
3442 { "vpbroadcastw", { XM, Rd } },
3443 },
3444 /* EVEX_W_0F387D_P_2 */
3445 {
3446 { Bad_Opcode },
3447 { "vpermt2w", { XM, Vex, EXx } },
3448 },
3449 /* EVEX_W_0F388D_P_2 */
3450 {
3451 { Bad_Opcode },
3452 { "vpermw", { XM, Vex, EXx } },
3453 },
43234a1e
L
3454 /* EVEX_W_0F3891_P_2 */
3455 {
5fc35d96 3456 { "vpgatherqd", { XMxmmq, MVexVSIBQDWpX } },
43234a1e
L
3457 { "vpgatherqq", { XM, MVexVSIBQWpX } },
3458 },
3459 /* EVEX_W_0F3893_P_2 */
3460 {
5fc35d96 3461 { "vgatherqps", { XMxmmq, MVexVSIBQDWpX } },
43234a1e
L
3462 { "vgatherqpd", { XM, MVexVSIBQWpX } },
3463 },
3464 /* EVEX_W_0F38A1_P_2 */
3465 {
5fc35d96 3466 { "vpscatterqd", { MVexVSIBQDWpX, XMxmmq } },
43234a1e
L
3467 { "vpscatterqq", { MVexVSIBQWpX, XM } },
3468 },
3469 /* EVEX_W_0F38A3_P_2 */
3470 {
5fc35d96 3471 { "vscatterqps", { MVexVSIBQDWpX, XMxmmq } },
43234a1e
L
3472 { "vscatterqpd", { MVexVSIBQWpX, XM } },
3473 },
3474 /* EVEX_W_0F38C7_R_1_P_2 */
3475 {
5fc35d96 3476 { "vgatherpf0qps", { MVexVSIBDQWpX } },
43234a1e
L
3477 { "vgatherpf0qpd", { MVexVSIBQWpX } },
3478 },
3479 /* EVEX_W_0F38C7_R_2_P_2 */
3480 {
5fc35d96 3481 { "vgatherpf1qps", { MVexVSIBDQWpX } },
43234a1e
L
3482 { "vgatherpf1qpd", { MVexVSIBQWpX } },
3483 },
3484 /* EVEX_W_0F38C7_R_5_P_2 */
3485 {
5fc35d96 3486 { "vscatterpf0qps", { MVexVSIBDQWpX } },
43234a1e
L
3487 { "vscatterpf0qpd", { MVexVSIBQWpX } },
3488 },
3489 /* EVEX_W_0F38C7_R_6_P_2 */
3490 {
5fc35d96 3491 { "vscatterpf1qps", { MVexVSIBDQWpX } },
43234a1e
L
3492 { "vscatterpf1qpd", { MVexVSIBQWpX } },
3493 },
43234a1e
L
3494 /* EVEX_W_0F3A00_P_2 */
3495 {
3496 { Bad_Opcode },
3497 { "vpermq", { XM, EXx, Ib } },
3498 },
3499 /* EVEX_W_0F3A01_P_2 */
3500 {
3501 { Bad_Opcode },
3502 { "vpermpd", { XM, EXx, Ib } },
3503 },
3504 /* EVEX_W_0F3A04_P_2 */
3505 {
3506 { "vpermilps", { XM, EXx, Ib } },
3507 },
3508 /* EVEX_W_0F3A05_P_2 */
3509 {
3510 { Bad_Opcode },
3511 { "vpermilpd", { XM, EXx, Ib } },
3512 },
3513 /* EVEX_W_0F3A08_P_2 */
3514 {
3515 { "vrndscaleps", { XM, EXx, EXxEVexS, Ib } },
3516 },
3517 /* EVEX_W_0F3A09_P_2 */
3518 {
3519 { Bad_Opcode },
3520 { "vrndscalepd", { XM, EXx, EXxEVexS, Ib } },
3521 },
3522 /* EVEX_W_0F3A0A_P_2 */
3523 {
3524 { "vrndscaless", { XMScalar, VexScalar, EXxmm_md, EXxEVexS, Ib } },
3525 },
3526 /* EVEX_W_0F3A0B_P_2 */
3527 {
3528 { Bad_Opcode },
3529 { "vrndscalesd", { XMScalar, VexScalar, EXxmm_mq, EXxEVexS, Ib } },
3530 },
3531 /* EVEX_W_0F3A18_P_2 */
3532 {
3533 { "vinsertf32x4", { XM, Vex, EXxmm, Ib } },
3534 },
3535 /* EVEX_W_0F3A19_P_2 */
3536 {
3537 { "vextractf32x4", { EXxmm, XM, Ib } },
3538 },
3539 /* EVEX_W_0F3A1A_P_2 */
3540 {
3541 { Bad_Opcode },
3542 { "vinsertf64x4", { XM, Vex, EXxmmq, Ib } },
3543 },
3544 /* EVEX_W_0F3A1B_P_2 */
3545 {
3546 { Bad_Opcode },
3547 { "vextractf64x4", { EXxmmq, XM, Ib } },
3548 },
3549 /* EVEX_W_0F3A1D_P_2 */
3550 {
3551 { "vcvtps2ph", { EXxmmq, XM, EXxEVexS, Ib } },
3552 },
3553 /* EVEX_W_0F3A21_P_2 */
3554 {
3555 { "vinsertps", { XMM, Vex, EXxmm_md, Ib } },
3556 },
3557 /* EVEX_W_0F3A23_P_2 */
3558 {
3559 { "vshuff32x4", { XM, Vex, EXx, Ib } },
3560 { "vshuff64x2", { XM, Vex, EXx, Ib } },
3561 },
3562 /* EVEX_W_0F3A38_P_2 */
3563 {
3564 { "vinserti32x4", { XM, Vex, EXxmm, Ib } },
3565 },
3566 /* EVEX_W_0F3A39_P_2 */
3567 {
3568 { "vextracti32x4", { EXxmm, XM, Ib } },
3569 },
3570 /* EVEX_W_0F3A3A_P_2 */
3571 {
3572 { Bad_Opcode },
3573 { "vinserti64x4", { XM, Vex, EXxmmq, Ib } },
3574 },
3575 /* EVEX_W_0F3A3B_P_2 */
3576 {
3577 { Bad_Opcode },
3578 { "vextracti64x4", { EXxmmq, XM, Ib } },
3579 },
1ba585e8
IT
3580 /* EVEX_W_0F3A3E_P_2 */
3581 {
3582 { "vpcmpub", { XMask, Vex, EXx, Ib } },
3583 { "vpcmpuw", { XMask, Vex, EXx, Ib } },
3584 },
3585 /* EVEX_W_0F3A3F_P_2 */
3586 {
3587 { "vpcmpb", { XMask, Vex, EXx, Ib } },
3588 { "vpcmpw", { XMask, Vex, EXx, Ib } },
3589 },
3590 /* EVEX_W_0F3A42_P_2 */
3591 {
3592 { "vdbpsadbw", { XM, Vex, EXx, Ib } },
3593 },
43234a1e
L
3594 /* EVEX_W_0F3A43_P_2 */
3595 {
3596 { "vshufi32x4", { XM, Vex, EXx, Ib } },
3597 { "vshufi64x2", { XM, Vex, EXx, Ib } },
3598 },
3599#endif /* NEED_VEX_W_TABLE */
3600#ifdef NEED_MOD_TABLE
3601 {
3602 /* MOD_EVEX_0F10_PREFIX_1 */
3603 { VEX_W_TABLE (EVEX_W_0F10_P_1_M_0) },
3604 { VEX_W_TABLE (EVEX_W_0F10_P_1_M_1) },
3605 },
3606 {
3607 /* MOD_EVEX_0F10_PREFIX_3 */
3608 { VEX_W_TABLE (EVEX_W_0F10_P_3_M_0) },
3609 { VEX_W_TABLE (EVEX_W_0F10_P_3_M_1) },
3610 },
3611 {
3612 /* MOD_EVEX_0F11_PREFIX_1 */
3613 { VEX_W_TABLE (EVEX_W_0F11_P_1_M_0) },
3614 { VEX_W_TABLE (EVEX_W_0F11_P_1_M_1) },
3615 },
3616 {
3617 /* MOD_EVEX_0F11_PREFIX_3 */
3618 { VEX_W_TABLE (EVEX_W_0F11_P_3_M_0) },
3619 { VEX_W_TABLE (EVEX_W_0F11_P_3_M_1) },
3620 },
3621 {
3622 /* MOD_EVEX_0F12_PREFIX_0 */
3623 { VEX_W_TABLE (EVEX_W_0F12_P_0_M_0) },
3624 { VEX_W_TABLE (EVEX_W_0F12_P_0_M_1) },
3625 },
3626 {
3627 /* MOD_EVEX_0F16_PREFIX_0 */
3628 { VEX_W_TABLE (EVEX_W_0F16_P_0_M_0) },
3629 { VEX_W_TABLE (EVEX_W_0F16_P_0_M_1) },
3630 },
3631 {
3632 /* MOD_EVEX_0F38C6_REG_1 */
3633 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_1) },
3634 },
3635 {
3636 /* MOD_EVEX_0F38C6_REG_2 */
3637 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_2) },
3638 },
3639 {
3640 /* MOD_EVEX_0F38C6_REG_5 */
3641 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_5) },
3642 },
3643 {
3644 /* MOD_EVEX_0F38C6_REG_6 */
3645 { PREFIX_TABLE (PREFIX_EVEX_0F38C6_REG_6) },
3646 },
3647 {
3648 /* MOD_EVEX_0F38C7_REG_1 */
3649 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_1) },
3650 },
3651 {
3652 /* MOD_EVEX_0F38C7_REG_2 */
3653 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_2) },
3654 },
3655 {
3656 /* MOD_EVEX_0F38C7_REG_5 */
3657 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_5) },
3658 },
3659 {
3660 /* MOD_EVEX_0F38C7_REG_6 */
3661 { PREFIX_TABLE (PREFIX_EVEX_0F38C7_REG_6) },
3662 },
3663#endif /* NEED_MOD_TABLE */
This page took 0.196737 seconds and 4 git commands to generate.