xref: /netbsd-src/external/gpl3/gdb/dist/opcodes/i386-dis.c (revision 4adfa041e14dc071f6d5e464e5b88c9721db4b02)
1 /* Print i386 instructions for GDB, the GNU debugger.
2    Copyright (C) 1988-2024 Free Software Foundation, Inc.
3 
4    This file is part of the GNU opcodes library.
5 
6    This library is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 3, or (at your option)
9    any later version.
10 
11    It is distributed in the hope that it will be useful, but WITHOUT
12    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
14    License for more details.
15 
16    You should have received a copy of the GNU General Public License
17    along with this program; if not, write to the Free Software
18    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19    MA 02110-1301, USA.  */
20 
21 
22 /* 80386 instruction printer by Pace Willisson (pace@prep.ai.mit.edu)
23    July 1988
24     modified by John Hassey (hassey@dg-rtp.dg.com)
25     x86-64 support added by Jan Hubicka (jh@suse.cz)
26     VIA PadLock support by Michal Ludvig (mludvig@suse.cz).  */
27 
28 /* The main tables describing the instructions is essentially a copy
29    of the "Opcode Map" chapter (Appendix A) of the Intel 80386
30    Programmers Manual.  Usually, there is a capital letter, followed
31    by a small letter.  The capital letter tell the addressing mode,
32    and the small letter tells about the operand size.  Refer to
33    the Intel manual for details.  */
34 
35 #include "sysdep.h"
36 #include "disassemble.h"
37 #include "opintl.h"
38 #include "opcode/i386.h"
39 #include "libiberty.h"
40 #include "safe-ctype.h"
41 
42 typedef struct instr_info instr_info;
43 
44 static bool dofloat (instr_info *, int);
45 static int putop (instr_info *, const char *, int);
46 static void oappend_with_style (instr_info *, const char *,
47 				enum disassembler_style);
48 
49 static bool OP_E (instr_info *, int, int);
50 static bool OP_E_memory (instr_info *, int, int);
51 static bool OP_indirE (instr_info *, int, int);
52 static bool OP_G (instr_info *, int, int);
53 static bool OP_ST (instr_info *, int, int);
54 static bool OP_STi (instr_info *, int, int);
55 static bool OP_Skip_MODRM (instr_info *, int, int);
56 static bool OP_REG (instr_info *, int, int);
57 static bool OP_IMREG (instr_info *, int, int);
58 static bool OP_I (instr_info *, int, int);
59 static bool OP_I64 (instr_info *, int, int);
60 static bool OP_sI (instr_info *, int, int);
61 static bool OP_J (instr_info *, int, int);
62 static bool OP_SEG (instr_info *, int, int);
63 static bool OP_DIR (instr_info *, int, int);
64 static bool OP_OFF (instr_info *, int, int);
65 static bool OP_OFF64 (instr_info *, int, int);
66 static bool OP_ESreg (instr_info *, int, int);
67 static bool OP_DSreg (instr_info *, int, int);
68 static bool OP_C (instr_info *, int, int);
69 static bool OP_D (instr_info *, int, int);
70 static bool OP_T (instr_info *, int, int);
71 static bool OP_MMX (instr_info *, int, int);
72 static bool OP_XMM (instr_info *, int, int);
73 static bool OP_EM (instr_info *, int, int);
74 static bool OP_EX (instr_info *, int, int);
75 static bool OP_EMC (instr_info *, int,int);
76 static bool OP_MXC (instr_info *, int,int);
77 static bool OP_R (instr_info *, int, int);
78 static bool OP_M (instr_info *, int, int);
79 static bool OP_VEX (instr_info *, int, int);
80 static bool OP_VexR (instr_info *, int, int);
81 static bool OP_VexW (instr_info *, int, int);
82 static bool OP_Rounding (instr_info *, int, int);
83 static bool OP_REG_VexI4 (instr_info *, int, int);
84 static bool OP_VexI4 (instr_info *, int, int);
85 static bool OP_0f07 (instr_info *, int, int);
86 static bool OP_Monitor (instr_info *, int, int);
87 static bool OP_Mwait (instr_info *, int, int);
88 
89 static bool PCLMUL_Fixup (instr_info *, int, int);
90 static bool VPCMP_Fixup (instr_info *, int, int);
91 static bool VPCOM_Fixup (instr_info *, int, int);
92 static bool NOP_Fixup (instr_info *, int, int);
93 static bool OP_3DNowSuffix (instr_info *, int, int);
94 static bool CMP_Fixup (instr_info *, int, int);
95 static bool REP_Fixup (instr_info *, int, int);
96 static bool SEP_Fixup (instr_info *, int, int);
97 static bool BND_Fixup (instr_info *, int, int);
98 static bool NOTRACK_Fixup (instr_info *, int, int);
99 static bool HLE_Fixup1 (instr_info *, int, int);
100 static bool HLE_Fixup2 (instr_info *, int, int);
101 static bool HLE_Fixup3 (instr_info *, int, int);
102 static bool CMPXCHG8B_Fixup (instr_info *, int, int);
103 static bool XMM_Fixup (instr_info *, int, int);
104 static bool FXSAVE_Fixup (instr_info *, int, int);
105 static bool MOVSXD_Fixup (instr_info *, int, int);
106 static bool DistinctDest_Fixup (instr_info *, int, int);
107 static bool PREFETCHI_Fixup (instr_info *, int, int);
108 static bool PUSH2_POP2_Fixup (instr_info *, int, int);
109 static bool JMPABS_Fixup (instr_info *, int, int);
110 
111 static void ATTRIBUTE_PRINTF_3 i386_dis_printf (const disassemble_info *,
112 						enum disassembler_style,
113 						const char *, ...);
114 
115 /* This character is used to encode style information within the output
116    buffers.  See oappend_insert_style for more details.  */
117 #define STYLE_MARKER_CHAR '\002'
118 
119 /* The maximum operand buffer size.  */
120 #define MAX_OPERAND_BUFFER_SIZE 128
121 
122 enum address_mode
123 {
124   mode_16bit,
125   mode_32bit,
126   mode_64bit
127 };
128 
129 static const char *prefix_name (enum address_mode, uint8_t, int);
130 
131 enum x86_64_isa
132 {
133   amd64 = 1,
134   intel64
135 };
136 
137 enum evex_type
138 {
139   evex_default = 0,
140   evex_from_legacy,
141   evex_from_vex,
142 };
143 
144 struct instr_info
145 {
146   enum address_mode address_mode;
147 
148   /* Flags for the prefixes for the current instruction.  See below.  */
149   int prefixes;
150 
151   /* REX prefix the current instruction.  See below.  */
152   uint8_t rex;
153   /* Bits of REX we've already used.  */
154   uint8_t rex_used;
155 
156   /* Record W R4 X4 B4 bits for rex2.  */
157   unsigned char rex2;
158   /* Bits of rex2 we've already used.  */
159   unsigned char rex2_used;
160   unsigned char rex2_payload;
161 
162   bool need_modrm;
163   unsigned char need_vex;
164   bool has_sib;
165 
166   /* Flags for ins->prefixes which we somehow handled when printing the
167      current instruction.  */
168   int used_prefixes;
169 
170   /* Flags for EVEX bits which we somehow handled when printing the
171      current instruction.  */
172   int evex_used;
173 
174   char obuf[MAX_OPERAND_BUFFER_SIZE];
175   char *obufp;
176   char *mnemonicendp;
177   const uint8_t *start_codep;
178   uint8_t *codep;
179   const uint8_t *end_codep;
180   unsigned char nr_prefixes;
181   signed char last_lock_prefix;
182   signed char last_repz_prefix;
183   signed char last_repnz_prefix;
184   signed char last_data_prefix;
185   signed char last_addr_prefix;
186   signed char last_rex_prefix;
187   signed char last_rex2_prefix;
188   signed char last_seg_prefix;
189   signed char fwait_prefix;
190   /* The active segment register prefix.  */
191   unsigned char active_seg_prefix;
192 
193 #define MAX_CODE_LENGTH 15
194   /* We can up to 14 ins->prefixes since the maximum instruction length is
195      15bytes.  */
196   uint8_t all_prefixes[MAX_CODE_LENGTH - 1];
197   disassemble_info *info;
198 
199   struct
200   {
201     int mod;
202     int reg;
203     int rm;
204   }
205   modrm;
206 
207   struct
208   {
209     int scale;
210     int index;
211     int base;
212   }
213   sib;
214 
215   struct
216   {
217     int register_specifier;
218     int length;
219     int prefix;
220     int mask_register_specifier;
221     int ll;
222     bool w;
223     bool evex;
224     bool v;
225     bool zeroing;
226     bool b;
227     bool no_broadcast;
228     bool nf;
229   }
230   vex;
231 
232 /* For APX EVEX-promoted prefix, EVEX.ND shares the same bit as vex.b.  */
233 #define nd b
234 
235   enum evex_type evex_type;
236 
237   /* Remember if the current op is a jump instruction.  */
238   bool op_is_jump;
239 
240   bool two_source_ops;
241 
242   /* Record whether EVEX masking is used incorrectly.  */
243   bool illegal_masking;
244 
245   /* Record whether the modrm byte has been skipped.  */
246   bool has_skipped_modrm;
247 
248   unsigned char op_ad;
249   signed char op_index[MAX_OPERANDS];
250   bool op_riprel[MAX_OPERANDS];
251   char *op_out[MAX_OPERANDS];
252   bfd_vma op_address[MAX_OPERANDS];
253   bfd_vma start_pc;
254 
255   /* On the 386's of 1988, the maximum length of an instruction is 15 bytes.
256    *   (see topic "Redundant ins->prefixes" in the "Differences from 8086"
257    *   section of the "Virtual 8086 Mode" chapter.)
258    * 'pc' should be the address of this instruction, it will
259    *   be used to print the target address if this is a relative jump or call
260    * The function returns the length of this instruction in bytes.
261    */
262   char intel_syntax;
263   bool intel_mnemonic;
264   char open_char;
265   char close_char;
266   char separator_char;
267   char scale_char;
268 
269   enum x86_64_isa isa64;
270 };
271 
272 struct dis_private {
273   bfd_vma insn_start;
274   int orig_sizeflag;
275 
276   /* Indexes first byte not fetched.  */
277   unsigned int fetched;
278   uint8_t the_buffer[2 * MAX_CODE_LENGTH - 1];
279 };
280 
281 /* Mark parts used in the REX prefix.  When we are testing for
282    empty prefix (for 8bit register REX extension), just mask it
283    out.  Otherwise test for REX bit is excuse for existence of REX
284    only in case value is nonzero.  */
285 #define USED_REX(value)					\
286   {							\
287     if (value)						\
288       {							\
289 	if (ins->rex & value)				\
290 	  ins->rex_used |= (value) | REX_OPCODE;	\
291 	if (ins->rex2 & value)				\
292 	  {						\
293 	    ins->rex2_used |= (value);			\
294 	    ins->rex_used |= REX_OPCODE;		\
295 	  }						\
296       }							\
297     else						\
298       ins->rex_used |= REX_OPCODE;			\
299   }
300 
301 
302 #define EVEX_b_used 1
303 #define EVEX_len_used 2
304 
305 
306 /* {rex2} is not printed when the REX2_SPECIAL is set.  */
307 #define REX2_SPECIAL 16
308 
309 /* Flags stored in PREFIXES.  */
310 #define PREFIX_REPZ 1
311 #define PREFIX_REPNZ 2
312 #define PREFIX_CS 4
313 #define PREFIX_SS 8
314 #define PREFIX_DS 0x10
315 #define PREFIX_ES 0x20
316 #define PREFIX_FS 0x40
317 #define PREFIX_GS 0x80
318 #define PREFIX_LOCK 0x100
319 #define PREFIX_DATA 0x200
320 #define PREFIX_ADDR 0x400
321 #define PREFIX_FWAIT 0x800
322 #define PREFIX_REX2 0x1000
323 #define PREFIX_NP_OR_DATA 0x2000
324 #define NO_PREFIX   0x4000
325 
326 /* Make sure that bytes from INFO->PRIVATE_DATA->BUFFER (inclusive)
327    to ADDR (exclusive) are valid.  Returns true for success, false
328    on error.  */
329 static bool
330 fetch_code (struct disassemble_info *info, const uint8_t *until)
331 {
332   int status = -1;
333   struct dis_private *priv = info->private_data;
334   bfd_vma start = priv->insn_start + priv->fetched;
335   uint8_t *fetch_end = priv->the_buffer + priv->fetched;
336   ptrdiff_t needed = until - fetch_end;
337 
338   if (needed <= 0)
339     return true;
340 
341   if (priv->fetched + (size_t) needed <= ARRAY_SIZE (priv->the_buffer))
342     status = (*info->read_memory_func) (start, fetch_end, needed, info);
343   if (status != 0)
344     {
345       /* If we did manage to read at least one byte, then
346 	 print_insn_i386 will do something sensible.  Otherwise, print
347 	 an error.  We do that here because this is where we know
348 	 STATUS.  */
349       if (!priv->fetched)
350 	(*info->memory_error_func) (status, start, info);
351       return false;
352     }
353 
354   priv->fetched += needed;
355   return true;
356 }
357 
358 static bool
359 fetch_modrm (instr_info *ins)
360 {
361   if (!fetch_code (ins->info, ins->codep + 1))
362     return false;
363 
364   ins->modrm.mod = (*ins->codep >> 6) & 3;
365   ins->modrm.reg = (*ins->codep >> 3) & 7;
366   ins->modrm.rm = *ins->codep & 7;
367 
368   return true;
369 }
370 
371 static int
372 fetch_error (const instr_info *ins)
373 {
374   /* Getting here means we tried for data but didn't get it.  That
375      means we have an incomplete instruction of some sort.  Just
376      print the first byte as a prefix or a .byte pseudo-op.  */
377   const struct dis_private *priv = ins->info->private_data;
378   const char *name = NULL;
379 
380   if (ins->codep <= priv->the_buffer)
381     return -1;
382 
383   if (ins->prefixes || ins->fwait_prefix >= 0 || (ins->rex & REX_OPCODE))
384     name = prefix_name (ins->address_mode, priv->the_buffer[0],
385 			priv->orig_sizeflag);
386   if (name != NULL)
387     i386_dis_printf (ins->info, dis_style_mnemonic, "%s", name);
388   else
389     {
390       /* Just print the first byte as a .byte instruction.  */
391       i386_dis_printf (ins->info, dis_style_assembler_directive, ".byte ");
392       i386_dis_printf (ins->info, dis_style_immediate, "%#x",
393 		       (unsigned int) priv->the_buffer[0]);
394     }
395 
396   return 1;
397 }
398 
399 /* Possible values for prefix requirement.  */
400 #define PREFIX_IGNORED_SHIFT	16
401 #define PREFIX_IGNORED_REPZ	(PREFIX_REPZ << PREFIX_IGNORED_SHIFT)
402 #define PREFIX_IGNORED_REPNZ	(PREFIX_REPNZ << PREFIX_IGNORED_SHIFT)
403 #define PREFIX_IGNORED_DATA	(PREFIX_DATA << PREFIX_IGNORED_SHIFT)
404 #define PREFIX_IGNORED_ADDR	(PREFIX_ADDR << PREFIX_IGNORED_SHIFT)
405 #define PREFIX_IGNORED_LOCK	(PREFIX_LOCK << PREFIX_IGNORED_SHIFT)
406 #define PREFIX_REX2_ILLEGAL	(PREFIX_REX2 << PREFIX_IGNORED_SHIFT)
407 
408 /* Opcode prefixes.  */
409 #define PREFIX_OPCODE		(PREFIX_REPZ \
410 				 | PREFIX_REPNZ \
411 				 | PREFIX_DATA)
412 
413 /* Prefixes ignored.  */
414 #define PREFIX_IGNORED		(PREFIX_IGNORED_REPZ \
415 				 | PREFIX_IGNORED_REPNZ \
416 				 | PREFIX_IGNORED_DATA)
417 
418 #define XX { NULL, 0 }
419 #define Bad_Opcode NULL, { { NULL, 0 } }, 0
420 
421 #define Eb { OP_E, b_mode }
422 #define Ebnd { OP_E, bnd_mode }
423 #define EbS { OP_E, b_swap_mode }
424 #define EbndS { OP_E, bnd_swap_mode }
425 #define Ev { OP_E, v_mode }
426 #define Eva { OP_E, va_mode }
427 #define Ev_bnd { OP_E, v_bnd_mode }
428 #define EvS { OP_E, v_swap_mode }
429 #define Ed { OP_E, d_mode }
430 #define Edq { OP_E, dq_mode }
431 #define Edb { OP_E, db_mode }
432 #define Edw { OP_E, dw_mode }
433 #define Eq { OP_E, q_mode }
434 #define indirEv { OP_indirE, indir_v_mode }
435 #define indirEp { OP_indirE, f_mode }
436 #define stackEv { OP_E, stack_v_mode }
437 #define Em { OP_E, m_mode }
438 #define Ew { OP_E, w_mode }
439 #define M { OP_M, 0 }		/* lea, lgdt, etc. */
440 #define Ma { OP_M, a_mode }
441 #define Mb { OP_M, b_mode }
442 #define Md { OP_M, d_mode }
443 #define Mdq { OP_M, dq_mode }
444 #define Mo { OP_M, o_mode }
445 #define Mp { OP_M, f_mode }		/* 32 or 48 bit memory operand for LDS, LES etc */
446 #define Mq { OP_M, q_mode }
447 #define Mv { OP_M, v_mode }
448 #define Mv_bnd { OP_M, v_bndmk_mode }
449 #define Mw { OP_M, w_mode }
450 #define Mx { OP_M, x_mode }
451 #define Mxmm { OP_M, xmm_mode }
452 #define Mymm { OP_M, ymm_mode }
453 #define Gb { OP_G, b_mode }
454 #define Gbnd { OP_G, bnd_mode }
455 #define Gv { OP_G, v_mode }
456 #define Gd { OP_G, d_mode }
457 #define Gdq { OP_G, dq_mode }
458 #define Gq { OP_G, q_mode }
459 #define Gm { OP_G, m_mode }
460 #define Gva { OP_G, va_mode }
461 #define Gw { OP_G, w_mode }
462 #define Ib { OP_I, b_mode }
463 #define sIb { OP_sI, b_mode }	/* sign extened byte */
464 #define sIbT { OP_sI, b_T_mode } /* sign extened byte like 'T' */
465 #define Iv { OP_I, v_mode }
466 #define sIv { OP_sI, v_mode }
467 #define Iv64 { OP_I64, v_mode }
468 #define Id { OP_I, d_mode }
469 #define Iw { OP_I, w_mode }
470 #define I1 { OP_I, const_1_mode }
471 #define Jb { OP_J, b_mode }
472 #define Jv { OP_J, v_mode }
473 #define Jdqw { OP_J, dqw_mode }
474 #define Cm { OP_C, m_mode }
475 #define Dm { OP_D, m_mode }
476 #define Td { OP_T, d_mode }
477 #define Skip_MODRM { OP_Skip_MODRM, 0 }
478 
479 #define RMeAX { OP_REG, eAX_reg }
480 #define RMeBX { OP_REG, eBX_reg }
481 #define RMeCX { OP_REG, eCX_reg }
482 #define RMeDX { OP_REG, eDX_reg }
483 #define RMeSP { OP_REG, eSP_reg }
484 #define RMeBP { OP_REG, eBP_reg }
485 #define RMeSI { OP_REG, eSI_reg }
486 #define RMeDI { OP_REG, eDI_reg }
487 #define RMrAX { OP_REG, rAX_reg }
488 #define RMrBX { OP_REG, rBX_reg }
489 #define RMrCX { OP_REG, rCX_reg }
490 #define RMrDX { OP_REG, rDX_reg }
491 #define RMrSP { OP_REG, rSP_reg }
492 #define RMrBP { OP_REG, rBP_reg }
493 #define RMrSI { OP_REG, rSI_reg }
494 #define RMrDI { OP_REG, rDI_reg }
495 #define RMAL { OP_REG, al_reg }
496 #define RMCL { OP_REG, cl_reg }
497 #define RMDL { OP_REG, dl_reg }
498 #define RMBL { OP_REG, bl_reg }
499 #define RMAH { OP_REG, ah_reg }
500 #define RMCH { OP_REG, ch_reg }
501 #define RMDH { OP_REG, dh_reg }
502 #define RMBH { OP_REG, bh_reg }
503 #define RMAX { OP_REG, ax_reg }
504 #define RMDX { OP_REG, dx_reg }
505 
506 #define eAX { OP_IMREG, eAX_reg }
507 #define AL { OP_IMREG, al_reg }
508 #define CL { OP_IMREG, cl_reg }
509 #define zAX { OP_IMREG, z_mode_ax_reg }
510 #define indirDX { OP_IMREG, indir_dx_reg }
511 
512 #define Sw { OP_SEG, w_mode }
513 #define Sv { OP_SEG, v_mode }
514 #define Ap { OP_DIR, 0 }
515 #define Ob { OP_OFF64, b_mode }
516 #define Ov { OP_OFF64, v_mode }
517 #define Xb { OP_DSreg, eSI_reg }
518 #define Xv { OP_DSreg, eSI_reg }
519 #define Xz { OP_DSreg, eSI_reg }
520 #define Yb { OP_ESreg, eDI_reg }
521 #define Yv { OP_ESreg, eDI_reg }
522 #define DSBX { OP_DSreg, eBX_reg }
523 
524 #define es { OP_REG, es_reg }
525 #define ss { OP_REG, ss_reg }
526 #define cs { OP_REG, cs_reg }
527 #define ds { OP_REG, ds_reg }
528 #define fs { OP_REG, fs_reg }
529 #define gs { OP_REG, gs_reg }
530 
531 #define MX { OP_MMX, 0 }
532 #define XM { OP_XMM, 0 }
533 #define XMScalar { OP_XMM, scalar_mode }
534 #define XMGatherD { OP_XMM, vex_vsib_d_w_dq_mode }
535 #define XMGatherQ { OP_XMM, vex_vsib_q_w_dq_mode }
536 #define XMM { OP_XMM, xmm_mode }
537 #define TMM { OP_XMM, tmm_mode }
538 #define XMxmmq { OP_XMM, xmmq_mode }
539 #define EM { OP_EM, v_mode }
540 #define EMS { OP_EM, v_swap_mode }
541 #define EMd { OP_EM, d_mode }
542 #define EMx { OP_EM, x_mode }
543 #define EXbwUnit { OP_EX, bw_unit_mode }
544 #define EXb { OP_EX, b_mode }
545 #define EXw { OP_EX, w_mode }
546 #define EXd { OP_EX, d_mode }
547 #define EXdS { OP_EX, d_swap_mode }
548 #define EXwS { OP_EX, w_swap_mode }
549 #define EXq { OP_EX, q_mode }
550 #define EXqS { OP_EX, q_swap_mode }
551 #define EXdq { OP_EX, dq_mode }
552 #define EXx { OP_EX, x_mode }
553 #define EXxh { OP_EX, xh_mode }
554 #define EXxS { OP_EX, x_swap_mode }
555 #define EXxmm { OP_EX, xmm_mode }
556 #define EXymm { OP_EX, ymm_mode }
557 #define EXxmmq { OP_EX, xmmq_mode }
558 #define EXxmmqh { OP_EX, evex_half_bcst_xmmqh_mode }
559 #define EXEvexHalfBcstXmmq { OP_EX, evex_half_bcst_xmmq_mode }
560 #define EXxmmdw { OP_EX, xmmdw_mode }
561 #define EXxmmqd { OP_EX, xmmqd_mode }
562 #define EXxmmqdh { OP_EX, evex_half_bcst_xmmqdh_mode }
563 #define EXymmq { OP_EX, ymmq_mode }
564 #define EXEvexXGscat { OP_EX, evex_x_gscat_mode }
565 #define EXEvexXNoBcst { OP_EX, evex_x_nobcst_mode }
566 #define Rd { OP_R, d_mode }
567 #define Rdq { OP_R, dq_mode }
568 #define Rq { OP_R, q_mode }
569 #define Nq { OP_R, q_mm_mode }
570 #define Ux { OP_R, x_mode }
571 #define Uxmm { OP_R, xmm_mode }
572 #define Rxmmq { OP_R, xmmq_mode }
573 #define Rymm { OP_R, ymm_mode }
574 #define Rtmm { OP_R, tmm_mode }
575 #define EMCq { OP_EMC, q_mode }
576 #define MXC { OP_MXC, 0 }
577 #define OPSUF { OP_3DNowSuffix, 0 }
578 #define SEP { SEP_Fixup, 0 }
579 #define CMP { CMP_Fixup, 0 }
580 #define XMM0 { XMM_Fixup, 0 }
581 #define FXSAVE { FXSAVE_Fixup, 0 }
582 
583 #define Vex { OP_VEX, x_mode }
584 #define VexW { OP_VexW, x_mode }
585 #define VexScalar { OP_VEX, scalar_mode }
586 #define VexScalarR { OP_VexR, scalar_mode }
587 #define VexGatherD { OP_VEX, vex_vsib_d_w_dq_mode }
588 #define VexGatherQ { OP_VEX, vex_vsib_q_w_dq_mode }
589 #define VexGdq { OP_VEX, dq_mode }
590 #define VexGb { OP_VEX, b_mode }
591 #define VexGv { OP_VEX, v_mode }
592 #define VexTmm { OP_VEX, tmm_mode }
593 #define XMVexI4 { OP_REG_VexI4, x_mode }
594 #define XMVexScalarI4 { OP_REG_VexI4, scalar_mode }
595 #define VexI4 { OP_VexI4, 0 }
596 #define PCLMUL { PCLMUL_Fixup, 0 }
597 #define VPCMP { VPCMP_Fixup, 0 }
598 #define VPCOM { VPCOM_Fixup, 0 }
599 
600 #define EXxEVexR { OP_Rounding, evex_rounding_mode }
601 #define EXxEVexR64 { OP_Rounding, evex_rounding_64_mode }
602 #define EXxEVexS { OP_Rounding, evex_sae_mode }
603 
604 #define MaskG { OP_G, mask_mode }
605 #define MaskE { OP_E, mask_mode }
606 #define MaskR { OP_R, mask_mode }
607 #define MaskBDE { OP_E, mask_bd_mode }
608 #define MaskVex { OP_VEX, mask_mode }
609 
610 #define MVexVSIBDWpX { OP_M, vex_vsib_d_w_dq_mode }
611 #define MVexVSIBQWpX { OP_M, vex_vsib_q_w_dq_mode }
612 
613 #define MVexSIBMEM { OP_M, vex_sibmem_mode }
614 
615 /* Used handle "rep" prefix for string instructions.  */
616 #define Xbr { REP_Fixup, eSI_reg }
617 #define Xvr { REP_Fixup, eSI_reg }
618 #define Ybr { REP_Fixup, eDI_reg }
619 #define Yvr { REP_Fixup, eDI_reg }
620 #define Yzr { REP_Fixup, eDI_reg }
621 #define indirDXr { REP_Fixup, indir_dx_reg }
622 #define ALr { REP_Fixup, al_reg }
623 #define eAXr { REP_Fixup, eAX_reg }
624 
625 /* Used handle HLE prefix for lockable instructions.  */
626 #define Ebh1 { HLE_Fixup1, b_mode }
627 #define Evh1 { HLE_Fixup1, v_mode }
628 #define Ebh2 { HLE_Fixup2, b_mode }
629 #define Evh2 { HLE_Fixup2, v_mode }
630 #define Ebh3 { HLE_Fixup3, b_mode }
631 #define Evh3 { HLE_Fixup3, v_mode }
632 
633 #define BND { BND_Fixup, 0 }
634 #define NOTRACK { NOTRACK_Fixup, 0 }
635 
636 #define cond_jump_flag { NULL, cond_jump_mode }
637 #define loop_jcxz_flag { NULL, loop_jcxz_mode }
638 
639 /* bits in sizeflag */
640 #define SUFFIX_ALWAYS 4
641 #define AFLAG 2
642 #define DFLAG 1
643 
644 enum
645 {
646   /* byte operand */
647   b_mode = 1,
648   /* byte operand with operand swapped */
649   b_swap_mode,
650   /* byte operand, sign extend like 'T' suffix */
651   b_T_mode,
652   /* operand size depends on prefixes */
653   v_mode,
654   /* operand size depends on prefixes with operand swapped */
655   v_swap_mode,
656   /* operand size depends on address prefix */
657   va_mode,
658   /* word operand */
659   w_mode,
660   /* double word operand  */
661   d_mode,
662   /* word operand with operand swapped  */
663   w_swap_mode,
664   /* double word operand with operand swapped */
665   d_swap_mode,
666   /* quad word operand */
667   q_mode,
668   /* 8-byte MM operand */
669   q_mm_mode,
670   /* quad word operand with operand swapped */
671   q_swap_mode,
672   /* ten-byte operand */
673   t_mode,
674   /* 16-byte XMM, 32-byte YMM or 64-byte ZMM operand.  In EVEX with
675      broadcast enabled.  */
676   x_mode,
677   /* Similar to x_mode, but with different EVEX mem shifts.  */
678   evex_x_gscat_mode,
679   /* Similar to x_mode, but with yet different EVEX mem shifts.  */
680   bw_unit_mode,
681   /* Similar to x_mode, but with disabled broadcast.  */
682   evex_x_nobcst_mode,
683   /* Similar to x_mode, but with operands swapped and disabled broadcast
684      in EVEX.  */
685   x_swap_mode,
686   /* 16-byte XMM, 32-byte YMM or 64-byte ZMM operand.  In EVEX with
687      broadcast of 16bit enabled.  */
688   xh_mode,
689   /* 16-byte XMM operand */
690   xmm_mode,
691   /* XMM, XMM or YMM register operand, or quad word, xmmword or ymmword
692      memory operand (depending on vector length).  Broadcast isn't
693      allowed.  */
694   xmmq_mode,
695   /* Same as xmmq_mode, but broadcast is allowed.  */
696   evex_half_bcst_xmmq_mode,
697   /* XMM, XMM or YMM register operand, or quad word, xmmword or ymmword
698      memory operand (depending on vector length).  16bit broadcast.  */
699   evex_half_bcst_xmmqh_mode,
700   /* 16-byte XMM, word, double word or quad word operand.  */
701   xmmdw_mode,
702   /* 16-byte XMM, double word, quad word operand or xmm word operand.  */
703   xmmqd_mode,
704   /* 16-byte XMM, double word, quad word operand or xmm word operand.
705      16bit broadcast.  */
706   evex_half_bcst_xmmqdh_mode,
707   /* 32-byte YMM operand */
708   ymm_mode,
709   /* quad word, ymmword or zmmword memory operand.  */
710   ymmq_mode,
711   /* TMM operand */
712   tmm_mode,
713   /* d_mode in 32bit, q_mode in 64bit mode.  */
714   m_mode,
715   /* pair of v_mode operands */
716   a_mode,
717   cond_jump_mode,
718   loop_jcxz_mode,
719   movsxd_mode,
720   v_bnd_mode,
721   /* like v_bnd_mode in 32bit, no RIP-rel in 64bit mode.  */
722   v_bndmk_mode,
723   /* operand size depends on REX.W / VEX.W.  */
724   dq_mode,
725   /* Displacements like v_mode without considering Intel64 ISA.  */
726   dqw_mode,
727   /* bounds operand */
728   bnd_mode,
729   /* bounds operand with operand swapped */
730   bnd_swap_mode,
731   /* 4- or 6-byte pointer operand */
732   f_mode,
733   const_1_mode,
734   /* v_mode for indirect branch opcodes.  */
735   indir_v_mode,
736   /* v_mode for stack-related opcodes.  */
737   stack_v_mode,
738   /* non-quad operand size depends on prefixes */
739   z_mode,
740   /* 16-byte operand */
741   o_mode,
742   /* registers like d_mode, memory like b_mode.  */
743   db_mode,
744   /* registers like d_mode, memory like w_mode.  */
745   dw_mode,
746 
747   /* Operand size depends on the VEX.W bit, with VSIB dword indices.  */
748   vex_vsib_d_w_dq_mode,
749   /* Operand size depends on the VEX.W bit, with VSIB qword indices.  */
750   vex_vsib_q_w_dq_mode,
751   /* mandatory non-vector SIB.  */
752   vex_sibmem_mode,
753 
754   /* scalar, ignore vector length.  */
755   scalar_mode,
756 
757   /* Static rounding.  */
758   evex_rounding_mode,
759   /* Static rounding, 64-bit mode only.  */
760   evex_rounding_64_mode,
761   /* Supress all exceptions.  */
762   evex_sae_mode,
763 
764   /* Mask register operand.  */
765   mask_mode,
766   /* Mask register operand.  */
767   mask_bd_mode,
768 
769   es_reg,
770   cs_reg,
771   ss_reg,
772   ds_reg,
773   fs_reg,
774   gs_reg,
775 
776   eAX_reg,
777   eCX_reg,
778   eDX_reg,
779   eBX_reg,
780   eSP_reg,
781   eBP_reg,
782   eSI_reg,
783   eDI_reg,
784 
785   al_reg,
786   cl_reg,
787   dl_reg,
788   bl_reg,
789   ah_reg,
790   ch_reg,
791   dh_reg,
792   bh_reg,
793 
794   ax_reg,
795   cx_reg,
796   dx_reg,
797   bx_reg,
798   sp_reg,
799   bp_reg,
800   si_reg,
801   di_reg,
802 
803   rAX_reg,
804   rCX_reg,
805   rDX_reg,
806   rBX_reg,
807   rSP_reg,
808   rBP_reg,
809   rSI_reg,
810   rDI_reg,
811 
812   z_mode_ax_reg,
813   indir_dx_reg
814 };
815 
816 enum
817 {
818   FLOATCODE = 1,
819   USE_REG_TABLE,
820   USE_MOD_TABLE,
821   USE_RM_TABLE,
822   USE_PREFIX_TABLE,
823   USE_X86_64_TABLE,
824   USE_X86_64_EVEX_FROM_VEX_TABLE,
825   USE_X86_64_EVEX_PFX_TABLE,
826   USE_X86_64_EVEX_W_TABLE,
827   USE_X86_64_EVEX_MEM_W_TABLE,
828   USE_3BYTE_TABLE,
829   USE_XOP_8F_TABLE,
830   USE_VEX_C4_TABLE,
831   USE_VEX_C5_TABLE,
832   USE_VEX_LEN_TABLE,
833   USE_VEX_W_TABLE,
834   USE_EVEX_TABLE,
835   USE_EVEX_LEN_TABLE
836 };
837 
838 #define FLOAT			NULL, { { NULL, FLOATCODE } }, 0
839 
840 #define DIS386(T, I)		NULL, { { NULL, (T)}, { NULL,  (I) } }, 0
841 #define REG_TABLE(I)		DIS386 (USE_REG_TABLE, (I))
842 #define MOD_TABLE(I)		DIS386 (USE_MOD_TABLE, (I))
843 #define RM_TABLE(I)		DIS386 (USE_RM_TABLE, (I))
844 #define PREFIX_TABLE(I)		DIS386 (USE_PREFIX_TABLE, (I))
845 #define X86_64_TABLE(I)		DIS386 (USE_X86_64_TABLE, (I))
846 #define X86_64_EVEX_FROM_VEX_TABLE(I) \
847   DIS386 (USE_X86_64_EVEX_FROM_VEX_TABLE, (I))
848 #define X86_64_EVEX_PFX_TABLE(I) DIS386 (USE_X86_64_EVEX_PFX_TABLE, (I))
849 #define X86_64_EVEX_W_TABLE(I) DIS386 (USE_X86_64_EVEX_W_TABLE, (I))
850 #define X86_64_EVEX_MEM_W_TABLE(I) DIS386 (USE_X86_64_EVEX_MEM_W_TABLE, (I))
851 #define THREE_BYTE_TABLE(I)	DIS386 (USE_3BYTE_TABLE, (I))
852 #define XOP_8F_TABLE()		DIS386 (USE_XOP_8F_TABLE, 0)
853 #define VEX_C4_TABLE()		DIS386 (USE_VEX_C4_TABLE, 0)
854 #define VEX_C5_TABLE()		DIS386 (USE_VEX_C5_TABLE, 0)
855 #define VEX_LEN_TABLE(I)	DIS386 (USE_VEX_LEN_TABLE, (I))
856 #define VEX_W_TABLE(I)		DIS386 (USE_VEX_W_TABLE, (I))
857 #define EVEX_TABLE()		DIS386 (USE_EVEX_TABLE, 0)
858 #define EVEX_LEN_TABLE(I)	DIS386 (USE_EVEX_LEN_TABLE, (I))
859 
860 enum
861 {
862   REG_80 = 0,
863   REG_81,
864   REG_83,
865   REG_8F,
866   REG_C0,
867   REG_C1,
868   REG_C6,
869   REG_C7,
870   REG_D0,
871   REG_D1,
872   REG_D2,
873   REG_D3,
874   REG_F6,
875   REG_F7,
876   REG_FE,
877   REG_FF,
878   REG_0F00,
879   REG_0F01,
880   REG_0F0D,
881   REG_0F18,
882   REG_0F1C_P_0_MOD_0,
883   REG_0F1E_P_1_MOD_3,
884   REG_0F38D8_PREFIX_1,
885   REG_0F3A0F_P_1,
886   REG_0F71,
887   REG_0F72,
888   REG_0F73,
889   REG_0FA6,
890   REG_0FA7,
891   REG_0FAE,
892   REG_0FBA,
893   REG_0FC7,
894   REG_VEX_0F71,
895   REG_VEX_0F72,
896   REG_VEX_0F73,
897   REG_VEX_0FAE,
898   REG_VEX_0F3849_X86_64_L_0_W_0_M_1_P_0,
899   REG_VEX_0F38F3_L_0_P_0,
900   REG_VEX_MAP7_F8_L_0_W_0,
901 
902   REG_XOP_09_01_L_0,
903   REG_XOP_09_02_L_0,
904   REG_XOP_09_12_L_0,
905   REG_XOP_0A_12_L_0,
906 
907   REG_EVEX_0F71,
908   REG_EVEX_0F72,
909   REG_EVEX_0F73,
910   REG_EVEX_0F38C6_L_2,
911   REG_EVEX_0F38C7_L_2,
912   REG_EVEX_MAP4_80,
913   REG_EVEX_MAP4_81,
914   REG_EVEX_MAP4_83,
915   REG_EVEX_MAP4_8F,
916   REG_EVEX_MAP4_F6,
917   REG_EVEX_MAP4_F7,
918   REG_EVEX_MAP4_FE,
919   REG_EVEX_MAP4_FF,
920 };
921 
922 enum
923 {
924   MOD_62_32BIT = 0,
925   MOD_C4_32BIT,
926   MOD_C5_32BIT,
927   MOD_0F01_REG_0,
928   MOD_0F01_REG_1,
929   MOD_0F01_REG_2,
930   MOD_0F01_REG_3,
931   MOD_0F01_REG_5,
932   MOD_0F01_REG_7,
933   MOD_0F12_PREFIX_0,
934   MOD_0F16_PREFIX_0,
935   MOD_0F18_REG_0,
936   MOD_0F18_REG_1,
937   MOD_0F18_REG_2,
938   MOD_0F18_REG_3,
939   MOD_0F18_REG_6,
940   MOD_0F18_REG_7,
941   MOD_0F1A_PREFIX_0,
942   MOD_0F1B_PREFIX_0,
943   MOD_0F1B_PREFIX_1,
944   MOD_0F1C_PREFIX_0,
945   MOD_0F1E_PREFIX_1,
946   MOD_0FAE_REG_0,
947   MOD_0FAE_REG_1,
948   MOD_0FAE_REG_2,
949   MOD_0FAE_REG_3,
950   MOD_0FAE_REG_4,
951   MOD_0FAE_REG_5,
952   MOD_0FAE_REG_6,
953   MOD_0FAE_REG_7,
954   MOD_0FC7_REG_6,
955   MOD_0FC7_REG_7,
956   MOD_0F38DC_PREFIX_1,
957   MOD_0F38F8,
958 
959   MOD_VEX_0F3849_X86_64_L_0_W_0,
960 
961   MOD_EVEX_MAP4_F8_P_1,
962   MOD_EVEX_MAP4_F8_P_3,
963 };
964 
965 enum
966 {
967   RM_C6_REG_7 = 0,
968   RM_C7_REG_7,
969   RM_0F01_REG_0,
970   RM_0F01_REG_1,
971   RM_0F01_REG_2,
972   RM_0F01_REG_3,
973   RM_0F01_REG_5_MOD_3,
974   RM_0F01_REG_7_MOD_3,
975   RM_0F1E_P_1_MOD_3_REG_7,
976   RM_0FAE_REG_6_MOD_3_P_0,
977   RM_0FAE_REG_7_MOD_3,
978   RM_0F3A0F_P_1_R_0,
979 
980   RM_VEX_0F3849_X86_64_L_0_W_0_M_1_P_0_R_0,
981   RM_VEX_0F3849_X86_64_L_0_W_0_M_1_P_3,
982 };
983 
984 enum
985 {
986   PREFIX_90 = 0,
987   PREFIX_0F00_REG_6_X86_64,
988   PREFIX_0F01_REG_0_MOD_3_RM_6,
989   PREFIX_0F01_REG_0_MOD_3_RM_7,
990   PREFIX_0F01_REG_1_RM_2,
991   PREFIX_0F01_REG_1_RM_4,
992   PREFIX_0F01_REG_1_RM_5,
993   PREFIX_0F01_REG_1_RM_6,
994   PREFIX_0F01_REG_1_RM_7,
995   PREFIX_0F01_REG_3_RM_1,
996   PREFIX_0F01_REG_5_MOD_0,
997   PREFIX_0F01_REG_5_MOD_3_RM_0,
998   PREFIX_0F01_REG_5_MOD_3_RM_1,
999   PREFIX_0F01_REG_5_MOD_3_RM_2,
1000   PREFIX_0F01_REG_5_MOD_3_RM_4,
1001   PREFIX_0F01_REG_5_MOD_3_RM_5,
1002   PREFIX_0F01_REG_5_MOD_3_RM_6,
1003   PREFIX_0F01_REG_5_MOD_3_RM_7,
1004   PREFIX_0F01_REG_7_MOD_3_RM_2,
1005   PREFIX_0F01_REG_7_MOD_3_RM_5,
1006   PREFIX_0F01_REG_7_MOD_3_RM_6,
1007   PREFIX_0F01_REG_7_MOD_3_RM_7,
1008   PREFIX_0F09,
1009   PREFIX_0F10,
1010   PREFIX_0F11,
1011   PREFIX_0F12,
1012   PREFIX_0F16,
1013   PREFIX_0F18_REG_6_MOD_0_X86_64,
1014   PREFIX_0F18_REG_7_MOD_0_X86_64,
1015   PREFIX_0F1A,
1016   PREFIX_0F1B,
1017   PREFIX_0F1C,
1018   PREFIX_0F1E,
1019   PREFIX_0F2A,
1020   PREFIX_0F2B,
1021   PREFIX_0F2C,
1022   PREFIX_0F2D,
1023   PREFIX_0F2E,
1024   PREFIX_0F2F,
1025   PREFIX_0F51,
1026   PREFIX_0F52,
1027   PREFIX_0F53,
1028   PREFIX_0F58,
1029   PREFIX_0F59,
1030   PREFIX_0F5A,
1031   PREFIX_0F5B,
1032   PREFIX_0F5C,
1033   PREFIX_0F5D,
1034   PREFIX_0F5E,
1035   PREFIX_0F5F,
1036   PREFIX_0F60,
1037   PREFIX_0F61,
1038   PREFIX_0F62,
1039   PREFIX_0F6F,
1040   PREFIX_0F70,
1041   PREFIX_0F78,
1042   PREFIX_0F79,
1043   PREFIX_0F7C,
1044   PREFIX_0F7D,
1045   PREFIX_0F7E,
1046   PREFIX_0F7F,
1047   PREFIX_0FAE_REG_0_MOD_3,
1048   PREFIX_0FAE_REG_1_MOD_3,
1049   PREFIX_0FAE_REG_2_MOD_3,
1050   PREFIX_0FAE_REG_3_MOD_3,
1051   PREFIX_0FAE_REG_4_MOD_0,
1052   PREFIX_0FAE_REG_4_MOD_3,
1053   PREFIX_0FAE_REG_5_MOD_3,
1054   PREFIX_0FAE_REG_6_MOD_0,
1055   PREFIX_0FAE_REG_6_MOD_3,
1056   PREFIX_0FAE_REG_7_MOD_0,
1057   PREFIX_0FB8,
1058   PREFIX_0FBC,
1059   PREFIX_0FBD,
1060   PREFIX_0FC2,
1061   PREFIX_0FC7_REG_6_MOD_0,
1062   PREFIX_0FC7_REG_6_MOD_3,
1063   PREFIX_0FC7_REG_7_MOD_3,
1064   PREFIX_0FD0,
1065   PREFIX_0FD6,
1066   PREFIX_0FE6,
1067   PREFIX_0FE7,
1068   PREFIX_0FF0,
1069   PREFIX_0FF7,
1070   PREFIX_0F38D8,
1071   PREFIX_0F38DC,
1072   PREFIX_0F38DD,
1073   PREFIX_0F38DE,
1074   PREFIX_0F38DF,
1075   PREFIX_0F38F0,
1076   PREFIX_0F38F1,
1077   PREFIX_0F38F6,
1078   PREFIX_0F38F8_M_0,
1079   PREFIX_0F38F8_M_1_X86_64,
1080   PREFIX_0F38FA,
1081   PREFIX_0F38FB,
1082   PREFIX_0F38FC,
1083   PREFIX_0F3A0F,
1084   PREFIX_VEX_0F12,
1085   PREFIX_VEX_0F16,
1086   PREFIX_VEX_0F2A,
1087   PREFIX_VEX_0F2C,
1088   PREFIX_VEX_0F2D,
1089   PREFIX_VEX_0F41_L_1_W_0,
1090   PREFIX_VEX_0F41_L_1_W_1,
1091   PREFIX_VEX_0F42_L_1_W_0,
1092   PREFIX_VEX_0F42_L_1_W_1,
1093   PREFIX_VEX_0F44_L_0_W_0,
1094   PREFIX_VEX_0F44_L_0_W_1,
1095   PREFIX_VEX_0F45_L_1_W_0,
1096   PREFIX_VEX_0F45_L_1_W_1,
1097   PREFIX_VEX_0F46_L_1_W_0,
1098   PREFIX_VEX_0F46_L_1_W_1,
1099   PREFIX_VEX_0F47_L_1_W_0,
1100   PREFIX_VEX_0F47_L_1_W_1,
1101   PREFIX_VEX_0F4A_L_1_W_0,
1102   PREFIX_VEX_0F4A_L_1_W_1,
1103   PREFIX_VEX_0F4B_L_1_W_0,
1104   PREFIX_VEX_0F4B_L_1_W_1,
1105   PREFIX_VEX_0F6F,
1106   PREFIX_VEX_0F70,
1107   PREFIX_VEX_0F7E,
1108   PREFIX_VEX_0F7F,
1109   PREFIX_VEX_0F90_L_0_W_0,
1110   PREFIX_VEX_0F90_L_0_W_1,
1111   PREFIX_VEX_0F91_L_0_W_0,
1112   PREFIX_VEX_0F91_L_0_W_1,
1113   PREFIX_VEX_0F92_L_0_W_0,
1114   PREFIX_VEX_0F92_L_0_W_1,
1115   PREFIX_VEX_0F93_L_0_W_0,
1116   PREFIX_VEX_0F93_L_0_W_1,
1117   PREFIX_VEX_0F98_L_0_W_0,
1118   PREFIX_VEX_0F98_L_0_W_1,
1119   PREFIX_VEX_0F99_L_0_W_0,
1120   PREFIX_VEX_0F99_L_0_W_1,
1121   PREFIX_VEX_0F3849_X86_64_L_0_W_0_M_0,
1122   PREFIX_VEX_0F3849_X86_64_L_0_W_0_M_1,
1123   PREFIX_VEX_0F384B_X86_64_L_0_W_0,
1124   PREFIX_VEX_0F3850_W_0,
1125   PREFIX_VEX_0F3851_W_0,
1126   PREFIX_VEX_0F385C_X86_64_L_0_W_0,
1127   PREFIX_VEX_0F385E_X86_64_L_0_W_0,
1128   PREFIX_VEX_0F386C_X86_64_L_0_W_0,
1129   PREFIX_VEX_0F3872,
1130   PREFIX_VEX_0F38B0_W_0,
1131   PREFIX_VEX_0F38B1_W_0,
1132   PREFIX_VEX_0F38D2_W_0,
1133   PREFIX_VEX_0F38D3_W_0,
1134   PREFIX_VEX_0F38CB,
1135   PREFIX_VEX_0F38CC,
1136   PREFIX_VEX_0F38CD,
1137   PREFIX_VEX_0F38DA_W_0,
1138   PREFIX_VEX_0F38F2_L_0,
1139   PREFIX_VEX_0F38F3_L_0,
1140   PREFIX_VEX_0F38F5_L_0,
1141   PREFIX_VEX_0F38F6_L_0,
1142   PREFIX_VEX_0F38F7_L_0,
1143   PREFIX_VEX_0F3AF0_L_0,
1144   PREFIX_VEX_MAP7_F8_L_0_W_0_R_0_X86_64,
1145 
1146   PREFIX_EVEX_0F5B,
1147   PREFIX_EVEX_0F6F,
1148   PREFIX_EVEX_0F70,
1149   PREFIX_EVEX_0F78,
1150   PREFIX_EVEX_0F79,
1151   PREFIX_EVEX_0F7A,
1152   PREFIX_EVEX_0F7B,
1153   PREFIX_EVEX_0F7E,
1154   PREFIX_EVEX_0F7F,
1155   PREFIX_EVEX_0FC2,
1156   PREFIX_EVEX_0FE6,
1157   PREFIX_EVEX_0F3810,
1158   PREFIX_EVEX_0F3811,
1159   PREFIX_EVEX_0F3812,
1160   PREFIX_EVEX_0F3813,
1161   PREFIX_EVEX_0F3814,
1162   PREFIX_EVEX_0F3815,
1163   PREFIX_EVEX_0F3820,
1164   PREFIX_EVEX_0F3821,
1165   PREFIX_EVEX_0F3822,
1166   PREFIX_EVEX_0F3823,
1167   PREFIX_EVEX_0F3824,
1168   PREFIX_EVEX_0F3825,
1169   PREFIX_EVEX_0F3826,
1170   PREFIX_EVEX_0F3827,
1171   PREFIX_EVEX_0F3828,
1172   PREFIX_EVEX_0F3829,
1173   PREFIX_EVEX_0F382A,
1174   PREFIX_EVEX_0F3830,
1175   PREFIX_EVEX_0F3831,
1176   PREFIX_EVEX_0F3832,
1177   PREFIX_EVEX_0F3833,
1178   PREFIX_EVEX_0F3834,
1179   PREFIX_EVEX_0F3835,
1180   PREFIX_EVEX_0F3838,
1181   PREFIX_EVEX_0F3839,
1182   PREFIX_EVEX_0F383A,
1183   PREFIX_EVEX_0F3852,
1184   PREFIX_EVEX_0F3853,
1185   PREFIX_EVEX_0F3868,
1186   PREFIX_EVEX_0F3872,
1187   PREFIX_EVEX_0F389A,
1188   PREFIX_EVEX_0F389B,
1189   PREFIX_EVEX_0F38AA,
1190   PREFIX_EVEX_0F38AB,
1191 
1192   PREFIX_EVEX_0F3A08,
1193   PREFIX_EVEX_0F3A0A,
1194   PREFIX_EVEX_0F3A26,
1195   PREFIX_EVEX_0F3A27,
1196   PREFIX_EVEX_0F3A56,
1197   PREFIX_EVEX_0F3A57,
1198   PREFIX_EVEX_0F3A66,
1199   PREFIX_EVEX_0F3A67,
1200   PREFIX_EVEX_0F3AC2,
1201 
1202   PREFIX_EVEX_MAP4_40,
1203   PREFIX_EVEX_MAP4_41,
1204   PREFIX_EVEX_MAP4_42,
1205   PREFIX_EVEX_MAP4_43,
1206   PREFIX_EVEX_MAP4_44,
1207   PREFIX_EVEX_MAP4_45,
1208   PREFIX_EVEX_MAP4_46,
1209   PREFIX_EVEX_MAP4_47,
1210   PREFIX_EVEX_MAP4_48,
1211   PREFIX_EVEX_MAP4_49,
1212   PREFIX_EVEX_MAP4_4A,
1213   PREFIX_EVEX_MAP4_4B,
1214   PREFIX_EVEX_MAP4_4C,
1215   PREFIX_EVEX_MAP4_4D,
1216   PREFIX_EVEX_MAP4_4E,
1217   PREFIX_EVEX_MAP4_4F,
1218   PREFIX_EVEX_MAP4_F0,
1219   PREFIX_EVEX_MAP4_F1,
1220   PREFIX_EVEX_MAP4_F2,
1221   PREFIX_EVEX_MAP4_F8,
1222 
1223   PREFIX_EVEX_MAP5_10,
1224   PREFIX_EVEX_MAP5_11,
1225   PREFIX_EVEX_MAP5_1D,
1226   PREFIX_EVEX_MAP5_2A,
1227   PREFIX_EVEX_MAP5_2C,
1228   PREFIX_EVEX_MAP5_2D,
1229   PREFIX_EVEX_MAP5_2E,
1230   PREFIX_EVEX_MAP5_2F,
1231   PREFIX_EVEX_MAP5_51,
1232   PREFIX_EVEX_MAP5_58,
1233   PREFIX_EVEX_MAP5_59,
1234   PREFIX_EVEX_MAP5_5A,
1235   PREFIX_EVEX_MAP5_5B,
1236   PREFIX_EVEX_MAP5_5C,
1237   PREFIX_EVEX_MAP5_5D,
1238   PREFIX_EVEX_MAP5_5E,
1239   PREFIX_EVEX_MAP5_5F,
1240   PREFIX_EVEX_MAP5_78,
1241   PREFIX_EVEX_MAP5_79,
1242   PREFIX_EVEX_MAP5_7A,
1243   PREFIX_EVEX_MAP5_7B,
1244   PREFIX_EVEX_MAP5_7C,
1245   PREFIX_EVEX_MAP5_7D,
1246 
1247   PREFIX_EVEX_MAP6_13,
1248   PREFIX_EVEX_MAP6_56,
1249   PREFIX_EVEX_MAP6_57,
1250   PREFIX_EVEX_MAP6_D6,
1251   PREFIX_EVEX_MAP6_D7,
1252 };
1253 
1254 enum
1255 {
1256   X86_64_06 = 0,
1257   X86_64_07,
1258   X86_64_0E,
1259   X86_64_16,
1260   X86_64_17,
1261   X86_64_1E,
1262   X86_64_1F,
1263   X86_64_27,
1264   X86_64_2F,
1265   X86_64_37,
1266   X86_64_3F,
1267   X86_64_60,
1268   X86_64_61,
1269   X86_64_62,
1270   X86_64_63,
1271   X86_64_6D,
1272   X86_64_6F,
1273   X86_64_82,
1274   X86_64_9A,
1275   X86_64_C2,
1276   X86_64_C3,
1277   X86_64_C4,
1278   X86_64_C5,
1279   X86_64_CE,
1280   X86_64_D4,
1281   X86_64_D5,
1282   X86_64_E8,
1283   X86_64_E9,
1284   X86_64_EA,
1285   X86_64_0F00_REG_6,
1286   X86_64_0F01_REG_0,
1287   X86_64_0F01_REG_0_MOD_3_RM_6_P_1,
1288   X86_64_0F01_REG_0_MOD_3_RM_6_P_3,
1289   X86_64_0F01_REG_0_MOD_3_RM_7_P_0,
1290   X86_64_0F01_REG_1,
1291   X86_64_0F01_REG_1_RM_2_PREFIX_1,
1292   X86_64_0F01_REG_1_RM_2_PREFIX_3,
1293   X86_64_0F01_REG_1_RM_5_PREFIX_2,
1294   X86_64_0F01_REG_1_RM_6_PREFIX_2,
1295   X86_64_0F01_REG_1_RM_7_PREFIX_2,
1296   X86_64_0F01_REG_2,
1297   X86_64_0F01_REG_3,
1298   X86_64_0F01_REG_5_MOD_3_RM_4_PREFIX_1,
1299   X86_64_0F01_REG_5_MOD_3_RM_5_PREFIX_1,
1300   X86_64_0F01_REG_5_MOD_3_RM_6_PREFIX_1,
1301   X86_64_0F01_REG_5_MOD_3_RM_7_PREFIX_1,
1302   X86_64_0F01_REG_7_MOD_3_RM_5_PREFIX_1,
1303   X86_64_0F01_REG_7_MOD_3_RM_6_PREFIX_1,
1304   X86_64_0F01_REG_7_MOD_3_RM_6_PREFIX_3,
1305   X86_64_0F01_REG_7_MOD_3_RM_7_PREFIX_1,
1306   X86_64_0F18_REG_6_MOD_0,
1307   X86_64_0F18_REG_7_MOD_0,
1308   X86_64_0F24,
1309   X86_64_0F26,
1310   X86_64_0F38F8_M_1,
1311   X86_64_0FC7_REG_6_MOD_3_PREFIX_1,
1312 
1313   X86_64_VEX_0F3849,
1314   X86_64_VEX_0F384B,
1315   X86_64_VEX_0F385C,
1316   X86_64_VEX_0F385E,
1317   X86_64_VEX_0F386C,
1318   X86_64_VEX_0F38E0,
1319   X86_64_VEX_0F38E1,
1320   X86_64_VEX_0F38E2,
1321   X86_64_VEX_0F38E3,
1322   X86_64_VEX_0F38E4,
1323   X86_64_VEX_0F38E5,
1324   X86_64_VEX_0F38E6,
1325   X86_64_VEX_0F38E7,
1326   X86_64_VEX_0F38E8,
1327   X86_64_VEX_0F38E9,
1328   X86_64_VEX_0F38EA,
1329   X86_64_VEX_0F38EB,
1330   X86_64_VEX_0F38EC,
1331   X86_64_VEX_0F38ED,
1332   X86_64_VEX_0F38EE,
1333   X86_64_VEX_0F38EF,
1334 
1335   X86_64_VEX_MAP7_F8_L_0_W_0_R_0,
1336 };
1337 
1338 enum
1339 {
1340   THREE_BYTE_0F38 = 0,
1341   THREE_BYTE_0F3A
1342 };
1343 
1344 enum
1345 {
1346   XOP_08 = 0,
1347   XOP_09,
1348   XOP_0A
1349 };
1350 
1351 enum
1352 {
1353   VEX_0F = 0,
1354   VEX_0F38,
1355   VEX_0F3A,
1356   VEX_MAP7,
1357 };
1358 
1359 enum
1360 {
1361   EVEX_0F = 0,
1362   EVEX_0F38,
1363   EVEX_0F3A,
1364   EVEX_MAP4,
1365   EVEX_MAP5,
1366   EVEX_MAP6,
1367   EVEX_MAP7,
1368 };
1369 
1370 enum
1371 {
1372   VEX_LEN_0F12_P_0 = 0,
1373   VEX_LEN_0F12_P_2,
1374   VEX_LEN_0F13,
1375   VEX_LEN_0F16_P_0,
1376   VEX_LEN_0F16_P_2,
1377   VEX_LEN_0F17,
1378   VEX_LEN_0F41,
1379   VEX_LEN_0F42,
1380   VEX_LEN_0F44,
1381   VEX_LEN_0F45,
1382   VEX_LEN_0F46,
1383   VEX_LEN_0F47,
1384   VEX_LEN_0F4A,
1385   VEX_LEN_0F4B,
1386   VEX_LEN_0F6E,
1387   VEX_LEN_0F77,
1388   VEX_LEN_0F7E_P_1,
1389   VEX_LEN_0F7E_P_2,
1390   VEX_LEN_0F90,
1391   VEX_LEN_0F91,
1392   VEX_LEN_0F92,
1393   VEX_LEN_0F93,
1394   VEX_LEN_0F98,
1395   VEX_LEN_0F99,
1396   VEX_LEN_0FAE_R_2,
1397   VEX_LEN_0FAE_R_3,
1398   VEX_LEN_0FC4,
1399   VEX_LEN_0FD6,
1400   VEX_LEN_0F3816,
1401   VEX_LEN_0F3819,
1402   VEX_LEN_0F381A,
1403   VEX_LEN_0F3836,
1404   VEX_LEN_0F3841,
1405   VEX_LEN_0F3849_X86_64,
1406   VEX_LEN_0F384B_X86_64,
1407   VEX_LEN_0F385A,
1408   VEX_LEN_0F385C_X86_64,
1409   VEX_LEN_0F385E_X86_64,
1410   VEX_LEN_0F386C_X86_64,
1411   VEX_LEN_0F38CB_P_3_W_0,
1412   VEX_LEN_0F38CC_P_3_W_0,
1413   VEX_LEN_0F38CD_P_3_W_0,
1414   VEX_LEN_0F38DA_W_0_P_0,
1415   VEX_LEN_0F38DA_W_0_P_2,
1416   VEX_LEN_0F38DB,
1417   VEX_LEN_0F38F2,
1418   VEX_LEN_0F38F3,
1419   VEX_LEN_0F38F5,
1420   VEX_LEN_0F38F6,
1421   VEX_LEN_0F38F7,
1422   VEX_LEN_0F3A00,
1423   VEX_LEN_0F3A01,
1424   VEX_LEN_0F3A06,
1425   VEX_LEN_0F3A14,
1426   VEX_LEN_0F3A15,
1427   VEX_LEN_0F3A16,
1428   VEX_LEN_0F3A17,
1429   VEX_LEN_0F3A18,
1430   VEX_LEN_0F3A19,
1431   VEX_LEN_0F3A20,
1432   VEX_LEN_0F3A21,
1433   VEX_LEN_0F3A22,
1434   VEX_LEN_0F3A30,
1435   VEX_LEN_0F3A31,
1436   VEX_LEN_0F3A32,
1437   VEX_LEN_0F3A33,
1438   VEX_LEN_0F3A38,
1439   VEX_LEN_0F3A39,
1440   VEX_LEN_0F3A41,
1441   VEX_LEN_0F3A46,
1442   VEX_LEN_0F3A60,
1443   VEX_LEN_0F3A61,
1444   VEX_LEN_0F3A62,
1445   VEX_LEN_0F3A63,
1446   VEX_LEN_0F3ADE_W_0,
1447   VEX_LEN_0F3ADF,
1448   VEX_LEN_0F3AF0,
1449   VEX_LEN_MAP7_F8,
1450   VEX_LEN_XOP_08_85,
1451   VEX_LEN_XOP_08_86,
1452   VEX_LEN_XOP_08_87,
1453   VEX_LEN_XOP_08_8E,
1454   VEX_LEN_XOP_08_8F,
1455   VEX_LEN_XOP_08_95,
1456   VEX_LEN_XOP_08_96,
1457   VEX_LEN_XOP_08_97,
1458   VEX_LEN_XOP_08_9E,
1459   VEX_LEN_XOP_08_9F,
1460   VEX_LEN_XOP_08_A3,
1461   VEX_LEN_XOP_08_A6,
1462   VEX_LEN_XOP_08_B6,
1463   VEX_LEN_XOP_08_C0,
1464   VEX_LEN_XOP_08_C1,
1465   VEX_LEN_XOP_08_C2,
1466   VEX_LEN_XOP_08_C3,
1467   VEX_LEN_XOP_08_CC,
1468   VEX_LEN_XOP_08_CD,
1469   VEX_LEN_XOP_08_CE,
1470   VEX_LEN_XOP_08_CF,
1471   VEX_LEN_XOP_08_EC,
1472   VEX_LEN_XOP_08_ED,
1473   VEX_LEN_XOP_08_EE,
1474   VEX_LEN_XOP_08_EF,
1475   VEX_LEN_XOP_09_01,
1476   VEX_LEN_XOP_09_02,
1477   VEX_LEN_XOP_09_12,
1478   VEX_LEN_XOP_09_82_W_0,
1479   VEX_LEN_XOP_09_83_W_0,
1480   VEX_LEN_XOP_09_90,
1481   VEX_LEN_XOP_09_91,
1482   VEX_LEN_XOP_09_92,
1483   VEX_LEN_XOP_09_93,
1484   VEX_LEN_XOP_09_94,
1485   VEX_LEN_XOP_09_95,
1486   VEX_LEN_XOP_09_96,
1487   VEX_LEN_XOP_09_97,
1488   VEX_LEN_XOP_09_98,
1489   VEX_LEN_XOP_09_99,
1490   VEX_LEN_XOP_09_9A,
1491   VEX_LEN_XOP_09_9B,
1492   VEX_LEN_XOP_09_C1,
1493   VEX_LEN_XOP_09_C2,
1494   VEX_LEN_XOP_09_C3,
1495   VEX_LEN_XOP_09_C6,
1496   VEX_LEN_XOP_09_C7,
1497   VEX_LEN_XOP_09_CB,
1498   VEX_LEN_XOP_09_D1,
1499   VEX_LEN_XOP_09_D2,
1500   VEX_LEN_XOP_09_D3,
1501   VEX_LEN_XOP_09_D6,
1502   VEX_LEN_XOP_09_D7,
1503   VEX_LEN_XOP_09_DB,
1504   VEX_LEN_XOP_09_E1,
1505   VEX_LEN_XOP_09_E2,
1506   VEX_LEN_XOP_09_E3,
1507   VEX_LEN_XOP_0A_12,
1508 };
1509 
1510 enum
1511 {
1512   EVEX_LEN_0F3816 = 0,
1513   EVEX_LEN_0F3819,
1514   EVEX_LEN_0F381A,
1515   EVEX_LEN_0F381B,
1516   EVEX_LEN_0F3836,
1517   EVEX_LEN_0F385A,
1518   EVEX_LEN_0F385B,
1519   EVEX_LEN_0F38C6,
1520   EVEX_LEN_0F38C7,
1521   EVEX_LEN_0F3A00,
1522   EVEX_LEN_0F3A01,
1523   EVEX_LEN_0F3A18,
1524   EVEX_LEN_0F3A19,
1525   EVEX_LEN_0F3A1A,
1526   EVEX_LEN_0F3A1B,
1527   EVEX_LEN_0F3A23,
1528   EVEX_LEN_0F3A38,
1529   EVEX_LEN_0F3A39,
1530   EVEX_LEN_0F3A3A,
1531   EVEX_LEN_0F3A3B,
1532   EVEX_LEN_0F3A43
1533 };
1534 
1535 enum
1536 {
1537   VEX_W_0F41_L_1 = 0,
1538   VEX_W_0F42_L_1,
1539   VEX_W_0F44_L_0,
1540   VEX_W_0F45_L_1,
1541   VEX_W_0F46_L_1,
1542   VEX_W_0F47_L_1,
1543   VEX_W_0F4A_L_1,
1544   VEX_W_0F4B_L_1,
1545   VEX_W_0F90_L_0,
1546   VEX_W_0F91_L_0,
1547   VEX_W_0F92_L_0,
1548   VEX_W_0F93_L_0,
1549   VEX_W_0F98_L_0,
1550   VEX_W_0F99_L_0,
1551   VEX_W_0F380C,
1552   VEX_W_0F380D,
1553   VEX_W_0F380E,
1554   VEX_W_0F380F,
1555   VEX_W_0F3813,
1556   VEX_W_0F3816_L_1,
1557   VEX_W_0F3818,
1558   VEX_W_0F3819_L_1,
1559   VEX_W_0F381A_L_1,
1560   VEX_W_0F382C,
1561   VEX_W_0F382D,
1562   VEX_W_0F382E,
1563   VEX_W_0F382F,
1564   VEX_W_0F3836,
1565   VEX_W_0F3846,
1566   VEX_W_0F3849_X86_64_L_0,
1567   VEX_W_0F384B_X86_64_L_0,
1568   VEX_W_0F3850,
1569   VEX_W_0F3851,
1570   VEX_W_0F3852,
1571   VEX_W_0F3853,
1572   VEX_W_0F3858,
1573   VEX_W_0F3859,
1574   VEX_W_0F385A_L_0,
1575   VEX_W_0F385C_X86_64_L_0,
1576   VEX_W_0F385E_X86_64_L_0,
1577   VEX_W_0F386C_X86_64_L_0,
1578   VEX_W_0F3872_P_1,
1579   VEX_W_0F3878,
1580   VEX_W_0F3879,
1581   VEX_W_0F38B0,
1582   VEX_W_0F38B1,
1583   VEX_W_0F38B4,
1584   VEX_W_0F38B5,
1585   VEX_W_0F38CB_P_3,
1586   VEX_W_0F38CC_P_3,
1587   VEX_W_0F38CD_P_3,
1588   VEX_W_0F38CF,
1589   VEX_W_0F38D2,
1590   VEX_W_0F38D3,
1591   VEX_W_0F38DA,
1592   VEX_W_0F3A00_L_1,
1593   VEX_W_0F3A01_L_1,
1594   VEX_W_0F3A02,
1595   VEX_W_0F3A04,
1596   VEX_W_0F3A05,
1597   VEX_W_0F3A06_L_1,
1598   VEX_W_0F3A18_L_1,
1599   VEX_W_0F3A19_L_1,
1600   VEX_W_0F3A1D,
1601   VEX_W_0F3A38_L_1,
1602   VEX_W_0F3A39_L_1,
1603   VEX_W_0F3A46_L_1,
1604   VEX_W_0F3A4A,
1605   VEX_W_0F3A4B,
1606   VEX_W_0F3A4C,
1607   VEX_W_0F3ACE,
1608   VEX_W_0F3ACF,
1609   VEX_W_0F3ADE,
1610   VEX_W_MAP7_F8_L_0,
1611 
1612   VEX_W_XOP_08_85_L_0,
1613   VEX_W_XOP_08_86_L_0,
1614   VEX_W_XOP_08_87_L_0,
1615   VEX_W_XOP_08_8E_L_0,
1616   VEX_W_XOP_08_8F_L_0,
1617   VEX_W_XOP_08_95_L_0,
1618   VEX_W_XOP_08_96_L_0,
1619   VEX_W_XOP_08_97_L_0,
1620   VEX_W_XOP_08_9E_L_0,
1621   VEX_W_XOP_08_9F_L_0,
1622   VEX_W_XOP_08_A6_L_0,
1623   VEX_W_XOP_08_B6_L_0,
1624   VEX_W_XOP_08_C0_L_0,
1625   VEX_W_XOP_08_C1_L_0,
1626   VEX_W_XOP_08_C2_L_0,
1627   VEX_W_XOP_08_C3_L_0,
1628   VEX_W_XOP_08_CC_L_0,
1629   VEX_W_XOP_08_CD_L_0,
1630   VEX_W_XOP_08_CE_L_0,
1631   VEX_W_XOP_08_CF_L_0,
1632   VEX_W_XOP_08_EC_L_0,
1633   VEX_W_XOP_08_ED_L_0,
1634   VEX_W_XOP_08_EE_L_0,
1635   VEX_W_XOP_08_EF_L_0,
1636 
1637   VEX_W_XOP_09_80,
1638   VEX_W_XOP_09_81,
1639   VEX_W_XOP_09_82,
1640   VEX_W_XOP_09_83,
1641   VEX_W_XOP_09_C1_L_0,
1642   VEX_W_XOP_09_C2_L_0,
1643   VEX_W_XOP_09_C3_L_0,
1644   VEX_W_XOP_09_C6_L_0,
1645   VEX_W_XOP_09_C7_L_0,
1646   VEX_W_XOP_09_CB_L_0,
1647   VEX_W_XOP_09_D1_L_0,
1648   VEX_W_XOP_09_D2_L_0,
1649   VEX_W_XOP_09_D3_L_0,
1650   VEX_W_XOP_09_D6_L_0,
1651   VEX_W_XOP_09_D7_L_0,
1652   VEX_W_XOP_09_DB_L_0,
1653   VEX_W_XOP_09_E1_L_0,
1654   VEX_W_XOP_09_E2_L_0,
1655   VEX_W_XOP_09_E3_L_0,
1656 
1657   EVEX_W_0F5B_P_0,
1658   EVEX_W_0F62,
1659   EVEX_W_0F66,
1660   EVEX_W_0F6A,
1661   EVEX_W_0F6B,
1662   EVEX_W_0F6C,
1663   EVEX_W_0F6D,
1664   EVEX_W_0F6F_P_1,
1665   EVEX_W_0F6F_P_2,
1666   EVEX_W_0F6F_P_3,
1667   EVEX_W_0F70_P_2,
1668   EVEX_W_0F72_R_2,
1669   EVEX_W_0F72_R_6,
1670   EVEX_W_0F73_R_2,
1671   EVEX_W_0F73_R_6,
1672   EVEX_W_0F76,
1673   EVEX_W_0F78_P_0,
1674   EVEX_W_0F78_P_2,
1675   EVEX_W_0F79_P_0,
1676   EVEX_W_0F79_P_2,
1677   EVEX_W_0F7A_P_1,
1678   EVEX_W_0F7A_P_2,
1679   EVEX_W_0F7A_P_3,
1680   EVEX_W_0F7B_P_2,
1681   EVEX_W_0F7E_P_1,
1682   EVEX_W_0F7F_P_1,
1683   EVEX_W_0F7F_P_2,
1684   EVEX_W_0F7F_P_3,
1685   EVEX_W_0FD2,
1686   EVEX_W_0FD3,
1687   EVEX_W_0FD4,
1688   EVEX_W_0FD6,
1689   EVEX_W_0FE6_P_1,
1690   EVEX_W_0FE7,
1691   EVEX_W_0FF2,
1692   EVEX_W_0FF3,
1693   EVEX_W_0FF4,
1694   EVEX_W_0FFA,
1695   EVEX_W_0FFB,
1696   EVEX_W_0FFE,
1697 
1698   EVEX_W_0F3810_P_1,
1699   EVEX_W_0F3810_P_2,
1700   EVEX_W_0F3811_P_1,
1701   EVEX_W_0F3811_P_2,
1702   EVEX_W_0F3812_P_1,
1703   EVEX_W_0F3812_P_2,
1704   EVEX_W_0F3813_P_1,
1705   EVEX_W_0F3814_P_1,
1706   EVEX_W_0F3815_P_1,
1707   EVEX_W_0F3819_L_n,
1708   EVEX_W_0F381A_L_n,
1709   EVEX_W_0F381B_L_2,
1710   EVEX_W_0F381E,
1711   EVEX_W_0F381F,
1712   EVEX_W_0F3820_P_1,
1713   EVEX_W_0F3821_P_1,
1714   EVEX_W_0F3822_P_1,
1715   EVEX_W_0F3823_P_1,
1716   EVEX_W_0F3824_P_1,
1717   EVEX_W_0F3825_P_1,
1718   EVEX_W_0F3825_P_2,
1719   EVEX_W_0F3828_P_2,
1720   EVEX_W_0F3829_P_2,
1721   EVEX_W_0F382A_P_1,
1722   EVEX_W_0F382A_P_2,
1723   EVEX_W_0F382B,
1724   EVEX_W_0F3830_P_1,
1725   EVEX_W_0F3831_P_1,
1726   EVEX_W_0F3832_P_1,
1727   EVEX_W_0F3833_P_1,
1728   EVEX_W_0F3834_P_1,
1729   EVEX_W_0F3835_P_1,
1730   EVEX_W_0F3835_P_2,
1731   EVEX_W_0F3837,
1732   EVEX_W_0F383A_P_1,
1733   EVEX_W_0F3859,
1734   EVEX_W_0F385A_L_n,
1735   EVEX_W_0F385B_L_2,
1736   EVEX_W_0F3870,
1737   EVEX_W_0F3872_P_2,
1738   EVEX_W_0F387A,
1739   EVEX_W_0F387B,
1740   EVEX_W_0F3883,
1741 
1742   EVEX_W_0F3A18_L_n,
1743   EVEX_W_0F3A19_L_n,
1744   EVEX_W_0F3A1A_L_2,
1745   EVEX_W_0F3A1B_L_2,
1746   EVEX_W_0F3A21,
1747   EVEX_W_0F3A23_L_n,
1748   EVEX_W_0F3A38_L_n,
1749   EVEX_W_0F3A39_L_n,
1750   EVEX_W_0F3A3A_L_2,
1751   EVEX_W_0F3A3B_L_2,
1752   EVEX_W_0F3A42,
1753   EVEX_W_0F3A43_L_n,
1754   EVEX_W_0F3A70,
1755   EVEX_W_0F3A72,
1756 
1757   EVEX_W_MAP4_8F_R_0,
1758   EVEX_W_MAP4_F8_P1_M_1,
1759   EVEX_W_MAP4_F8_P3_M_1,
1760   EVEX_W_MAP4_FF_R_6,
1761 
1762   EVEX_W_MAP5_5B_P_0,
1763   EVEX_W_MAP5_7A_P_3,
1764 };
1765 
1766 typedef bool (*op_rtn) (instr_info *ins, int bytemode, int sizeflag);
1767 
1768 struct dis386 {
1769   const char *name;
1770   struct
1771     {
1772       op_rtn rtn;
1773       int bytemode;
1774     } op[MAX_OPERANDS];
1775   unsigned int prefix_requirement;
1776 };
1777 
1778 /* Upper case letters in the instruction names here are macros.
1779    'A' => print 'b' if no (suitable) register operand or suffix_always is true
1780    'B' => print 'b' if suffix_always is true
1781    'C' => print 's' or 'l' ('w' or 'd' in Intel mode) depending on operand
1782 	  size prefix
1783    'D' => print 'w' if no register operands or 'w', 'l' or 'q', if
1784 	  suffix_always is true
1785    'E' => print 'e' if 32-bit form of jcxz
1786    'F' => print 'w' or 'l' depending on address size prefix (loop insns)
1787    'G' => print 'w' or 'l' depending on operand size prefix (i/o insns)
1788    'H' => print ",pt" or ",pn" branch hint
1789    'I' unused.
1790    'J' unused.
1791    'K' => print 'd' or 'q' if rex prefix is present.
1792    'L' => print 'l' or 'q' if suffix_always is true
1793    'M' => print 'r' if intel_mnemonic is false.
1794    'N' => print 'n' if instruction has no wait "prefix"
1795    'O' => print 'd' or 'o' (or 'q' in Intel mode)
1796    'P' => behave as 'T' except with register operand outside of suffix_always
1797 	  mode
1798    'Q' => print 'w', 'l' or 'q' if no (suitable) register operand or
1799 	  suffix_always is true
1800    'R' => print 'w', 'l' or 'q' ('d' for 'l' and 'e' in Intel mode)
1801    'S' => print 'w', 'l' or 'q' if suffix_always is true
1802    'T' => print 'w', 'l'/'d', or 'q' if instruction has an operand size
1803 	  prefix or if suffix_always is true.
1804    'U' unused.
1805    'V' => print 'v' for VEX/EVEX and nothing for legacy encodings.
1806    'W' => print 'b', 'w' or 'l' ('d' in Intel mode)
1807    'X' => print 's', 'd' depending on data16 prefix (for XMM)
1808    'Y' => no output, mark EVEX.aaa != 0 as bad.
1809    'Z' => print 'q' in 64bit mode and 'l' otherwise, if suffix_always is true.
1810    '!' => change condition from true to false or from false to true.
1811    '%' => add 1 upper case letter to the macro.
1812    '^' => print 'w', 'l', or 'q' (Intel64 ISA only) depending on operand size
1813 	  prefix or suffix_always is true (lcall/ljmp).
1814    '@' => in 64bit mode for Intel64 ISA or if instruction
1815 	  has no operand sizing prefix, print 'q' if suffix_always is true or
1816 	  nothing otherwise; behave as 'P' in all other cases
1817 
1818    2 upper case letter macros:
1819    "XY" => print 'x' or 'y' if suffix_always is true or no register
1820 	   operands and no broadcast.
1821    "XZ" => print 'x', 'y', or 'z' if suffix_always is true or no
1822 	   register operands and no broadcast.
1823    "XW" => print 's', 'd' depending on the VEX.W bit (for FMA)
1824    "XD" => print 'd' if !EVEX or EVEX.W=1, EVEX.W=0 is not a valid encoding
1825    "XH" => print 'h' if EVEX.W=0, EVEX.W=1 is not a valid encoding (for FP16)
1826    "XS" => print 's' if !EVEX or EVEX.W=0, EVEX.W=1 is not a valid encoding
1827    "XV" => print "{vex} " pseudo prefix
1828    "XE" => print "{evex} " pseudo prefix if no EVEX-specific functionality is
1829 	   is used by an EVEX-encoded (AVX512VL) instruction.
1830    "ME" => print "{evex} " pseudo prefix for ins->modrm.mod != 3,if no
1831 	   EVEX-specific functionality is used by an EVEX-encoded (AVX512VL)
1832 	   instruction.
1833    "NF" => print "{nf} " pseudo prefix when EVEX.NF = 1 and print "{evex} "
1834 	   pseudo prefix when instructions without NF, EGPR and VVVV,
1835    "ZU" => print 'zu' if EVEX.ZU=1.
1836    "YK" keep unused, to avoid ambiguity with the combined use of Y and K.
1837    "YX" keep unused, to avoid ambiguity with the combined use of Y and X.
1838    "LQ" => print 'l' ('d' in Intel mode) or 'q' for memory operand, cond
1839 	   being false, or no operand at all in 64bit mode, or if suffix_always
1840 	   is true.
1841    "LB" => print "abs" in 64bit mode and behave as 'B' otherwise
1842    "LS" => print "abs" in 64bit mode and behave as 'S' otherwise
1843    "LV" => print "abs" for 64bit operand and behave as 'S' otherwise
1844    "DQ" => print 'd' or 'q' depending on the VEX.W bit
1845    "BW" => print 'b' or 'w' depending on the VEX.W bit
1846    "LP" => print 'w' or 'l' ('d' in Intel mode) if instruction has
1847 	   an operand size prefix, or suffix_always is true.  print
1848 	   'q' if rex prefix is present.
1849 
1850    Many of the above letters print nothing in Intel mode.  See "putop"
1851    for the details.
1852 
1853    Braces '{' and '}', and vertical bars '|', indicate alternative
1854    mnemonic strings for AT&T and Intel.  */
1855 
1856 static const struct dis386 dis386[] = {
1857   /* 00 */
1858   { "addB",		{ Ebh1, Gb }, 0 },
1859   { "addS",		{ Evh1, Gv }, 0 },
1860   { "addB",		{ Gb, EbS }, 0 },
1861   { "addS",		{ Gv, EvS }, 0 },
1862   { "addB",		{ AL, Ib }, 0 },
1863   { "addS",		{ eAX, Iv }, 0 },
1864   { X86_64_TABLE (X86_64_06) },
1865   { X86_64_TABLE (X86_64_07) },
1866   /* 08 */
1867   { "orB",		{ Ebh1, Gb }, 0 },
1868   { "orS",		{ Evh1, Gv }, 0 },
1869   { "orB",		{ Gb, EbS }, 0 },
1870   { "orS",		{ Gv, EvS }, 0 },
1871   { "orB",		{ AL, Ib }, 0 },
1872   { "orS",		{ eAX, Iv }, 0 },
1873   { X86_64_TABLE (X86_64_0E) },
1874   { Bad_Opcode },	/* 0x0f extended opcode escape */
1875   /* 10 */
1876   { "adcB",		{ Ebh1, Gb }, 0 },
1877   { "adcS",		{ Evh1, Gv }, 0 },
1878   { "adcB",		{ Gb, EbS }, 0 },
1879   { "adcS",		{ Gv, EvS }, 0 },
1880   { "adcB",		{ AL, Ib }, 0 },
1881   { "adcS",		{ eAX, Iv }, 0 },
1882   { X86_64_TABLE (X86_64_16) },
1883   { X86_64_TABLE (X86_64_17) },
1884   /* 18 */
1885   { "sbbB",		{ Ebh1, Gb }, 0 },
1886   { "sbbS",		{ Evh1, Gv }, 0 },
1887   { "sbbB",		{ Gb, EbS }, 0 },
1888   { "sbbS",		{ Gv, EvS }, 0 },
1889   { "sbbB",		{ AL, Ib }, 0 },
1890   { "sbbS",		{ eAX, Iv }, 0 },
1891   { X86_64_TABLE (X86_64_1E) },
1892   { X86_64_TABLE (X86_64_1F) },
1893   /* 20 */
1894   { "andB",		{ Ebh1, Gb }, 0 },
1895   { "andS",		{ Evh1, Gv }, 0 },
1896   { "andB",		{ Gb, EbS }, 0 },
1897   { "andS",		{ Gv, EvS }, 0 },
1898   { "andB",		{ AL, Ib }, 0 },
1899   { "andS",		{ eAX, Iv }, 0 },
1900   { Bad_Opcode },	/* SEG ES prefix */
1901   { X86_64_TABLE (X86_64_27) },
1902   /* 28 */
1903   { "subB",		{ Ebh1, Gb }, 0 },
1904   { "subS",		{ Evh1, Gv }, 0 },
1905   { "subB",		{ Gb, EbS }, 0 },
1906   { "subS",		{ Gv, EvS }, 0 },
1907   { "subB",		{ AL, Ib }, 0 },
1908   { "subS",		{ eAX, Iv }, 0 },
1909   { Bad_Opcode },	/* SEG CS prefix */
1910   { X86_64_TABLE (X86_64_2F) },
1911   /* 30 */
1912   { "xorB",		{ Ebh1, Gb }, 0 },
1913   { "xorS",		{ Evh1, Gv }, 0 },
1914   { "xorB",		{ Gb, EbS }, 0 },
1915   { "xorS",		{ Gv, EvS }, 0 },
1916   { "xorB",		{ AL, Ib }, 0 },
1917   { "xorS",		{ eAX, Iv }, 0 },
1918   { Bad_Opcode },	/* SEG SS prefix */
1919   { X86_64_TABLE (X86_64_37) },
1920   /* 38 */
1921   { "cmpB",		{ Eb, Gb }, 0 },
1922   { "cmpS",		{ Ev, Gv }, 0 },
1923   { "cmpB",		{ Gb, EbS }, 0 },
1924   { "cmpS",		{ Gv, EvS }, 0 },
1925   { "cmpB",		{ AL, Ib }, 0 },
1926   { "cmpS",		{ eAX, Iv }, 0 },
1927   { Bad_Opcode },	/* SEG DS prefix */
1928   { X86_64_TABLE (X86_64_3F) },
1929   /* 40 */
1930   { "inc{S|}",		{ RMeAX }, 0 },
1931   { "inc{S|}",		{ RMeCX }, 0 },
1932   { "inc{S|}",		{ RMeDX }, 0 },
1933   { "inc{S|}",		{ RMeBX }, 0 },
1934   { "inc{S|}",		{ RMeSP }, 0 },
1935   { "inc{S|}",		{ RMeBP }, 0 },
1936   { "inc{S|}",		{ RMeSI }, 0 },
1937   { "inc{S|}",		{ RMeDI }, 0 },
1938   /* 48 */
1939   { "dec{S|}",		{ RMeAX }, 0 },
1940   { "dec{S|}",		{ RMeCX }, 0 },
1941   { "dec{S|}",		{ RMeDX }, 0 },
1942   { "dec{S|}",		{ RMeBX }, 0 },
1943   { "dec{S|}",		{ RMeSP }, 0 },
1944   { "dec{S|}",		{ RMeBP }, 0 },
1945   { "dec{S|}",		{ RMeSI }, 0 },
1946   { "dec{S|}",		{ RMeDI }, 0 },
1947   /* 50 */
1948   { "push!P",		{ RMrAX }, 0 },
1949   { "push!P",		{ RMrCX }, 0 },
1950   { "push!P",		{ RMrDX }, 0 },
1951   { "push!P",		{ RMrBX }, 0 },
1952   { "push!P",		{ RMrSP }, 0 },
1953   { "push!P",		{ RMrBP }, 0 },
1954   { "push!P",		{ RMrSI }, 0 },
1955   { "push!P",		{ RMrDI }, 0 },
1956   /* 58 */
1957   { "pop!P",		{ RMrAX }, 0 },
1958   { "pop!P",		{ RMrCX }, 0 },
1959   { "pop!P",		{ RMrDX }, 0 },
1960   { "pop!P",		{ RMrBX }, 0 },
1961   { "pop!P",		{ RMrSP }, 0 },
1962   { "pop!P",		{ RMrBP }, 0 },
1963   { "pop!P",		{ RMrSI }, 0 },
1964   { "pop!P",		{ RMrDI }, 0 },
1965   /* 60 */
1966   { X86_64_TABLE (X86_64_60) },
1967   { X86_64_TABLE (X86_64_61) },
1968   { X86_64_TABLE (X86_64_62) },
1969   { X86_64_TABLE (X86_64_63) },
1970   { Bad_Opcode },	/* seg fs */
1971   { Bad_Opcode },	/* seg gs */
1972   { Bad_Opcode },	/* op size prefix */
1973   { Bad_Opcode },	/* adr size prefix */
1974   /* 68 */
1975   { "pushP",		{ sIv }, 0 },
1976   { "imulS",		{ Gv, Ev, Iv }, 0 },
1977   { "pushP",		{ sIbT }, 0 },
1978   { "imulS",		{ Gv, Ev, sIb }, 0 },
1979   { "ins{b|}",		{ Ybr, indirDX }, 0 },
1980   { X86_64_TABLE (X86_64_6D) },
1981   { "outs{b|}",		{ indirDXr, Xb }, 0 },
1982   { X86_64_TABLE (X86_64_6F) },
1983   /* 70 */
1984   { "joH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1985   { "jnoH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1986   { "jbH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1987   { "jaeH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1988   { "jeH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1989   { "jneH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1990   { "jbeH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1991   { "jaH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1992   /* 78 */
1993   { "jsH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1994   { "jnsH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1995   { "jpH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1996   { "jnpH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1997   { "jlH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1998   { "jgeH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
1999   { "jleH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2000   { "jgH",		{ Jb, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2001   /* 80 */
2002   { REG_TABLE (REG_80) },
2003   { REG_TABLE (REG_81) },
2004   { X86_64_TABLE (X86_64_82) },
2005   { REG_TABLE (REG_83) },
2006   { "testB",		{ Eb, Gb }, 0 },
2007   { "testS",		{ Ev, Gv }, 0 },
2008   { "xchgB",		{ Ebh2, Gb }, 0 },
2009   { "xchgS",		{ Evh2, Gv }, 0 },
2010   /* 88 */
2011   { "movB",		{ Ebh3, Gb }, 0 },
2012   { "movS",		{ Evh3, Gv }, 0 },
2013   { "movB",		{ Gb, EbS }, 0 },
2014   { "movS",		{ Gv, EvS }, 0 },
2015   { "movD",		{ Sv, Sw }, 0 },
2016   { "leaS",		{ Gv, M }, 0 },
2017   { "movD",		{ Sw, Sv }, 0 },
2018   { REG_TABLE (REG_8F) },
2019   /* 90 */
2020   { PREFIX_TABLE (PREFIX_90) },
2021   { "xchgS",		{ RMeCX, eAX }, 0 },
2022   { "xchgS",		{ RMeDX, eAX }, 0 },
2023   { "xchgS",		{ RMeBX, eAX }, 0 },
2024   { "xchgS",		{ RMeSP, eAX }, 0 },
2025   { "xchgS",		{ RMeBP, eAX }, 0 },
2026   { "xchgS",		{ RMeSI, eAX }, 0 },
2027   { "xchgS",		{ RMeDI, eAX }, 0 },
2028   /* 98 */
2029   { "cW{t|}R",		{ XX }, 0 },
2030   { "cR{t|}O",		{ XX }, 0 },
2031   { X86_64_TABLE (X86_64_9A) },
2032   { Bad_Opcode },	/* fwait */
2033   { "pushfP",		{ XX }, 0 },
2034   { "popfP",		{ XX }, 0 },
2035   { "sahf",		{ XX }, 0 },
2036   { "lahf",		{ XX }, 0 },
2037   /* a0 */
2038   { "mov%LB",		{ AL, Ob }, PREFIX_REX2_ILLEGAL },
2039   { "mov%LS",		{ { JMPABS_Fixup, eAX_reg }, { JMPABS_Fixup, v_mode } }, PREFIX_REX2_ILLEGAL },
2040   { "mov%LB",		{ Ob, AL }, PREFIX_REX2_ILLEGAL },
2041   { "mov%LS",		{ Ov, eAX }, PREFIX_REX2_ILLEGAL },
2042   { "movs{b|}",		{ Ybr, Xb }, PREFIX_REX2_ILLEGAL },
2043   { "movs{R|}",		{ Yvr, Xv }, PREFIX_REX2_ILLEGAL },
2044   { "cmps{b|}",		{ Xb, Yb }, PREFIX_REX2_ILLEGAL },
2045   { "cmps{R|}",		{ Xv, Yv }, PREFIX_REX2_ILLEGAL },
2046   /* a8 */
2047   { "testB",		{ AL, Ib }, PREFIX_REX2_ILLEGAL },
2048   { "testS",		{ eAX, Iv }, PREFIX_REX2_ILLEGAL },
2049   { "stosB",		{ Ybr, AL }, PREFIX_REX2_ILLEGAL },
2050   { "stosS",		{ Yvr, eAX }, PREFIX_REX2_ILLEGAL },
2051   { "lodsB",		{ ALr, Xb }, PREFIX_REX2_ILLEGAL },
2052   { "lodsS",		{ eAXr, Xv }, PREFIX_REX2_ILLEGAL },
2053   { "scasB",		{ AL, Yb }, PREFIX_REX2_ILLEGAL },
2054   { "scasS",		{ eAX, Yv }, PREFIX_REX2_ILLEGAL },
2055   /* b0 */
2056   { "movB",		{ RMAL, Ib }, 0 },
2057   { "movB",		{ RMCL, Ib }, 0 },
2058   { "movB",		{ RMDL, Ib }, 0 },
2059   { "movB",		{ RMBL, Ib }, 0 },
2060   { "movB",		{ RMAH, Ib }, 0 },
2061   { "movB",		{ RMCH, Ib }, 0 },
2062   { "movB",		{ RMDH, Ib }, 0 },
2063   { "movB",		{ RMBH, Ib }, 0 },
2064   /* b8 */
2065   { "mov%LV",		{ RMeAX, Iv64 }, 0 },
2066   { "mov%LV",		{ RMeCX, Iv64 }, 0 },
2067   { "mov%LV",		{ RMeDX, Iv64 }, 0 },
2068   { "mov%LV",		{ RMeBX, Iv64 }, 0 },
2069   { "mov%LV",		{ RMeSP, Iv64 }, 0 },
2070   { "mov%LV",		{ RMeBP, Iv64 }, 0 },
2071   { "mov%LV",		{ RMeSI, Iv64 }, 0 },
2072   { "mov%LV",		{ RMeDI, Iv64 }, 0 },
2073   /* c0 */
2074   { REG_TABLE (REG_C0) },
2075   { REG_TABLE (REG_C1) },
2076   { X86_64_TABLE (X86_64_C2) },
2077   { X86_64_TABLE (X86_64_C3) },
2078   { X86_64_TABLE (X86_64_C4) },
2079   { X86_64_TABLE (X86_64_C5) },
2080   { REG_TABLE (REG_C6) },
2081   { REG_TABLE (REG_C7) },
2082   /* c8 */
2083   { "enterP",		{ Iw, Ib }, 0 },
2084   { "leaveP",		{ XX }, 0 },
2085   { "{l|}ret{|f}%LP",	{ Iw }, 0 },
2086   { "{l|}ret{|f}%LP",	{ XX }, 0 },
2087   { "int3",		{ XX }, 0 },
2088   { "int",		{ Ib }, 0 },
2089   { X86_64_TABLE (X86_64_CE) },
2090   { "iret%LP",		{ XX }, 0 },
2091   /* d0 */
2092   { REG_TABLE (REG_D0) },
2093   { REG_TABLE (REG_D1) },
2094   { REG_TABLE (REG_D2) },
2095   { REG_TABLE (REG_D3) },
2096   { X86_64_TABLE (X86_64_D4) },
2097   { X86_64_TABLE (X86_64_D5) },
2098   { Bad_Opcode },
2099   { "xlat",		{ DSBX }, 0 },
2100   /* d8 */
2101   { FLOAT },
2102   { FLOAT },
2103   { FLOAT },
2104   { FLOAT },
2105   { FLOAT },
2106   { FLOAT },
2107   { FLOAT },
2108   { FLOAT },
2109   /* e0 */
2110   { "loopneFH",		{ Jb, XX, loop_jcxz_flag }, PREFIX_REX2_ILLEGAL },
2111   { "loopeFH",		{ Jb, XX, loop_jcxz_flag }, PREFIX_REX2_ILLEGAL },
2112   { "loopFH",		{ Jb, XX, loop_jcxz_flag }, PREFIX_REX2_ILLEGAL },
2113   { "jEcxzH",		{ Jb, XX, loop_jcxz_flag }, PREFIX_REX2_ILLEGAL },
2114   { "inB",		{ AL, Ib }, PREFIX_REX2_ILLEGAL },
2115   { "inG",		{ zAX, Ib }, PREFIX_REX2_ILLEGAL },
2116   { "outB",		{ Ib, AL }, PREFIX_REX2_ILLEGAL },
2117   { "outG",		{ Ib, zAX }, PREFIX_REX2_ILLEGAL },
2118   /* e8 */
2119   { X86_64_TABLE (X86_64_E8) },
2120   { X86_64_TABLE (X86_64_E9) },
2121   { X86_64_TABLE (X86_64_EA) },
2122   { "jmp",		{ Jb, BND }, PREFIX_REX2_ILLEGAL },
2123   { "inB",		{ AL, indirDX }, PREFIX_REX2_ILLEGAL },
2124   { "inG",		{ zAX, indirDX }, PREFIX_REX2_ILLEGAL },
2125   { "outB",		{ indirDX, AL }, PREFIX_REX2_ILLEGAL },
2126   { "outG",		{ indirDX, zAX }, PREFIX_REX2_ILLEGAL },
2127   /* f0 */
2128   { Bad_Opcode },	/* lock prefix */
2129   { "int1",		{ XX }, 0 },
2130   { Bad_Opcode },	/* repne */
2131   { Bad_Opcode },	/* repz */
2132   { "hlt",		{ XX }, 0 },
2133   { "cmc",		{ XX }, 0 },
2134   { REG_TABLE (REG_F6) },
2135   { REG_TABLE (REG_F7) },
2136   /* f8 */
2137   { "clc",		{ XX }, 0 },
2138   { "stc",		{ XX }, 0 },
2139   { "cli",		{ XX }, 0 },
2140   { "sti",		{ XX }, 0 },
2141   { "cld",		{ XX }, 0 },
2142   { "std",		{ XX }, 0 },
2143   { REG_TABLE (REG_FE) },
2144   { REG_TABLE (REG_FF) },
2145 };
2146 
2147 static const struct dis386 dis386_twobyte[] = {
2148   /* 00 */
2149   { REG_TABLE (REG_0F00 ) },
2150   { REG_TABLE (REG_0F01 ) },
2151   { "larS",		{ Gv, Sv }, 0 },
2152   { "lslS",		{ Gv, Sv }, 0 },
2153   { Bad_Opcode },
2154   { "syscall",		{ XX }, 0 },
2155   { "clts",		{ XX }, 0 },
2156   { "sysret%LQ",		{ XX }, 0 },
2157   /* 08 */
2158   { "invd",		{ XX }, 0 },
2159   { PREFIX_TABLE (PREFIX_0F09) },
2160   { Bad_Opcode },
2161   { "ud2",		{ XX }, 0 },
2162   { Bad_Opcode },
2163   { REG_TABLE (REG_0F0D) },
2164   { "femms",		{ XX }, 0 },
2165   { "",			{ MX, EM, OPSUF }, 0 }, /* See OP_3DNowSuffix.  */
2166   /* 10 */
2167   { PREFIX_TABLE (PREFIX_0F10) },
2168   { PREFIX_TABLE (PREFIX_0F11) },
2169   { PREFIX_TABLE (PREFIX_0F12) },
2170   { "movlpX",		{ Mq, XM }, PREFIX_OPCODE },
2171   { "unpcklpX",		{ XM, EXx }, PREFIX_OPCODE },
2172   { "unpckhpX",		{ XM, EXx }, PREFIX_OPCODE },
2173   { PREFIX_TABLE (PREFIX_0F16) },
2174   { "movhpX",		{ Mq, XM }, PREFIX_OPCODE },
2175   /* 18 */
2176   { REG_TABLE (REG_0F18) },
2177   { "nopQ",		{ Ev }, 0 },
2178   { PREFIX_TABLE (PREFIX_0F1A) },
2179   { PREFIX_TABLE (PREFIX_0F1B) },
2180   { PREFIX_TABLE (PREFIX_0F1C) },
2181   { "nopQ",		{ Ev }, 0 },
2182   { PREFIX_TABLE (PREFIX_0F1E) },
2183   { "nopQ",		{ Ev }, 0 },
2184   /* 20 */
2185   { "movZ",		{ Em, Cm }, 0 },
2186   { "movZ",		{ Em, Dm }, 0 },
2187   { "movZ",		{ Cm, Em }, 0 },
2188   { "movZ",		{ Dm, Em }, 0 },
2189   { X86_64_TABLE (X86_64_0F24) },
2190   { Bad_Opcode },
2191   { X86_64_TABLE (X86_64_0F26) },
2192   { Bad_Opcode },
2193   /* 28 */
2194   { "movapX",		{ XM, EXx }, PREFIX_OPCODE },
2195   { "movapX",		{ EXxS, XM }, PREFIX_OPCODE },
2196   { PREFIX_TABLE (PREFIX_0F2A) },
2197   { PREFIX_TABLE (PREFIX_0F2B) },
2198   { PREFIX_TABLE (PREFIX_0F2C) },
2199   { PREFIX_TABLE (PREFIX_0F2D) },
2200   { PREFIX_TABLE (PREFIX_0F2E) },
2201   { PREFIX_TABLE (PREFIX_0F2F) },
2202   /* 30 */
2203   { "wrmsr",		{ XX }, PREFIX_REX2_ILLEGAL },
2204   { "rdtsc",		{ XX }, PREFIX_REX2_ILLEGAL },
2205   { "rdmsr",		{ XX }, PREFIX_REX2_ILLEGAL },
2206   { "rdpmc",		{ XX }, PREFIX_REX2_ILLEGAL },
2207   { "sysenter",		{ SEP }, PREFIX_REX2_ILLEGAL },
2208   { "sysexit%LQ",	{ SEP }, PREFIX_REX2_ILLEGAL },
2209   { Bad_Opcode },
2210   { "getsec",		{ XX }, 0 },
2211   /* 38 */
2212   { THREE_BYTE_TABLE (THREE_BYTE_0F38) },
2213   { Bad_Opcode },
2214   { THREE_BYTE_TABLE (THREE_BYTE_0F3A) },
2215   { Bad_Opcode },
2216   { Bad_Opcode },
2217   { Bad_Opcode },
2218   { Bad_Opcode },
2219   { Bad_Opcode },
2220   /* 40 */
2221   { "cmovoS",		{ Gv, Ev }, 0 },
2222   { "cmovnoS",		{ Gv, Ev }, 0 },
2223   { "cmovbS",		{ Gv, Ev }, 0 },
2224   { "cmovaeS",		{ Gv, Ev }, 0 },
2225   { "cmoveS",		{ Gv, Ev }, 0 },
2226   { "cmovneS",		{ Gv, Ev }, 0 },
2227   { "cmovbeS",		{ Gv, Ev }, 0 },
2228   { "cmovaS",		{ Gv, Ev }, 0 },
2229   /* 48 */
2230   { "cmovsS",		{ Gv, Ev }, 0 },
2231   { "cmovnsS",		{ Gv, Ev }, 0 },
2232   { "cmovpS",		{ Gv, Ev }, 0 },
2233   { "cmovnpS",		{ Gv, Ev }, 0 },
2234   { "cmovlS",		{ Gv, Ev }, 0 },
2235   { "cmovgeS",		{ Gv, Ev }, 0 },
2236   { "cmovleS",		{ Gv, Ev }, 0 },
2237   { "cmovgS",		{ Gv, Ev }, 0 },
2238   /* 50 */
2239   { "movmskpX",		{ Gdq, Ux }, PREFIX_OPCODE },
2240   { PREFIX_TABLE (PREFIX_0F51) },
2241   { PREFIX_TABLE (PREFIX_0F52) },
2242   { PREFIX_TABLE (PREFIX_0F53) },
2243   { "andpX",		{ XM, EXx }, PREFIX_OPCODE },
2244   { "andnpX",		{ XM, EXx }, PREFIX_OPCODE },
2245   { "orpX",		{ XM, EXx }, PREFIX_OPCODE },
2246   { "xorpX",		{ XM, EXx }, PREFIX_OPCODE },
2247   /* 58 */
2248   { PREFIX_TABLE (PREFIX_0F58) },
2249   { PREFIX_TABLE (PREFIX_0F59) },
2250   { PREFIX_TABLE (PREFIX_0F5A) },
2251   { PREFIX_TABLE (PREFIX_0F5B) },
2252   { PREFIX_TABLE (PREFIX_0F5C) },
2253   { PREFIX_TABLE (PREFIX_0F5D) },
2254   { PREFIX_TABLE (PREFIX_0F5E) },
2255   { PREFIX_TABLE (PREFIX_0F5F) },
2256   /* 60 */
2257   { PREFIX_TABLE (PREFIX_0F60) },
2258   { PREFIX_TABLE (PREFIX_0F61) },
2259   { PREFIX_TABLE (PREFIX_0F62) },
2260   { "packsswb",		{ MX, EM }, PREFIX_OPCODE },
2261   { "pcmpgtb",		{ MX, EM }, PREFIX_OPCODE },
2262   { "pcmpgtw",		{ MX, EM }, PREFIX_OPCODE },
2263   { "pcmpgtd",		{ MX, EM }, PREFIX_OPCODE },
2264   { "packuswb",		{ MX, EM }, PREFIX_OPCODE },
2265   /* 68 */
2266   { "punpckhbw",	{ MX, EM }, PREFIX_OPCODE },
2267   { "punpckhwd",	{ MX, EM }, PREFIX_OPCODE },
2268   { "punpckhdq",	{ MX, EM }, PREFIX_OPCODE },
2269   { "packssdw",		{ MX, EM }, PREFIX_OPCODE },
2270   { "punpcklqdq", { XM, EXx }, PREFIX_DATA },
2271   { "punpckhqdq", { XM, EXx }, PREFIX_DATA },
2272   { "movK",		{ MX, Edq }, PREFIX_OPCODE },
2273   { PREFIX_TABLE (PREFIX_0F6F) },
2274   /* 70 */
2275   { PREFIX_TABLE (PREFIX_0F70) },
2276   { REG_TABLE (REG_0F71) },
2277   { REG_TABLE (REG_0F72) },
2278   { REG_TABLE (REG_0F73) },
2279   { "pcmpeqb",		{ MX, EM }, PREFIX_OPCODE },
2280   { "pcmpeqw",		{ MX, EM }, PREFIX_OPCODE },
2281   { "pcmpeqd",		{ MX, EM }, PREFIX_OPCODE },
2282   { "emms",		{ XX }, PREFIX_OPCODE },
2283   /* 78 */
2284   { PREFIX_TABLE (PREFIX_0F78) },
2285   { PREFIX_TABLE (PREFIX_0F79) },
2286   { Bad_Opcode },
2287   { Bad_Opcode },
2288   { PREFIX_TABLE (PREFIX_0F7C) },
2289   { PREFIX_TABLE (PREFIX_0F7D) },
2290   { PREFIX_TABLE (PREFIX_0F7E) },
2291   { PREFIX_TABLE (PREFIX_0F7F) },
2292   /* 80 */
2293   { "joH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2294   { "jnoH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2295   { "jbH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2296   { "jaeH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2297   { "jeH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2298   { "jneH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2299   { "jbeH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2300   { "jaH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2301   /* 88 */
2302   { "jsH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2303   { "jnsH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2304   { "jpH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2305   { "jnpH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2306   { "jlH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2307   { "jgeH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2308   { "jleH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2309   { "jgH",		{ Jv, BND, cond_jump_flag }, PREFIX_REX2_ILLEGAL },
2310   /* 90 */
2311   { "seto",		{ Eb }, 0 },
2312   { "setno",		{ Eb }, 0 },
2313   { "setb",		{ Eb }, 0 },
2314   { "setae",		{ Eb }, 0 },
2315   { "sete",		{ Eb }, 0 },
2316   { "setne",		{ Eb }, 0 },
2317   { "setbe",		{ Eb }, 0 },
2318   { "seta",		{ Eb }, 0 },
2319   /* 98 */
2320   { "sets",		{ Eb }, 0 },
2321   { "setns",		{ Eb }, 0 },
2322   { "setp",		{ Eb }, 0 },
2323   { "setnp",		{ Eb }, 0 },
2324   { "setl",		{ Eb }, 0 },
2325   { "setge",		{ Eb }, 0 },
2326   { "setle",		{ Eb }, 0 },
2327   { "setg",		{ Eb }, 0 },
2328   /* a0 */
2329   { "pushP",		{ fs }, 0 },
2330   { "popP",		{ fs }, 0 },
2331   { "cpuid",		{ XX }, 0 },
2332   { "btS",		{ Ev, Gv }, 0 },
2333   { "shldS",		{ Ev, Gv, Ib }, 0 },
2334   { "shldS",		{ Ev, Gv, CL }, 0 },
2335   { REG_TABLE (REG_0FA6) },
2336   { REG_TABLE (REG_0FA7) },
2337   /* a8 */
2338   { "pushP",		{ gs }, 0 },
2339   { "popP",		{ gs }, 0 },
2340   { "rsm",		{ XX }, 0 },
2341   { "btsS",		{ Evh1, Gv }, 0 },
2342   { "shrdS",		{ Ev, Gv, Ib }, 0 },
2343   { "shrdS",		{ Ev, Gv, CL }, 0 },
2344   { REG_TABLE (REG_0FAE) },
2345   { "imulS",		{ Gv, Ev }, 0 },
2346   /* b0 */
2347   { "cmpxchgB",		{ Ebh1, Gb }, 0 },
2348   { "cmpxchgS",		{ Evh1, Gv }, 0 },
2349   { "lssS",		{ Gv, Mp }, 0 },
2350   { "btrS",		{ Evh1, Gv }, 0 },
2351   { "lfsS",		{ Gv, Mp }, 0 },
2352   { "lgsS",		{ Gv, Mp }, 0 },
2353   { "movz{bR|x}",	{ Gv, Eb }, 0 },
2354   { "movz{wR|x}",	{ Gv, Ew }, 0 }, /* yes, there really is movzww ! */
2355   /* b8 */
2356   { PREFIX_TABLE (PREFIX_0FB8) },
2357   { "ud1S",		{ Gv, Ev }, 0 },
2358   { REG_TABLE (REG_0FBA) },
2359   { "btcS",		{ Evh1, Gv }, 0 },
2360   { PREFIX_TABLE (PREFIX_0FBC) },
2361   { PREFIX_TABLE (PREFIX_0FBD) },
2362   { "movs{bR|x}",	{ Gv, Eb }, 0 },
2363   { "movs{wR|x}",	{ Gv, Ew }, 0 }, /* yes, there really is movsww ! */
2364   /* c0 */
2365   { "xaddB",		{ Ebh1, Gb }, 0 },
2366   { "xaddS",		{ Evh1, Gv }, 0 },
2367   { PREFIX_TABLE (PREFIX_0FC2) },
2368   { "movntiS",		{ Mdq, Gdq }, PREFIX_OPCODE },
2369   { "pinsrw",		{ MX, Edw, Ib }, PREFIX_OPCODE },
2370   { "pextrw",		{ Gd, Nq, Ib }, PREFIX_OPCODE },
2371   { "shufpX",		{ XM, EXx, Ib }, PREFIX_OPCODE },
2372   { REG_TABLE (REG_0FC7) },
2373   /* c8 */
2374   { "bswap",		{ RMeAX }, 0 },
2375   { "bswap",		{ RMeCX }, 0 },
2376   { "bswap",		{ RMeDX }, 0 },
2377   { "bswap",		{ RMeBX }, 0 },
2378   { "bswap",		{ RMeSP }, 0 },
2379   { "bswap",		{ RMeBP }, 0 },
2380   { "bswap",		{ RMeSI }, 0 },
2381   { "bswap",		{ RMeDI }, 0 },
2382   /* d0 */
2383   { PREFIX_TABLE (PREFIX_0FD0) },
2384   { "psrlw",		{ MX, EM }, PREFIX_OPCODE },
2385   { "psrld",		{ MX, EM }, PREFIX_OPCODE },
2386   { "psrlq",		{ MX, EM }, PREFIX_OPCODE },
2387   { "paddq",		{ MX, EM }, PREFIX_OPCODE },
2388   { "pmullw",		{ MX, EM }, PREFIX_OPCODE },
2389   { PREFIX_TABLE (PREFIX_0FD6) },
2390   { "pmovmskb",		{ Gdq, Nq }, PREFIX_OPCODE },
2391   /* d8 */
2392   { "psubusb",		{ MX, EM }, PREFIX_OPCODE },
2393   { "psubusw",		{ MX, EM }, PREFIX_OPCODE },
2394   { "pminub",		{ MX, EM }, PREFIX_OPCODE },
2395   { "pand",		{ MX, EM }, PREFIX_OPCODE },
2396   { "paddusb",		{ MX, EM }, PREFIX_OPCODE },
2397   { "paddusw",		{ MX, EM }, PREFIX_OPCODE },
2398   { "pmaxub",		{ MX, EM }, PREFIX_OPCODE },
2399   { "pandn",		{ MX, EM }, PREFIX_OPCODE },
2400   /* e0 */
2401   { "pavgb",		{ MX, EM }, PREFIX_OPCODE },
2402   { "psraw",		{ MX, EM }, PREFIX_OPCODE },
2403   { "psrad",		{ MX, EM }, PREFIX_OPCODE },
2404   { "pavgw",		{ MX, EM }, PREFIX_OPCODE },
2405   { "pmulhuw",		{ MX, EM }, PREFIX_OPCODE },
2406   { "pmulhw",		{ MX, EM }, PREFIX_OPCODE },
2407   { PREFIX_TABLE (PREFIX_0FE6) },
2408   { PREFIX_TABLE (PREFIX_0FE7) },
2409   /* e8 */
2410   { "psubsb",		{ MX, EM }, PREFIX_OPCODE },
2411   { "psubsw",		{ MX, EM }, PREFIX_OPCODE },
2412   { "pminsw",		{ MX, EM }, PREFIX_OPCODE },
2413   { "por",		{ MX, EM }, PREFIX_OPCODE },
2414   { "paddsb",		{ MX, EM }, PREFIX_OPCODE },
2415   { "paddsw",		{ MX, EM }, PREFIX_OPCODE },
2416   { "pmaxsw",		{ MX, EM }, PREFIX_OPCODE },
2417   { "pxor",		{ MX, EM }, PREFIX_OPCODE },
2418   /* f0 */
2419   { PREFIX_TABLE (PREFIX_0FF0) },
2420   { "psllw",		{ MX, EM }, PREFIX_OPCODE },
2421   { "pslld",		{ MX, EM }, PREFIX_OPCODE },
2422   { "psllq",		{ MX, EM }, PREFIX_OPCODE },
2423   { "pmuludq",		{ MX, EM }, PREFIX_OPCODE },
2424   { "pmaddwd",		{ MX, EM }, PREFIX_OPCODE },
2425   { "psadbw",		{ MX, EM }, PREFIX_OPCODE },
2426   { PREFIX_TABLE (PREFIX_0FF7) },
2427   /* f8 */
2428   { "psubb",		{ MX, EM }, PREFIX_OPCODE },
2429   { "psubw",		{ MX, EM }, PREFIX_OPCODE },
2430   { "psubd",		{ MX, EM }, PREFIX_OPCODE },
2431   { "psubq",		{ MX, EM }, PREFIX_OPCODE },
2432   { "paddb",		{ MX, EM }, PREFIX_OPCODE },
2433   { "paddw",		{ MX, EM }, PREFIX_OPCODE },
2434   { "paddd",		{ MX, EM }, PREFIX_OPCODE },
2435   { "ud0S",		{ Gv, Ev }, 0 },
2436 };
2437 
2438 static const bool onebyte_has_modrm[256] = {
2439   /*       0 1 2 3 4 5 6 7 8 9 a b c d e f        */
2440   /*       -------------------------------        */
2441   /* 00 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 00 */
2442   /* 10 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 10 */
2443   /* 20 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 20 */
2444   /* 30 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 30 */
2445   /* 40 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 40 */
2446   /* 50 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 50 */
2447   /* 60 */ 0,0,1,1,0,0,0,0,0,1,0,1,0,0,0,0, /* 60 */
2448   /* 70 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 70 */
2449   /* 80 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 80 */
2450   /* 90 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 90 */
2451   /* a0 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* a0 */
2452   /* b0 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* b0 */
2453   /* c0 */ 1,1,0,0,1,1,1,1,0,0,0,0,0,0,0,0, /* c0 */
2454   /* d0 */ 1,1,1,1,0,0,0,0,1,1,1,1,1,1,1,1, /* d0 */
2455   /* e0 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* e0 */
2456   /* f0 */ 0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,1  /* f0 */
2457   /*       -------------------------------        */
2458   /*       0 1 2 3 4 5 6 7 8 9 a b c d e f        */
2459 };
2460 
2461 static const bool twobyte_has_modrm[256] = {
2462   /*       0 1 2 3 4 5 6 7 8 9 a b c d e f        */
2463   /*       -------------------------------        */
2464   /* 00 */ 1,1,1,1,0,0,0,0,0,0,0,0,0,1,0,1, /* 0f */
2465   /* 10 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 1f */
2466   /* 20 */ 1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1, /* 2f */
2467   /* 30 */ 0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0, /* 3f */
2468   /* 40 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 4f */
2469   /* 50 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 5f */
2470   /* 60 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 6f */
2471   /* 70 */ 1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1, /* 7f */
2472   /* 80 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 8f */
2473   /* 90 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 9f */
2474   /* a0 */ 0,0,0,1,1,1,1,1,0,0,0,1,1,1,1,1, /* af */
2475   /* b0 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* bf */
2476   /* c0 */ 1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0, /* cf */
2477   /* d0 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* df */
2478   /* e0 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* ef */
2479   /* f0 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1  /* ff */
2480   /*       -------------------------------        */
2481   /*       0 1 2 3 4 5 6 7 8 9 a b c d e f        */
2482 };
2483 
2484 
2485 struct op
2486   {
2487     const char *name;
2488     unsigned int len;
2489   };
2490 
2491 /* If we are accessing mod/rm/reg without need_modrm set, then the
2492    values are stale.  Hitting this abort likely indicates that you
2493    need to update onebyte_has_modrm or twobyte_has_modrm.  */
2494 #define MODRM_CHECK  if (!ins->need_modrm) abort ()
2495 
2496 static const char intel_index16[][6] = {
2497   "bx+si", "bx+di", "bp+si", "bp+di", "si", "di", "bp", "bx"
2498 };
2499 
2500 static const char att_names64[][8] = {
2501   "%rax", "%rcx", "%rdx", "%rbx", "%rsp", "%rbp", "%rsi", "%rdi",
2502   "%r8", "%r9", "%r10", "%r11", "%r12", "%r13", "%r14", "%r15",
2503   "%r16", "%r17", "%r18", "%r19", "%r20", "%r21", "%r22", "%r23",
2504   "%r24", "%r25", "%r26", "%r27", "%r28", "%r29", "%r30", "%r31",
2505 };
2506 static const char att_names32[][8] = {
2507   "%eax", "%ecx", "%edx", "%ebx", "%esp", "%ebp", "%esi", "%edi",
2508   "%r8d", "%r9d", "%r10d", "%r11d", "%r12d", "%r13d", "%r14d", "%r15d",
2509   "%r16d", "%r17d", "%r18d", "%r19d", "%r20d", "%r21d", "%r22d", "%r23d",
2510   "%r24d", "%r25d", "%r26d", "%r27d", "%r28d", "%r29d", "%r30d", "%r31d",
2511 };
2512 static const char att_names16[][8] = {
2513   "%ax", "%cx", "%dx", "%bx", "%sp", "%bp", "%si", "%di",
2514   "%r8w", "%r9w", "%r10w", "%r11w", "%r12w", "%r13w", "%r14w", "%r15w",
2515   "%r16w", "%r17w", "%r18w", "%r19w", "%r20w", "%r21w", "%r22w", "%r23w",
2516   "%r24w", "%r25w", "%r26w", "%r27w", "%r28w", "%r29w", "%r30w", "%r31w",
2517 };
2518 static const char att_names8[][8] = {
2519   "%al", "%cl", "%dl", "%bl", "%ah", "%ch", "%dh", "%bh",
2520 };
2521 static const char att_names8rex[][8] = {
2522   "%al", "%cl", "%dl", "%bl", "%spl", "%bpl", "%sil", "%dil",
2523   "%r8b", "%r9b", "%r10b", "%r11b", "%r12b", "%r13b", "%r14b", "%r15b",
2524   "%r16b", "%r17b", "%r18b", "%r19b", "%r20b", "%r21b", "%r22b", "%r23b",
2525   "%r24b", "%r25b", "%r26b", "%r27b", "%r28b", "%r29b", "%r30b", "%r31b",
2526 };
2527 static const char att_names_seg[][4] = {
2528   "%es", "%cs", "%ss", "%ds", "%fs", "%gs", "%?", "%?",
2529 };
2530 static const char att_index64[] = "%riz";
2531 static const char att_index32[] = "%eiz";
2532 static const char att_index16[][8] = {
2533   "%bx,%si", "%bx,%di", "%bp,%si", "%bp,%di", "%si", "%di", "%bp", "%bx"
2534 };
2535 
2536 static const char att_names_mm[][8] = {
2537   "%mm0", "%mm1", "%mm2", "%mm3",
2538   "%mm4", "%mm5", "%mm6", "%mm7"
2539 };
2540 
2541 static const char att_names_bnd[][8] = {
2542   "%bnd0", "%bnd1", "%bnd2", "%bnd3"
2543 };
2544 
2545 static const char att_names_xmm[][8] = {
2546   "%xmm0", "%xmm1", "%xmm2", "%xmm3",
2547   "%xmm4", "%xmm5", "%xmm6", "%xmm7",
2548   "%xmm8", "%xmm9", "%xmm10", "%xmm11",
2549   "%xmm12", "%xmm13", "%xmm14", "%xmm15",
2550   "%xmm16", "%xmm17", "%xmm18", "%xmm19",
2551   "%xmm20", "%xmm21", "%xmm22", "%xmm23",
2552   "%xmm24", "%xmm25", "%xmm26", "%xmm27",
2553   "%xmm28", "%xmm29", "%xmm30", "%xmm31"
2554 };
2555 
2556 static const char att_names_ymm[][8] = {
2557   "%ymm0", "%ymm1", "%ymm2", "%ymm3",
2558   "%ymm4", "%ymm5", "%ymm6", "%ymm7",
2559   "%ymm8", "%ymm9", "%ymm10", "%ymm11",
2560   "%ymm12", "%ymm13", "%ymm14", "%ymm15",
2561   "%ymm16", "%ymm17", "%ymm18", "%ymm19",
2562   "%ymm20", "%ymm21", "%ymm22", "%ymm23",
2563   "%ymm24", "%ymm25", "%ymm26", "%ymm27",
2564   "%ymm28", "%ymm29", "%ymm30", "%ymm31"
2565 };
2566 
2567 static const char att_names_zmm[][8] = {
2568   "%zmm0", "%zmm1", "%zmm2", "%zmm3",
2569   "%zmm4", "%zmm5", "%zmm6", "%zmm7",
2570   "%zmm8", "%zmm9", "%zmm10", "%zmm11",
2571   "%zmm12", "%zmm13", "%zmm14", "%zmm15",
2572   "%zmm16", "%zmm17", "%zmm18", "%zmm19",
2573   "%zmm20", "%zmm21", "%zmm22", "%zmm23",
2574   "%zmm24", "%zmm25", "%zmm26", "%zmm27",
2575   "%zmm28", "%zmm29", "%zmm30", "%zmm31"
2576 };
2577 
2578 static const char att_names_tmm[][8] = {
2579   "%tmm0", "%tmm1", "%tmm2", "%tmm3",
2580   "%tmm4", "%tmm5", "%tmm6", "%tmm7"
2581 };
2582 
2583 static const char att_names_mask[][8] = {
2584   "%k0", "%k1", "%k2", "%k3", "%k4", "%k5", "%k6", "%k7"
2585 };
2586 
2587 static const char *const names_rounding[] =
2588 {
2589   "{rn-",
2590   "{rd-",
2591   "{ru-",
2592   "{rz-"
2593 };
2594 
2595 static const struct dis386 reg_table[][8] = {
2596   /* REG_80 */
2597   {
2598     { "addA",	{ Ebh1, Ib }, 0 },
2599     { "orA",	{ Ebh1, Ib }, 0 },
2600     { "adcA",	{ Ebh1, Ib }, 0 },
2601     { "sbbA",	{ Ebh1, Ib }, 0 },
2602     { "andA",	{ Ebh1, Ib }, 0 },
2603     { "subA",	{ Ebh1, Ib }, 0 },
2604     { "xorA",	{ Ebh1, Ib }, 0 },
2605     { "cmpA",	{ Eb, Ib }, 0 },
2606   },
2607   /* REG_81 */
2608   {
2609     { "addQ",	{ Evh1, Iv }, 0 },
2610     { "orQ",	{ Evh1, Iv }, 0 },
2611     { "adcQ",	{ Evh1, Iv }, 0 },
2612     { "sbbQ",	{ Evh1, Iv }, 0 },
2613     { "andQ",	{ Evh1, Iv }, 0 },
2614     { "subQ",	{ Evh1, Iv }, 0 },
2615     { "xorQ",	{ Evh1, Iv }, 0 },
2616     { "cmpQ",	{ Ev, Iv }, 0 },
2617   },
2618   /* REG_83 */
2619   {
2620     { "addQ",	{ Evh1, sIb }, 0 },
2621     { "orQ",	{ Evh1, sIb }, 0 },
2622     { "adcQ",	{ Evh1, sIb }, 0 },
2623     { "sbbQ",	{ Evh1, sIb }, 0 },
2624     { "andQ",	{ Evh1, sIb }, 0 },
2625     { "subQ",	{ Evh1, sIb }, 0 },
2626     { "xorQ",	{ Evh1, sIb }, 0 },
2627     { "cmpQ",	{ Ev, sIb }, 0 },
2628   },
2629   /* REG_8F */
2630   {
2631     { "pop{P|}", { stackEv }, 0 },
2632     { XOP_8F_TABLE () },
2633     { Bad_Opcode },
2634     { Bad_Opcode },
2635     { Bad_Opcode },
2636     { XOP_8F_TABLE () },
2637   },
2638   /* REG_C0 */
2639   {
2640     { "%NFrolA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2641     { "%NFrorA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2642     { "rclA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2643     { "rcrA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2644     { "%NFshlA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2645     { "%NFshrA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2646     { "%NFshlA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2647     { "%NFsarA",	{ VexGb, Eb, Ib }, NO_PREFIX },
2648   },
2649   /* REG_C1 */
2650   {
2651     { "%NFrolQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2652     { "%NFrorQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2653     { "rclQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2654     { "rcrQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2655     { "%NFshlQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2656     { "%NFshrQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2657     { "%NFshlQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2658     { "%NFsarQ",	{ VexGv, Ev, Ib }, PREFIX_NP_OR_DATA },
2659   },
2660   /* REG_C6 */
2661   {
2662     { "movA",	{ Ebh3, Ib }, 0 },
2663     { Bad_Opcode },
2664     { Bad_Opcode },
2665     { Bad_Opcode },
2666     { Bad_Opcode },
2667     { Bad_Opcode },
2668     { Bad_Opcode },
2669     { RM_TABLE (RM_C6_REG_7) },
2670   },
2671   /* REG_C7 */
2672   {
2673     { "movQ",	{ Evh3, Iv }, 0 },
2674     { Bad_Opcode },
2675     { Bad_Opcode },
2676     { Bad_Opcode },
2677     { Bad_Opcode },
2678     { Bad_Opcode },
2679     { Bad_Opcode },
2680     { RM_TABLE (RM_C7_REG_7) },
2681   },
2682   /* REG_D0 */
2683   {
2684     { "%NFrolA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2685     { "%NFrorA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2686     { "rclA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2687     { "rcrA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2688     { "%NFshlA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2689     { "%NFshrA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2690     { "%NFshlA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2691     { "%NFsarA",	{ VexGb, Eb, I1 }, NO_PREFIX },
2692   },
2693   /* REG_D1 */
2694   {
2695     { "%NFrolQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2696     { "%NFrorQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2697     { "rclQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2698     { "rcrQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2699     { "%NFshlQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2700     { "%NFshrQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2701     { "%NFshlQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2702     { "%NFsarQ",	{ VexGv, Ev, I1 }, PREFIX_NP_OR_DATA },
2703   },
2704   /* REG_D2 */
2705   {
2706     { "%NFrolA",	{ VexGb, Eb, CL }, NO_PREFIX },
2707     { "%NFrorA",	{ VexGb, Eb, CL }, NO_PREFIX },
2708     { "rclA",	{ VexGb, Eb, CL }, NO_PREFIX },
2709     { "rcrA",	{ VexGb, Eb, CL }, NO_PREFIX },
2710     { "%NFshlA",	{ VexGb, Eb, CL }, NO_PREFIX },
2711     { "%NFshrA",	{ VexGb, Eb, CL }, NO_PREFIX },
2712     { "%NFshlA",	{ VexGb, Eb, CL }, NO_PREFIX },
2713     { "%NFsarA",	{ VexGb, Eb, CL }, NO_PREFIX },
2714   },
2715   /* REG_D3 */
2716   {
2717     { "%NFrolQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2718     { "%NFrorQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2719     { "rclQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2720     { "rcrQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2721     { "%NFshlQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2722     { "%NFshrQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2723     { "%NFshlQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2724     { "%NFsarQ",	{ VexGv, Ev, CL }, PREFIX_NP_OR_DATA },
2725   },
2726   /* REG_F6 */
2727   {
2728     { "testA",	{ Eb, Ib }, 0 },
2729     { "testA",	{ Eb, Ib }, 0 },
2730     { "notA",	{ Ebh1 }, 0 },
2731     { "negA",	{ Ebh1 }, 0 },
2732     { "mulA",	{ Eb }, 0 },	/* Don't print the implicit %al register,  */
2733     { "imulA",	{ Eb }, 0 },	/* to distinguish these opcodes from other */
2734     { "divA",	{ Eb }, 0 },	/* mul/imul opcodes.  Do the same for div  */
2735     { "idivA",	{ Eb }, 0 },	/* and idiv for consistency.		   */
2736   },
2737   /* REG_F7 */
2738   {
2739     { "testQ",	{ Ev, Iv }, 0 },
2740     { "testQ",	{ Ev, Iv }, 0 },
2741     { "notQ",	{ Evh1 }, 0 },
2742     { "negQ",	{ Evh1 }, 0 },
2743     { "mulQ",	{ Ev }, 0 },	/* Don't print the implicit register.  */
2744     { "imulQ",	{ Ev }, 0 },
2745     { "divQ",	{ Ev }, 0 },
2746     { "idivQ",	{ Ev }, 0 },
2747   },
2748   /* REG_FE */
2749   {
2750     { "incA",	{ Ebh1 }, 0 },
2751     { "decA",	{ Ebh1 }, 0 },
2752   },
2753   /* REG_FF */
2754   {
2755     { "incQ",	{ Evh1 }, 0 },
2756     { "decQ",	{ Evh1 }, 0 },
2757     { "call{@|}", { NOTRACK, indirEv, BND }, 0 },
2758     { "{l|}call^", { indirEp }, 0 },
2759     { "jmp{@|}", { NOTRACK, indirEv, BND }, 0 },
2760     { "{l|}jmp^", { indirEp }, 0 },
2761     { "push{P|}", { stackEv }, 0 },
2762     { Bad_Opcode },
2763   },
2764   /* REG_0F00 */
2765   {
2766     { "sldtD",	{ Sv }, 0 },
2767     { "strD",	{ Sv }, 0 },
2768     { "lldtD",	{ Sv }, 0 },
2769     { "ltrD",	{ Sv }, 0 },
2770     { "verrD",	{ Sv }, 0 },
2771     { "verwD",	{ Sv }, 0 },
2772     { X86_64_TABLE (X86_64_0F00_REG_6) },
2773     { Bad_Opcode },
2774   },
2775   /* REG_0F01 */
2776   {
2777     { MOD_TABLE (MOD_0F01_REG_0) },
2778     { MOD_TABLE (MOD_0F01_REG_1) },
2779     { MOD_TABLE (MOD_0F01_REG_2) },
2780     { MOD_TABLE (MOD_0F01_REG_3) },
2781     { "smswD",	{ Sv }, 0 },
2782     { MOD_TABLE (MOD_0F01_REG_5) },
2783     { "lmsw",	{ Ew }, 0 },
2784     { MOD_TABLE (MOD_0F01_REG_7) },
2785   },
2786   /* REG_0F0D */
2787   {
2788     { "prefetch",	{ Mb }, 0 },
2789     { "prefetchw",	{ Mb }, 0 },
2790     { "prefetchwt1",	{ Mb }, 0 },
2791     { "prefetch",	{ Mb }, 0 },
2792     { "prefetch",	{ Mb }, 0 },
2793     { "prefetch",	{ Mb }, 0 },
2794     { "prefetch",	{ Mb }, 0 },
2795     { "prefetch",	{ Mb }, 0 },
2796   },
2797   /* REG_0F18 */
2798   {
2799     { MOD_TABLE (MOD_0F18_REG_0) },
2800     { MOD_TABLE (MOD_0F18_REG_1) },
2801     { MOD_TABLE (MOD_0F18_REG_2) },
2802     { MOD_TABLE (MOD_0F18_REG_3) },
2803     { "nopQ",		{ Ev }, 0 },
2804     { "nopQ",		{ Ev }, 0 },
2805     { MOD_TABLE (MOD_0F18_REG_6) },
2806     { MOD_TABLE (MOD_0F18_REG_7) },
2807   },
2808   /* REG_0F1C_P_0_MOD_0 */
2809   {
2810     { "cldemote",	{ Mb }, 0 },
2811     { "nopQ",		{ Ev }, 0 },
2812     { "nopQ",		{ Ev }, 0 },
2813     { "nopQ",		{ Ev }, 0 },
2814     { "nopQ",		{ Ev }, 0 },
2815     { "nopQ",		{ Ev }, 0 },
2816     { "nopQ",		{ Ev }, 0 },
2817     { "nopQ",		{ Ev }, 0 },
2818   },
2819   /* REG_0F1E_P_1_MOD_3 */
2820   {
2821     { "nopQ",		{ Ev }, PREFIX_IGNORED },
2822     { "rdsspK",		{ Edq }, 0 },
2823     { "nopQ",		{ Ev }, PREFIX_IGNORED },
2824     { "nopQ",		{ Ev }, PREFIX_IGNORED },
2825     { "nopQ",		{ Ev }, PREFIX_IGNORED },
2826     { "nopQ",		{ Ev }, PREFIX_IGNORED },
2827     { "nopQ",		{ Ev }, PREFIX_IGNORED },
2828     { RM_TABLE (RM_0F1E_P_1_MOD_3_REG_7) },
2829   },
2830   /* REG_0F38D8_PREFIX_1 */
2831   {
2832     { "aesencwide128kl",	{ M }, 0 },
2833     { "aesdecwide128kl",	{ M }, 0 },
2834     { "aesencwide256kl",	{ M }, 0 },
2835     { "aesdecwide256kl",	{ M }, 0 },
2836   },
2837   /* REG_0F3A0F_P_1 */
2838   {
2839     { RM_TABLE (RM_0F3A0F_P_1_R_0) },
2840   },
2841   /* REG_0F71 */
2842   {
2843     { Bad_Opcode },
2844     { Bad_Opcode },
2845     { "psrlw",		{ Nq, Ib }, PREFIX_OPCODE },
2846     { Bad_Opcode },
2847     { "psraw",		{ Nq, Ib }, PREFIX_OPCODE },
2848     { Bad_Opcode },
2849     { "psllw",		{ Nq, Ib }, PREFIX_OPCODE },
2850   },
2851   /* REG_0F72 */
2852   {
2853     { Bad_Opcode },
2854     { Bad_Opcode },
2855     { "psrld",		{ Nq, Ib }, PREFIX_OPCODE },
2856     { Bad_Opcode },
2857     { "psrad",		{ Nq, Ib }, PREFIX_OPCODE },
2858     { Bad_Opcode },
2859     { "pslld",		{ Nq, Ib }, PREFIX_OPCODE },
2860   },
2861   /* REG_0F73 */
2862   {
2863     { Bad_Opcode },
2864     { Bad_Opcode },
2865     { "psrlq",		{ Nq, Ib }, PREFIX_OPCODE },
2866     { "psrldq",		{ Ux, Ib }, PREFIX_DATA },
2867     { Bad_Opcode },
2868     { Bad_Opcode },
2869     { "psllq",		{ Nq, Ib }, PREFIX_OPCODE },
2870     { "pslldq",		{ Ux, Ib }, PREFIX_DATA },
2871   },
2872   /* REG_0FA6 */
2873   {
2874     { "montmul",	{ { OP_0f07, 0 } }, 0 },
2875     { "xsha1",		{ { OP_0f07, 0 } }, 0 },
2876     { "xsha256",	{ { OP_0f07, 0 } }, 0 },
2877   },
2878   /* REG_0FA7 */
2879   {
2880     { "xstore-rng",	{ { OP_0f07, 0 } }, 0 },
2881     { "xcrypt-ecb",	{ { OP_0f07, 0 } }, 0 },
2882     { "xcrypt-cbc",	{ { OP_0f07, 0 } }, 0 },
2883     { "xcrypt-ctr",	{ { OP_0f07, 0 } }, 0 },
2884     { "xcrypt-cfb",	{ { OP_0f07, 0 } }, 0 },
2885     { "xcrypt-ofb",	{ { OP_0f07, 0 } }, 0 },
2886   },
2887   /* REG_0FAE */
2888   {
2889     { MOD_TABLE (MOD_0FAE_REG_0) },
2890     { MOD_TABLE (MOD_0FAE_REG_1) },
2891     { MOD_TABLE (MOD_0FAE_REG_2) },
2892     { MOD_TABLE (MOD_0FAE_REG_3) },
2893     { MOD_TABLE (MOD_0FAE_REG_4) },
2894     { MOD_TABLE (MOD_0FAE_REG_5) },
2895     { MOD_TABLE (MOD_0FAE_REG_6) },
2896     { MOD_TABLE (MOD_0FAE_REG_7) },
2897   },
2898   /* REG_0FBA */
2899   {
2900     { Bad_Opcode },
2901     { Bad_Opcode },
2902     { Bad_Opcode },
2903     { Bad_Opcode },
2904     { "btQ",	{ Ev, Ib }, 0 },
2905     { "btsQ",	{ Evh1, Ib }, 0 },
2906     { "btrQ",	{ Evh1, Ib }, 0 },
2907     { "btcQ",	{ Evh1, Ib }, 0 },
2908   },
2909   /* REG_0FC7 */
2910   {
2911     { Bad_Opcode },
2912     { "cmpxchg8b", { { CMPXCHG8B_Fixup, q_mode } }, 0 },
2913     { Bad_Opcode },
2914     { "xrstors", { FXSAVE }, PREFIX_REX2_ILLEGAL },
2915     { "xsavec", { FXSAVE }, PREFIX_REX2_ILLEGAL },
2916     { "xsaves", { FXSAVE }, PREFIX_REX2_ILLEGAL },
2917     { MOD_TABLE (MOD_0FC7_REG_6) },
2918     { MOD_TABLE (MOD_0FC7_REG_7) },
2919   },
2920   /* REG_VEX_0F71 */
2921   {
2922     { Bad_Opcode },
2923     { Bad_Opcode },
2924     { "vpsrlw",		{ Vex, Ux, Ib }, PREFIX_DATA },
2925     { Bad_Opcode },
2926     { "vpsraw",		{ Vex, Ux, Ib }, PREFIX_DATA },
2927     { Bad_Opcode },
2928     { "vpsllw",		{ Vex, Ux, Ib }, PREFIX_DATA },
2929   },
2930   /* REG_VEX_0F72 */
2931   {
2932     { Bad_Opcode },
2933     { Bad_Opcode },
2934     { "vpsrld",		{ Vex, Ux, Ib }, PREFIX_DATA },
2935     { Bad_Opcode },
2936     { "vpsrad",		{ Vex, Ux, Ib }, PREFIX_DATA },
2937     { Bad_Opcode },
2938     { "vpslld",		{ Vex, Ux, Ib }, PREFIX_DATA },
2939   },
2940   /* REG_VEX_0F73 */
2941   {
2942     { Bad_Opcode },
2943     { Bad_Opcode },
2944     { "vpsrlq",		{ Vex, Ux, Ib }, PREFIX_DATA },
2945     { "vpsrldq",	{ Vex, Ux, Ib }, PREFIX_DATA },
2946     { Bad_Opcode },
2947     { Bad_Opcode },
2948     { "vpsllq",		{ Vex, Ux, Ib }, PREFIX_DATA },
2949     { "vpslldq",	{ Vex, Ux, Ib }, PREFIX_DATA },
2950   },
2951   /* REG_VEX_0FAE */
2952   {
2953     { Bad_Opcode },
2954     { Bad_Opcode },
2955     { VEX_LEN_TABLE (VEX_LEN_0FAE_R_2) },
2956     { VEX_LEN_TABLE (VEX_LEN_0FAE_R_3) },
2957   },
2958   /* REG_VEX_0F3849_X86_64_L_0_W_0_M_1_P_0 */
2959   {
2960     { RM_TABLE (RM_VEX_0F3849_X86_64_L_0_W_0_M_1_P_0_R_0) },
2961   },
2962   /* REG_VEX_0F38F3_L_0_P_0 */
2963   {
2964     { Bad_Opcode },
2965     { "%NFblsrS",		{ VexGdq, Edq }, 0 },
2966     { "%NFblsmskS",		{ VexGdq, Edq }, 0 },
2967     { "%NFblsiS",		{ VexGdq, Edq }, 0 },
2968   },
2969   /* REG_VEX_MAP7_F8_L_0_W_0 */
2970   {
2971     { X86_64_TABLE (X86_64_VEX_MAP7_F8_L_0_W_0_R_0) },
2972   },
2973   /* REG_XOP_09_01_L_0 */
2974   {
2975     { Bad_Opcode },
2976     { "blcfill",	{ VexGdq, Edq }, 0 },
2977     { "blsfill",	{ VexGdq, Edq }, 0 },
2978     { "blcs",	{ VexGdq, Edq }, 0 },
2979     { "tzmsk",	{ VexGdq, Edq }, 0 },
2980     { "blcic",	{ VexGdq, Edq }, 0 },
2981     { "blsic",	{ VexGdq, Edq }, 0 },
2982     { "t1mskc",	{ VexGdq, Edq }, 0 },
2983   },
2984   /* REG_XOP_09_02_L_0 */
2985   {
2986     { Bad_Opcode },
2987     { "blcmsk",	{ VexGdq, Edq }, 0 },
2988     { Bad_Opcode },
2989     { Bad_Opcode },
2990     { Bad_Opcode },
2991     { Bad_Opcode },
2992     { "blci",	{ VexGdq, Edq }, 0 },
2993   },
2994   /* REG_XOP_09_12_L_0 */
2995   {
2996     { "llwpcb",	{ Rdq }, 0 },
2997     { "slwpcb",	{ Rdq }, 0 },
2998   },
2999   /* REG_XOP_0A_12_L_0 */
3000   {
3001     { "lwpins",	{ VexGdq, Ed, Id }, 0 },
3002     { "lwpval",	{ VexGdq, Ed, Id }, 0 },
3003   },
3004 
3005 #include "i386-dis-evex-reg.h"
3006 };
3007 
3008 static const struct dis386 prefix_table[][4] = {
3009   /* PREFIX_90 */
3010   {
3011     { "xchgS", { { NOP_Fixup, 0 }, { NOP_Fixup, 1 } }, 0 },
3012     { "pause", { XX }, 0 },
3013     { "xchgS", { { NOP_Fixup, 0 }, { NOP_Fixup, 1 } }, 0 },
3014     { NULL, { { NULL, 0 } }, PREFIX_IGNORED }
3015   },
3016 
3017   /* PREFIX_0F00_REG_6_X86_64 */
3018   {
3019     { Bad_Opcode },
3020     { Bad_Opcode },
3021     { Bad_Opcode },
3022     { "lkgsD", { Sv }, 0 },
3023   },
3024 
3025   /* PREFIX_0F01_REG_0_MOD_3_RM_6 */
3026   {
3027     { "wrmsrns",        { Skip_MODRM }, 0 },
3028     { X86_64_TABLE (X86_64_0F01_REG_0_MOD_3_RM_6_P_1) },
3029     { Bad_Opcode },
3030     { X86_64_TABLE (X86_64_0F01_REG_0_MOD_3_RM_6_P_3) },
3031   },
3032 
3033   /* PREFIX_0F01_REG_0_MOD_3_RM_7 */
3034   {
3035     { X86_64_TABLE (X86_64_0F01_REG_0_MOD_3_RM_7_P_0) },
3036   },
3037 
3038   /* PREFIX_0F01_REG_1_RM_2 */
3039   {
3040     { "clac",		{ Skip_MODRM }, 0 },
3041     { X86_64_TABLE (X86_64_0F01_REG_1_RM_2_PREFIX_1) },
3042     { Bad_Opcode },
3043     { X86_64_TABLE (X86_64_0F01_REG_1_RM_2_PREFIX_3)},
3044   },
3045 
3046   /* PREFIX_0F01_REG_1_RM_4 */
3047   {
3048     { Bad_Opcode },
3049     { Bad_Opcode },
3050     { "tdcall", 	{ Skip_MODRM }, 0 },
3051     { Bad_Opcode },
3052   },
3053 
3054   /* PREFIX_0F01_REG_1_RM_5 */
3055   {
3056     { Bad_Opcode },
3057     { Bad_Opcode },
3058     { X86_64_TABLE (X86_64_0F01_REG_1_RM_5_PREFIX_2) },
3059     { Bad_Opcode },
3060   },
3061 
3062   /* PREFIX_0F01_REG_1_RM_6 */
3063   {
3064     { Bad_Opcode },
3065     { Bad_Opcode },
3066     { X86_64_TABLE (X86_64_0F01_REG_1_RM_6_PREFIX_2) },
3067     { Bad_Opcode },
3068   },
3069 
3070   /* PREFIX_0F01_REG_1_RM_7 */
3071   {
3072     { "encls",		{ Skip_MODRM }, 0 },
3073     { Bad_Opcode },
3074     { X86_64_TABLE (X86_64_0F01_REG_1_RM_7_PREFIX_2) },
3075     { Bad_Opcode },
3076   },
3077 
3078   /* PREFIX_0F01_REG_3_RM_1 */
3079   {
3080     { "vmmcall",	{ Skip_MODRM }, 0 },
3081     { "vmgexit",	{ Skip_MODRM }, 0 },
3082     { Bad_Opcode },
3083     { "vmgexit",	{ Skip_MODRM }, 0 },
3084   },
3085 
3086   /* PREFIX_0F01_REG_5_MOD_0 */
3087   {
3088     { Bad_Opcode },
3089     { "rstorssp",	{ Mq }, PREFIX_OPCODE },
3090   },
3091 
3092   /* PREFIX_0F01_REG_5_MOD_3_RM_0 */
3093   {
3094     { "serialize",	{ Skip_MODRM }, PREFIX_OPCODE },
3095     { "setssbsy",	{ Skip_MODRM }, PREFIX_OPCODE },
3096     { Bad_Opcode },
3097     { "xsusldtrk",	{ Skip_MODRM }, PREFIX_OPCODE },
3098   },
3099 
3100   /* PREFIX_0F01_REG_5_MOD_3_RM_1 */
3101   {
3102     { Bad_Opcode },
3103     { Bad_Opcode },
3104     { Bad_Opcode },
3105     { "xresldtrk",     { Skip_MODRM }, PREFIX_OPCODE },
3106   },
3107 
3108   /* PREFIX_0F01_REG_5_MOD_3_RM_2 */
3109   {
3110     { Bad_Opcode },
3111     { "saveprevssp",	{ Skip_MODRM }, PREFIX_OPCODE },
3112   },
3113 
3114   /* PREFIX_0F01_REG_5_MOD_3_RM_4 */
3115   {
3116     { Bad_Opcode },
3117     { X86_64_TABLE (X86_64_0F01_REG_5_MOD_3_RM_4_PREFIX_1) },
3118   },
3119 
3120   /* PREFIX_0F01_REG_5_MOD_3_RM_5 */
3121   {
3122     { Bad_Opcode },
3123     { X86_64_TABLE (X86_64_0F01_REG_5_MOD_3_RM_5_PREFIX_1) },
3124   },
3125 
3126   /* PREFIX_0F01_REG_5_MOD_3_RM_6 */
3127   {
3128     { "rdpkru", { Skip_MODRM }, 0 },
3129     { X86_64_TABLE (X86_64_0F01_REG_5_MOD_3_RM_6_PREFIX_1) },
3130   },
3131 
3132   /* PREFIX_0F01_REG_5_MOD_3_RM_7 */
3133   {
3134     { "wrpkru",	{ Skip_MODRM }, 0 },
3135     { X86_64_TABLE (X86_64_0F01_REG_5_MOD_3_RM_7_PREFIX_1) },
3136   },
3137 
3138   /* PREFIX_0F01_REG_7_MOD_3_RM_2 */
3139   {
3140     { "monitorx",	{ { OP_Monitor, 0 } }, 0  },
3141     { "mcommit",	{ Skip_MODRM }, 0 },
3142   },
3143 
3144   /* PREFIX_0F01_REG_7_MOD_3_RM_5 */
3145   {
3146     { "rdpru", { Skip_MODRM }, 0 },
3147     { X86_64_TABLE (X86_64_0F01_REG_7_MOD_3_RM_5_PREFIX_1) },
3148   },
3149 
3150   /* PREFIX_0F01_REG_7_MOD_3_RM_6 */
3151   {
3152     { "invlpgb",        { Skip_MODRM }, 0 },
3153     { X86_64_TABLE (X86_64_0F01_REG_7_MOD_3_RM_6_PREFIX_1) },
3154     { Bad_Opcode },
3155     { X86_64_TABLE (X86_64_0F01_REG_7_MOD_3_RM_6_PREFIX_3) },
3156   },
3157 
3158   /* PREFIX_0F01_REG_7_MOD_3_RM_7 */
3159   {
3160     { "tlbsync",        { Skip_MODRM }, 0 },
3161     { X86_64_TABLE (X86_64_0F01_REG_7_MOD_3_RM_7_PREFIX_1) },
3162     { Bad_Opcode },
3163     { "pvalidate",      { Skip_MODRM }, 0 },
3164   },
3165 
3166   /* PREFIX_0F09 */
3167   {
3168     { "wbinvd",   { XX }, 0 },
3169     { "wbnoinvd", { XX }, 0 },
3170   },
3171 
3172   /* PREFIX_0F10 */
3173   {
3174     { "%XEVmovupX",	{ XM, EXEvexXNoBcst }, 0 },
3175     { "%XEVmovs%XS",	{ XMScalar, VexScalarR, EXd }, 0 },
3176     { "%XEVmovupX",	{ XM, EXEvexXNoBcst }, 0 },
3177     { "%XEVmovs%XD",	{ XMScalar, VexScalarR, EXq }, 0 },
3178   },
3179 
3180   /* PREFIX_0F11 */
3181   {
3182     { "%XEVmovupX",	{ EXxS, XM }, 0 },
3183     { "%XEVmovs%XS",	{ EXdS, VexScalarR, XMScalar }, 0 },
3184     { "%XEVmovupX",	{ EXxS, XM }, 0 },
3185     { "%XEVmovs%XD",	{ EXqS, VexScalarR, XMScalar }, 0 },
3186   },
3187 
3188   /* PREFIX_0F12 */
3189   {
3190     { MOD_TABLE (MOD_0F12_PREFIX_0) },
3191     { "movsldup",	{ XM, EXx }, 0 },
3192     { "%XEVmovlpYX",	{ XM, Vex, Mq }, 0 },
3193     { "movddup",	{ XM, EXq }, 0 },
3194   },
3195 
3196   /* PREFIX_0F16 */
3197   {
3198     { MOD_TABLE (MOD_0F16_PREFIX_0) },
3199     { "movshdup",	{ XM, EXx }, 0 },
3200     { "%XEVmovhpYX",	{ XM, Vex, Mq }, 0 },
3201   },
3202 
3203   /* PREFIX_0F18_REG_6_MOD_0_X86_64 */
3204   {
3205     { "prefetchit1",	{ { PREFETCHI_Fixup, b_mode } }, 0 },
3206     { "nopQ",		{ Ev }, 0 },
3207     { "nopQ",		{ Ev }, 0 },
3208     { "nopQ",		{ Ev }, 0 },
3209   },
3210 
3211   /* PREFIX_0F18_REG_7_MOD_0_X86_64 */
3212   {
3213     { "prefetchit0",	{ { PREFETCHI_Fixup, b_mode } }, 0 },
3214     { "nopQ",		{ Ev }, 0 },
3215     { "nopQ",		{ Ev }, 0 },
3216     { "nopQ",		{ Ev }, 0 },
3217   },
3218 
3219   /* PREFIX_0F1A */
3220   {
3221     { MOD_TABLE (MOD_0F1A_PREFIX_0) },
3222     { "bndcl",  { Gbnd, Ev_bnd }, 0 },
3223     { "bndmov", { Gbnd, Ebnd }, 0 },
3224     { "bndcu",  { Gbnd, Ev_bnd }, 0 },
3225   },
3226 
3227   /* PREFIX_0F1B */
3228   {
3229     { MOD_TABLE (MOD_0F1B_PREFIX_0) },
3230     { MOD_TABLE (MOD_0F1B_PREFIX_1) },
3231     { "bndmov", { EbndS, Gbnd }, 0 },
3232     { "bndcn",  { Gbnd, Ev_bnd }, 0 },
3233   },
3234 
3235   /* PREFIX_0F1C */
3236   {
3237     { MOD_TABLE (MOD_0F1C_PREFIX_0) },
3238     { "nopQ",	{ Ev }, PREFIX_IGNORED },
3239     { "nopQ",	{ Ev }, 0 },
3240     { "nopQ",	{ Ev }, PREFIX_IGNORED },
3241   },
3242 
3243   /* PREFIX_0F1E */
3244   {
3245     { "nopQ",	{ Ev }, 0 },
3246     { MOD_TABLE (MOD_0F1E_PREFIX_1) },
3247     { "nopQ",	{ Ev }, 0 },
3248     { NULL,	{ XX }, PREFIX_IGNORED },
3249   },
3250 
3251   /* PREFIX_0F2A */
3252   {
3253     { "cvtpi2ps", { XM, EMCq }, PREFIX_OPCODE },
3254     { "cvtsi2ss{%LQ|}", { XM, Edq }, PREFIX_OPCODE },
3255     { "cvtpi2pd", { XM, EMCq }, PREFIX_OPCODE },
3256     { "cvtsi2sd{%LQ|}", { XM, Edq }, 0 },
3257   },
3258 
3259   /* PREFIX_0F2B */
3260   {
3261     { "movntps", { Mx, XM }, 0 },
3262     { "movntss", { Md, XM }, 0 },
3263     { "movntpd", { Mx, XM }, 0 },
3264     { "movntsd", { Mq, XM }, 0 },
3265   },
3266 
3267   /* PREFIX_0F2C */
3268   {
3269     { "cvttps2pi", { MXC, EXq }, PREFIX_OPCODE },
3270     { "cvttss2si", { Gdq, EXd }, PREFIX_OPCODE },
3271     { "cvttpd2pi", { MXC, EXx }, PREFIX_OPCODE },
3272     { "cvttsd2si", { Gdq, EXq }, PREFIX_OPCODE },
3273   },
3274 
3275   /* PREFIX_0F2D */
3276   {
3277     { "cvtps2pi", { MXC, EXq }, PREFIX_OPCODE },
3278     { "cvtss2si", { Gdq, EXd }, PREFIX_OPCODE },
3279     { "cvtpd2pi", { MXC, EXx }, PREFIX_OPCODE },
3280     { "cvtsd2si", { Gdq, EXq }, PREFIX_OPCODE },
3281   },
3282 
3283   /* PREFIX_0F2E */
3284   {
3285     { "%XEVucomisYX",	{ XMScalar, EXd, EXxEVexS }, 0 },
3286     { Bad_Opcode },
3287     { "%XEVucomisYX",	{ XMScalar, EXq, EXxEVexS }, 0 },
3288   },
3289 
3290   /* PREFIX_0F2F */
3291   {
3292     { "%XEVcomisYX",	{ XMScalar, EXd, EXxEVexS }, 0 },
3293     { Bad_Opcode },
3294     { "%XEVcomisYX",	{ XMScalar, EXq, EXxEVexS }, 0 },
3295   },
3296 
3297   /* PREFIX_0F51 */
3298   {
3299     { "%XEVsqrtpX",	{ XM, EXx, EXxEVexR }, 0 },
3300     { "%XEVsqrts%XS",	{ XMScalar, VexScalar, EXd, EXxEVexR }, 0 },
3301     { "%XEVsqrtpX",	{ XM, EXx, EXxEVexR }, 0 },
3302     { "%XEVsqrts%XD",	{ XMScalar, VexScalar, EXq, EXxEVexR }, 0 },
3303   },
3304 
3305   /* PREFIX_0F52 */
3306   {
3307     { "Vrsqrtps",	{ XM, EXx }, 0 },
3308     { "Vrsqrtss",	{ XMScalar, VexScalar, EXd }, 0 },
3309   },
3310 
3311   /* PREFIX_0F53 */
3312   {
3313     { "Vrcpps",		{ XM, EXx }, 0 },
3314     { "Vrcpss",		{ XMScalar, VexScalar, EXd }, 0 },
3315   },
3316 
3317   /* PREFIX_0F58 */
3318   {
3319     { "%XEVaddpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3320     { "%XEVadds%XS",	{ XMScalar, VexScalar, EXd, EXxEVexR }, 0 },
3321     { "%XEVaddpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3322     { "%XEVadds%XD",	{ XMScalar, VexScalar, EXq, EXxEVexR }, 0 },
3323   },
3324 
3325   /* PREFIX_0F59 */
3326   {
3327     { "%XEVmulpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3328     { "%XEVmuls%XS",	{ XMScalar, VexScalar, EXd, EXxEVexR }, 0 },
3329     { "%XEVmulpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3330     { "%XEVmuls%XD",	{ XMScalar, VexScalar, EXq, EXxEVexR }, 0 },
3331   },
3332 
3333   /* PREFIX_0F5A */
3334   {
3335     { "%XEVcvtp%XS2pd", { XM, EXEvexHalfBcstXmmq, EXxEVexS }, 0 },
3336     { "%XEVcvts%XS2sd", { XMScalar, VexScalar, EXd, EXxEVexS }, 0 },
3337     { "%XEVcvtp%XD2ps%XY", { XMxmmq, EXx, EXxEVexR }, 0 },
3338     { "%XEVcvts%XD2ss", { XMScalar, VexScalar, EXq, EXxEVexR }, 0 },
3339   },
3340 
3341   /* PREFIX_0F5B */
3342   {
3343     { "Vcvtdq2ps",	{ XM, EXx }, 0 },
3344     { "Vcvttps2dq",	{ XM, EXx }, 0 },
3345     { "Vcvtps2dq",	{ XM, EXx }, 0 },
3346   },
3347 
3348   /* PREFIX_0F5C */
3349   {
3350     { "%XEVsubpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3351     { "%XEVsubs%XS",	{ XMScalar, VexScalar, EXd, EXxEVexR }, 0 },
3352     { "%XEVsubpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3353     { "%XEVsubs%XD",	{ XMScalar, VexScalar, EXq, EXxEVexR }, 0 },
3354   },
3355 
3356   /* PREFIX_0F5D */
3357   {
3358     { "%XEVminpX",	{ XM, Vex, EXx, EXxEVexS }, 0 },
3359     { "%XEVmins%XS",	{ XMScalar, VexScalar, EXd, EXxEVexS }, 0 },
3360     { "%XEVminpX",	{ XM, Vex, EXx, EXxEVexS }, 0 },
3361     { "%XEVmins%XD",	{ XMScalar, VexScalar, EXq, EXxEVexS }, 0 },
3362   },
3363 
3364   /* PREFIX_0F5E */
3365   {
3366     { "%XEVdivpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3367     { "%XEVdivs%XS",	{ XMScalar, VexScalar, EXd, EXxEVexR }, 0 },
3368     { "%XEVdivpX",	{ XM, Vex, EXx, EXxEVexR }, 0 },
3369     { "%XEVdivs%XD",	{ XMScalar, VexScalar, EXq, EXxEVexR }, 0 },
3370   },
3371 
3372   /* PREFIX_0F5F */
3373   {
3374     { "%XEVmaxpX",	{ XM, Vex, EXx, EXxEVexS }, 0 },
3375     { "%XEVmaxs%XS",	{ XMScalar, VexScalar, EXd, EXxEVexS }, 0 },
3376     { "%XEVmaxpX",	{ XM, Vex, EXx, EXxEVexS }, 0 },
3377     { "%XEVmaxs%XD",	{ XMScalar, VexScalar, EXq, EXxEVexS }, 0 },
3378   },
3379 
3380   /* PREFIX_0F60 */
3381   {
3382     { "punpcklbw",{ MX, EMd }, PREFIX_OPCODE },
3383     { Bad_Opcode },
3384     { "punpcklbw",{ MX, EMx }, PREFIX_OPCODE },
3385   },
3386 
3387   /* PREFIX_0F61 */
3388   {
3389     { "punpcklwd",{ MX, EMd }, PREFIX_OPCODE },
3390     { Bad_Opcode },
3391     { "punpcklwd",{ MX, EMx }, PREFIX_OPCODE },
3392   },
3393 
3394   /* PREFIX_0F62 */
3395   {
3396     { "punpckldq",{ MX, EMd }, PREFIX_OPCODE },
3397     { Bad_Opcode },
3398     { "punpckldq",{ MX, EMx }, PREFIX_OPCODE },
3399   },
3400 
3401   /* PREFIX_0F6F */
3402   {
3403     { "movq",	{ MX, EM }, PREFIX_OPCODE },
3404     { "movdqu",	{ XM, EXx }, PREFIX_OPCODE },
3405     { "movdqa",	{ XM, EXx }, PREFIX_OPCODE },
3406   },
3407 
3408   /* PREFIX_0F70 */
3409   {
3410     { "pshufw",	{ MX, EM, Ib }, PREFIX_OPCODE },
3411     { "pshufhw",{ XM, EXx, Ib }, PREFIX_OPCODE },
3412     { "pshufd",	{ XM, EXx, Ib }, PREFIX_OPCODE },
3413     { "pshuflw",{ XM, EXx, Ib }, PREFIX_OPCODE },
3414   },
3415 
3416   /* PREFIX_0F78 */
3417   {
3418     {"vmread",	{ Em, Gm }, 0 },
3419     { Bad_Opcode },
3420     {"extrq",	{ Uxmm, Ib, Ib }, 0 },
3421     {"insertq",	{ XM, Uxmm, Ib, Ib }, 0 },
3422   },
3423 
3424   /* PREFIX_0F79 */
3425   {
3426     {"vmwrite",	{ Gm, Em }, 0 },
3427     { Bad_Opcode },
3428     {"extrq",	{ XM, Uxmm }, 0 },
3429     {"insertq",	{ XM, Uxmm }, 0 },
3430   },
3431 
3432   /* PREFIX_0F7C */
3433   {
3434     { Bad_Opcode },
3435     { Bad_Opcode },
3436     { "Vhaddpd",	{ XM, Vex, EXx }, 0 },
3437     { "Vhaddps",	{ XM, Vex, EXx }, 0 },
3438   },
3439 
3440   /* PREFIX_0F7D */
3441   {
3442     { Bad_Opcode },
3443     { Bad_Opcode },
3444     { "Vhsubpd",	{ XM, Vex, EXx }, 0 },
3445     { "Vhsubps",	{ XM, Vex, EXx }, 0 },
3446   },
3447 
3448   /* PREFIX_0F7E */
3449   {
3450     { "movK",	{ Edq, MX }, PREFIX_OPCODE },
3451     { "movq",	{ XM, EXq }, PREFIX_OPCODE },
3452     { "movK",	{ Edq, XM }, PREFIX_OPCODE },
3453   },
3454 
3455   /* PREFIX_0F7F */
3456   {
3457     { "movq",	{ EMS, MX }, PREFIX_OPCODE },
3458     { "movdqu",	{ EXxS, XM }, PREFIX_OPCODE },
3459     { "movdqa",	{ EXxS, XM }, PREFIX_OPCODE },
3460   },
3461 
3462   /* PREFIX_0FAE_REG_0_MOD_3 */
3463   {
3464     { Bad_Opcode },
3465     { "rdfsbase", { Ev }, 0 },
3466   },
3467 
3468   /* PREFIX_0FAE_REG_1_MOD_3 */
3469   {
3470     { Bad_Opcode },
3471     { "rdgsbase", { Ev }, 0 },
3472   },
3473 
3474   /* PREFIX_0FAE_REG_2_MOD_3 */
3475   {
3476     { Bad_Opcode },
3477     { "wrfsbase", { Ev }, 0 },
3478   },
3479 
3480   /* PREFIX_0FAE_REG_3_MOD_3 */
3481   {
3482     { Bad_Opcode },
3483     { "wrgsbase", { Ev }, 0 },
3484   },
3485 
3486   /* PREFIX_0FAE_REG_4_MOD_0 */
3487   {
3488     { "xsave",	{ FXSAVE }, PREFIX_REX2_ILLEGAL },
3489     { "ptwrite{%LQ|}", { Edq }, 0 },
3490   },
3491 
3492   /* PREFIX_0FAE_REG_4_MOD_3 */
3493   {
3494     { Bad_Opcode },
3495     { "ptwrite{%LQ|}", { Edq }, 0 },
3496   },
3497 
3498   /* PREFIX_0FAE_REG_5_MOD_3 */
3499   {
3500     { "lfence",		{ Skip_MODRM }, 0 },
3501     { "incsspK",	{ Edq }, PREFIX_OPCODE },
3502   },
3503 
3504   /* PREFIX_0FAE_REG_6_MOD_0 */
3505   {
3506     { "xsaveopt",	{ FXSAVE }, PREFIX_OPCODE | PREFIX_REX2_ILLEGAL },
3507     { "clrssbsy",	{ Mq }, PREFIX_OPCODE },
3508     { "clwb",	{ Mb }, PREFIX_OPCODE },
3509   },
3510 
3511   /* PREFIX_0FAE_REG_6_MOD_3 */
3512   {
3513     { RM_TABLE (RM_0FAE_REG_6_MOD_3_P_0) },
3514     { "umonitor",	{ Eva }, PREFIX_OPCODE },
3515     { "tpause",	{ Edq }, PREFIX_OPCODE },
3516     { "umwait",	{ Edq }, PREFIX_OPCODE },
3517   },
3518 
3519   /* PREFIX_0FAE_REG_7_MOD_0 */
3520   {
3521     { "clflush",	{ Mb }, 0 },
3522     { Bad_Opcode },
3523     { "clflushopt",	{ Mb }, 0 },
3524   },
3525 
3526   /* PREFIX_0FB8 */
3527   {
3528     { Bad_Opcode },
3529     { "popcntS", { Gv, Ev }, 0 },
3530   },
3531 
3532   /* PREFIX_0FBC */
3533   {
3534     { "bsfS",	{ Gv, Ev }, 0 },
3535     { "tzcntS",	{ Gv, Ev }, 0 },
3536     { "bsfS",	{ Gv, Ev }, 0 },
3537   },
3538 
3539   /* PREFIX_0FBD */
3540   {
3541     { "bsrS",	{ Gv, Ev }, 0 },
3542     { "lzcntS",	{ Gv, Ev }, 0 },
3543     { "bsrS",	{ Gv, Ev }, 0 },
3544   },
3545 
3546   /* PREFIX_0FC2 */
3547   {
3548     { "VcmppX",	{ XM, Vex, EXx, CMP }, 0 },
3549     { "Vcmpss",	{ XMScalar, VexScalar, EXd, CMP }, 0 },
3550     { "VcmppX",	{ XM, Vex, EXx, CMP }, 0 },
3551     { "Vcmpsd",	{ XMScalar, VexScalar, EXq, CMP }, 0 },
3552   },
3553 
3554   /* PREFIX_0FC7_REG_6_MOD_0 */
3555   {
3556     { "vmptrld",{ Mq }, 0 },
3557     { "vmxon",	{ Mq }, 0 },
3558     { "vmclear",{ Mq }, 0 },
3559   },
3560 
3561   /* PREFIX_0FC7_REG_6_MOD_3 */
3562   {
3563     { "rdrand",	{ Ev }, 0 },
3564     { X86_64_TABLE (X86_64_0FC7_REG_6_MOD_3_PREFIX_1) },
3565     { "rdrand",	{ Ev }, 0 }
3566   },
3567 
3568   /* PREFIX_0FC7_REG_7_MOD_3 */
3569   {
3570     { "rdseed",	{ Ev }, 0 },
3571     { "rdpid",	{ Em }, 0 },
3572     { "rdseed",	{ Ev }, 0 },
3573   },
3574 
3575   /* PREFIX_0FD0 */
3576   {
3577     { Bad_Opcode },
3578     { Bad_Opcode },
3579     { "VaddsubpX",	{ XM, Vex, EXx }, 0 },
3580     { "VaddsubpX",	{ XM, Vex, EXx }, 0 },
3581   },
3582 
3583   /* PREFIX_0FD6 */
3584   {
3585     { Bad_Opcode },
3586     { "movq2dq",{ XM, Nq }, 0 },
3587     { "movq",	{ EXqS, XM }, 0 },
3588     { "movdq2q",{ MX, Ux }, 0 },
3589   },
3590 
3591   /* PREFIX_0FE6 */
3592   {
3593     { Bad_Opcode },
3594     { "Vcvtdq2pd",	{ XM, EXxmmq }, 0 },
3595     { "Vcvttpd2dq%XY",	{ XMM, EXx }, 0 },
3596     { "Vcvtpd2dq%XY",	{ XMM, EXx }, 0 },
3597   },
3598 
3599   /* PREFIX_0FE7 */
3600   {
3601     { "movntq",		{ Mq, MX }, 0 },
3602     { Bad_Opcode },
3603     { "movntdq",	{ Mx, XM }, 0 },
3604   },
3605 
3606   /* PREFIX_0FF0 */
3607   {
3608     { Bad_Opcode },
3609     { Bad_Opcode },
3610     { Bad_Opcode },
3611     { "Vlddqu",		{ XM, M }, 0 },
3612   },
3613 
3614   /* PREFIX_0FF7 */
3615   {
3616     { "maskmovq", { MX, Nq }, PREFIX_OPCODE },
3617     { Bad_Opcode },
3618     { "maskmovdqu", { XM, Ux }, PREFIX_OPCODE },
3619   },
3620 
3621   /* PREFIX_0F38D8 */
3622   {
3623     { Bad_Opcode },
3624     { REG_TABLE (REG_0F38D8_PREFIX_1) },
3625   },
3626 
3627   /* PREFIX_0F38DC */
3628   {
3629     { Bad_Opcode },
3630     { MOD_TABLE (MOD_0F38DC_PREFIX_1) },
3631     { "aesenc", { XM, EXx }, 0 },
3632   },
3633 
3634   /* PREFIX_0F38DD */
3635   {
3636     { Bad_Opcode },
3637     { "aesdec128kl", { XM, M }, 0 },
3638     { "aesenclast", { XM, EXx }, 0 },
3639   },
3640 
3641   /* PREFIX_0F38DE */
3642   {
3643     { Bad_Opcode },
3644     { "aesenc256kl", { XM, M }, 0 },
3645     { "aesdec", { XM, EXx }, 0 },
3646   },
3647 
3648   /* PREFIX_0F38DF */
3649   {
3650     { Bad_Opcode },
3651     { "aesdec256kl", { XM, M }, 0 },
3652     { "aesdeclast", { XM, EXx }, 0 },
3653   },
3654 
3655   /* PREFIX_0F38F0 */
3656   {
3657     { "movbeS",	{ Gv, Mv }, PREFIX_OPCODE },
3658     { Bad_Opcode },
3659     { "movbeS",	{ Gv, Mv }, PREFIX_OPCODE },
3660     { "crc32A",	{ Gdq, Eb }, PREFIX_OPCODE },
3661   },
3662 
3663   /* PREFIX_0F38F1 */
3664   {
3665     { "movbeS",	{ Mv, Gv }, PREFIX_OPCODE },
3666     { Bad_Opcode },
3667     { "movbeS",	{ Mv, Gv }, PREFIX_OPCODE },
3668     { "crc32Q",	{ Gdq, Ev }, PREFIX_OPCODE },
3669   },
3670 
3671   /* PREFIX_0F38F6 */
3672   {
3673     { "wrssK",	{ M, Gdq }, 0 },
3674     { "adoxL",	{ VexGdq, Gdq, Edq }, 0 },
3675     { "adcxL",	{ VexGdq, Gdq, Edq }, 0 },
3676     { Bad_Opcode },
3677   },
3678 
3679   /* PREFIX_0F38F8_M_0 */
3680   {
3681     { Bad_Opcode },
3682     { "enqcmds", { Gva, M }, 0 },
3683     { "movdir64b", { Gva, M }, 0 },
3684     { "enqcmd",	{ Gva, M }, 0 },
3685   },
3686 
3687   /* PREFIX_0F38F8_M_1_X86_64 */
3688   {
3689     { Bad_Opcode },
3690     { "uwrmsr",		{ Gq, Rq }, 0 },
3691     { Bad_Opcode },
3692     { "urdmsr",		{ Rq, Gq }, 0 },
3693   },
3694 
3695   /* PREFIX_0F38FA */
3696   {
3697     { Bad_Opcode },
3698     { "encodekey128", { Gd, Rd }, 0 },
3699   },
3700 
3701   /* PREFIX_0F38FB */
3702   {
3703     { Bad_Opcode },
3704     { "encodekey256", { Gd, Rd }, 0 },
3705   },
3706 
3707   /* PREFIX_0F38FC */
3708   {
3709     { "aadd",	{ Mdq, Gdq }, 0 },
3710     { "axor",	{ Mdq, Gdq }, 0 },
3711     { "aand",	{ Mdq, Gdq }, 0 },
3712     { "aor",	{ Mdq, Gdq }, 0 },
3713   },
3714 
3715   /* PREFIX_0F3A0F */
3716   {
3717     { Bad_Opcode },
3718     { REG_TABLE (REG_0F3A0F_P_1) },
3719   },
3720 
3721   /* PREFIX_VEX_0F12 */
3722   {
3723     { VEX_LEN_TABLE (VEX_LEN_0F12_P_0) },
3724     { "%XEvmov%XSldup",	{ XM, EXEvexXNoBcst }, 0 },
3725     { VEX_LEN_TABLE (VEX_LEN_0F12_P_2) },
3726     { "%XEvmov%XDdup",	{ XM, EXymmq }, 0 },
3727   },
3728 
3729   /* PREFIX_VEX_0F16 */
3730   {
3731     { VEX_LEN_TABLE (VEX_LEN_0F16_P_0) },
3732     { "%XEvmov%XShdup",	{ XM, EXEvexXNoBcst }, 0 },
3733     { VEX_LEN_TABLE (VEX_LEN_0F16_P_2) },
3734   },
3735 
3736   /* PREFIX_VEX_0F2A */
3737   {
3738     { Bad_Opcode },
3739     { "%XEvcvtsi2ssY{%LQ|}",	{ XMScalar, VexScalar, EXxEVexR, Edq }, 0 },
3740     { Bad_Opcode },
3741     { "%XEvcvtsi2sdY{%LQ|}",	{ XMScalar, VexScalar, EXxEVexR64, Edq }, 0 },
3742   },
3743 
3744   /* PREFIX_VEX_0F2C */
3745   {
3746     { Bad_Opcode },
3747     { "%XEvcvttss2si",	{ Gdq, EXd, EXxEVexS }, 0 },
3748     { Bad_Opcode },
3749     { "%XEvcvttsd2si",	{ Gdq, EXq, EXxEVexS }, 0 },
3750   },
3751 
3752   /* PREFIX_VEX_0F2D */
3753   {
3754     { Bad_Opcode },
3755     { "%XEvcvtss2si",	{ Gdq, EXd, EXxEVexR }, 0 },
3756     { Bad_Opcode },
3757     { "%XEvcvtsd2si",	{ Gdq, EXq, EXxEVexR }, 0 },
3758   },
3759 
3760   /* PREFIX_VEX_0F41_L_1_W_0 */
3761   {
3762     { "kandw",          { MaskG, MaskVex, MaskR }, 0 },
3763     { Bad_Opcode },
3764     { "kandb",          { MaskG, MaskVex, MaskR }, 0 },
3765   },
3766 
3767   /* PREFIX_VEX_0F41_L_1_W_1 */
3768   {
3769     { "kandq",          { MaskG, MaskVex, MaskR }, 0 },
3770     { Bad_Opcode },
3771     { "kandd",          { MaskG, MaskVex, MaskR }, 0 },
3772   },
3773 
3774   /* PREFIX_VEX_0F42_L_1_W_0 */
3775   {
3776     { "kandnw",         { MaskG, MaskVex, MaskR }, 0 },
3777     { Bad_Opcode },
3778     { "kandnb",         { MaskG, MaskVex, MaskR }, 0 },
3779   },
3780 
3781   /* PREFIX_VEX_0F42_L_1_W_1 */
3782   {
3783     { "kandnq",         { MaskG, MaskVex, MaskR }, 0 },
3784     { Bad_Opcode },
3785     { "kandnd",         { MaskG, MaskVex, MaskR }, 0 },
3786   },
3787 
3788   /* PREFIX_VEX_0F44_L_0_W_0 */
3789   {
3790     { "knotw",          { MaskG, MaskR }, 0 },
3791     { Bad_Opcode },
3792     { "knotb",          { MaskG, MaskR }, 0 },
3793   },
3794 
3795   /* PREFIX_VEX_0F44_L_0_W_1 */
3796   {
3797     { "knotq",          { MaskG, MaskR }, 0 },
3798     { Bad_Opcode },
3799     { "knotd",          { MaskG, MaskR }, 0 },
3800   },
3801 
3802   /* PREFIX_VEX_0F45_L_1_W_0 */
3803   {
3804     { "korw",       { MaskG, MaskVex, MaskR }, 0 },
3805     { Bad_Opcode },
3806     { "korb",       { MaskG, MaskVex, MaskR }, 0 },
3807   },
3808 
3809   /* PREFIX_VEX_0F45_L_1_W_1 */
3810   {
3811     { "korq",       { MaskG, MaskVex, MaskR }, 0 },
3812     { Bad_Opcode },
3813     { "kord",       { MaskG, MaskVex, MaskR }, 0 },
3814   },
3815 
3816   /* PREFIX_VEX_0F46_L_1_W_0 */
3817   {
3818     { "kxnorw",     { MaskG, MaskVex, MaskR }, 0 },
3819     { Bad_Opcode },
3820     { "kxnorb",     { MaskG, MaskVex, MaskR }, 0 },
3821   },
3822 
3823   /* PREFIX_VEX_0F46_L_1_W_1 */
3824   {
3825     { "kxnorq",     { MaskG, MaskVex, MaskR }, 0 },
3826     { Bad_Opcode },
3827     { "kxnord",     { MaskG, MaskVex, MaskR }, 0 },
3828   },
3829 
3830   /* PREFIX_VEX_0F47_L_1_W_0 */
3831   {
3832     { "kxorw",      { MaskG, MaskVex, MaskR }, 0 },
3833     { Bad_Opcode },
3834     { "kxorb",      { MaskG, MaskVex, MaskR }, 0 },
3835   },
3836 
3837   /* PREFIX_VEX_0F47_L_1_W_1 */
3838   {
3839     { "kxorq",      { MaskG, MaskVex, MaskR }, 0 },
3840     { Bad_Opcode },
3841     { "kxord",      { MaskG, MaskVex, MaskR }, 0 },
3842   },
3843 
3844   /* PREFIX_VEX_0F4A_L_1_W_0 */
3845   {
3846     { "kaddw",          { MaskG, MaskVex, MaskR }, 0 },
3847     { Bad_Opcode },
3848     { "kaddb",          { MaskG, MaskVex, MaskR }, 0 },
3849   },
3850 
3851   /* PREFIX_VEX_0F4A_L_1_W_1 */
3852   {
3853     { "kaddq",          { MaskG, MaskVex, MaskR }, 0 },
3854     { Bad_Opcode },
3855     { "kaddd",          { MaskG, MaskVex, MaskR }, 0 },
3856   },
3857 
3858   /* PREFIX_VEX_0F4B_L_1_W_0 */
3859   {
3860     { "kunpckwd",   { MaskG, MaskVex, MaskR }, 0 },
3861     { Bad_Opcode },
3862     { "kunpckbw",   { MaskG, MaskVex, MaskR }, 0 },
3863   },
3864 
3865   /* PREFIX_VEX_0F4B_L_1_W_1 */
3866   {
3867     { "kunpckdq",   { MaskG, MaskVex, MaskR }, 0 },
3868   },
3869 
3870   /* PREFIX_VEX_0F6F */
3871   {
3872     { Bad_Opcode },
3873     { "vmovdqu",	{ XM, EXx }, 0 },
3874     { "vmovdqa",	{ XM, EXx }, 0 },
3875   },
3876 
3877   /* PREFIX_VEX_0F70 */
3878   {
3879     { Bad_Opcode },
3880     { "vpshufhw",	{ XM, EXx, Ib }, 0 },
3881     { "vpshufd",	{ XM, EXx, Ib }, 0 },
3882     { "vpshuflw",	{ XM, EXx, Ib }, 0 },
3883   },
3884 
3885   /* PREFIX_VEX_0F7E */
3886   {
3887     { Bad_Opcode },
3888     { VEX_LEN_TABLE (VEX_LEN_0F7E_P_1) },
3889     { VEX_LEN_TABLE (VEX_LEN_0F7E_P_2) },
3890   },
3891 
3892   /* PREFIX_VEX_0F7F */
3893   {
3894     { Bad_Opcode },
3895     { "vmovdqu",	{ EXxS, XM }, 0 },
3896     { "vmovdqa",	{ EXxS, XM }, 0 },
3897   },
3898 
3899   /* PREFIX_VEX_0F90_L_0_W_0 */
3900   {
3901     { "%XEkmovw",		{ MaskG, MaskE }, 0 },
3902     { Bad_Opcode },
3903     { "%XEkmovb",		{ MaskG, MaskBDE }, 0 },
3904   },
3905 
3906   /* PREFIX_VEX_0F90_L_0_W_1 */
3907   {
3908     { "%XEkmovq",		{ MaskG, MaskE }, 0 },
3909     { Bad_Opcode },
3910     { "%XEkmovd",		{ MaskG, MaskBDE }, 0 },
3911   },
3912 
3913   /* PREFIX_VEX_0F91_L_0_W_0 */
3914   {
3915     { "%XEkmovw",		{ Mw, MaskG }, 0 },
3916     { Bad_Opcode },
3917     { "%XEkmovb",		{ Mb, MaskG }, 0 },
3918   },
3919 
3920   /* PREFIX_VEX_0F91_L_0_W_1 */
3921   {
3922     { "%XEkmovq",		{ Mq, MaskG }, 0 },
3923     { Bad_Opcode },
3924     { "%XEkmovd",		{ Md, MaskG }, 0 },
3925   },
3926 
3927   /* PREFIX_VEX_0F92_L_0_W_0 */
3928   {
3929     { "%XEkmovw",		{ MaskG, Rdq }, 0 },
3930     { Bad_Opcode },
3931     { "%XEkmovb",		{ MaskG, Rdq }, 0 },
3932     { "%XEkmovd",		{ MaskG, Rdq }, 0 },
3933   },
3934 
3935   /* PREFIX_VEX_0F92_L_0_W_1 */
3936   {
3937     { Bad_Opcode },
3938     { Bad_Opcode },
3939     { Bad_Opcode },
3940     { "%XEkmovK",		{ MaskG, Rdq }, 0 },
3941   },
3942 
3943   /* PREFIX_VEX_0F93_L_0_W_0 */
3944   {
3945     { "%XEkmovw",		{ Gdq, MaskR }, 0 },
3946     { Bad_Opcode },
3947     { "%XEkmovb",		{ Gdq, MaskR }, 0 },
3948     { "%XEkmovd",		{ Gdq, MaskR }, 0 },
3949   },
3950 
3951   /* PREFIX_VEX_0F93_L_0_W_1 */
3952   {
3953     { Bad_Opcode },
3954     { Bad_Opcode },
3955     { Bad_Opcode },
3956     { "%XEkmovK",		{ Gdq, MaskR }, 0 },
3957   },
3958 
3959   /* PREFIX_VEX_0F98_L_0_W_0 */
3960   {
3961     { "kortestw", { MaskG, MaskR }, 0 },
3962     { Bad_Opcode },
3963     { "kortestb", { MaskG, MaskR }, 0 },
3964   },
3965 
3966   /* PREFIX_VEX_0F98_L_0_W_1 */
3967   {
3968     { "kortestq", { MaskG, MaskR }, 0 },
3969     { Bad_Opcode },
3970     { "kortestd", { MaskG, MaskR }, 0 },
3971   },
3972 
3973   /* PREFIX_VEX_0F99_L_0_W_0 */
3974   {
3975     { "ktestw", { MaskG, MaskR }, 0 },
3976     { Bad_Opcode },
3977     { "ktestb", { MaskG, MaskR }, 0 },
3978   },
3979 
3980   /* PREFIX_VEX_0F99_L_0_W_1 */
3981   {
3982     { "ktestq", { MaskG, MaskR }, 0 },
3983     { Bad_Opcode },
3984     { "ktestd", { MaskG, MaskR }, 0 },
3985   },
3986 
3987   /* PREFIX_VEX_0F3849_X86_64_L_0_W_0_M_0 */
3988   {
3989     { "ldtilecfg", { M }, 0 },
3990     { Bad_Opcode },
3991     { "sttilecfg", { M }, 0 },
3992   },
3993 
3994   /* PREFIX_VEX_0F3849_X86_64_L_0_W_0_M_1 */
3995   {
3996     { REG_TABLE (REG_VEX_0F3849_X86_64_L_0_W_0_M_1_P_0) },
3997     { Bad_Opcode },
3998     { Bad_Opcode },
3999     { RM_TABLE (RM_VEX_0F3849_X86_64_L_0_W_0_M_1_P_3) },
4000   },
4001 
4002   /* PREFIX_VEX_0F384B_X86_64_L_0_W_0 */
4003   {
4004     { Bad_Opcode },
4005     { "tilestored",	{ MVexSIBMEM, TMM }, 0 },
4006     { "tileloaddt1",	{ TMM, MVexSIBMEM }, 0 },
4007     { "tileloadd",	{ TMM, MVexSIBMEM }, 0 },
4008   },
4009 
4010   /* PREFIX_VEX_0F3850_W_0 */
4011   {
4012     { "vpdpbuud",	{ XM, Vex, EXx }, 0 },
4013     { "vpdpbsud",	{ XM, Vex, EXx }, 0 },
4014     { "%XVvpdpbusd",	{ XM, Vex, EXx }, 0 },
4015     { "vpdpbssd",	{ XM, Vex, EXx }, 0 },
4016   },
4017 
4018   /* PREFIX_VEX_0F3851_W_0 */
4019   {
4020     { "vpdpbuuds",	{ XM, Vex, EXx }, 0 },
4021     { "vpdpbsuds",	{ XM, Vex, EXx }, 0 },
4022     { "%XVvpdpbusds",	{ XM, Vex, EXx }, 0 },
4023     { "vpdpbssds",	{ XM, Vex, EXx }, 0 },
4024   },
4025   /* PREFIX_VEX_0F385C_X86_64_L_0_W_0 */
4026   {
4027     { Bad_Opcode },
4028     { "tdpbf16ps", { TMM, Rtmm, VexTmm }, 0 },
4029     { Bad_Opcode },
4030     { "tdpfp16ps", { TMM, Rtmm, VexTmm }, 0 },
4031   },
4032 
4033   /* PREFIX_VEX_0F385E_X86_64_L_0_W_0 */
4034   {
4035     { "tdpbuud", {TMM, Rtmm, VexTmm }, 0 },
4036     { "tdpbsud", {TMM, Rtmm, VexTmm }, 0 },
4037     { "tdpbusd", {TMM, Rtmm, VexTmm }, 0 },
4038     { "tdpbssd", {TMM, Rtmm, VexTmm }, 0 },
4039   },
4040 
4041   /* PREFIX_VEX_0F386C_X86_64_L_0_W_0 */
4042   {
4043     { "tcmmrlfp16ps", { TMM, Rtmm, VexTmm }, 0 },
4044     { Bad_Opcode },
4045     { "tcmmimfp16ps", { TMM, Rtmm, VexTmm }, 0 },
4046   },
4047 
4048   /* PREFIX_VEX_0F3872 */
4049   {
4050     { Bad_Opcode },
4051     { VEX_W_TABLE (VEX_W_0F3872_P_1) },
4052   },
4053 
4054   /* PREFIX_VEX_0F38B0_W_0 */
4055   {
4056     { "vcvtneoph2ps", { XM, Mx }, 0 },
4057     { "vcvtneebf162ps", { XM, Mx }, 0 },
4058     { "vcvtneeph2ps", { XM, Mx }, 0 },
4059     { "vcvtneobf162ps", { XM, Mx }, 0 },
4060   },
4061 
4062   /* PREFIX_VEX_0F38B1_W_0 */
4063   {
4064     { Bad_Opcode },
4065     { "vbcstnebf162ps", { XM, Mw }, 0 },
4066     { "vbcstnesh2ps", { XM, Mw }, 0 },
4067   },
4068 
4069   /* PREFIX_VEX_0F38D2_W_0 */
4070   {
4071     { "vpdpwuud",	{ XM, Vex, EXx }, 0 },
4072     { "vpdpwsud",	{ XM, Vex, EXx }, 0 },
4073     { "vpdpwusd",	{ XM, Vex, EXx }, 0 },
4074   },
4075 
4076   /* PREFIX_VEX_0F38D3_W_0 */
4077   {
4078     { "vpdpwuuds",	{ XM, Vex, EXx }, 0 },
4079     { "vpdpwsuds",	{ XM, Vex, EXx }, 0 },
4080     { "vpdpwusds",	{ XM, Vex, EXx }, 0 },
4081   },
4082 
4083   /* PREFIX_VEX_0F38CB */
4084   {
4085     { Bad_Opcode },
4086     { Bad_Opcode },
4087     { Bad_Opcode },
4088     { VEX_W_TABLE (VEX_W_0F38CB_P_3) },
4089   },
4090 
4091   /* PREFIX_VEX_0F38CC */
4092   {
4093     { Bad_Opcode },
4094     { Bad_Opcode },
4095     { Bad_Opcode },
4096     { VEX_W_TABLE (VEX_W_0F38CC_P_3) },
4097   },
4098 
4099   /* PREFIX_VEX_0F38CD */
4100   {
4101     { Bad_Opcode },
4102     { Bad_Opcode },
4103     { Bad_Opcode },
4104     { VEX_W_TABLE (VEX_W_0F38CD_P_3) },
4105   },
4106 
4107   /* PREFIX_VEX_0F38DA_W_0 */
4108   {
4109     { VEX_LEN_TABLE (VEX_LEN_0F38DA_W_0_P_0) },
4110     { "vsm4key4", { XM, Vex, EXx }, 0 },
4111     { VEX_LEN_TABLE (VEX_LEN_0F38DA_W_0_P_2) },
4112     { "vsm4rnds4", { XM, Vex, EXx }, 0 },
4113   },
4114 
4115   /* PREFIX_VEX_0F38F2_L_0 */
4116   {
4117     { "%NFandnS",          { Gdq, VexGdq, Edq }, 0 },
4118   },
4119 
4120   /* PREFIX_VEX_0F38F3_L_0 */
4121   {
4122     { REG_TABLE (REG_VEX_0F38F3_L_0_P_0) },
4123   },
4124 
4125   /* PREFIX_VEX_0F38F5_L_0 */
4126   {
4127     { "%NFbzhiS",	{ Gdq, Edq, VexGdq }, 0 },
4128     { "%XEpextS",		{ Gdq, VexGdq, Edq }, 0 },
4129     { Bad_Opcode },
4130     { "%XEpdepS",		{ Gdq, VexGdq, Edq }, 0 },
4131   },
4132 
4133   /* PREFIX_VEX_0F38F6_L_0 */
4134   {
4135     { Bad_Opcode },
4136     { Bad_Opcode },
4137     { Bad_Opcode },
4138     { "%XEmulxS",		{ Gdq, VexGdq, Edq }, 0 },
4139   },
4140 
4141   /* PREFIX_VEX_0F38F7_L_0 */
4142   {
4143     { "%NFbextrS",	{ Gdq, Edq, VexGdq }, 0 },
4144     { "%XEsarxS",		{ Gdq, Edq, VexGdq }, 0 },
4145     { "%XEshlxS",		{ Gdq, Edq, VexGdq }, 0 },
4146     { "%XEshrxS",		{ Gdq, Edq, VexGdq }, 0 },
4147   },
4148 
4149   /* PREFIX_VEX_0F3AF0_L_0 */
4150   {
4151     { Bad_Opcode },
4152     { Bad_Opcode },
4153     { Bad_Opcode },
4154     { "%XErorxS",		{ Gdq, Edq, Ib }, 0 },
4155   },
4156 
4157   /* PREFIX_VEX_MAP7_F8_L_0_W_0_R_0_X86_64 */
4158   {
4159     { Bad_Opcode },
4160     { "uwrmsr", { Skip_MODRM, Id, Rq }, 0 },
4161     { Bad_Opcode },
4162     { "urdmsr", { Rq, Id }, 0 },
4163   },
4164 
4165 #include "i386-dis-evex-prefix.h"
4166 };
4167 
4168 static const struct dis386 x86_64_table[][2] = {
4169   /* X86_64_06 */
4170   {
4171     { "pushP", { es }, 0 },
4172   },
4173 
4174   /* X86_64_07 */
4175   {
4176     { "popP", { es }, 0 },
4177   },
4178 
4179   /* X86_64_0E */
4180   {
4181     { "pushP", { cs }, 0 },
4182   },
4183 
4184   /* X86_64_16 */
4185   {
4186     { "pushP", { ss }, 0 },
4187   },
4188 
4189   /* X86_64_17 */
4190   {
4191     { "popP", { ss }, 0 },
4192   },
4193 
4194   /* X86_64_1E */
4195   {
4196     { "pushP", { ds }, 0 },
4197   },
4198 
4199   /* X86_64_1F */
4200   {
4201     { "popP", { ds }, 0 },
4202   },
4203 
4204   /* X86_64_27 */
4205   {
4206     { "daa", { XX }, 0 },
4207   },
4208 
4209   /* X86_64_2F */
4210   {
4211     { "das", { XX }, 0 },
4212   },
4213 
4214   /* X86_64_37 */
4215   {
4216     { "aaa", { XX }, 0 },
4217   },
4218 
4219   /* X86_64_3F */
4220   {
4221     { "aas", { XX }, 0 },
4222   },
4223 
4224   /* X86_64_60 */
4225   {
4226     { "pushaP", { XX }, 0 },
4227   },
4228 
4229   /* X86_64_61 */
4230   {
4231     { "popaP", { XX }, 0 },
4232   },
4233 
4234   /* X86_64_62 */
4235   {
4236     { MOD_TABLE (MOD_62_32BIT) },
4237     { EVEX_TABLE () },
4238   },
4239 
4240   /* X86_64_63 */
4241   {
4242     { "arplS", { Sv, Gv }, 0 },
4243     { "movs", { Gv, { MOVSXD_Fixup, movsxd_mode } }, 0 },
4244   },
4245 
4246   /* X86_64_6D */
4247   {
4248     { "ins{R|}", { Yzr, indirDX }, 0 },
4249     { "ins{G|}", { Yzr, indirDX }, 0 },
4250   },
4251 
4252   /* X86_64_6F */
4253   {
4254     { "outs{R|}", { indirDXr, Xz }, 0 },
4255     { "outs{G|}", { indirDXr, Xz }, 0 },
4256   },
4257 
4258   /* X86_64_82 */
4259   {
4260     /* Opcode 0x82 is an alias of opcode 0x80 in 32-bit mode.  */
4261     { REG_TABLE (REG_80) },
4262   },
4263 
4264   /* X86_64_9A */
4265   {
4266     { "{l|}call{P|}", { Ap }, 0 },
4267   },
4268 
4269   /* X86_64_C2 */
4270   {
4271     { "retP",		{ Iw, BND }, 0 },
4272     { "ret@",		{ Iw, BND }, 0 },
4273   },
4274 
4275   /* X86_64_C3 */
4276   {
4277     { "retP",		{ BND }, 0 },
4278     { "ret@",		{ BND }, 0 },
4279   },
4280 
4281   /* X86_64_C4 */
4282   {
4283     { MOD_TABLE (MOD_C4_32BIT) },
4284     { VEX_C4_TABLE () },
4285   },
4286 
4287   /* X86_64_C5 */
4288   {
4289     { MOD_TABLE (MOD_C5_32BIT) },
4290     { VEX_C5_TABLE () },
4291   },
4292 
4293   /* X86_64_CE */
4294   {
4295     { "into", { XX }, 0 },
4296   },
4297 
4298   /* X86_64_D4 */
4299   {
4300     { "aam", { Ib }, 0 },
4301   },
4302 
4303   /* X86_64_D5 */
4304   {
4305     { "aad", { Ib }, 0 },
4306   },
4307 
4308   /* X86_64_E8 */
4309   {
4310     { "callP",		{ Jv, BND }, 0 },
4311     { "call@",		{ Jv, BND }, PREFIX_REX2_ILLEGAL }
4312   },
4313 
4314   /* X86_64_E9 */
4315   {
4316     { "jmpP",		{ Jv, BND }, 0 },
4317     { "jmp@",		{ Jv, BND }, PREFIX_REX2_ILLEGAL }
4318   },
4319 
4320   /* X86_64_EA */
4321   {
4322     { "{l|}jmp{P|}", { Ap }, 0 },
4323   },
4324 
4325   /* X86_64_0F00_REG_6 */
4326   {
4327     { Bad_Opcode },
4328     { PREFIX_TABLE (PREFIX_0F00_REG_6_X86_64) },
4329   },
4330 
4331   /* X86_64_0F01_REG_0 */
4332   {
4333     { "sgdt{Q|Q}", { M }, 0 },
4334     { "sgdt", { M }, 0 },
4335   },
4336 
4337   /* X86_64_0F01_REG_0_MOD_3_RM_6_P_1 */
4338   {
4339     { Bad_Opcode },
4340     { "wrmsrlist",	{ Skip_MODRM }, 0 },
4341   },
4342 
4343   /* X86_64_0F01_REG_0_MOD_3_RM_6_P_3 */
4344   {
4345     { Bad_Opcode },
4346     { "rdmsrlist",	{ Skip_MODRM }, 0 },
4347   },
4348 
4349   /* X86_64_0F01_REG_0_MOD_3_RM_7_P_0 */
4350   {
4351     { Bad_Opcode },
4352     { "pbndkb",		{ Skip_MODRM }, 0 },
4353   },
4354 
4355   /* X86_64_0F01_REG_1 */
4356   {
4357     { "sidt{Q|Q}", { M }, 0 },
4358     { "sidt", { M }, 0 },
4359   },
4360 
4361   /* X86_64_0F01_REG_1_RM_2_PREFIX_1 */
4362   {
4363     { Bad_Opcode },
4364     { "eretu",		{ Skip_MODRM }, 0 },
4365   },
4366 
4367   /* X86_64_0F01_REG_1_RM_2_PREFIX_3 */
4368   {
4369     { Bad_Opcode },
4370     { "erets",		{ Skip_MODRM }, 0 },
4371   },
4372 
4373   /* X86_64_0F01_REG_1_RM_5_PREFIX_2 */
4374   {
4375     { Bad_Opcode },
4376     { "seamret",	{ Skip_MODRM }, 0 },
4377   },
4378 
4379   /* X86_64_0F01_REG_1_RM_6_PREFIX_2 */
4380   {
4381     { Bad_Opcode },
4382     { "seamops",	{ Skip_MODRM }, 0 },
4383   },
4384 
4385   /* X86_64_0F01_REG_1_RM_7_PREFIX_2 */
4386   {
4387     { Bad_Opcode },
4388     { "seamcall",	{ Skip_MODRM }, 0 },
4389   },
4390 
4391   /* X86_64_0F01_REG_2 */
4392   {
4393     { "lgdt{Q|Q}", { M }, 0 },
4394     { "lgdt", { M }, 0 },
4395   },
4396 
4397   /* X86_64_0F01_REG_3 */
4398   {
4399     { "lidt{Q|Q}", { M }, 0 },
4400     { "lidt", { M }, 0 },
4401   },
4402 
4403   /* X86_64_0F01_REG_5_MOD_3_RM_4_PREFIX_1 */
4404   {
4405     { Bad_Opcode },
4406     { "uiret",	{ Skip_MODRM }, 0 },
4407   },
4408 
4409   /* X86_64_0F01_REG_5_MOD_3_RM_5_PREFIX_1 */
4410   {
4411     { Bad_Opcode },
4412     { "testui",	{ Skip_MODRM }, 0 },
4413   },
4414 
4415   /* X86_64_0F01_REG_5_MOD_3_RM_6_PREFIX_1 */
4416   {
4417     { Bad_Opcode },
4418     { "clui",	{ Skip_MODRM }, 0 },
4419   },
4420 
4421   /* X86_64_0F01_REG_5_MOD_3_RM_7_PREFIX_1 */
4422   {
4423     { Bad_Opcode },
4424     { "stui",	{ Skip_MODRM }, 0 },
4425   },
4426 
4427   /* X86_64_0F01_REG_7_MOD_3_RM_5_PREFIX_1 */
4428   {
4429     { Bad_Opcode },
4430     { "rmpquery", { Skip_MODRM }, 0 },
4431   },
4432 
4433   /* X86_64_0F01_REG_7_MOD_3_RM_6_PREFIX_1 */
4434   {
4435     { Bad_Opcode },
4436     { "rmpadjust",	{ Skip_MODRM }, 0 },
4437   },
4438 
4439   /* X86_64_0F01_REG_7_MOD_3_RM_6_PREFIX_3 */
4440   {
4441     { Bad_Opcode },
4442     { "rmpupdate",	{ Skip_MODRM }, 0 },
4443   },
4444 
4445   /* X86_64_0F01_REG_7_MOD_3_RM_7_PREFIX_1 */
4446   {
4447     { Bad_Opcode },
4448     { "psmash",	{ Skip_MODRM }, 0 },
4449   },
4450 
4451   /* X86_64_0F18_REG_6_MOD_0 */
4452   {
4453     { "nopQ",		{ Ev }, 0 },
4454     { PREFIX_TABLE (PREFIX_0F18_REG_6_MOD_0_X86_64) },
4455   },
4456 
4457   /* X86_64_0F18_REG_7_MOD_0 */
4458   {
4459     { "nopQ",		{ Ev }, 0 },
4460     { PREFIX_TABLE (PREFIX_0F18_REG_7_MOD_0_X86_64) },
4461   },
4462 
4463   {
4464     /* X86_64_0F24 */
4465     { "movZ",		{ Em, Td }, 0 },
4466   },
4467 
4468   {
4469     /* X86_64_0F26 */
4470     { "movZ",		{ Td, Em }, 0 },
4471   },
4472 
4473   {
4474     /* X86_64_0F38F8_M_1 */
4475     { Bad_Opcode },
4476     { PREFIX_TABLE (PREFIX_0F38F8_M_1_X86_64) },
4477   },
4478 
4479   /* X86_64_0FC7_REG_6_MOD_3_PREFIX_1 */
4480   {
4481     { Bad_Opcode },
4482     { "senduipi",	{ Eq }, 0 },
4483   },
4484 
4485   /* X86_64_VEX_0F3849 */
4486   {
4487     { Bad_Opcode },
4488     { VEX_LEN_TABLE (VEX_LEN_0F3849_X86_64) },
4489   },
4490 
4491   /* X86_64_VEX_0F384B */
4492   {
4493     { Bad_Opcode },
4494     { VEX_LEN_TABLE (VEX_LEN_0F384B_X86_64) },
4495   },
4496 
4497   /* X86_64_VEX_0F385C */
4498   {
4499     { Bad_Opcode },
4500     { VEX_LEN_TABLE (VEX_LEN_0F385C_X86_64) },
4501   },
4502 
4503   /* X86_64_VEX_0F385E */
4504   {
4505     { Bad_Opcode },
4506     { VEX_LEN_TABLE (VEX_LEN_0F385E_X86_64) },
4507   },
4508 
4509   /* X86_64_VEX_0F386C */
4510   {
4511     { Bad_Opcode },
4512     { VEX_LEN_TABLE (VEX_LEN_0F386C_X86_64) },
4513   },
4514 
4515   /* X86_64_VEX_0F38E0 */
4516   {
4517     { Bad_Opcode },
4518     { "%XEcmpoxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4519   },
4520 
4521   /* X86_64_VEX_0F38E1 */
4522   {
4523     { Bad_Opcode },
4524     { "%XEcmpnoxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4525   },
4526 
4527   /* X86_64_VEX_0F38E2 */
4528   {
4529     { Bad_Opcode },
4530     { "%XEcmpbxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4531   },
4532 
4533   /* X86_64_VEX_0F38E3 */
4534   {
4535     { Bad_Opcode },
4536     { "%XEcmpnbxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4537   },
4538 
4539   /* X86_64_VEX_0F38E4 */
4540   {
4541     { Bad_Opcode },
4542     { "%XEcmpzxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4543   },
4544 
4545   /* X86_64_VEX_0F38E5 */
4546   {
4547     { Bad_Opcode },
4548     { "%XEcmpnzxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4549   },
4550 
4551   /* X86_64_VEX_0F38E6 */
4552   {
4553     { Bad_Opcode },
4554     { "%XEcmpbexadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4555   },
4556 
4557   /* X86_64_VEX_0F38E7 */
4558   {
4559     { Bad_Opcode },
4560     { "%XEcmpnbexadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4561   },
4562 
4563   /* X86_64_VEX_0F38E8 */
4564   {
4565     { Bad_Opcode },
4566     { "%XEcmpsxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4567   },
4568 
4569   /* X86_64_VEX_0F38E9 */
4570   {
4571     { Bad_Opcode },
4572     { "%XEcmpnsxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4573   },
4574 
4575   /* X86_64_VEX_0F38EA */
4576   {
4577     { Bad_Opcode },
4578     { "%XEcmppxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4579   },
4580 
4581   /* X86_64_VEX_0F38EB */
4582   {
4583     { Bad_Opcode },
4584     { "%XEcmpnpxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4585   },
4586 
4587   /* X86_64_VEX_0F38EC */
4588   {
4589     { Bad_Opcode },
4590     { "%XEcmplxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4591   },
4592 
4593   /* X86_64_VEX_0F38ED */
4594   {
4595     { Bad_Opcode },
4596     { "%XEcmpnlxadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4597   },
4598 
4599   /* X86_64_VEX_0F38EE */
4600   {
4601     { Bad_Opcode },
4602     { "%XEcmplexadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4603   },
4604 
4605   /* X86_64_VEX_0F38EF */
4606   {
4607     { Bad_Opcode },
4608     { "%XEcmpnlexadd", { Mdq, Gdq, VexGdq }, PREFIX_DATA },
4609   },
4610 
4611   /* X86_64_VEX_MAP7_F8_L_0_W_0_R_0 */
4612   {
4613     { Bad_Opcode },
4614     { PREFIX_TABLE (PREFIX_VEX_MAP7_F8_L_0_W_0_R_0_X86_64) },
4615   },
4616 };
4617 
4618 static const struct dis386 three_byte_table[][256] = {
4619 
4620   /* THREE_BYTE_0F38 */
4621   {
4622     /* 00 */
4623     { "pshufb",		{ MX, EM }, PREFIX_OPCODE },
4624     { "phaddw",		{ MX, EM }, PREFIX_OPCODE },
4625     { "phaddd",		{ MX, EM }, PREFIX_OPCODE },
4626     { "phaddsw",	{ MX, EM }, PREFIX_OPCODE },
4627     { "pmaddubsw",	{ MX, EM }, PREFIX_OPCODE },
4628     { "phsubw",		{ MX, EM }, PREFIX_OPCODE },
4629     { "phsubd",		{ MX, EM }, PREFIX_OPCODE },
4630     { "phsubsw",	{ MX, EM }, PREFIX_OPCODE },
4631     /* 08 */
4632     { "psignb",		{ MX, EM }, PREFIX_OPCODE },
4633     { "psignw",		{ MX, EM }, PREFIX_OPCODE },
4634     { "psignd",		{ MX, EM }, PREFIX_OPCODE },
4635     { "pmulhrsw",	{ MX, EM }, PREFIX_OPCODE },
4636     { Bad_Opcode },
4637     { Bad_Opcode },
4638     { Bad_Opcode },
4639     { Bad_Opcode },
4640     /* 10 */
4641     { "pblendvb", { XM, EXx, XMM0 }, PREFIX_DATA },
4642     { Bad_Opcode },
4643     { Bad_Opcode },
4644     { Bad_Opcode },
4645     { "blendvps", { XM, EXx, XMM0 }, PREFIX_DATA },
4646     { "blendvpd", { XM, EXx, XMM0 }, PREFIX_DATA },
4647     { Bad_Opcode },
4648     { "ptest",  { XM, EXx }, PREFIX_DATA },
4649     /* 18 */
4650     { Bad_Opcode },
4651     { Bad_Opcode },
4652     { Bad_Opcode },
4653     { Bad_Opcode },
4654     { "pabsb",		{ MX, EM }, PREFIX_OPCODE },
4655     { "pabsw",		{ MX, EM }, PREFIX_OPCODE },
4656     { "pabsd",		{ MX, EM }, PREFIX_OPCODE },
4657     { Bad_Opcode },
4658     /* 20 */
4659     { "pmovsxbw", { XM, EXq }, PREFIX_DATA },
4660     { "pmovsxbd", { XM, EXd }, PREFIX_DATA },
4661     { "pmovsxbq", { XM, EXw }, PREFIX_DATA },
4662     { "pmovsxwd", { XM, EXq }, PREFIX_DATA },
4663     { "pmovsxwq", { XM, EXd }, PREFIX_DATA },
4664     { "pmovsxdq", { XM, EXq }, PREFIX_DATA },
4665     { Bad_Opcode },
4666     { Bad_Opcode },
4667     /* 28 */
4668     { "pmuldq", { XM, EXx }, PREFIX_DATA },
4669     { "pcmpeqq", { XM, EXx }, PREFIX_DATA },
4670     { "movntdqa", { XM, Mx }, PREFIX_DATA },
4671     { "packusdw", { XM, EXx }, PREFIX_DATA },
4672     { Bad_Opcode },
4673     { Bad_Opcode },
4674     { Bad_Opcode },
4675     { Bad_Opcode },
4676     /* 30 */
4677     { "pmovzxbw", { XM, EXq }, PREFIX_DATA },
4678     { "pmovzxbd", { XM, EXd }, PREFIX_DATA },
4679     { "pmovzxbq", { XM, EXw }, PREFIX_DATA },
4680     { "pmovzxwd", { XM, EXq }, PREFIX_DATA },
4681     { "pmovzxwq", { XM, EXd }, PREFIX_DATA },
4682     { "pmovzxdq", { XM, EXq }, PREFIX_DATA },
4683     { Bad_Opcode },
4684     { "pcmpgtq", { XM, EXx }, PREFIX_DATA },
4685     /* 38 */
4686     { "pminsb",	{ XM, EXx }, PREFIX_DATA },
4687     { "pminsd",	{ XM, EXx }, PREFIX_DATA },
4688     { "pminuw",	{ XM, EXx }, PREFIX_DATA },
4689     { "pminud",	{ XM, EXx }, PREFIX_DATA },
4690     { "pmaxsb",	{ XM, EXx }, PREFIX_DATA },
4691     { "pmaxsd",	{ XM, EXx }, PREFIX_DATA },
4692     { "pmaxuw", { XM, EXx }, PREFIX_DATA },
4693     { "pmaxud", { XM, EXx }, PREFIX_DATA },
4694     /* 40 */
4695     { "pmulld", { XM, EXx }, PREFIX_DATA },
4696     { "phminposuw", { XM, EXx }, PREFIX_DATA },
4697     { Bad_Opcode },
4698     { Bad_Opcode },
4699     { Bad_Opcode },
4700     { Bad_Opcode },
4701     { Bad_Opcode },
4702     { Bad_Opcode },
4703     /* 48 */
4704     { Bad_Opcode },
4705     { Bad_Opcode },
4706     { Bad_Opcode },
4707     { Bad_Opcode },
4708     { Bad_Opcode },
4709     { Bad_Opcode },
4710     { Bad_Opcode },
4711     { Bad_Opcode },
4712     /* 50 */
4713     { Bad_Opcode },
4714     { Bad_Opcode },
4715     { Bad_Opcode },
4716     { Bad_Opcode },
4717     { Bad_Opcode },
4718     { Bad_Opcode },
4719     { Bad_Opcode },
4720     { Bad_Opcode },
4721     /* 58 */
4722     { Bad_Opcode },
4723     { Bad_Opcode },
4724     { Bad_Opcode },
4725     { Bad_Opcode },
4726     { Bad_Opcode },
4727     { Bad_Opcode },
4728     { Bad_Opcode },
4729     { Bad_Opcode },
4730     /* 60 */
4731     { Bad_Opcode },
4732     { Bad_Opcode },
4733     { Bad_Opcode },
4734     { Bad_Opcode },
4735     { Bad_Opcode },
4736     { Bad_Opcode },
4737     { Bad_Opcode },
4738     { Bad_Opcode },
4739     /* 68 */
4740     { Bad_Opcode },
4741     { Bad_Opcode },
4742     { Bad_Opcode },
4743     { Bad_Opcode },
4744     { Bad_Opcode },
4745     { Bad_Opcode },
4746     { Bad_Opcode },
4747     { Bad_Opcode },
4748     /* 70 */
4749     { Bad_Opcode },
4750     { Bad_Opcode },
4751     { Bad_Opcode },
4752     { Bad_Opcode },
4753     { Bad_Opcode },
4754     { Bad_Opcode },
4755     { Bad_Opcode },
4756     { Bad_Opcode },
4757     /* 78 */
4758     { Bad_Opcode },
4759     { Bad_Opcode },
4760     { Bad_Opcode },
4761     { Bad_Opcode },
4762     { Bad_Opcode },
4763     { Bad_Opcode },
4764     { Bad_Opcode },
4765     { Bad_Opcode },
4766     /* 80 */
4767     { "invept",	{ Gm, Mo }, PREFIX_DATA },
4768     { "invvpid", { Gm, Mo }, PREFIX_DATA },
4769     { "invpcid", { Gm, M }, PREFIX_DATA },
4770     { Bad_Opcode },
4771     { Bad_Opcode },
4772     { Bad_Opcode },
4773     { Bad_Opcode },
4774     { Bad_Opcode },
4775     /* 88 */
4776     { Bad_Opcode },
4777     { Bad_Opcode },
4778     { Bad_Opcode },
4779     { Bad_Opcode },
4780     { Bad_Opcode },
4781     { Bad_Opcode },
4782     { Bad_Opcode },
4783     { Bad_Opcode },
4784     /* 90 */
4785     { Bad_Opcode },
4786     { Bad_Opcode },
4787     { Bad_Opcode },
4788     { Bad_Opcode },
4789     { Bad_Opcode },
4790     { Bad_Opcode },
4791     { Bad_Opcode },
4792     { Bad_Opcode },
4793     /* 98 */
4794     { Bad_Opcode },
4795     { Bad_Opcode },
4796     { Bad_Opcode },
4797     { Bad_Opcode },
4798     { Bad_Opcode },
4799     { Bad_Opcode },
4800     { Bad_Opcode },
4801     { Bad_Opcode },
4802     /* a0 */
4803     { Bad_Opcode },
4804     { Bad_Opcode },
4805     { Bad_Opcode },
4806     { Bad_Opcode },
4807     { Bad_Opcode },
4808     { Bad_Opcode },
4809     { Bad_Opcode },
4810     { Bad_Opcode },
4811     /* a8 */
4812     { Bad_Opcode },
4813     { Bad_Opcode },
4814     { Bad_Opcode },
4815     { Bad_Opcode },
4816     { Bad_Opcode },
4817     { Bad_Opcode },
4818     { Bad_Opcode },
4819     { Bad_Opcode },
4820     /* b0 */
4821     { Bad_Opcode },
4822     { Bad_Opcode },
4823     { Bad_Opcode },
4824     { Bad_Opcode },
4825     { Bad_Opcode },
4826     { Bad_Opcode },
4827     { Bad_Opcode },
4828     { Bad_Opcode },
4829     /* b8 */
4830     { Bad_Opcode },
4831     { Bad_Opcode },
4832     { Bad_Opcode },
4833     { Bad_Opcode },
4834     { Bad_Opcode },
4835     { Bad_Opcode },
4836     { Bad_Opcode },
4837     { Bad_Opcode },
4838     /* c0 */
4839     { Bad_Opcode },
4840     { Bad_Opcode },
4841     { Bad_Opcode },
4842     { Bad_Opcode },
4843     { Bad_Opcode },
4844     { Bad_Opcode },
4845     { Bad_Opcode },
4846     { Bad_Opcode },
4847     /* c8 */
4848     { "sha1nexte", { XM, EXxmm }, PREFIX_OPCODE },
4849     { "sha1msg1", { XM, EXxmm }, PREFIX_OPCODE },
4850     { "sha1msg2", { XM, EXxmm }, PREFIX_OPCODE },
4851     { "sha256rnds2", { XM, EXxmm, XMM0 }, PREFIX_OPCODE },
4852     { "sha256msg1", { XM, EXxmm }, PREFIX_OPCODE },
4853     { "sha256msg2", { XM, EXxmm }, PREFIX_OPCODE },
4854     { Bad_Opcode },
4855     { "gf2p8mulb", { XM, EXxmm }, PREFIX_DATA },
4856     /* d0 */
4857     { Bad_Opcode },
4858     { Bad_Opcode },
4859     { Bad_Opcode },
4860     { Bad_Opcode },
4861     { Bad_Opcode },
4862     { Bad_Opcode },
4863     { Bad_Opcode },
4864     { Bad_Opcode },
4865     /* d8 */
4866     { PREFIX_TABLE (PREFIX_0F38D8) },
4867     { Bad_Opcode },
4868     { Bad_Opcode },
4869     { "aesimc", { XM, EXx }, PREFIX_DATA },
4870     { PREFIX_TABLE (PREFIX_0F38DC) },
4871     { PREFIX_TABLE (PREFIX_0F38DD) },
4872     { PREFIX_TABLE (PREFIX_0F38DE) },
4873     { PREFIX_TABLE (PREFIX_0F38DF) },
4874     /* e0 */
4875     { Bad_Opcode },
4876     { Bad_Opcode },
4877     { Bad_Opcode },
4878     { Bad_Opcode },
4879     { Bad_Opcode },
4880     { Bad_Opcode },
4881     { Bad_Opcode },
4882     { Bad_Opcode },
4883     /* e8 */
4884     { Bad_Opcode },
4885     { Bad_Opcode },
4886     { Bad_Opcode },
4887     { Bad_Opcode },
4888     { Bad_Opcode },
4889     { Bad_Opcode },
4890     { Bad_Opcode },
4891     { Bad_Opcode },
4892     /* f0 */
4893     { PREFIX_TABLE (PREFIX_0F38F0) },
4894     { PREFIX_TABLE (PREFIX_0F38F1) },
4895     { Bad_Opcode },
4896     { Bad_Opcode },
4897     { Bad_Opcode },
4898     { "wrussK",		{ M, Gdq }, PREFIX_DATA },
4899     { PREFIX_TABLE (PREFIX_0F38F6) },
4900     { Bad_Opcode },
4901     /* f8 */
4902     { MOD_TABLE (MOD_0F38F8) },
4903     { "movdiri",	{ Mdq, Gdq }, PREFIX_OPCODE },
4904     { PREFIX_TABLE (PREFIX_0F38FA) },
4905     { PREFIX_TABLE (PREFIX_0F38FB) },
4906     { PREFIX_TABLE (PREFIX_0F38FC) },
4907     { Bad_Opcode },
4908     { Bad_Opcode },
4909     { Bad_Opcode },
4910   },
4911   /* THREE_BYTE_0F3A */
4912   {
4913     /* 00 */
4914     { Bad_Opcode },
4915     { Bad_Opcode },
4916     { Bad_Opcode },
4917     { Bad_Opcode },
4918     { Bad_Opcode },
4919     { Bad_Opcode },
4920     { Bad_Opcode },
4921     { Bad_Opcode },
4922     /* 08 */
4923     { "roundps", { XM, EXx, Ib }, PREFIX_DATA },
4924     { "roundpd", { XM, EXx, Ib }, PREFIX_DATA },
4925     { "roundss", { XM, EXd, Ib }, PREFIX_DATA },
4926     { "roundsd", { XM, EXq, Ib }, PREFIX_DATA },
4927     { "blendps", { XM, EXx, Ib }, PREFIX_DATA },
4928     { "blendpd", { XM, EXx, Ib }, PREFIX_DATA },
4929     { "pblendw", { XM, EXx, Ib }, PREFIX_DATA },
4930     { "palignr",	{ MX, EM, Ib }, PREFIX_OPCODE },
4931     /* 10 */
4932     { Bad_Opcode },
4933     { Bad_Opcode },
4934     { Bad_Opcode },
4935     { Bad_Opcode },
4936     { "pextrb",	{ Edb, XM, Ib }, PREFIX_DATA },
4937     { "pextrw",	{ Edw, XM, Ib }, PREFIX_DATA },
4938     { "pextrK",	{ Edq, XM, Ib }, PREFIX_DATA },
4939     { "extractps", { Ed, XM, Ib }, PREFIX_DATA },
4940     /* 18 */
4941     { Bad_Opcode },
4942     { Bad_Opcode },
4943     { Bad_Opcode },
4944     { Bad_Opcode },
4945     { Bad_Opcode },
4946     { Bad_Opcode },
4947     { Bad_Opcode },
4948     { Bad_Opcode },
4949     /* 20 */
4950     { "pinsrb",	{ XM, Edb, Ib }, PREFIX_DATA },
4951     { "insertps", { XM, EXd, Ib }, PREFIX_DATA },
4952     { "pinsrK",	{ XM, Edq, Ib }, PREFIX_DATA },
4953     { Bad_Opcode },
4954     { Bad_Opcode },
4955     { Bad_Opcode },
4956     { Bad_Opcode },
4957     { Bad_Opcode },
4958     /* 28 */
4959     { Bad_Opcode },
4960     { Bad_Opcode },
4961     { Bad_Opcode },
4962     { Bad_Opcode },
4963     { Bad_Opcode },
4964     { Bad_Opcode },
4965     { Bad_Opcode },
4966     { Bad_Opcode },
4967     /* 30 */
4968     { Bad_Opcode },
4969     { Bad_Opcode },
4970     { Bad_Opcode },
4971     { Bad_Opcode },
4972     { Bad_Opcode },
4973     { Bad_Opcode },
4974     { Bad_Opcode },
4975     { Bad_Opcode },
4976     /* 38 */
4977     { Bad_Opcode },
4978     { Bad_Opcode },
4979     { Bad_Opcode },
4980     { Bad_Opcode },
4981     { Bad_Opcode },
4982     { Bad_Opcode },
4983     { Bad_Opcode },
4984     { Bad_Opcode },
4985     /* 40 */
4986     { "dpps",	{ XM, EXx, Ib }, PREFIX_DATA },
4987     { "dppd",	{ XM, EXx, Ib }, PREFIX_DATA },
4988     { "mpsadbw", { XM, EXx, Ib }, PREFIX_DATA },
4989     { Bad_Opcode },
4990     { "pclmulqdq", { XM, EXx, PCLMUL }, PREFIX_DATA },
4991     { Bad_Opcode },
4992     { Bad_Opcode },
4993     { Bad_Opcode },
4994     /* 48 */
4995     { Bad_Opcode },
4996     { Bad_Opcode },
4997     { Bad_Opcode },
4998     { Bad_Opcode },
4999     { Bad_Opcode },
5000     { Bad_Opcode },
5001     { Bad_Opcode },
5002     { Bad_Opcode },
5003     /* 50 */
5004     { Bad_Opcode },
5005     { Bad_Opcode },
5006     { Bad_Opcode },
5007     { Bad_Opcode },
5008     { Bad_Opcode },
5009     { Bad_Opcode },
5010     { Bad_Opcode },
5011     { Bad_Opcode },
5012     /* 58 */
5013     { Bad_Opcode },
5014     { Bad_Opcode },
5015     { Bad_Opcode },
5016     { Bad_Opcode },
5017     { Bad_Opcode },
5018     { Bad_Opcode },
5019     { Bad_Opcode },
5020     { Bad_Opcode },
5021     /* 60 */
5022     { "pcmpestrm!%LQ", { XM, EXx, Ib }, PREFIX_DATA },
5023     { "pcmpestri!%LQ", { XM, EXx, Ib }, PREFIX_DATA },
5024     { "pcmpistrm", { XM, EXx, Ib }, PREFIX_DATA },
5025     { "pcmpistri", { XM, EXx, Ib }, PREFIX_DATA },
5026     { Bad_Opcode },
5027     { Bad_Opcode },
5028     { Bad_Opcode },
5029     { Bad_Opcode },
5030     /* 68 */
5031     { Bad_Opcode },
5032     { Bad_Opcode },
5033     { Bad_Opcode },
5034     { Bad_Opcode },
5035     { Bad_Opcode },
5036     { Bad_Opcode },
5037     { Bad_Opcode },
5038     { Bad_Opcode },
5039     /* 70 */
5040     { Bad_Opcode },
5041     { Bad_Opcode },
5042     { Bad_Opcode },
5043     { Bad_Opcode },
5044     { Bad_Opcode },
5045     { Bad_Opcode },
5046     { Bad_Opcode },
5047     { Bad_Opcode },
5048     /* 78 */
5049     { Bad_Opcode },
5050     { Bad_Opcode },
5051     { Bad_Opcode },
5052     { Bad_Opcode },
5053     { Bad_Opcode },
5054     { Bad_Opcode },
5055     { Bad_Opcode },
5056     { Bad_Opcode },
5057     /* 80 */
5058     { Bad_Opcode },
5059     { Bad_Opcode },
5060     { Bad_Opcode },
5061     { Bad_Opcode },
5062     { Bad_Opcode },
5063     { Bad_Opcode },
5064     { Bad_Opcode },
5065     { Bad_Opcode },
5066     /* 88 */
5067     { Bad_Opcode },
5068     { Bad_Opcode },
5069     { Bad_Opcode },
5070     { Bad_Opcode },
5071     { Bad_Opcode },
5072     { Bad_Opcode },
5073     { Bad_Opcode },
5074     { Bad_Opcode },
5075     /* 90 */
5076     { Bad_Opcode },
5077     { Bad_Opcode },
5078     { Bad_Opcode },
5079     { Bad_Opcode },
5080     { Bad_Opcode },
5081     { Bad_Opcode },
5082     { Bad_Opcode },
5083     { Bad_Opcode },
5084     /* 98 */
5085     { Bad_Opcode },
5086     { Bad_Opcode },
5087     { Bad_Opcode },
5088     { Bad_Opcode },
5089     { Bad_Opcode },
5090     { Bad_Opcode },
5091     { Bad_Opcode },
5092     { Bad_Opcode },
5093     /* a0 */
5094     { Bad_Opcode },
5095     { Bad_Opcode },
5096     { Bad_Opcode },
5097     { Bad_Opcode },
5098     { Bad_Opcode },
5099     { Bad_Opcode },
5100     { Bad_Opcode },
5101     { Bad_Opcode },
5102     /* a8 */
5103     { Bad_Opcode },
5104     { Bad_Opcode },
5105     { Bad_Opcode },
5106     { Bad_Opcode },
5107     { Bad_Opcode },
5108     { Bad_Opcode },
5109     { Bad_Opcode },
5110     { Bad_Opcode },
5111     /* b0 */
5112     { Bad_Opcode },
5113     { Bad_Opcode },
5114     { Bad_Opcode },
5115     { Bad_Opcode },
5116     { Bad_Opcode },
5117     { Bad_Opcode },
5118     { Bad_Opcode },
5119     { Bad_Opcode },
5120     /* b8 */
5121     { Bad_Opcode },
5122     { Bad_Opcode },
5123     { Bad_Opcode },
5124     { Bad_Opcode },
5125     { Bad_Opcode },
5126     { Bad_Opcode },
5127     { Bad_Opcode },
5128     { Bad_Opcode },
5129     /* c0 */
5130     { Bad_Opcode },
5131     { Bad_Opcode },
5132     { Bad_Opcode },
5133     { Bad_Opcode },
5134     { Bad_Opcode },
5135     { Bad_Opcode },
5136     { Bad_Opcode },
5137     { Bad_Opcode },
5138     /* c8 */
5139     { Bad_Opcode },
5140     { Bad_Opcode },
5141     { Bad_Opcode },
5142     { Bad_Opcode },
5143     { "sha1rnds4", { XM, EXxmm, Ib }, PREFIX_OPCODE },
5144     { Bad_Opcode },
5145     { "gf2p8affineqb", { XM, EXxmm, Ib }, PREFIX_DATA },
5146     { "gf2p8affineinvqb", { XM, EXxmm, Ib }, PREFIX_DATA },
5147     /* d0 */
5148     { Bad_Opcode },
5149     { Bad_Opcode },
5150     { Bad_Opcode },
5151     { Bad_Opcode },
5152     { Bad_Opcode },
5153     { Bad_Opcode },
5154     { Bad_Opcode },
5155     { Bad_Opcode },
5156     /* d8 */
5157     { Bad_Opcode },
5158     { Bad_Opcode },
5159     { Bad_Opcode },
5160     { Bad_Opcode },
5161     { Bad_Opcode },
5162     { Bad_Opcode },
5163     { Bad_Opcode },
5164     { "aeskeygenassist", { XM, EXx, Ib }, PREFIX_DATA },
5165     /* e0 */
5166     { Bad_Opcode },
5167     { Bad_Opcode },
5168     { Bad_Opcode },
5169     { Bad_Opcode },
5170     { Bad_Opcode },
5171     { Bad_Opcode },
5172     { Bad_Opcode },
5173     { Bad_Opcode },
5174     /* e8 */
5175     { Bad_Opcode },
5176     { Bad_Opcode },
5177     { Bad_Opcode },
5178     { Bad_Opcode },
5179     { Bad_Opcode },
5180     { Bad_Opcode },
5181     { Bad_Opcode },
5182     { Bad_Opcode },
5183     /* f0 */
5184     { PREFIX_TABLE (PREFIX_0F3A0F) },
5185     { Bad_Opcode },
5186     { Bad_Opcode },
5187     { Bad_Opcode },
5188     { Bad_Opcode },
5189     { Bad_Opcode },
5190     { Bad_Opcode },
5191     { Bad_Opcode },
5192     /* f8 */
5193     { Bad_Opcode },
5194     { Bad_Opcode },
5195     { Bad_Opcode },
5196     { Bad_Opcode },
5197     { Bad_Opcode },
5198     { Bad_Opcode },
5199     { Bad_Opcode },
5200     { Bad_Opcode },
5201   },
5202 };
5203 
5204 static const struct dis386 xop_table[][256] = {
5205   /* XOP_08 */
5206   {
5207     /* 00 */
5208     { Bad_Opcode },
5209     { Bad_Opcode },
5210     { Bad_Opcode },
5211     { Bad_Opcode },
5212     { Bad_Opcode },
5213     { Bad_Opcode },
5214     { Bad_Opcode },
5215     { Bad_Opcode },
5216     /* 08 */
5217     { Bad_Opcode },
5218     { Bad_Opcode },
5219     { Bad_Opcode },
5220     { Bad_Opcode },
5221     { Bad_Opcode },
5222     { Bad_Opcode },
5223     { Bad_Opcode },
5224     { Bad_Opcode },
5225     /* 10 */
5226     { Bad_Opcode },
5227     { Bad_Opcode },
5228     { Bad_Opcode },
5229     { Bad_Opcode },
5230     { Bad_Opcode },
5231     { Bad_Opcode },
5232     { Bad_Opcode },
5233     { Bad_Opcode },
5234     /* 18 */
5235     { Bad_Opcode },
5236     { Bad_Opcode },
5237     { Bad_Opcode },
5238     { Bad_Opcode },
5239     { Bad_Opcode },
5240     { Bad_Opcode },
5241     { Bad_Opcode },
5242     { Bad_Opcode },
5243     /* 20 */
5244     { Bad_Opcode },
5245     { Bad_Opcode },
5246     { Bad_Opcode },
5247     { Bad_Opcode },
5248     { Bad_Opcode },
5249     { Bad_Opcode },
5250     { Bad_Opcode },
5251     { Bad_Opcode },
5252     /* 28 */
5253     { Bad_Opcode },
5254     { Bad_Opcode },
5255     { Bad_Opcode },
5256     { Bad_Opcode },
5257     { Bad_Opcode },
5258     { Bad_Opcode },
5259     { Bad_Opcode },
5260     { Bad_Opcode },
5261     /* 30 */
5262     { Bad_Opcode },
5263     { Bad_Opcode },
5264     { Bad_Opcode },
5265     { Bad_Opcode },
5266     { Bad_Opcode },
5267     { Bad_Opcode },
5268     { Bad_Opcode },
5269     { Bad_Opcode },
5270     /* 38 */
5271     { Bad_Opcode },
5272     { Bad_Opcode },
5273     { Bad_Opcode },
5274     { Bad_Opcode },
5275     { Bad_Opcode },
5276     { Bad_Opcode },
5277     { Bad_Opcode },
5278     { Bad_Opcode },
5279     /* 40 */
5280     { Bad_Opcode },
5281     { Bad_Opcode },
5282     { Bad_Opcode },
5283     { Bad_Opcode },
5284     { Bad_Opcode },
5285     { Bad_Opcode },
5286     { Bad_Opcode },
5287     { Bad_Opcode },
5288     /* 48 */
5289     { Bad_Opcode },
5290     { Bad_Opcode },
5291     { Bad_Opcode },
5292     { Bad_Opcode },
5293     { Bad_Opcode },
5294     { Bad_Opcode },
5295     { Bad_Opcode },
5296     { Bad_Opcode },
5297     /* 50 */
5298     { Bad_Opcode },
5299     { Bad_Opcode },
5300     { Bad_Opcode },
5301     { Bad_Opcode },
5302     { Bad_Opcode },
5303     { Bad_Opcode },
5304     { Bad_Opcode },
5305     { Bad_Opcode },
5306     /* 58 */
5307     { Bad_Opcode },
5308     { Bad_Opcode },
5309     { Bad_Opcode },
5310     { Bad_Opcode },
5311     { Bad_Opcode },
5312     { Bad_Opcode },
5313     { Bad_Opcode },
5314     { Bad_Opcode },
5315     /* 60 */
5316     { Bad_Opcode },
5317     { Bad_Opcode },
5318     { Bad_Opcode },
5319     { Bad_Opcode },
5320     { Bad_Opcode },
5321     { Bad_Opcode },
5322     { Bad_Opcode },
5323     { Bad_Opcode },
5324     /* 68 */
5325     { Bad_Opcode },
5326     { Bad_Opcode },
5327     { Bad_Opcode },
5328     { Bad_Opcode },
5329     { Bad_Opcode },
5330     { Bad_Opcode },
5331     { Bad_Opcode },
5332     { Bad_Opcode },
5333     /* 70 */
5334     { Bad_Opcode },
5335     { Bad_Opcode },
5336     { Bad_Opcode },
5337     { Bad_Opcode },
5338     { Bad_Opcode },
5339     { Bad_Opcode },
5340     { Bad_Opcode },
5341     { Bad_Opcode },
5342     /* 78 */
5343     { Bad_Opcode },
5344     { Bad_Opcode },
5345     { Bad_Opcode },
5346     { Bad_Opcode },
5347     { Bad_Opcode },
5348     { Bad_Opcode },
5349     { Bad_Opcode },
5350     { Bad_Opcode },
5351     /* 80 */
5352     { Bad_Opcode },
5353     { Bad_Opcode },
5354     { Bad_Opcode },
5355     { Bad_Opcode },
5356     { Bad_Opcode },
5357     { VEX_LEN_TABLE (VEX_LEN_XOP_08_85) },
5358     { VEX_LEN_TABLE (VEX_LEN_XOP_08_86) },
5359     { VEX_LEN_TABLE (VEX_LEN_XOP_08_87) },
5360     /* 88 */
5361     { Bad_Opcode },
5362     { Bad_Opcode },
5363     { Bad_Opcode },
5364     { Bad_Opcode },
5365     { Bad_Opcode },
5366     { Bad_Opcode },
5367     { VEX_LEN_TABLE (VEX_LEN_XOP_08_8E) },
5368     { VEX_LEN_TABLE (VEX_LEN_XOP_08_8F) },
5369     /* 90 */
5370     { Bad_Opcode },
5371     { Bad_Opcode },
5372     { Bad_Opcode },
5373     { Bad_Opcode },
5374     { Bad_Opcode },
5375     { VEX_LEN_TABLE (VEX_LEN_XOP_08_95) },
5376     { VEX_LEN_TABLE (VEX_LEN_XOP_08_96) },
5377     { VEX_LEN_TABLE (VEX_LEN_XOP_08_97) },
5378     /* 98 */
5379     { Bad_Opcode },
5380     { Bad_Opcode },
5381     { Bad_Opcode },
5382     { Bad_Opcode },
5383     { Bad_Opcode },
5384     { Bad_Opcode },
5385     { VEX_LEN_TABLE (VEX_LEN_XOP_08_9E) },
5386     { VEX_LEN_TABLE (VEX_LEN_XOP_08_9F) },
5387     /* a0 */
5388     { Bad_Opcode },
5389     { Bad_Opcode },
5390     { "vpcmov", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
5391     { VEX_LEN_TABLE (VEX_LEN_XOP_08_A3) },
5392     { Bad_Opcode },
5393     { Bad_Opcode },
5394     { VEX_LEN_TABLE (VEX_LEN_XOP_08_A6) },
5395     { Bad_Opcode },
5396     /* a8 */
5397     { Bad_Opcode },
5398     { Bad_Opcode },
5399     { Bad_Opcode },
5400     { Bad_Opcode },
5401     { Bad_Opcode },
5402     { Bad_Opcode },
5403     { Bad_Opcode },
5404     { Bad_Opcode },
5405     /* b0 */
5406     { Bad_Opcode },
5407     { Bad_Opcode },
5408     { Bad_Opcode },
5409     { Bad_Opcode },
5410     { Bad_Opcode },
5411     { Bad_Opcode },
5412     { VEX_LEN_TABLE (VEX_LEN_XOP_08_B6) },
5413     { Bad_Opcode },
5414     /* b8 */
5415     { Bad_Opcode },
5416     { Bad_Opcode },
5417     { Bad_Opcode },
5418     { Bad_Opcode },
5419     { Bad_Opcode },
5420     { Bad_Opcode },
5421     { Bad_Opcode },
5422     { Bad_Opcode },
5423     /* c0 */
5424     { VEX_LEN_TABLE (VEX_LEN_XOP_08_C0) },
5425     { VEX_LEN_TABLE (VEX_LEN_XOP_08_C1) },
5426     { VEX_LEN_TABLE (VEX_LEN_XOP_08_C2) },
5427     { VEX_LEN_TABLE (VEX_LEN_XOP_08_C3) },
5428     { Bad_Opcode },
5429     { Bad_Opcode },
5430     { Bad_Opcode },
5431     { Bad_Opcode },
5432     /* c8 */
5433     { Bad_Opcode },
5434     { Bad_Opcode },
5435     { Bad_Opcode },
5436     { Bad_Opcode },
5437     { VEX_LEN_TABLE (VEX_LEN_XOP_08_CC) },
5438     { VEX_LEN_TABLE (VEX_LEN_XOP_08_CD) },
5439     { VEX_LEN_TABLE (VEX_LEN_XOP_08_CE) },
5440     { VEX_LEN_TABLE (VEX_LEN_XOP_08_CF) },
5441     /* d0 */
5442     { Bad_Opcode },
5443     { Bad_Opcode },
5444     { Bad_Opcode },
5445     { Bad_Opcode },
5446     { Bad_Opcode },
5447     { Bad_Opcode },
5448     { Bad_Opcode },
5449     { Bad_Opcode },
5450     /* d8 */
5451     { Bad_Opcode },
5452     { Bad_Opcode },
5453     { Bad_Opcode },
5454     { Bad_Opcode },
5455     { Bad_Opcode },
5456     { Bad_Opcode },
5457     { Bad_Opcode },
5458     { Bad_Opcode },
5459     /* e0 */
5460     { Bad_Opcode },
5461     { Bad_Opcode },
5462     { Bad_Opcode },
5463     { Bad_Opcode },
5464     { Bad_Opcode },
5465     { Bad_Opcode },
5466     { Bad_Opcode },
5467     { Bad_Opcode },
5468     /* e8 */
5469     { Bad_Opcode },
5470     { Bad_Opcode },
5471     { Bad_Opcode },
5472     { Bad_Opcode },
5473     { VEX_LEN_TABLE (VEX_LEN_XOP_08_EC) },
5474     { VEX_LEN_TABLE (VEX_LEN_XOP_08_ED) },
5475     { VEX_LEN_TABLE (VEX_LEN_XOP_08_EE) },
5476     { VEX_LEN_TABLE (VEX_LEN_XOP_08_EF) },
5477     /* f0 */
5478     { Bad_Opcode },
5479     { Bad_Opcode },
5480     { Bad_Opcode },
5481     { Bad_Opcode },
5482     { Bad_Opcode },
5483     { Bad_Opcode },
5484     { Bad_Opcode },
5485     { Bad_Opcode },
5486     /* f8 */
5487     { Bad_Opcode },
5488     { Bad_Opcode },
5489     { Bad_Opcode },
5490     { Bad_Opcode },
5491     { Bad_Opcode },
5492     { Bad_Opcode },
5493     { Bad_Opcode },
5494     { Bad_Opcode },
5495   },
5496   /* XOP_09 */
5497   {
5498     /* 00 */
5499     { Bad_Opcode },
5500     { VEX_LEN_TABLE (VEX_LEN_XOP_09_01) },
5501     { VEX_LEN_TABLE (VEX_LEN_XOP_09_02) },
5502     { Bad_Opcode },
5503     { Bad_Opcode },
5504     { Bad_Opcode },
5505     { Bad_Opcode },
5506     { Bad_Opcode },
5507     /* 08 */
5508     { Bad_Opcode },
5509     { Bad_Opcode },
5510     { Bad_Opcode },
5511     { Bad_Opcode },
5512     { Bad_Opcode },
5513     { Bad_Opcode },
5514     { Bad_Opcode },
5515     { Bad_Opcode },
5516     /* 10 */
5517     { Bad_Opcode },
5518     { Bad_Opcode },
5519     { VEX_LEN_TABLE (VEX_LEN_XOP_09_12) },
5520     { Bad_Opcode },
5521     { Bad_Opcode },
5522     { Bad_Opcode },
5523     { Bad_Opcode },
5524     { Bad_Opcode },
5525     /* 18 */
5526     { Bad_Opcode },
5527     { Bad_Opcode },
5528     { Bad_Opcode },
5529     { Bad_Opcode },
5530     { Bad_Opcode },
5531     { Bad_Opcode },
5532     { Bad_Opcode },
5533     { Bad_Opcode },
5534     /* 20 */
5535     { Bad_Opcode },
5536     { Bad_Opcode },
5537     { Bad_Opcode },
5538     { Bad_Opcode },
5539     { Bad_Opcode },
5540     { Bad_Opcode },
5541     { Bad_Opcode },
5542     { Bad_Opcode },
5543     /* 28 */
5544     { Bad_Opcode },
5545     { Bad_Opcode },
5546     { Bad_Opcode },
5547     { Bad_Opcode },
5548     { Bad_Opcode },
5549     { Bad_Opcode },
5550     { Bad_Opcode },
5551     { Bad_Opcode },
5552     /* 30 */
5553     { Bad_Opcode },
5554     { Bad_Opcode },
5555     { Bad_Opcode },
5556     { Bad_Opcode },
5557     { Bad_Opcode },
5558     { Bad_Opcode },
5559     { Bad_Opcode },
5560     { Bad_Opcode },
5561     /* 38 */
5562     { Bad_Opcode },
5563     { Bad_Opcode },
5564     { Bad_Opcode },
5565     { Bad_Opcode },
5566     { Bad_Opcode },
5567     { Bad_Opcode },
5568     { Bad_Opcode },
5569     { Bad_Opcode },
5570     /* 40 */
5571     { Bad_Opcode },
5572     { Bad_Opcode },
5573     { Bad_Opcode },
5574     { Bad_Opcode },
5575     { Bad_Opcode },
5576     { Bad_Opcode },
5577     { Bad_Opcode },
5578     { Bad_Opcode },
5579     /* 48 */
5580     { Bad_Opcode },
5581     { Bad_Opcode },
5582     { Bad_Opcode },
5583     { Bad_Opcode },
5584     { Bad_Opcode },
5585     { Bad_Opcode },
5586     { Bad_Opcode },
5587     { Bad_Opcode },
5588     /* 50 */
5589     { Bad_Opcode },
5590     { Bad_Opcode },
5591     { Bad_Opcode },
5592     { Bad_Opcode },
5593     { Bad_Opcode },
5594     { Bad_Opcode },
5595     { Bad_Opcode },
5596     { Bad_Opcode },
5597     /* 58 */
5598     { Bad_Opcode },
5599     { Bad_Opcode },
5600     { Bad_Opcode },
5601     { Bad_Opcode },
5602     { Bad_Opcode },
5603     { Bad_Opcode },
5604     { Bad_Opcode },
5605     { Bad_Opcode },
5606     /* 60 */
5607     { Bad_Opcode },
5608     { Bad_Opcode },
5609     { Bad_Opcode },
5610     { Bad_Opcode },
5611     { Bad_Opcode },
5612     { Bad_Opcode },
5613     { Bad_Opcode },
5614     { Bad_Opcode },
5615     /* 68 */
5616     { Bad_Opcode },
5617     { Bad_Opcode },
5618     { Bad_Opcode },
5619     { Bad_Opcode },
5620     { Bad_Opcode },
5621     { Bad_Opcode },
5622     { Bad_Opcode },
5623     { Bad_Opcode },
5624     /* 70 */
5625     { Bad_Opcode },
5626     { Bad_Opcode },
5627     { Bad_Opcode },
5628     { Bad_Opcode },
5629     { Bad_Opcode },
5630     { Bad_Opcode },
5631     { Bad_Opcode },
5632     { Bad_Opcode },
5633     /* 78 */
5634     { Bad_Opcode },
5635     { Bad_Opcode },
5636     { Bad_Opcode },
5637     { Bad_Opcode },
5638     { Bad_Opcode },
5639     { Bad_Opcode },
5640     { Bad_Opcode },
5641     { Bad_Opcode },
5642     /* 80 */
5643     { VEX_W_TABLE (VEX_W_XOP_09_80) },
5644     { VEX_W_TABLE (VEX_W_XOP_09_81) },
5645     { VEX_W_TABLE (VEX_W_XOP_09_82) },
5646     { VEX_W_TABLE (VEX_W_XOP_09_83) },
5647     { Bad_Opcode },
5648     { Bad_Opcode },
5649     { Bad_Opcode },
5650     { Bad_Opcode },
5651     /* 88 */
5652     { Bad_Opcode },
5653     { Bad_Opcode },
5654     { Bad_Opcode },
5655     { Bad_Opcode },
5656     { Bad_Opcode },
5657     { Bad_Opcode },
5658     { Bad_Opcode },
5659     { Bad_Opcode },
5660     /* 90 */
5661     { VEX_LEN_TABLE (VEX_LEN_XOP_09_90) },
5662     { VEX_LEN_TABLE (VEX_LEN_XOP_09_91) },
5663     { VEX_LEN_TABLE (VEX_LEN_XOP_09_92) },
5664     { VEX_LEN_TABLE (VEX_LEN_XOP_09_93) },
5665     { VEX_LEN_TABLE (VEX_LEN_XOP_09_94) },
5666     { VEX_LEN_TABLE (VEX_LEN_XOP_09_95) },
5667     { VEX_LEN_TABLE (VEX_LEN_XOP_09_96) },
5668     { VEX_LEN_TABLE (VEX_LEN_XOP_09_97) },
5669     /* 98 */
5670     { VEX_LEN_TABLE (VEX_LEN_XOP_09_98) },
5671     { VEX_LEN_TABLE (VEX_LEN_XOP_09_99) },
5672     { VEX_LEN_TABLE (VEX_LEN_XOP_09_9A) },
5673     { VEX_LEN_TABLE (VEX_LEN_XOP_09_9B) },
5674     { Bad_Opcode },
5675     { Bad_Opcode },
5676     { Bad_Opcode },
5677     { Bad_Opcode },
5678     /* a0 */
5679     { Bad_Opcode },
5680     { Bad_Opcode },
5681     { Bad_Opcode },
5682     { Bad_Opcode },
5683     { Bad_Opcode },
5684     { Bad_Opcode },
5685     { Bad_Opcode },
5686     { Bad_Opcode },
5687     /* a8 */
5688     { Bad_Opcode },
5689     { Bad_Opcode },
5690     { Bad_Opcode },
5691     { Bad_Opcode },
5692     { Bad_Opcode },
5693     { Bad_Opcode },
5694     { Bad_Opcode },
5695     { Bad_Opcode },
5696     /* b0 */
5697     { Bad_Opcode },
5698     { Bad_Opcode },
5699     { Bad_Opcode },
5700     { Bad_Opcode },
5701     { Bad_Opcode },
5702     { Bad_Opcode },
5703     { Bad_Opcode },
5704     { Bad_Opcode },
5705     /* b8 */
5706     { Bad_Opcode },
5707     { Bad_Opcode },
5708     { Bad_Opcode },
5709     { Bad_Opcode },
5710     { Bad_Opcode },
5711     { Bad_Opcode },
5712     { Bad_Opcode },
5713     { Bad_Opcode },
5714     /* c0 */
5715     { Bad_Opcode },
5716     { VEX_LEN_TABLE (VEX_LEN_XOP_09_C1) },
5717     { VEX_LEN_TABLE (VEX_LEN_XOP_09_C2) },
5718     { VEX_LEN_TABLE (VEX_LEN_XOP_09_C3) },
5719     { Bad_Opcode },
5720     { Bad_Opcode },
5721     { VEX_LEN_TABLE (VEX_LEN_XOP_09_C6) },
5722     { VEX_LEN_TABLE (VEX_LEN_XOP_09_C7) },
5723     /* c8 */
5724     { Bad_Opcode },
5725     { Bad_Opcode },
5726     { Bad_Opcode },
5727     { VEX_LEN_TABLE (VEX_LEN_XOP_09_CB) },
5728     { Bad_Opcode },
5729     { Bad_Opcode },
5730     { Bad_Opcode },
5731     { Bad_Opcode },
5732     /* d0 */
5733     { Bad_Opcode },
5734     { VEX_LEN_TABLE (VEX_LEN_XOP_09_D1) },
5735     { VEX_LEN_TABLE (VEX_LEN_XOP_09_D2) },
5736     { VEX_LEN_TABLE (VEX_LEN_XOP_09_D3) },
5737     { Bad_Opcode },
5738     { Bad_Opcode },
5739     { VEX_LEN_TABLE (VEX_LEN_XOP_09_D6) },
5740     { VEX_LEN_TABLE (VEX_LEN_XOP_09_D7) },
5741     /* d8 */
5742     { Bad_Opcode },
5743     { Bad_Opcode },
5744     { Bad_Opcode },
5745     { VEX_LEN_TABLE (VEX_LEN_XOP_09_DB) },
5746     { Bad_Opcode },
5747     { Bad_Opcode },
5748     { Bad_Opcode },
5749     { Bad_Opcode },
5750     /* e0 */
5751     { Bad_Opcode },
5752     { VEX_LEN_TABLE (VEX_LEN_XOP_09_E1) },
5753     { VEX_LEN_TABLE (VEX_LEN_XOP_09_E2) },
5754     { VEX_LEN_TABLE (VEX_LEN_XOP_09_E3) },
5755     { Bad_Opcode },
5756     { Bad_Opcode },
5757     { Bad_Opcode },
5758     { Bad_Opcode },
5759     /* e8 */
5760     { Bad_Opcode },
5761     { Bad_Opcode },
5762     { Bad_Opcode },
5763     { Bad_Opcode },
5764     { Bad_Opcode },
5765     { Bad_Opcode },
5766     { Bad_Opcode },
5767     { Bad_Opcode },
5768     /* f0 */
5769     { Bad_Opcode },
5770     { Bad_Opcode },
5771     { Bad_Opcode },
5772     { Bad_Opcode },
5773     { Bad_Opcode },
5774     { Bad_Opcode },
5775     { Bad_Opcode },
5776     { Bad_Opcode },
5777     /* f8 */
5778     { Bad_Opcode },
5779     { Bad_Opcode },
5780     { Bad_Opcode },
5781     { Bad_Opcode },
5782     { Bad_Opcode },
5783     { Bad_Opcode },
5784     { Bad_Opcode },
5785     { Bad_Opcode },
5786   },
5787   /* XOP_0A */
5788   {
5789     /* 00 */
5790     { Bad_Opcode },
5791     { Bad_Opcode },
5792     { Bad_Opcode },
5793     { Bad_Opcode },
5794     { Bad_Opcode },
5795     { Bad_Opcode },
5796     { Bad_Opcode },
5797     { Bad_Opcode },
5798     /* 08 */
5799     { Bad_Opcode },
5800     { Bad_Opcode },
5801     { Bad_Opcode },
5802     { Bad_Opcode },
5803     { Bad_Opcode },
5804     { Bad_Opcode },
5805     { Bad_Opcode },
5806     { Bad_Opcode },
5807     /* 10 */
5808     { "bextrS",	{ Gdq, Edq, Id }, 0 },
5809     { Bad_Opcode },
5810     { VEX_LEN_TABLE (VEX_LEN_XOP_0A_12) },
5811     { Bad_Opcode },
5812     { Bad_Opcode },
5813     { Bad_Opcode },
5814     { Bad_Opcode },
5815     { Bad_Opcode },
5816     /* 18 */
5817     { Bad_Opcode },
5818     { Bad_Opcode },
5819     { Bad_Opcode },
5820     { Bad_Opcode },
5821     { Bad_Opcode },
5822     { Bad_Opcode },
5823     { Bad_Opcode },
5824     { Bad_Opcode },
5825     /* 20 */
5826     { Bad_Opcode },
5827     { Bad_Opcode },
5828     { Bad_Opcode },
5829     { Bad_Opcode },
5830     { Bad_Opcode },
5831     { Bad_Opcode },
5832     { Bad_Opcode },
5833     { Bad_Opcode },
5834     /* 28 */
5835     { Bad_Opcode },
5836     { Bad_Opcode },
5837     { Bad_Opcode },
5838     { Bad_Opcode },
5839     { Bad_Opcode },
5840     { Bad_Opcode },
5841     { Bad_Opcode },
5842     { Bad_Opcode },
5843     /* 30 */
5844     { Bad_Opcode },
5845     { Bad_Opcode },
5846     { Bad_Opcode },
5847     { Bad_Opcode },
5848     { Bad_Opcode },
5849     { Bad_Opcode },
5850     { Bad_Opcode },
5851     { Bad_Opcode },
5852     /* 38 */
5853     { Bad_Opcode },
5854     { Bad_Opcode },
5855     { Bad_Opcode },
5856     { Bad_Opcode },
5857     { Bad_Opcode },
5858     { Bad_Opcode },
5859     { Bad_Opcode },
5860     { Bad_Opcode },
5861     /* 40 */
5862     { Bad_Opcode },
5863     { Bad_Opcode },
5864     { Bad_Opcode },
5865     { Bad_Opcode },
5866     { Bad_Opcode },
5867     { Bad_Opcode },
5868     { Bad_Opcode },
5869     { Bad_Opcode },
5870     /* 48 */
5871     { Bad_Opcode },
5872     { Bad_Opcode },
5873     { Bad_Opcode },
5874     { Bad_Opcode },
5875     { Bad_Opcode },
5876     { Bad_Opcode },
5877     { Bad_Opcode },
5878     { Bad_Opcode },
5879     /* 50 */
5880     { Bad_Opcode },
5881     { Bad_Opcode },
5882     { Bad_Opcode },
5883     { Bad_Opcode },
5884     { Bad_Opcode },
5885     { Bad_Opcode },
5886     { Bad_Opcode },
5887     { Bad_Opcode },
5888     /* 58 */
5889     { Bad_Opcode },
5890     { Bad_Opcode },
5891     { Bad_Opcode },
5892     { Bad_Opcode },
5893     { Bad_Opcode },
5894     { Bad_Opcode },
5895     { Bad_Opcode },
5896     { Bad_Opcode },
5897     /* 60 */
5898     { Bad_Opcode },
5899     { Bad_Opcode },
5900     { Bad_Opcode },
5901     { Bad_Opcode },
5902     { Bad_Opcode },
5903     { Bad_Opcode },
5904     { Bad_Opcode },
5905     { Bad_Opcode },
5906     /* 68 */
5907     { Bad_Opcode },
5908     { Bad_Opcode },
5909     { Bad_Opcode },
5910     { Bad_Opcode },
5911     { Bad_Opcode },
5912     { Bad_Opcode },
5913     { Bad_Opcode },
5914     { Bad_Opcode },
5915     /* 70 */
5916     { Bad_Opcode },
5917     { Bad_Opcode },
5918     { Bad_Opcode },
5919     { Bad_Opcode },
5920     { Bad_Opcode },
5921     { Bad_Opcode },
5922     { Bad_Opcode },
5923     { Bad_Opcode },
5924     /* 78 */
5925     { Bad_Opcode },
5926     { Bad_Opcode },
5927     { Bad_Opcode },
5928     { Bad_Opcode },
5929     { Bad_Opcode },
5930     { Bad_Opcode },
5931     { Bad_Opcode },
5932     { Bad_Opcode },
5933     /* 80 */
5934     { Bad_Opcode },
5935     { Bad_Opcode },
5936     { Bad_Opcode },
5937     { Bad_Opcode },
5938     { Bad_Opcode },
5939     { Bad_Opcode },
5940     { Bad_Opcode },
5941     { Bad_Opcode },
5942     /* 88 */
5943     { Bad_Opcode },
5944     { Bad_Opcode },
5945     { Bad_Opcode },
5946     { Bad_Opcode },
5947     { Bad_Opcode },
5948     { Bad_Opcode },
5949     { Bad_Opcode },
5950     { Bad_Opcode },
5951     /* 90 */
5952     { Bad_Opcode },
5953     { Bad_Opcode },
5954     { Bad_Opcode },
5955     { Bad_Opcode },
5956     { Bad_Opcode },
5957     { Bad_Opcode },
5958     { Bad_Opcode },
5959     { Bad_Opcode },
5960     /* 98 */
5961     { Bad_Opcode },
5962     { Bad_Opcode },
5963     { Bad_Opcode },
5964     { Bad_Opcode },
5965     { Bad_Opcode },
5966     { Bad_Opcode },
5967     { Bad_Opcode },
5968     { Bad_Opcode },
5969     /* a0 */
5970     { Bad_Opcode },
5971     { Bad_Opcode },
5972     { Bad_Opcode },
5973     { Bad_Opcode },
5974     { Bad_Opcode },
5975     { Bad_Opcode },
5976     { Bad_Opcode },
5977     { Bad_Opcode },
5978     /* a8 */
5979     { Bad_Opcode },
5980     { Bad_Opcode },
5981     { Bad_Opcode },
5982     { Bad_Opcode },
5983     { Bad_Opcode },
5984     { Bad_Opcode },
5985     { Bad_Opcode },
5986     { Bad_Opcode },
5987     /* b0 */
5988     { Bad_Opcode },
5989     { Bad_Opcode },
5990     { Bad_Opcode },
5991     { Bad_Opcode },
5992     { Bad_Opcode },
5993     { Bad_Opcode },
5994     { Bad_Opcode },
5995     { Bad_Opcode },
5996     /* b8 */
5997     { Bad_Opcode },
5998     { Bad_Opcode },
5999     { Bad_Opcode },
6000     { Bad_Opcode },
6001     { Bad_Opcode },
6002     { Bad_Opcode },
6003     { Bad_Opcode },
6004     { Bad_Opcode },
6005     /* c0 */
6006     { Bad_Opcode },
6007     { Bad_Opcode },
6008     { Bad_Opcode },
6009     { Bad_Opcode },
6010     { Bad_Opcode },
6011     { Bad_Opcode },
6012     { Bad_Opcode },
6013     { Bad_Opcode },
6014     /* c8 */
6015     { Bad_Opcode },
6016     { Bad_Opcode },
6017     { Bad_Opcode },
6018     { Bad_Opcode },
6019     { Bad_Opcode },
6020     { Bad_Opcode },
6021     { Bad_Opcode },
6022     { Bad_Opcode },
6023     /* d0 */
6024     { Bad_Opcode },
6025     { Bad_Opcode },
6026     { Bad_Opcode },
6027     { Bad_Opcode },
6028     { Bad_Opcode },
6029     { Bad_Opcode },
6030     { Bad_Opcode },
6031     { Bad_Opcode },
6032     /* d8 */
6033     { Bad_Opcode },
6034     { Bad_Opcode },
6035     { Bad_Opcode },
6036     { Bad_Opcode },
6037     { Bad_Opcode },
6038     { Bad_Opcode },
6039     { Bad_Opcode },
6040     { Bad_Opcode },
6041     /* e0 */
6042     { Bad_Opcode },
6043     { Bad_Opcode },
6044     { Bad_Opcode },
6045     { Bad_Opcode },
6046     { Bad_Opcode },
6047     { Bad_Opcode },
6048     { Bad_Opcode },
6049     { Bad_Opcode },
6050     /* e8 */
6051     { Bad_Opcode },
6052     { Bad_Opcode },
6053     { Bad_Opcode },
6054     { Bad_Opcode },
6055     { Bad_Opcode },
6056     { Bad_Opcode },
6057     { Bad_Opcode },
6058     { Bad_Opcode },
6059     /* f0 */
6060     { Bad_Opcode },
6061     { Bad_Opcode },
6062     { Bad_Opcode },
6063     { Bad_Opcode },
6064     { Bad_Opcode },
6065     { Bad_Opcode },
6066     { Bad_Opcode },
6067     { Bad_Opcode },
6068     /* f8 */
6069     { Bad_Opcode },
6070     { Bad_Opcode },
6071     { Bad_Opcode },
6072     { Bad_Opcode },
6073     { Bad_Opcode },
6074     { Bad_Opcode },
6075     { Bad_Opcode },
6076     { Bad_Opcode },
6077   },
6078 };
6079 
6080 static const struct dis386 vex_table[][256] = {
6081   /* VEX_0F */
6082   {
6083     /* 00 */
6084     { Bad_Opcode },
6085     { Bad_Opcode },
6086     { Bad_Opcode },
6087     { Bad_Opcode },
6088     { Bad_Opcode },
6089     { Bad_Opcode },
6090     { Bad_Opcode },
6091     { Bad_Opcode },
6092     /* 08 */
6093     { Bad_Opcode },
6094     { Bad_Opcode },
6095     { Bad_Opcode },
6096     { Bad_Opcode },
6097     { Bad_Opcode },
6098     { Bad_Opcode },
6099     { Bad_Opcode },
6100     { Bad_Opcode },
6101     /* 10 */
6102     { PREFIX_TABLE (PREFIX_0F10) },
6103     { PREFIX_TABLE (PREFIX_0F11) },
6104     { PREFIX_TABLE (PREFIX_VEX_0F12) },
6105     { VEX_LEN_TABLE (VEX_LEN_0F13) },
6106     { "vunpcklpX",	{ XM, Vex, EXx }, PREFIX_OPCODE },
6107     { "vunpckhpX",	{ XM, Vex, EXx }, PREFIX_OPCODE },
6108     { PREFIX_TABLE (PREFIX_VEX_0F16) },
6109     { VEX_LEN_TABLE (VEX_LEN_0F17) },
6110     /* 18 */
6111     { Bad_Opcode },
6112     { Bad_Opcode },
6113     { Bad_Opcode },
6114     { Bad_Opcode },
6115     { Bad_Opcode },
6116     { Bad_Opcode },
6117     { Bad_Opcode },
6118     { Bad_Opcode },
6119     /* 20 */
6120     { Bad_Opcode },
6121     { Bad_Opcode },
6122     { Bad_Opcode },
6123     { Bad_Opcode },
6124     { Bad_Opcode },
6125     { Bad_Opcode },
6126     { Bad_Opcode },
6127     { Bad_Opcode },
6128     /* 28 */
6129     { "vmovapX",	{ XM, EXx }, PREFIX_OPCODE },
6130     { "vmovapX",	{ EXxS, XM }, PREFIX_OPCODE },
6131     { PREFIX_TABLE (PREFIX_VEX_0F2A) },
6132     { "vmovntpX",	{ Mx, XM }, PREFIX_OPCODE },
6133     { PREFIX_TABLE (PREFIX_VEX_0F2C) },
6134     { PREFIX_TABLE (PREFIX_VEX_0F2D) },
6135     { PREFIX_TABLE (PREFIX_0F2E) },
6136     { PREFIX_TABLE (PREFIX_0F2F) },
6137     /* 30 */
6138     { Bad_Opcode },
6139     { Bad_Opcode },
6140     { Bad_Opcode },
6141     { Bad_Opcode },
6142     { Bad_Opcode },
6143     { Bad_Opcode },
6144     { Bad_Opcode },
6145     { Bad_Opcode },
6146     /* 38 */
6147     { Bad_Opcode },
6148     { Bad_Opcode },
6149     { Bad_Opcode },
6150     { Bad_Opcode },
6151     { Bad_Opcode },
6152     { Bad_Opcode },
6153     { Bad_Opcode },
6154     { Bad_Opcode },
6155     /* 40 */
6156     { Bad_Opcode },
6157     { VEX_LEN_TABLE (VEX_LEN_0F41) },
6158     { VEX_LEN_TABLE (VEX_LEN_0F42) },
6159     { Bad_Opcode },
6160     { VEX_LEN_TABLE (VEX_LEN_0F44) },
6161     { VEX_LEN_TABLE (VEX_LEN_0F45) },
6162     { VEX_LEN_TABLE (VEX_LEN_0F46) },
6163     { VEX_LEN_TABLE (VEX_LEN_0F47) },
6164     /* 48 */
6165     { Bad_Opcode },
6166     { Bad_Opcode },
6167     { VEX_LEN_TABLE (VEX_LEN_0F4A) },
6168     { VEX_LEN_TABLE (VEX_LEN_0F4B) },
6169     { Bad_Opcode },
6170     { Bad_Opcode },
6171     { Bad_Opcode },
6172     { Bad_Opcode },
6173     /* 50 */
6174     { "vmovmskpX",	{ Gdq, Ux }, PREFIX_OPCODE },
6175     { PREFIX_TABLE (PREFIX_0F51) },
6176     { PREFIX_TABLE (PREFIX_0F52) },
6177     { PREFIX_TABLE (PREFIX_0F53) },
6178     { "vandpX",		{ XM, Vex, EXx }, PREFIX_OPCODE },
6179     { "vandnpX",	{ XM, Vex, EXx }, PREFIX_OPCODE },
6180     { "vorpX",		{ XM, Vex, EXx }, PREFIX_OPCODE },
6181     { "vxorpX",		{ XM, Vex, EXx }, PREFIX_OPCODE },
6182     /* 58 */
6183     { PREFIX_TABLE (PREFIX_0F58) },
6184     { PREFIX_TABLE (PREFIX_0F59) },
6185     { PREFIX_TABLE (PREFIX_0F5A) },
6186     { PREFIX_TABLE (PREFIX_0F5B) },
6187     { PREFIX_TABLE (PREFIX_0F5C) },
6188     { PREFIX_TABLE (PREFIX_0F5D) },
6189     { PREFIX_TABLE (PREFIX_0F5E) },
6190     { PREFIX_TABLE (PREFIX_0F5F) },
6191     /* 60 */
6192     { "vpunpcklbw",	{ XM, Vex, EXx }, PREFIX_DATA },
6193     { "vpunpcklwd",	{ XM, Vex, EXx }, PREFIX_DATA },
6194     { "vpunpckldq",	{ XM, Vex, EXx }, PREFIX_DATA },
6195     { "vpacksswb",	{ XM, Vex, EXx }, PREFIX_DATA },
6196     { "vpcmpgtb",	{ XM, Vex, EXx }, PREFIX_DATA },
6197     { "vpcmpgtw",	{ XM, Vex, EXx }, PREFIX_DATA },
6198     { "vpcmpgtd",	{ XM, Vex, EXx }, PREFIX_DATA },
6199     { "vpackuswb",	{ XM, Vex, EXx }, PREFIX_DATA },
6200     /* 68 */
6201     { "vpunpckhbw",	{ XM, Vex, EXx }, PREFIX_DATA },
6202     { "vpunpckhwd",	{ XM, Vex, EXx }, PREFIX_DATA },
6203     { "vpunpckhdq",	{ XM, Vex, EXx }, PREFIX_DATA },
6204     { "vpackssdw",	{ XM, Vex, EXx }, PREFIX_DATA },
6205     { "vpunpcklqdq",	{ XM, Vex, EXx }, PREFIX_DATA },
6206     { "vpunpckhqdq",	{ XM, Vex, EXx }, PREFIX_DATA },
6207     { VEX_LEN_TABLE (VEX_LEN_0F6E) },
6208     { PREFIX_TABLE (PREFIX_VEX_0F6F) },
6209     /* 70 */
6210     { PREFIX_TABLE (PREFIX_VEX_0F70) },
6211     { REG_TABLE (REG_VEX_0F71) },
6212     { REG_TABLE (REG_VEX_0F72) },
6213     { REG_TABLE (REG_VEX_0F73) },
6214     { "vpcmpeqb",	{ XM, Vex, EXx }, PREFIX_DATA },
6215     { "vpcmpeqw",	{ XM, Vex, EXx }, PREFIX_DATA },
6216     { "vpcmpeqd",	{ XM, Vex, EXx }, PREFIX_DATA },
6217     { VEX_LEN_TABLE (VEX_LEN_0F77) },
6218     /* 78 */
6219     { Bad_Opcode },
6220     { Bad_Opcode },
6221     { Bad_Opcode },
6222     { Bad_Opcode },
6223     { PREFIX_TABLE (PREFIX_0F7C) },
6224     { PREFIX_TABLE (PREFIX_0F7D) },
6225     { PREFIX_TABLE (PREFIX_VEX_0F7E) },
6226     { PREFIX_TABLE (PREFIX_VEX_0F7F) },
6227     /* 80 */
6228     { Bad_Opcode },
6229     { Bad_Opcode },
6230     { Bad_Opcode },
6231     { Bad_Opcode },
6232     { Bad_Opcode },
6233     { Bad_Opcode },
6234     { Bad_Opcode },
6235     { Bad_Opcode },
6236     /* 88 */
6237     { Bad_Opcode },
6238     { Bad_Opcode },
6239     { Bad_Opcode },
6240     { Bad_Opcode },
6241     { Bad_Opcode },
6242     { Bad_Opcode },
6243     { Bad_Opcode },
6244     { Bad_Opcode },
6245     /* 90 */
6246     { VEX_LEN_TABLE (VEX_LEN_0F90) },
6247     { VEX_LEN_TABLE (VEX_LEN_0F91) },
6248     { VEX_LEN_TABLE (VEX_LEN_0F92) },
6249     { VEX_LEN_TABLE (VEX_LEN_0F93) },
6250     { Bad_Opcode },
6251     { Bad_Opcode },
6252     { Bad_Opcode },
6253     { Bad_Opcode },
6254     /* 98 */
6255     { VEX_LEN_TABLE (VEX_LEN_0F98) },
6256     { VEX_LEN_TABLE (VEX_LEN_0F99) },
6257     { Bad_Opcode },
6258     { Bad_Opcode },
6259     { Bad_Opcode },
6260     { Bad_Opcode },
6261     { Bad_Opcode },
6262     { Bad_Opcode },
6263     /* a0 */
6264     { Bad_Opcode },
6265     { Bad_Opcode },
6266     { Bad_Opcode },
6267     { Bad_Opcode },
6268     { Bad_Opcode },
6269     { Bad_Opcode },
6270     { Bad_Opcode },
6271     { Bad_Opcode },
6272     /* a8 */
6273     { Bad_Opcode },
6274     { Bad_Opcode },
6275     { Bad_Opcode },
6276     { Bad_Opcode },
6277     { Bad_Opcode },
6278     { Bad_Opcode },
6279     { REG_TABLE (REG_VEX_0FAE) },
6280     { Bad_Opcode },
6281     /* b0 */
6282     { Bad_Opcode },
6283     { Bad_Opcode },
6284     { Bad_Opcode },
6285     { Bad_Opcode },
6286     { Bad_Opcode },
6287     { Bad_Opcode },
6288     { Bad_Opcode },
6289     { Bad_Opcode },
6290     /* b8 */
6291     { Bad_Opcode },
6292     { Bad_Opcode },
6293     { Bad_Opcode },
6294     { Bad_Opcode },
6295     { Bad_Opcode },
6296     { Bad_Opcode },
6297     { Bad_Opcode },
6298     { Bad_Opcode },
6299     /* c0 */
6300     { Bad_Opcode },
6301     { Bad_Opcode },
6302     { PREFIX_TABLE (PREFIX_0FC2) },
6303     { Bad_Opcode },
6304     { VEX_LEN_TABLE (VEX_LEN_0FC4) },
6305     { "vpextrw",	{ Gd, Uxmm, Ib }, PREFIX_DATA },
6306     { "vshufpX",	{ XM, Vex, EXx, Ib }, PREFIX_OPCODE },
6307     { Bad_Opcode },
6308     /* c8 */
6309     { Bad_Opcode },
6310     { Bad_Opcode },
6311     { Bad_Opcode },
6312     { Bad_Opcode },
6313     { Bad_Opcode },
6314     { Bad_Opcode },
6315     { Bad_Opcode },
6316     { Bad_Opcode },
6317     /* d0 */
6318     { PREFIX_TABLE (PREFIX_0FD0) },
6319     { "vpsrlw",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6320     { "vpsrld",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6321     { "vpsrlq",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6322     { "vpaddq",		{ XM, Vex, EXx }, PREFIX_DATA },
6323     { "vpmullw",	{ XM, Vex, EXx }, PREFIX_DATA },
6324     { VEX_LEN_TABLE (VEX_LEN_0FD6) },
6325     { "vpmovmskb",	{ Gdq, Ux }, PREFIX_DATA },
6326     /* d8 */
6327     { "vpsubusb",	{ XM, Vex, EXx }, PREFIX_DATA },
6328     { "vpsubusw",	{ XM, Vex, EXx }, PREFIX_DATA },
6329     { "vpminub",	{ XM, Vex, EXx }, PREFIX_DATA },
6330     { "vpand",		{ XM, Vex, EXx }, PREFIX_DATA },
6331     { "vpaddusb",	{ XM, Vex, EXx }, PREFIX_DATA },
6332     { "vpaddusw",	{ XM, Vex, EXx }, PREFIX_DATA },
6333     { "vpmaxub",	{ XM, Vex, EXx }, PREFIX_DATA },
6334     { "vpandn",		{ XM, Vex, EXx }, PREFIX_DATA },
6335     /* e0 */
6336     { "vpavgb",		{ XM, Vex, EXx }, PREFIX_DATA },
6337     { "vpsraw",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6338     { "vpsrad",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6339     { "vpavgw",		{ XM, Vex, EXx }, PREFIX_DATA },
6340     { "vpmulhuw",	{ XM, Vex, EXx }, PREFIX_DATA },
6341     { "vpmulhw",	{ XM, Vex, EXx }, PREFIX_DATA },
6342     { PREFIX_TABLE (PREFIX_0FE6) },
6343     { "vmovntdq",	{ Mx, XM }, PREFIX_DATA },
6344     /* e8 */
6345     { "vpsubsb",	{ XM, Vex, EXx }, PREFIX_DATA },
6346     { "vpsubsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6347     { "vpminsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6348     { "vpor",		{ XM, Vex, EXx }, PREFIX_DATA },
6349     { "vpaddsb",	{ XM, Vex, EXx }, PREFIX_DATA },
6350     { "vpaddsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6351     { "vpmaxsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6352     { "vpxor",		{ XM, Vex, EXx }, PREFIX_DATA },
6353     /* f0 */
6354     { PREFIX_TABLE (PREFIX_0FF0) },
6355     { "vpsllw",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6356     { "vpslld",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6357     { "vpsllq",		{ XM, Vex, EXxmm }, PREFIX_DATA },
6358     { "vpmuludq",	{ XM, Vex, EXx }, PREFIX_DATA },
6359     { "vpmaddwd",	{ XM, Vex, EXx }, PREFIX_DATA },
6360     { "vpsadbw",	{ XM, Vex, EXx }, PREFIX_DATA },
6361     { "vmaskmovdqu",	{ XM, Uxmm }, PREFIX_DATA },
6362     /* f8 */
6363     { "vpsubb",		{ XM, Vex, EXx }, PREFIX_DATA },
6364     { "vpsubw",		{ XM, Vex, EXx }, PREFIX_DATA },
6365     { "vpsubd",		{ XM, Vex, EXx }, PREFIX_DATA },
6366     { "vpsubq",		{ XM, Vex, EXx }, PREFIX_DATA },
6367     { "vpaddb",		{ XM, Vex, EXx }, PREFIX_DATA },
6368     { "vpaddw",		{ XM, Vex, EXx }, PREFIX_DATA },
6369     { "vpaddd",		{ XM, Vex, EXx }, PREFIX_DATA },
6370     { Bad_Opcode },
6371   },
6372   /* VEX_0F38 */
6373   {
6374     /* 00 */
6375     { "vpshufb",	{ XM, Vex, EXx }, PREFIX_DATA },
6376     { "vphaddw",	{ XM, Vex, EXx }, PREFIX_DATA },
6377     { "vphaddd",	{ XM, Vex, EXx }, PREFIX_DATA },
6378     { "vphaddsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6379     { "vpmaddubsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6380     { "vphsubw",	{ XM, Vex, EXx }, PREFIX_DATA },
6381     { "vphsubd",	{ XM, Vex, EXx }, PREFIX_DATA },
6382     { "vphsubsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6383     /* 08 */
6384     { "vpsignb",	{ XM, Vex, EXx }, PREFIX_DATA },
6385     { "vpsignw",	{ XM, Vex, EXx }, PREFIX_DATA },
6386     { "vpsignd",	{ XM, Vex, EXx }, PREFIX_DATA },
6387     { "vpmulhrsw",	{ XM, Vex, EXx }, PREFIX_DATA },
6388     { VEX_W_TABLE (VEX_W_0F380C) },
6389     { VEX_W_TABLE (VEX_W_0F380D) },
6390     { VEX_W_TABLE (VEX_W_0F380E) },
6391     { VEX_W_TABLE (VEX_W_0F380F) },
6392     /* 10 */
6393     { Bad_Opcode },
6394     { Bad_Opcode },
6395     { Bad_Opcode },
6396     { VEX_W_TABLE (VEX_W_0F3813) },
6397     { Bad_Opcode },
6398     { Bad_Opcode },
6399     { VEX_LEN_TABLE (VEX_LEN_0F3816) },
6400     { "vptest",		{ XM, EXx }, PREFIX_DATA },
6401     /* 18 */
6402     { VEX_W_TABLE (VEX_W_0F3818) },
6403     { VEX_LEN_TABLE (VEX_LEN_0F3819) },
6404     { VEX_LEN_TABLE (VEX_LEN_0F381A) },
6405     { Bad_Opcode },
6406     { "vpabsb",		{ XM, EXx }, PREFIX_DATA },
6407     { "vpabsw",		{ XM, EXx }, PREFIX_DATA },
6408     { "vpabsd",		{ XM, EXx }, PREFIX_DATA },
6409     { Bad_Opcode },
6410     /* 20 */
6411     { "vpmovsxbw",	{ XM, EXxmmq }, PREFIX_DATA },
6412     { "vpmovsxbd",	{ XM, EXxmmqd }, PREFIX_DATA },
6413     { "vpmovsxbq",	{ XM, EXxmmdw }, PREFIX_DATA },
6414     { "vpmovsxwd",	{ XM, EXxmmq }, PREFIX_DATA },
6415     { "vpmovsxwq",	{ XM, EXxmmqd }, PREFIX_DATA },
6416     { "vpmovsxdq",	{ XM, EXxmmq }, PREFIX_DATA },
6417     { Bad_Opcode },
6418     { Bad_Opcode },
6419     /* 28 */
6420     { "vpmuldq",	{ XM, Vex, EXx }, PREFIX_DATA },
6421     { "vpcmpeqq",	{ XM, Vex, EXx }, PREFIX_DATA },
6422     { "vmovntdqa",	{ XM, Mx }, PREFIX_DATA },
6423     { "vpackusdw",	{ XM, Vex, EXx }, PREFIX_DATA },
6424     { VEX_W_TABLE (VEX_W_0F382C) },
6425     { VEX_W_TABLE (VEX_W_0F382D) },
6426     { VEX_W_TABLE (VEX_W_0F382E) },
6427     { VEX_W_TABLE (VEX_W_0F382F) },
6428     /* 30 */
6429     { "vpmovzxbw",	{ XM, EXxmmq }, PREFIX_DATA },
6430     { "vpmovzxbd",	{ XM, EXxmmqd }, PREFIX_DATA },
6431     { "vpmovzxbq",	{ XM, EXxmmdw }, PREFIX_DATA },
6432     { "vpmovzxwd",	{ XM, EXxmmq }, PREFIX_DATA },
6433     { "vpmovzxwq",	{ XM, EXxmmqd }, PREFIX_DATA },
6434     { "vpmovzxdq",	{ XM, EXxmmq }, PREFIX_DATA },
6435     { VEX_LEN_TABLE (VEX_LEN_0F3836) },
6436     { "vpcmpgtq",	{ XM, Vex, EXx }, PREFIX_DATA },
6437     /* 38 */
6438     { "vpminsb",	{ XM, Vex, EXx }, PREFIX_DATA },
6439     { "vpminsd",	{ XM, Vex, EXx }, PREFIX_DATA },
6440     { "vpminuw",	{ XM, Vex, EXx }, PREFIX_DATA },
6441     { "vpminud",	{ XM, Vex, EXx }, PREFIX_DATA },
6442     { "vpmaxsb",	{ XM, Vex, EXx }, PREFIX_DATA },
6443     { "vpmaxsd",	{ XM, Vex, EXx }, PREFIX_DATA },
6444     { "vpmaxuw",	{ XM, Vex, EXx }, PREFIX_DATA },
6445     { "vpmaxud",	{ XM, Vex, EXx }, PREFIX_DATA },
6446     /* 40 */
6447     { "vpmulld",	{ XM, Vex, EXx }, PREFIX_DATA },
6448     { VEX_LEN_TABLE (VEX_LEN_0F3841) },
6449     { Bad_Opcode },
6450     { Bad_Opcode },
6451     { Bad_Opcode },
6452     { "vpsrlv%DQ", { XM, Vex, EXx }, PREFIX_DATA },
6453     { VEX_W_TABLE (VEX_W_0F3846) },
6454     { "vpsllv%DQ", { XM, Vex, EXx }, PREFIX_DATA },
6455     /* 48 */
6456     { Bad_Opcode },
6457     { X86_64_TABLE (X86_64_VEX_0F3849) },
6458     { Bad_Opcode },
6459     { X86_64_TABLE (X86_64_VEX_0F384B) },
6460     { Bad_Opcode },
6461     { Bad_Opcode },
6462     { Bad_Opcode },
6463     { Bad_Opcode },
6464     /* 50 */
6465     { VEX_W_TABLE (VEX_W_0F3850) },
6466     { VEX_W_TABLE (VEX_W_0F3851) },
6467     { VEX_W_TABLE (VEX_W_0F3852) },
6468     { VEX_W_TABLE (VEX_W_0F3853) },
6469     { Bad_Opcode },
6470     { Bad_Opcode },
6471     { Bad_Opcode },
6472     { Bad_Opcode },
6473     /* 58 */
6474     { VEX_W_TABLE (VEX_W_0F3858) },
6475     { VEX_W_TABLE (VEX_W_0F3859) },
6476     { VEX_LEN_TABLE (VEX_LEN_0F385A) },
6477     { Bad_Opcode },
6478     { X86_64_TABLE (X86_64_VEX_0F385C) },
6479     { Bad_Opcode },
6480     { X86_64_TABLE (X86_64_VEX_0F385E) },
6481     { Bad_Opcode },
6482     /* 60 */
6483     { Bad_Opcode },
6484     { Bad_Opcode },
6485     { Bad_Opcode },
6486     { Bad_Opcode },
6487     { Bad_Opcode },
6488     { Bad_Opcode },
6489     { Bad_Opcode },
6490     { Bad_Opcode },
6491     /* 68 */
6492     { Bad_Opcode },
6493     { Bad_Opcode },
6494     { Bad_Opcode },
6495     { Bad_Opcode },
6496     { X86_64_TABLE (X86_64_VEX_0F386C) },
6497     { Bad_Opcode },
6498     { Bad_Opcode },
6499     { Bad_Opcode },
6500     /* 70 */
6501     { Bad_Opcode },
6502     { Bad_Opcode },
6503     { PREFIX_TABLE (PREFIX_VEX_0F3872) },
6504     { Bad_Opcode },
6505     { Bad_Opcode },
6506     { Bad_Opcode },
6507     { Bad_Opcode },
6508     { Bad_Opcode },
6509     /* 78 */
6510     { VEX_W_TABLE (VEX_W_0F3878) },
6511     { VEX_W_TABLE (VEX_W_0F3879) },
6512     { Bad_Opcode },
6513     { Bad_Opcode },
6514     { Bad_Opcode },
6515     { Bad_Opcode },
6516     { Bad_Opcode },
6517     { Bad_Opcode },
6518     /* 80 */
6519     { Bad_Opcode },
6520     { Bad_Opcode },
6521     { Bad_Opcode },
6522     { Bad_Opcode },
6523     { Bad_Opcode },
6524     { Bad_Opcode },
6525     { Bad_Opcode },
6526     { Bad_Opcode },
6527     /* 88 */
6528     { Bad_Opcode },
6529     { Bad_Opcode },
6530     { Bad_Opcode },
6531     { Bad_Opcode },
6532     { "vpmaskmov%DQ",	{ XM, Vex, Mx }, PREFIX_DATA },
6533     { Bad_Opcode },
6534     { "vpmaskmov%DQ",	{ Mx, Vex, XM }, PREFIX_DATA },
6535     { Bad_Opcode },
6536     /* 90 */
6537     { "vpgatherd%DQ", { XM, MVexVSIBDWpX, VexGatherD }, PREFIX_DATA },
6538     { "vpgatherq%DQ", { XMGatherQ, MVexVSIBQWpX, VexGatherQ }, PREFIX_DATA },
6539     { "vgatherdp%XW", { XM, MVexVSIBDWpX, VexGatherD }, PREFIX_DATA },
6540     { "vgatherqp%XW", { XMGatherQ, MVexVSIBQWpX, VexGatherQ }, PREFIX_DATA },
6541     { Bad_Opcode },
6542     { Bad_Opcode },
6543     { "vfmaddsub132p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6544     { "vfmsubadd132p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6545     /* 98 */
6546     { "vfmadd132p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6547     { "vfmadd132s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6548     { "vfmsub132p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6549     { "vfmsub132s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6550     { "vfnmadd132p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6551     { "vfnmadd132s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6552     { "vfnmsub132p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6553     { "vfnmsub132s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6554     /* a0 */
6555     { Bad_Opcode },
6556     { Bad_Opcode },
6557     { Bad_Opcode },
6558     { Bad_Opcode },
6559     { Bad_Opcode },
6560     { Bad_Opcode },
6561     { "vfmaddsub213p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6562     { "vfmsubadd213p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6563     /* a8 */
6564     { "vfmadd213p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6565     { "vfmadd213s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6566     { "vfmsub213p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6567     { "vfmsub213s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6568     { "vfnmadd213p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6569     { "vfnmadd213s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6570     { "vfnmsub213p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6571     { "vfnmsub213s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6572     /* b0 */
6573     { VEX_W_TABLE (VEX_W_0F38B0) },
6574     { VEX_W_TABLE (VEX_W_0F38B1) },
6575     { Bad_Opcode },
6576     { Bad_Opcode },
6577     { VEX_W_TABLE (VEX_W_0F38B4) },
6578     { VEX_W_TABLE (VEX_W_0F38B5) },
6579     { "vfmaddsub231p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6580     { "vfmsubadd231p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6581     /* b8 */
6582     { "vfmadd231p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6583     { "vfmadd231s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6584     { "vfmsub231p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6585     { "vfmsub231s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6586     { "vfnmadd231p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6587     { "vfnmadd231s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6588     { "vfnmsub231p%XW", { XM, Vex, EXx }, PREFIX_DATA },
6589     { "vfnmsub231s%XW", { XMScalar, VexScalar, EXdq }, PREFIX_DATA },
6590     /* c0 */
6591     { Bad_Opcode },
6592     { Bad_Opcode },
6593     { Bad_Opcode },
6594     { Bad_Opcode },
6595     { Bad_Opcode },
6596     { Bad_Opcode },
6597     { Bad_Opcode },
6598     { Bad_Opcode },
6599     /* c8 */
6600     { Bad_Opcode },
6601     { Bad_Opcode },
6602     { Bad_Opcode },
6603     { PREFIX_TABLE (PREFIX_VEX_0F38CB) },
6604     { PREFIX_TABLE (PREFIX_VEX_0F38CC) },
6605     { PREFIX_TABLE (PREFIX_VEX_0F38CD) },
6606     { Bad_Opcode },
6607     { VEX_W_TABLE (VEX_W_0F38CF) },
6608     /* d0 */
6609     { Bad_Opcode },
6610     { Bad_Opcode },
6611     { VEX_W_TABLE (VEX_W_0F38D2) },
6612     { VEX_W_TABLE (VEX_W_0F38D3) },
6613     { Bad_Opcode },
6614     { Bad_Opcode },
6615     { Bad_Opcode },
6616     { Bad_Opcode },
6617     /* d8 */
6618     { Bad_Opcode },
6619     { Bad_Opcode },
6620     { VEX_W_TABLE (VEX_W_0F38DA) },
6621     { VEX_LEN_TABLE (VEX_LEN_0F38DB) },
6622     { "vaesenc",	{ XM, Vex, EXx }, PREFIX_DATA },
6623     { "vaesenclast",	{ XM, Vex, EXx }, PREFIX_DATA },
6624     { "vaesdec",	{ XM, Vex, EXx }, PREFIX_DATA },
6625     { "vaesdeclast",	{ XM, Vex, EXx }, PREFIX_DATA },
6626     /* e0 */
6627     { X86_64_TABLE (X86_64_VEX_0F38E0) },
6628     { X86_64_TABLE (X86_64_VEX_0F38E1) },
6629     { X86_64_TABLE (X86_64_VEX_0F38E2) },
6630     { X86_64_TABLE (X86_64_VEX_0F38E3) },
6631     { X86_64_TABLE (X86_64_VEX_0F38E4) },
6632     { X86_64_TABLE (X86_64_VEX_0F38E5) },
6633     { X86_64_TABLE (X86_64_VEX_0F38E6) },
6634     { X86_64_TABLE (X86_64_VEX_0F38E7) },
6635     /* e8 */
6636     { X86_64_TABLE (X86_64_VEX_0F38E8) },
6637     { X86_64_TABLE (X86_64_VEX_0F38E9) },
6638     { X86_64_TABLE (X86_64_VEX_0F38EA) },
6639     { X86_64_TABLE (X86_64_VEX_0F38EB) },
6640     { X86_64_TABLE (X86_64_VEX_0F38EC) },
6641     { X86_64_TABLE (X86_64_VEX_0F38ED) },
6642     { X86_64_TABLE (X86_64_VEX_0F38EE) },
6643     { X86_64_TABLE (X86_64_VEX_0F38EF) },
6644     /* f0 */
6645     { Bad_Opcode },
6646     { Bad_Opcode },
6647     { VEX_LEN_TABLE (VEX_LEN_0F38F2) },
6648     { VEX_LEN_TABLE (VEX_LEN_0F38F3) },
6649     { Bad_Opcode },
6650     { VEX_LEN_TABLE (VEX_LEN_0F38F5) },
6651     { VEX_LEN_TABLE (VEX_LEN_0F38F6) },
6652     { VEX_LEN_TABLE (VEX_LEN_0F38F7) },
6653     /* f8 */
6654     { Bad_Opcode },
6655     { Bad_Opcode },
6656     { Bad_Opcode },
6657     { Bad_Opcode },
6658     { Bad_Opcode },
6659     { Bad_Opcode },
6660     { Bad_Opcode },
6661     { Bad_Opcode },
6662   },
6663   /* VEX_0F3A */
6664   {
6665     /* 00 */
6666     { VEX_LEN_TABLE (VEX_LEN_0F3A00) },
6667     { VEX_LEN_TABLE (VEX_LEN_0F3A01) },
6668     { VEX_W_TABLE (VEX_W_0F3A02) },
6669     { Bad_Opcode },
6670     { VEX_W_TABLE (VEX_W_0F3A04) },
6671     { VEX_W_TABLE (VEX_W_0F3A05) },
6672     { VEX_LEN_TABLE (VEX_LEN_0F3A06) },
6673     { Bad_Opcode },
6674     /* 08 */
6675     { "vroundps",	{ XM, EXx, Ib }, PREFIX_DATA },
6676     { "vroundpd",	{ XM, EXx, Ib }, PREFIX_DATA },
6677     { "vroundss",	{ XMScalar, VexScalar, EXd, Ib }, PREFIX_DATA },
6678     { "vroundsd",	{ XMScalar, VexScalar, EXq, Ib }, PREFIX_DATA },
6679     { "vblendps",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
6680     { "vblendpd",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
6681     { "vpblendw",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
6682     { "vpalignr",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
6683     /* 10 */
6684     { Bad_Opcode },
6685     { Bad_Opcode },
6686     { Bad_Opcode },
6687     { Bad_Opcode },
6688     { VEX_LEN_TABLE (VEX_LEN_0F3A14) },
6689     { VEX_LEN_TABLE (VEX_LEN_0F3A15) },
6690     { VEX_LEN_TABLE (VEX_LEN_0F3A16) },
6691     { VEX_LEN_TABLE (VEX_LEN_0F3A17) },
6692     /* 18 */
6693     { VEX_LEN_TABLE (VEX_LEN_0F3A18) },
6694     { VEX_LEN_TABLE (VEX_LEN_0F3A19) },
6695     { Bad_Opcode },
6696     { Bad_Opcode },
6697     { Bad_Opcode },
6698     { VEX_W_TABLE (VEX_W_0F3A1D) },
6699     { Bad_Opcode },
6700     { Bad_Opcode },
6701     /* 20 */
6702     { VEX_LEN_TABLE (VEX_LEN_0F3A20) },
6703     { VEX_LEN_TABLE (VEX_LEN_0F3A21) },
6704     { VEX_LEN_TABLE (VEX_LEN_0F3A22) },
6705     { Bad_Opcode },
6706     { Bad_Opcode },
6707     { Bad_Opcode },
6708     { Bad_Opcode },
6709     { Bad_Opcode },
6710     /* 28 */
6711     { Bad_Opcode },
6712     { Bad_Opcode },
6713     { Bad_Opcode },
6714     { Bad_Opcode },
6715     { Bad_Opcode },
6716     { Bad_Opcode },
6717     { Bad_Opcode },
6718     { Bad_Opcode },
6719     /* 30 */
6720     { VEX_LEN_TABLE (VEX_LEN_0F3A30) },
6721     { VEX_LEN_TABLE (VEX_LEN_0F3A31) },
6722     { VEX_LEN_TABLE (VEX_LEN_0F3A32) },
6723     { VEX_LEN_TABLE (VEX_LEN_0F3A33) },
6724     { Bad_Opcode },
6725     { Bad_Opcode },
6726     { Bad_Opcode },
6727     { Bad_Opcode },
6728     /* 38 */
6729     { VEX_LEN_TABLE (VEX_LEN_0F3A38) },
6730     { VEX_LEN_TABLE (VEX_LEN_0F3A39) },
6731     { Bad_Opcode },
6732     { Bad_Opcode },
6733     { Bad_Opcode },
6734     { Bad_Opcode },
6735     { Bad_Opcode },
6736     { Bad_Opcode },
6737     /* 40 */
6738     { "vdpps",		{ XM, Vex, EXx, Ib }, PREFIX_DATA },
6739     { VEX_LEN_TABLE (VEX_LEN_0F3A41) },
6740     { "vmpsadbw",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
6741     { Bad_Opcode },
6742     { "vpclmulqdq",	{ XM, Vex, EXx, PCLMUL }, PREFIX_DATA },
6743     { Bad_Opcode },
6744     { VEX_LEN_TABLE (VEX_LEN_0F3A46) },
6745     { Bad_Opcode },
6746     /* 48 */
6747     { "vpermil2ps",	{ XM, Vex, EXx, XMVexI4, VexI4 }, PREFIX_DATA },
6748     { "vpermil2pd",	{ XM, Vex, EXx, XMVexI4, VexI4 }, PREFIX_DATA },
6749     { VEX_W_TABLE (VEX_W_0F3A4A) },
6750     { VEX_W_TABLE (VEX_W_0F3A4B) },
6751     { VEX_W_TABLE (VEX_W_0F3A4C) },
6752     { Bad_Opcode },
6753     { Bad_Opcode },
6754     { Bad_Opcode },
6755     /* 50 */
6756     { Bad_Opcode },
6757     { Bad_Opcode },
6758     { Bad_Opcode },
6759     { Bad_Opcode },
6760     { Bad_Opcode },
6761     { Bad_Opcode },
6762     { Bad_Opcode },
6763     { Bad_Opcode },
6764     /* 58 */
6765     { Bad_Opcode },
6766     { Bad_Opcode },
6767     { Bad_Opcode },
6768     { Bad_Opcode },
6769     { "vfmaddsubps", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6770     { "vfmaddsubpd", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6771     { "vfmsubaddps", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6772     { "vfmsubaddpd", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6773     /* 60 */
6774     { VEX_LEN_TABLE (VEX_LEN_0F3A60) },
6775     { VEX_LEN_TABLE (VEX_LEN_0F3A61) },
6776     { VEX_LEN_TABLE (VEX_LEN_0F3A62) },
6777     { VEX_LEN_TABLE (VEX_LEN_0F3A63) },
6778     { Bad_Opcode },
6779     { Bad_Opcode },
6780     { Bad_Opcode },
6781     { Bad_Opcode },
6782     /* 68 */
6783     { "vfmaddps", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6784     { "vfmaddpd", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6785     { "vfmaddss",	{ XMScalar, VexScalar, EXd, XMVexScalarI4 }, PREFIX_DATA },
6786     { "vfmaddsd",	{ XMScalar, VexScalar, EXq, XMVexScalarI4 }, PREFIX_DATA },
6787     { "vfmsubps", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6788     { "vfmsubpd", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6789     { "vfmsubss",	{ XMScalar, VexScalar, EXd, XMVexScalarI4 }, PREFIX_DATA },
6790     { "vfmsubsd",	{ XMScalar, VexScalar, EXq, XMVexScalarI4 }, PREFIX_DATA },
6791     /* 70 */
6792     { Bad_Opcode },
6793     { Bad_Opcode },
6794     { Bad_Opcode },
6795     { Bad_Opcode },
6796     { Bad_Opcode },
6797     { Bad_Opcode },
6798     { Bad_Opcode },
6799     { Bad_Opcode },
6800     /* 78 */
6801     { "vfnmaddps", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6802     { "vfnmaddpd", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6803     { "vfnmaddss",	{ XMScalar, VexScalar, EXd, XMVexScalarI4 }, PREFIX_DATA },
6804     { "vfnmaddsd",	{ XMScalar, VexScalar, EXq, XMVexScalarI4 }, PREFIX_DATA },
6805     { "vfnmsubps", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6806     { "vfnmsubpd", { XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
6807     { "vfnmsubss",	{ XMScalar, VexScalar, EXd, XMVexScalarI4 }, PREFIX_DATA },
6808     { "vfnmsubsd",	{ XMScalar, VexScalar, EXq, XMVexScalarI4 }, PREFIX_DATA },
6809     /* 80 */
6810     { Bad_Opcode },
6811     { Bad_Opcode },
6812     { Bad_Opcode },
6813     { Bad_Opcode },
6814     { Bad_Opcode },
6815     { Bad_Opcode },
6816     { Bad_Opcode },
6817     { Bad_Opcode },
6818     /* 88 */
6819     { Bad_Opcode },
6820     { Bad_Opcode },
6821     { Bad_Opcode },
6822     { Bad_Opcode },
6823     { Bad_Opcode },
6824     { Bad_Opcode },
6825     { Bad_Opcode },
6826     { Bad_Opcode },
6827     /* 90 */
6828     { Bad_Opcode },
6829     { Bad_Opcode },
6830     { Bad_Opcode },
6831     { Bad_Opcode },
6832     { Bad_Opcode },
6833     { Bad_Opcode },
6834     { Bad_Opcode },
6835     { Bad_Opcode },
6836     /* 98 */
6837     { Bad_Opcode },
6838     { Bad_Opcode },
6839     { Bad_Opcode },
6840     { Bad_Opcode },
6841     { Bad_Opcode },
6842     { Bad_Opcode },
6843     { Bad_Opcode },
6844     { Bad_Opcode },
6845     /* a0 */
6846     { Bad_Opcode },
6847     { Bad_Opcode },
6848     { Bad_Opcode },
6849     { Bad_Opcode },
6850     { Bad_Opcode },
6851     { Bad_Opcode },
6852     { Bad_Opcode },
6853     { Bad_Opcode },
6854     /* a8 */
6855     { Bad_Opcode },
6856     { Bad_Opcode },
6857     { Bad_Opcode },
6858     { Bad_Opcode },
6859     { Bad_Opcode },
6860     { Bad_Opcode },
6861     { Bad_Opcode },
6862     { Bad_Opcode },
6863     /* b0 */
6864     { Bad_Opcode },
6865     { Bad_Opcode },
6866     { Bad_Opcode },
6867     { Bad_Opcode },
6868     { Bad_Opcode },
6869     { Bad_Opcode },
6870     { Bad_Opcode },
6871     { Bad_Opcode },
6872     /* b8 */
6873     { Bad_Opcode },
6874     { Bad_Opcode },
6875     { Bad_Opcode },
6876     { Bad_Opcode },
6877     { Bad_Opcode },
6878     { Bad_Opcode },
6879     { Bad_Opcode },
6880     { Bad_Opcode },
6881     /* c0 */
6882     { Bad_Opcode },
6883     { Bad_Opcode },
6884     { Bad_Opcode },
6885     { Bad_Opcode },
6886     { Bad_Opcode },
6887     { Bad_Opcode },
6888     { Bad_Opcode },
6889     { Bad_Opcode },
6890     /* c8 */
6891     { Bad_Opcode },
6892     { Bad_Opcode },
6893     { Bad_Opcode },
6894     { Bad_Opcode },
6895     { Bad_Opcode },
6896     { Bad_Opcode },
6897     { VEX_W_TABLE (VEX_W_0F3ACE) },
6898     { VEX_W_TABLE (VEX_W_0F3ACF) },
6899     /* d0 */
6900     { Bad_Opcode },
6901     { Bad_Opcode },
6902     { Bad_Opcode },
6903     { Bad_Opcode },
6904     { Bad_Opcode },
6905     { Bad_Opcode },
6906     { Bad_Opcode },
6907     { Bad_Opcode },
6908     /* d8 */
6909     { Bad_Opcode },
6910     { Bad_Opcode },
6911     { Bad_Opcode },
6912     { Bad_Opcode },
6913     { Bad_Opcode },
6914     { Bad_Opcode },
6915     { VEX_W_TABLE (VEX_W_0F3ADE) },
6916     { VEX_LEN_TABLE (VEX_LEN_0F3ADF) },
6917     /* e0 */
6918     { Bad_Opcode },
6919     { Bad_Opcode },
6920     { Bad_Opcode },
6921     { Bad_Opcode },
6922     { Bad_Opcode },
6923     { Bad_Opcode },
6924     { Bad_Opcode },
6925     { Bad_Opcode },
6926     /* e8 */
6927     { Bad_Opcode },
6928     { Bad_Opcode },
6929     { Bad_Opcode },
6930     { Bad_Opcode },
6931     { Bad_Opcode },
6932     { Bad_Opcode },
6933     { Bad_Opcode },
6934     { Bad_Opcode },
6935     /* f0 */
6936     { VEX_LEN_TABLE (VEX_LEN_0F3AF0) },
6937     { Bad_Opcode },
6938     { Bad_Opcode },
6939     { Bad_Opcode },
6940     { Bad_Opcode },
6941     { Bad_Opcode },
6942     { Bad_Opcode },
6943     { Bad_Opcode },
6944     /* f8 */
6945     { Bad_Opcode },
6946     { Bad_Opcode },
6947     { Bad_Opcode },
6948     { Bad_Opcode },
6949     { Bad_Opcode },
6950     { Bad_Opcode },
6951     { Bad_Opcode },
6952     { Bad_Opcode },
6953   },
6954 };
6955 
6956 #include "i386-dis-evex.h"
6957 
6958 static const struct dis386 vex_len_table[][2] = {
6959   /* VEX_LEN_0F12_P_0 */
6960   {
6961     { MOD_TABLE (MOD_0F12_PREFIX_0) },
6962   },
6963 
6964   /* VEX_LEN_0F12_P_2 */
6965   {
6966     { "%XEVmovlpYX",	{ XM, Vex, Mq }, 0 },
6967   },
6968 
6969   /* VEX_LEN_0F13 */
6970   {
6971     { "%XEVmovlpYX",	{ Mq, XM }, PREFIX_OPCODE },
6972   },
6973 
6974   /* VEX_LEN_0F16_P_0 */
6975   {
6976     { MOD_TABLE (MOD_0F16_PREFIX_0) },
6977   },
6978 
6979   /* VEX_LEN_0F16_P_2 */
6980   {
6981     { "%XEVmovhpYX",	{ XM, Vex, Mq }, 0 },
6982   },
6983 
6984   /* VEX_LEN_0F17 */
6985   {
6986     { "%XEVmovhpYX",	{ Mq, XM }, PREFIX_OPCODE },
6987   },
6988 
6989   /* VEX_LEN_0F41 */
6990   {
6991     { Bad_Opcode },
6992     { VEX_W_TABLE (VEX_W_0F41_L_1) },
6993   },
6994 
6995   /* VEX_LEN_0F42 */
6996   {
6997     { Bad_Opcode },
6998     { VEX_W_TABLE (VEX_W_0F42_L_1) },
6999   },
7000 
7001   /* VEX_LEN_0F44 */
7002   {
7003     { VEX_W_TABLE (VEX_W_0F44_L_0) },
7004   },
7005 
7006   /* VEX_LEN_0F45 */
7007   {
7008     { Bad_Opcode },
7009     { VEX_W_TABLE (VEX_W_0F45_L_1) },
7010   },
7011 
7012   /* VEX_LEN_0F46 */
7013   {
7014     { Bad_Opcode },
7015     { VEX_W_TABLE (VEX_W_0F46_L_1) },
7016   },
7017 
7018   /* VEX_LEN_0F47 */
7019   {
7020     { Bad_Opcode },
7021     { VEX_W_TABLE (VEX_W_0F47_L_1) },
7022   },
7023 
7024   /* VEX_LEN_0F4A */
7025   {
7026     { Bad_Opcode },
7027     { VEX_W_TABLE (VEX_W_0F4A_L_1) },
7028   },
7029 
7030   /* VEX_LEN_0F4B */
7031   {
7032     { Bad_Opcode },
7033     { VEX_W_TABLE (VEX_W_0F4B_L_1) },
7034   },
7035 
7036   /* VEX_LEN_0F6E */
7037   {
7038     { "%XEvmovYK",	{ XMScalar, Edq }, PREFIX_DATA },
7039   },
7040 
7041   /* VEX_LEN_0F77 */
7042   {
7043     { "vzeroupper",	{ XX }, 0 },
7044     { "vzeroall",	{ XX }, 0 },
7045   },
7046 
7047   /* VEX_LEN_0F7E_P_1 */
7048   {
7049     { "%XEvmovqY",	{ XMScalar, EXq }, 0 },
7050   },
7051 
7052   /* VEX_LEN_0F7E_P_2 */
7053   {
7054     { "%XEvmovK",	{ Edq, XMScalar }, 0 },
7055   },
7056 
7057   /* VEX_LEN_0F90 */
7058   {
7059     { VEX_W_TABLE (VEX_W_0F90_L_0) },
7060   },
7061 
7062   /* VEX_LEN_0F91 */
7063   {
7064     { VEX_W_TABLE (VEX_W_0F91_L_0) },
7065   },
7066 
7067   /* VEX_LEN_0F92 */
7068   {
7069     { VEX_W_TABLE (VEX_W_0F92_L_0) },
7070   },
7071 
7072   /* VEX_LEN_0F93 */
7073   {
7074     { VEX_W_TABLE (VEX_W_0F93_L_0) },
7075   },
7076 
7077   /* VEX_LEN_0F98 */
7078   {
7079     { VEX_W_TABLE (VEX_W_0F98_L_0) },
7080   },
7081 
7082   /* VEX_LEN_0F99 */
7083   {
7084     { VEX_W_TABLE (VEX_W_0F99_L_0) },
7085   },
7086 
7087   /* VEX_LEN_0FAE_R_2 */
7088   {
7089     { "vldmxcsr",	{ Md }, 0 },
7090   },
7091 
7092   /* VEX_LEN_0FAE_R_3 */
7093   {
7094     { "vstmxcsr",	{ Md }, 0 },
7095   },
7096 
7097   /* VEX_LEN_0FC4 */
7098   {
7099     { "%XEvpinsrwY",	{ XM, Vex, Edw, Ib }, PREFIX_DATA },
7100   },
7101 
7102   /* VEX_LEN_0FD6 */
7103   {
7104     { "%XEvmovqY",	{ EXqS, XMScalar }, PREFIX_DATA },
7105   },
7106 
7107   /* VEX_LEN_0F3816 */
7108   {
7109     { Bad_Opcode },
7110     { VEX_W_TABLE (VEX_W_0F3816_L_1) },
7111   },
7112 
7113   /* VEX_LEN_0F3819 */
7114   {
7115     { Bad_Opcode },
7116     { VEX_W_TABLE (VEX_W_0F3819_L_1) },
7117   },
7118 
7119   /* VEX_LEN_0F381A */
7120   {
7121     { Bad_Opcode },
7122     { VEX_W_TABLE (VEX_W_0F381A_L_1) },
7123   },
7124 
7125   /* VEX_LEN_0F3836 */
7126   {
7127     { Bad_Opcode },
7128     { VEX_W_TABLE (VEX_W_0F3836) },
7129   },
7130 
7131   /* VEX_LEN_0F3841 */
7132   {
7133     { "vphminposuw",	{ XM, EXx }, PREFIX_DATA },
7134   },
7135 
7136   /* VEX_LEN_0F3849_X86_64 */
7137   {
7138     { VEX_W_TABLE (VEX_W_0F3849_X86_64_L_0) },
7139   },
7140 
7141   /* VEX_LEN_0F384B_X86_64 */
7142   {
7143     { VEX_W_TABLE (VEX_W_0F384B_X86_64_L_0) },
7144   },
7145 
7146   /* VEX_LEN_0F385A */
7147   {
7148     { Bad_Opcode },
7149     { VEX_W_TABLE (VEX_W_0F385A_L_0) },
7150   },
7151 
7152   /* VEX_LEN_0F385C_X86_64 */
7153   {
7154     { VEX_W_TABLE (VEX_W_0F385C_X86_64_L_0) },
7155   },
7156 
7157   /* VEX_LEN_0F385E_X86_64 */
7158   {
7159     { VEX_W_TABLE (VEX_W_0F385E_X86_64_L_0) },
7160   },
7161 
7162   /* VEX_LEN_0F386C_X86_64 */
7163   {
7164     { VEX_W_TABLE (VEX_W_0F386C_X86_64_L_0) },
7165   },
7166 
7167   /* VEX_LEN_0F38CB_P_3_W_0 */
7168   {
7169     { Bad_Opcode },
7170     { "vsha512rnds2", { XM, Vex, Rxmmq }, 0 },
7171   },
7172 
7173   /* VEX_LEN_0F38CC_P_3_W_0 */
7174   {
7175     { Bad_Opcode },
7176     { "vsha512msg1", { XM, Rxmmq }, 0 },
7177   },
7178 
7179   /* VEX_LEN_0F38CD_P_3_W_0 */
7180   {
7181     { Bad_Opcode },
7182     { "vsha512msg2", { XM, Rymm }, 0 },
7183   },
7184 
7185   /* VEX_LEN_0F38DA_W_0_P_0 */
7186   {
7187     { "vsm3msg1", { XM, Vex, EXxmm }, 0 },
7188   },
7189 
7190   /* VEX_LEN_0F38DA_W_0_P_2 */
7191   {
7192     { "vsm3msg2", { XM, Vex, EXxmm }, 0 },
7193   },
7194 
7195   /* VEX_LEN_0F38DB */
7196   {
7197     { "vaesimc",	{ XM, EXx }, PREFIX_DATA },
7198   },
7199 
7200   /* VEX_LEN_0F38F2 */
7201   {
7202     { PREFIX_TABLE (PREFIX_VEX_0F38F2_L_0) },
7203   },
7204 
7205   /* VEX_LEN_0F38F3 */
7206   {
7207     { PREFIX_TABLE (PREFIX_VEX_0F38F3_L_0) },
7208   },
7209 
7210   /* VEX_LEN_0F38F5 */
7211   {
7212     { PREFIX_TABLE(PREFIX_VEX_0F38F5_L_0) },
7213   },
7214 
7215   /* VEX_LEN_0F38F6 */
7216   {
7217     { PREFIX_TABLE(PREFIX_VEX_0F38F6_L_0) },
7218   },
7219 
7220   /* VEX_LEN_0F38F7 */
7221   {
7222     { PREFIX_TABLE(PREFIX_VEX_0F38F7_L_0) },
7223   },
7224 
7225   /* VEX_LEN_0F3A00 */
7226   {
7227     { Bad_Opcode },
7228     { VEX_W_TABLE (VEX_W_0F3A00_L_1) },
7229   },
7230 
7231   /* VEX_LEN_0F3A01 */
7232   {
7233     { Bad_Opcode },
7234     { VEX_W_TABLE (VEX_W_0F3A01_L_1) },
7235   },
7236 
7237   /* VEX_LEN_0F3A06 */
7238   {
7239     { Bad_Opcode },
7240     { VEX_W_TABLE (VEX_W_0F3A06_L_1) },
7241   },
7242 
7243   /* VEX_LEN_0F3A14 */
7244   {
7245     { "%XEvpextrb",	{ Edb, XM, Ib }, PREFIX_DATA },
7246   },
7247 
7248   /* VEX_LEN_0F3A15 */
7249   {
7250     { "%XEvpextrw",	{ Edw, XM, Ib }, PREFIX_DATA },
7251   },
7252 
7253   /* VEX_LEN_0F3A16  */
7254   {
7255     { "%XEvpextrK",	{ Edq, XM, Ib }, PREFIX_DATA },
7256   },
7257 
7258   /* VEX_LEN_0F3A17 */
7259   {
7260     { "%XEvextractps",	{ Ed, XM, Ib }, PREFIX_DATA },
7261   },
7262 
7263   /* VEX_LEN_0F3A18 */
7264   {
7265     { Bad_Opcode },
7266     { VEX_W_TABLE (VEX_W_0F3A18_L_1) },
7267   },
7268 
7269   /* VEX_LEN_0F3A19 */
7270   {
7271     { Bad_Opcode },
7272     { VEX_W_TABLE (VEX_W_0F3A19_L_1) },
7273   },
7274 
7275   /* VEX_LEN_0F3A20 */
7276   {
7277     { "%XEvpinsrbY",	{ XM, Vex, Edb, Ib }, PREFIX_DATA },
7278   },
7279 
7280   /* VEX_LEN_0F3A21 */
7281   {
7282     { "%XEvinsertpsY",	{ XM, Vex, EXd, Ib }, PREFIX_DATA },
7283   },
7284 
7285   /* VEX_LEN_0F3A22 */
7286   {
7287     { "%XEvpinsrYK",	{ XM, Vex, Edq, Ib }, PREFIX_DATA },
7288   },
7289 
7290   /* VEX_LEN_0F3A30 */
7291   {
7292     { "kshiftr%BW",	{ MaskG, MaskR, Ib }, PREFIX_DATA },
7293   },
7294 
7295   /* VEX_LEN_0F3A31 */
7296   {
7297     { "kshiftr%DQ",	{ MaskG, MaskR, Ib }, PREFIX_DATA },
7298   },
7299 
7300   /* VEX_LEN_0F3A32 */
7301   {
7302     { "kshiftl%BW",	{ MaskG, MaskR, Ib }, PREFIX_DATA },
7303   },
7304 
7305   /* VEX_LEN_0F3A33 */
7306   {
7307     { "kshiftl%DQ",	{ MaskG, MaskR, Ib }, PREFIX_DATA },
7308   },
7309 
7310   /* VEX_LEN_0F3A38 */
7311   {
7312     { Bad_Opcode },
7313     { VEX_W_TABLE (VEX_W_0F3A38_L_1) },
7314   },
7315 
7316   /* VEX_LEN_0F3A39 */
7317   {
7318     { Bad_Opcode },
7319     { VEX_W_TABLE (VEX_W_0F3A39_L_1) },
7320   },
7321 
7322   /* VEX_LEN_0F3A41 */
7323   {
7324     { "vdppd",		{ XM, Vex, EXx, Ib }, PREFIX_DATA },
7325   },
7326 
7327   /* VEX_LEN_0F3A46 */
7328   {
7329     { Bad_Opcode },
7330     { VEX_W_TABLE (VEX_W_0F3A46_L_1) },
7331   },
7332 
7333   /* VEX_LEN_0F3A60 */
7334   {
7335     { "vpcmpestrm!%LQ",	{ XM, EXx, Ib }, PREFIX_DATA },
7336   },
7337 
7338   /* VEX_LEN_0F3A61 */
7339   {
7340     { "vpcmpestri!%LQ",	{ XM, EXx, Ib }, PREFIX_DATA },
7341   },
7342 
7343   /* VEX_LEN_0F3A62 */
7344   {
7345     { "vpcmpistrm",	{ XM, EXx, Ib }, PREFIX_DATA },
7346   },
7347 
7348   /* VEX_LEN_0F3A63 */
7349   {
7350     { "vpcmpistri",	{ XM, EXx, Ib }, PREFIX_DATA },
7351   },
7352 
7353   /* VEX_LEN_0F3ADE_W_0 */
7354   {
7355     { "vsm3rnds2", { XM, Vex, EXxmm, Ib }, PREFIX_DATA },
7356   },
7357 
7358   /* VEX_LEN_0F3ADF */
7359   {
7360     { "vaeskeygenassist", { XM, EXx, Ib }, PREFIX_DATA },
7361   },
7362 
7363   /* VEX_LEN_0F3AF0 */
7364   {
7365     { PREFIX_TABLE (PREFIX_VEX_0F3AF0_L_0) },
7366   },
7367 
7368   /* VEX_LEN_MAP7_F8 */
7369   {
7370     { VEX_W_TABLE (VEX_W_MAP7_F8_L_0) },
7371   },
7372 
7373   /* VEX_LEN_XOP_08_85 */
7374   {
7375     { VEX_W_TABLE (VEX_W_XOP_08_85_L_0) },
7376   },
7377 
7378   /* VEX_LEN_XOP_08_86 */
7379   {
7380     { VEX_W_TABLE (VEX_W_XOP_08_86_L_0) },
7381   },
7382 
7383   /* VEX_LEN_XOP_08_87 */
7384   {
7385     { VEX_W_TABLE (VEX_W_XOP_08_87_L_0) },
7386   },
7387 
7388   /* VEX_LEN_XOP_08_8E */
7389   {
7390     { VEX_W_TABLE (VEX_W_XOP_08_8E_L_0) },
7391   },
7392 
7393   /* VEX_LEN_XOP_08_8F */
7394   {
7395     { VEX_W_TABLE (VEX_W_XOP_08_8F_L_0) },
7396   },
7397 
7398   /* VEX_LEN_XOP_08_95 */
7399   {
7400     { VEX_W_TABLE (VEX_W_XOP_08_95_L_0) },
7401   },
7402 
7403   /* VEX_LEN_XOP_08_96 */
7404   {
7405     { VEX_W_TABLE (VEX_W_XOP_08_96_L_0) },
7406   },
7407 
7408   /* VEX_LEN_XOP_08_97 */
7409   {
7410     { VEX_W_TABLE (VEX_W_XOP_08_97_L_0) },
7411   },
7412 
7413   /* VEX_LEN_XOP_08_9E */
7414   {
7415     { VEX_W_TABLE (VEX_W_XOP_08_9E_L_0) },
7416   },
7417 
7418   /* VEX_LEN_XOP_08_9F */
7419   {
7420     { VEX_W_TABLE (VEX_W_XOP_08_9F_L_0) },
7421   },
7422 
7423   /* VEX_LEN_XOP_08_A3 */
7424   {
7425     { "vpperm", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
7426   },
7427 
7428   /* VEX_LEN_XOP_08_A6 */
7429   {
7430     { VEX_W_TABLE (VEX_W_XOP_08_A6_L_0) },
7431   },
7432 
7433   /* VEX_LEN_XOP_08_B6 */
7434   {
7435     { VEX_W_TABLE (VEX_W_XOP_08_B6_L_0) },
7436   },
7437 
7438   /* VEX_LEN_XOP_08_C0 */
7439   {
7440     { VEX_W_TABLE (VEX_W_XOP_08_C0_L_0) },
7441   },
7442 
7443   /* VEX_LEN_XOP_08_C1 */
7444   {
7445     { VEX_W_TABLE (VEX_W_XOP_08_C1_L_0) },
7446   },
7447 
7448   /* VEX_LEN_XOP_08_C2 */
7449   {
7450     { VEX_W_TABLE (VEX_W_XOP_08_C2_L_0) },
7451   },
7452 
7453   /* VEX_LEN_XOP_08_C3 */
7454   {
7455     { VEX_W_TABLE (VEX_W_XOP_08_C3_L_0) },
7456   },
7457 
7458   /* VEX_LEN_XOP_08_CC */
7459   {
7460     { VEX_W_TABLE (VEX_W_XOP_08_CC_L_0) },
7461   },
7462 
7463   /* VEX_LEN_XOP_08_CD */
7464   {
7465     { VEX_W_TABLE (VEX_W_XOP_08_CD_L_0) },
7466   },
7467 
7468   /* VEX_LEN_XOP_08_CE */
7469   {
7470     { VEX_W_TABLE (VEX_W_XOP_08_CE_L_0) },
7471   },
7472 
7473   /* VEX_LEN_XOP_08_CF */
7474   {
7475     { VEX_W_TABLE (VEX_W_XOP_08_CF_L_0) },
7476   },
7477 
7478   /* VEX_LEN_XOP_08_EC */
7479   {
7480     { VEX_W_TABLE (VEX_W_XOP_08_EC_L_0) },
7481   },
7482 
7483   /* VEX_LEN_XOP_08_ED */
7484   {
7485     { VEX_W_TABLE (VEX_W_XOP_08_ED_L_0) },
7486   },
7487 
7488   /* VEX_LEN_XOP_08_EE */
7489   {
7490     { VEX_W_TABLE (VEX_W_XOP_08_EE_L_0) },
7491   },
7492 
7493   /* VEX_LEN_XOP_08_EF */
7494   {
7495     { VEX_W_TABLE (VEX_W_XOP_08_EF_L_0) },
7496   },
7497 
7498   /* VEX_LEN_XOP_09_01 */
7499   {
7500     { REG_TABLE (REG_XOP_09_01_L_0) },
7501   },
7502 
7503   /* VEX_LEN_XOP_09_02 */
7504   {
7505     { REG_TABLE (REG_XOP_09_02_L_0) },
7506   },
7507 
7508   /* VEX_LEN_XOP_09_12 */
7509   {
7510     { REG_TABLE (REG_XOP_09_12_L_0) },
7511   },
7512 
7513   /* VEX_LEN_XOP_09_82_W_0 */
7514   {
7515     { "vfrczss", 	{ XM, EXd }, 0 },
7516   },
7517 
7518   /* VEX_LEN_XOP_09_83_W_0 */
7519   {
7520     { "vfrczsd", 	{ XM, EXq }, 0 },
7521   },
7522 
7523   /* VEX_LEN_XOP_09_90 */
7524   {
7525     { "vprotb",		{ XM, EXx, VexW }, 0 },
7526   },
7527 
7528   /* VEX_LEN_XOP_09_91 */
7529   {
7530     { "vprotw",		{ XM, EXx, VexW }, 0 },
7531   },
7532 
7533   /* VEX_LEN_XOP_09_92 */
7534   {
7535     { "vprotd",		{ XM, EXx, VexW }, 0 },
7536   },
7537 
7538   /* VEX_LEN_XOP_09_93 */
7539   {
7540     { "vprotq",		{ XM, EXx, VexW }, 0 },
7541   },
7542 
7543   /* VEX_LEN_XOP_09_94 */
7544   {
7545     { "vpshlb",		{ XM, EXx, VexW }, 0 },
7546   },
7547 
7548   /* VEX_LEN_XOP_09_95 */
7549   {
7550     { "vpshlw",		{ XM, EXx, VexW }, 0 },
7551   },
7552 
7553   /* VEX_LEN_XOP_09_96 */
7554   {
7555     { "vpshld",		{ XM, EXx, VexW }, 0 },
7556   },
7557 
7558   /* VEX_LEN_XOP_09_97 */
7559   {
7560     { "vpshlq",		{ XM, EXx, VexW }, 0 },
7561   },
7562 
7563   /* VEX_LEN_XOP_09_98 */
7564   {
7565     { "vpshab",		{ XM, EXx, VexW }, 0 },
7566   },
7567 
7568   /* VEX_LEN_XOP_09_99 */
7569   {
7570     { "vpshaw",		{ XM, EXx, VexW }, 0 },
7571   },
7572 
7573   /* VEX_LEN_XOP_09_9A */
7574   {
7575     { "vpshad",		{ XM, EXx, VexW }, 0 },
7576   },
7577 
7578   /* VEX_LEN_XOP_09_9B */
7579   {
7580     { "vpshaq",		{ XM, EXx, VexW }, 0 },
7581   },
7582 
7583   /* VEX_LEN_XOP_09_C1 */
7584   {
7585     { VEX_W_TABLE (VEX_W_XOP_09_C1_L_0) },
7586   },
7587 
7588   /* VEX_LEN_XOP_09_C2 */
7589   {
7590     { VEX_W_TABLE (VEX_W_XOP_09_C2_L_0) },
7591   },
7592 
7593   /* VEX_LEN_XOP_09_C3 */
7594   {
7595     { VEX_W_TABLE (VEX_W_XOP_09_C3_L_0) },
7596   },
7597 
7598   /* VEX_LEN_XOP_09_C6 */
7599   {
7600     { VEX_W_TABLE (VEX_W_XOP_09_C6_L_0) },
7601   },
7602 
7603   /* VEX_LEN_XOP_09_C7 */
7604   {
7605     { VEX_W_TABLE (VEX_W_XOP_09_C7_L_0) },
7606   },
7607 
7608   /* VEX_LEN_XOP_09_CB */
7609   {
7610     { VEX_W_TABLE (VEX_W_XOP_09_CB_L_0) },
7611   },
7612 
7613   /* VEX_LEN_XOP_09_D1 */
7614   {
7615     { VEX_W_TABLE (VEX_W_XOP_09_D1_L_0) },
7616   },
7617 
7618   /* VEX_LEN_XOP_09_D2 */
7619   {
7620     { VEX_W_TABLE (VEX_W_XOP_09_D2_L_0) },
7621   },
7622 
7623   /* VEX_LEN_XOP_09_D3 */
7624   {
7625     { VEX_W_TABLE (VEX_W_XOP_09_D3_L_0) },
7626   },
7627 
7628   /* VEX_LEN_XOP_09_D6 */
7629   {
7630     { VEX_W_TABLE (VEX_W_XOP_09_D6_L_0) },
7631   },
7632 
7633   /* VEX_LEN_XOP_09_D7 */
7634   {
7635     { VEX_W_TABLE (VEX_W_XOP_09_D7_L_0) },
7636   },
7637 
7638   /* VEX_LEN_XOP_09_DB */
7639   {
7640     { VEX_W_TABLE (VEX_W_XOP_09_DB_L_0) },
7641   },
7642 
7643   /* VEX_LEN_XOP_09_E1 */
7644   {
7645     { VEX_W_TABLE (VEX_W_XOP_09_E1_L_0) },
7646   },
7647 
7648   /* VEX_LEN_XOP_09_E2 */
7649   {
7650     { VEX_W_TABLE (VEX_W_XOP_09_E2_L_0) },
7651   },
7652 
7653   /* VEX_LEN_XOP_09_E3 */
7654   {
7655     { VEX_W_TABLE (VEX_W_XOP_09_E3_L_0) },
7656   },
7657 
7658   /* VEX_LEN_XOP_0A_12 */
7659   {
7660     { REG_TABLE (REG_XOP_0A_12_L_0) },
7661   },
7662 };
7663 
7664 #include "i386-dis-evex-len.h"
7665 
7666 static const struct dis386 vex_w_table[][2] = {
7667   {
7668     /* VEX_W_0F41_L_1_M_1 */
7669     { PREFIX_TABLE (PREFIX_VEX_0F41_L_1_W_0) },
7670     { PREFIX_TABLE (PREFIX_VEX_0F41_L_1_W_1) },
7671   },
7672   {
7673     /* VEX_W_0F42_L_1_M_1 */
7674     { PREFIX_TABLE (PREFIX_VEX_0F42_L_1_W_0) },
7675     { PREFIX_TABLE (PREFIX_VEX_0F42_L_1_W_1) },
7676   },
7677   {
7678     /* VEX_W_0F44_L_0_M_1 */
7679     { PREFIX_TABLE (PREFIX_VEX_0F44_L_0_W_0) },
7680     { PREFIX_TABLE (PREFIX_VEX_0F44_L_0_W_1) },
7681   },
7682   {
7683     /* VEX_W_0F45_L_1_M_1 */
7684     { PREFIX_TABLE (PREFIX_VEX_0F45_L_1_W_0) },
7685     { PREFIX_TABLE (PREFIX_VEX_0F45_L_1_W_1) },
7686   },
7687   {
7688     /* VEX_W_0F46_L_1_M_1 */
7689     { PREFIX_TABLE (PREFIX_VEX_0F46_L_1_W_0) },
7690     { PREFIX_TABLE (PREFIX_VEX_0F46_L_1_W_1) },
7691   },
7692   {
7693     /* VEX_W_0F47_L_1_M_1 */
7694     { PREFIX_TABLE (PREFIX_VEX_0F47_L_1_W_0) },
7695     { PREFIX_TABLE (PREFIX_VEX_0F47_L_1_W_1) },
7696   },
7697   {
7698     /* VEX_W_0F4A_L_1_M_1 */
7699     { PREFIX_TABLE (PREFIX_VEX_0F4A_L_1_W_0) },
7700     { PREFIX_TABLE (PREFIX_VEX_0F4A_L_1_W_1) },
7701   },
7702   {
7703     /* VEX_W_0F4B_L_1_M_1 */
7704     { PREFIX_TABLE (PREFIX_VEX_0F4B_L_1_W_0) },
7705     { PREFIX_TABLE (PREFIX_VEX_0F4B_L_1_W_1) },
7706   },
7707   {
7708     /* VEX_W_0F90_L_0 */
7709     { PREFIX_TABLE (PREFIX_VEX_0F90_L_0_W_0) },
7710     { PREFIX_TABLE (PREFIX_VEX_0F90_L_0_W_1) },
7711   },
7712   {
7713     /* VEX_W_0F91_L_0_M_0 */
7714     { PREFIX_TABLE (PREFIX_VEX_0F91_L_0_W_0) },
7715     { PREFIX_TABLE (PREFIX_VEX_0F91_L_0_W_1) },
7716   },
7717   {
7718     /* VEX_W_0F92_L_0_M_1 */
7719     { PREFIX_TABLE (PREFIX_VEX_0F92_L_0_W_0) },
7720     { PREFIX_TABLE (PREFIX_VEX_0F92_L_0_W_1) },
7721   },
7722   {
7723     /* VEX_W_0F93_L_0_M_1 */
7724     { PREFIX_TABLE (PREFIX_VEX_0F93_L_0_W_0) },
7725     { PREFIX_TABLE (PREFIX_VEX_0F93_L_0_W_1) },
7726   },
7727   {
7728     /* VEX_W_0F98_L_0_M_1 */
7729     { PREFIX_TABLE (PREFIX_VEX_0F98_L_0_W_0) },
7730     { PREFIX_TABLE (PREFIX_VEX_0F98_L_0_W_1) },
7731   },
7732   {
7733     /* VEX_W_0F99_L_0_M_1 */
7734     { PREFIX_TABLE (PREFIX_VEX_0F99_L_0_W_0) },
7735     { PREFIX_TABLE (PREFIX_VEX_0F99_L_0_W_1) },
7736   },
7737   {
7738     /* VEX_W_0F380C  */
7739     { "%XEvpermilps",	{ XM, Vex, EXx }, PREFIX_DATA },
7740   },
7741   {
7742     /* VEX_W_0F380D  */
7743     { "vpermilpd",	{ XM, Vex, EXx }, PREFIX_DATA },
7744   },
7745   {
7746     /* VEX_W_0F380E  */
7747     { "vtestps",	{ XM, EXx }, PREFIX_DATA },
7748   },
7749   {
7750     /* VEX_W_0F380F  */
7751     { "vtestpd",	{ XM, EXx }, PREFIX_DATA },
7752   },
7753   {
7754     /* VEX_W_0F3813 */
7755     { "vcvtph2ps", { XM, EXxmmq }, PREFIX_DATA },
7756   },
7757   {
7758     /* VEX_W_0F3816_L_1  */
7759     { "vpermps",	{ XM, Vex, EXx }, PREFIX_DATA },
7760   },
7761   {
7762     /* VEX_W_0F3818 */
7763     { "%XEvbroadcastss",	{ XM, EXd }, PREFIX_DATA },
7764   },
7765   {
7766     /* VEX_W_0F3819_L_1 */
7767     { "vbroadcastsd",	{ XM, EXq }, PREFIX_DATA },
7768   },
7769   {
7770     /* VEX_W_0F381A_L_1 */
7771     { "vbroadcastf128",	{ XM, Mxmm }, PREFIX_DATA },
7772   },
7773   {
7774     /* VEX_W_0F382C */
7775     { "vmaskmovps",	{ XM, Vex, Mx }, PREFIX_DATA },
7776   },
7777   {
7778     /* VEX_W_0F382D */
7779     { "vmaskmovpd",	{ XM, Vex, Mx }, PREFIX_DATA },
7780   },
7781   {
7782     /* VEX_W_0F382E */
7783     { "vmaskmovps",	{ Mx, Vex, XM }, PREFIX_DATA },
7784   },
7785   {
7786     /* VEX_W_0F382F */
7787     { "vmaskmovpd",	{ Mx, Vex, XM }, PREFIX_DATA },
7788   },
7789   {
7790     /* VEX_W_0F3836  */
7791     { "vpermd",		{ XM, Vex, EXx }, PREFIX_DATA },
7792   },
7793   {
7794     /* VEX_W_0F3846 */
7795     { "vpsravd",	{ XM, Vex, EXx }, PREFIX_DATA },
7796   },
7797   {
7798     /* VEX_W_0F3849_X86_64_L_0 */
7799     { MOD_TABLE (MOD_VEX_0F3849_X86_64_L_0_W_0) },
7800   },
7801   {
7802     /* VEX_W_0F384B_X86_64_L_0 */
7803     { PREFIX_TABLE (PREFIX_VEX_0F384B_X86_64_L_0_W_0) },
7804   },
7805   {
7806     /* VEX_W_0F3850 */
7807     { PREFIX_TABLE (PREFIX_VEX_0F3850_W_0) },
7808   },
7809   {
7810     /* VEX_W_0F3851 */
7811     { PREFIX_TABLE (PREFIX_VEX_0F3851_W_0) },
7812   },
7813   {
7814     /* VEX_W_0F3852 */
7815     { "%XVvpdpwssd",	{ XM, Vex, EXx }, PREFIX_DATA },
7816   },
7817   {
7818     /* VEX_W_0F3853 */
7819     { "%XVvpdpwssds",	{ XM, Vex, EXx }, PREFIX_DATA },
7820   },
7821   {
7822     /* VEX_W_0F3858 */
7823     { "%XEvpbroadcastd", { XM, EXd }, PREFIX_DATA },
7824   },
7825   {
7826     /* VEX_W_0F3859 */
7827     { "vpbroadcastq", { XM, EXq }, PREFIX_DATA },
7828   },
7829   {
7830     /* VEX_W_0F385A_L_0 */
7831     { "vbroadcasti128", { XM, Mxmm }, PREFIX_DATA },
7832   },
7833   {
7834     /* VEX_W_0F385C_X86_64_L_0 */
7835     { PREFIX_TABLE (PREFIX_VEX_0F385C_X86_64_L_0_W_0) },
7836   },
7837   {
7838     /* VEX_W_0F385E_X86_64_L_0 */
7839     { PREFIX_TABLE (PREFIX_VEX_0F385E_X86_64_L_0_W_0) },
7840   },
7841   {
7842     /* VEX_W_0F386C_X86_64_L_0 */
7843     { PREFIX_TABLE (PREFIX_VEX_0F386C_X86_64_L_0_W_0) },
7844   },
7845   {
7846     /* VEX_W_0F3872_P_1 */
7847     { "%XVvcvtneps2bf16%XY", { XMM, EXx }, 0 },
7848   },
7849   {
7850     /* VEX_W_0F3878 */
7851     { "%XEvpbroadcastb",	{ XM, EXb }, PREFIX_DATA },
7852   },
7853   {
7854     /* VEX_W_0F3879 */
7855     { "%XEvpbroadcastw",	{ XM, EXw }, PREFIX_DATA },
7856   },
7857   {
7858     /* VEX_W_0F38B0 */
7859     { PREFIX_TABLE (PREFIX_VEX_0F38B0_W_0) },
7860   },
7861   {
7862     /* VEX_W_0F38B1 */
7863     { PREFIX_TABLE (PREFIX_VEX_0F38B1_W_0) },
7864   },
7865   {
7866     /* VEX_W_0F38B4 */
7867     { Bad_Opcode },
7868     { "%XVvpmadd52luq",	{ XM, Vex, EXx }, PREFIX_DATA },
7869   },
7870   {
7871     /* VEX_W_0F38B5 */
7872     { Bad_Opcode },
7873     { "%XVvpmadd52huq",	{ XM, Vex, EXx }, PREFIX_DATA },
7874   },
7875   {
7876     /* VEX_W_0F38CB_P_3 */
7877     { VEX_LEN_TABLE (VEX_LEN_0F38CB_P_3_W_0) },
7878   },
7879   {
7880     /* VEX_W_0F38CC_P_3 */
7881     { VEX_LEN_TABLE (VEX_LEN_0F38CC_P_3_W_0) },
7882   },
7883   {
7884     /* VEX_W_0F38CD_P_3 */
7885     { VEX_LEN_TABLE (VEX_LEN_0F38CD_P_3_W_0) },
7886   },
7887   {
7888     /* VEX_W_0F38CF */
7889     { "%XEvgf2p8mulb", { XM, Vex, EXx }, PREFIX_DATA },
7890   },
7891   {
7892     /* VEX_W_0F38D2 */
7893     { PREFIX_TABLE (PREFIX_VEX_0F38D2_W_0) },
7894   },
7895   {
7896     /* VEX_W_0F38D3 */
7897     { PREFIX_TABLE (PREFIX_VEX_0F38D3_W_0) },
7898   },
7899   {
7900     /* VEX_W_0F38DA */
7901     { PREFIX_TABLE (PREFIX_VEX_0F38DA_W_0) },
7902   },
7903   {
7904     /* VEX_W_0F3A00_L_1 */
7905     { Bad_Opcode },
7906     { "%XEvpermq",		{ XM, EXx, Ib }, PREFIX_DATA },
7907   },
7908   {
7909     /* VEX_W_0F3A01_L_1 */
7910     { Bad_Opcode },
7911     { "%XEvpermpd",	{ XM, EXx, Ib }, PREFIX_DATA },
7912   },
7913   {
7914     /* VEX_W_0F3A02 */
7915     { "vpblendd",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
7916   },
7917   {
7918     /* VEX_W_0F3A04 */
7919     { "%XEvpermilps",	{ XM, EXx, Ib }, PREFIX_DATA },
7920   },
7921   {
7922     /* VEX_W_0F3A05 */
7923     { "vpermilpd",	{ XM, EXx, Ib }, PREFIX_DATA },
7924   },
7925   {
7926     /* VEX_W_0F3A06_L_1 */
7927     { "vperm2f128",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
7928   },
7929   {
7930     /* VEX_W_0F3A18_L_1 */
7931     { "vinsertf128",	{ XM, Vex, EXxmm, Ib }, PREFIX_DATA },
7932   },
7933   {
7934     /* VEX_W_0F3A19_L_1 */
7935     { "vextractf128",	{ EXxmm, XM, Ib }, PREFIX_DATA },
7936   },
7937   {
7938     /* VEX_W_0F3A1D */
7939     { "%XEvcvtps2ph", { EXxmmq, XM, EXxEVexS, Ib }, PREFIX_DATA },
7940   },
7941   {
7942     /* VEX_W_0F3A38_L_1 */
7943     { "vinserti128",	{ XM, Vex, EXxmm, Ib }, PREFIX_DATA },
7944   },
7945   {
7946     /* VEX_W_0F3A39_L_1 */
7947     { "vextracti128",	{ EXxmm, XM, Ib }, PREFIX_DATA },
7948   },
7949   {
7950     /* VEX_W_0F3A46_L_1 */
7951     { "vperm2i128",	{ XM, Vex, EXx, Ib }, PREFIX_DATA },
7952   },
7953   {
7954     /* VEX_W_0F3A4A */
7955     { "vblendvps",	{ XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
7956   },
7957   {
7958     /* VEX_W_0F3A4B */
7959     { "vblendvpd",	{ XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
7960   },
7961   {
7962     /* VEX_W_0F3A4C */
7963     { "vpblendvb",	{ XM, Vex, EXx, XMVexI4 }, PREFIX_DATA },
7964   },
7965   {
7966     /* VEX_W_0F3ACE */
7967     { Bad_Opcode },
7968     { "%XEvgf2p8affineqb", { XM, Vex, EXx, Ib }, PREFIX_DATA },
7969   },
7970   {
7971     /* VEX_W_0F3ACF */
7972     { Bad_Opcode },
7973     { "%XEvgf2p8affineinvqb",  { XM, Vex, EXx, Ib }, PREFIX_DATA },
7974   },
7975   {
7976     /* VEX_W_0F3ADE */
7977     { VEX_LEN_TABLE (VEX_LEN_0F3ADE_W_0) },
7978   },
7979   {
7980     /* VEX_W_MAP7_F8_L_0 */
7981     { REG_TABLE (REG_VEX_MAP7_F8_L_0_W_0) },
7982   },
7983   /* VEX_W_XOP_08_85_L_0 */
7984   {
7985     { "vpmacssww", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
7986   },
7987   /* VEX_W_XOP_08_86_L_0 */
7988   {
7989     { "vpmacsswd", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
7990   },
7991   /* VEX_W_XOP_08_87_L_0 */
7992   {
7993     { "vpmacssdql", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
7994   },
7995   /* VEX_W_XOP_08_8E_L_0 */
7996   {
7997     { "vpmacssdd", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
7998   },
7999   /* VEX_W_XOP_08_8F_L_0 */
8000   {
8001     { "vpmacssdqh", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8002   },
8003   /* VEX_W_XOP_08_95_L_0 */
8004   {
8005     { "vpmacsww", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8006   },
8007   /* VEX_W_XOP_08_96_L_0 */
8008   {
8009     { "vpmacswd", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8010   },
8011   /* VEX_W_XOP_08_97_L_0 */
8012   {
8013     { "vpmacsdql", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8014   },
8015   /* VEX_W_XOP_08_9E_L_0 */
8016   {
8017     { "vpmacsdd", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8018   },
8019   /* VEX_W_XOP_08_9F_L_0 */
8020   {
8021     { "vpmacsdqh", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8022   },
8023   /* VEX_W_XOP_08_A6_L_0 */
8024   {
8025     { "vpmadcsswd", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8026   },
8027   /* VEX_W_XOP_08_B6_L_0 */
8028   {
8029     { "vpmadcswd", 	{ XM, Vex, EXx, XMVexI4 }, 0 },
8030   },
8031   /* VEX_W_XOP_08_C0_L_0 */
8032   {
8033     { "vprotb", 	{ XM, EXx, Ib }, 0 },
8034   },
8035   /* VEX_W_XOP_08_C1_L_0 */
8036   {
8037     { "vprotw", 	{ XM, EXx, Ib }, 0 },
8038   },
8039   /* VEX_W_XOP_08_C2_L_0 */
8040   {
8041     { "vprotd", 	{ XM, EXx, Ib }, 0 },
8042   },
8043   /* VEX_W_XOP_08_C3_L_0 */
8044   {
8045     { "vprotq", 	{ XM, EXx, Ib }, 0 },
8046   },
8047   /* VEX_W_XOP_08_CC_L_0 */
8048   {
8049      { "vpcomb",	{ XM, Vex, EXx, VPCOM }, 0 },
8050   },
8051   /* VEX_W_XOP_08_CD_L_0 */
8052   {
8053      { "vpcomw",	{ XM, Vex, EXx, VPCOM }, 0 },
8054   },
8055   /* VEX_W_XOP_08_CE_L_0 */
8056   {
8057      { "vpcomd",	{ XM, Vex, EXx, VPCOM }, 0 },
8058   },
8059   /* VEX_W_XOP_08_CF_L_0 */
8060   {
8061      { "vpcomq",	{ XM, Vex, EXx, VPCOM }, 0 },
8062   },
8063   /* VEX_W_XOP_08_EC_L_0 */
8064   {
8065      { "vpcomub",	{ XM, Vex, EXx, VPCOM }, 0 },
8066   },
8067   /* VEX_W_XOP_08_ED_L_0 */
8068   {
8069      { "vpcomuw",	{ XM, Vex, EXx, VPCOM }, 0 },
8070   },
8071   /* VEX_W_XOP_08_EE_L_0 */
8072   {
8073      { "vpcomud",	{ XM, Vex, EXx, VPCOM }, 0 },
8074   },
8075   /* VEX_W_XOP_08_EF_L_0 */
8076   {
8077      { "vpcomuq",	{ XM, Vex, EXx, VPCOM }, 0 },
8078   },
8079   /* VEX_W_XOP_09_80 */
8080   {
8081     { "vfrczps",	{ XM, EXx }, 0 },
8082   },
8083   /* VEX_W_XOP_09_81 */
8084   {
8085     { "vfrczpd",	{ XM, EXx }, 0 },
8086   },
8087   /* VEX_W_XOP_09_82 */
8088   {
8089     { VEX_LEN_TABLE (VEX_LEN_XOP_09_82_W_0) },
8090   },
8091   /* VEX_W_XOP_09_83 */
8092   {
8093     { VEX_LEN_TABLE (VEX_LEN_XOP_09_83_W_0) },
8094   },
8095   /* VEX_W_XOP_09_C1_L_0 */
8096   {
8097     { "vphaddbw",	{ XM, EXxmm }, 0 },
8098   },
8099   /* VEX_W_XOP_09_C2_L_0 */
8100   {
8101     { "vphaddbd",	{ XM, EXxmm }, 0 },
8102   },
8103   /* VEX_W_XOP_09_C3_L_0 */
8104   {
8105     { "vphaddbq",	{ XM, EXxmm }, 0 },
8106   },
8107   /* VEX_W_XOP_09_C6_L_0 */
8108   {
8109     { "vphaddwd",	{ XM, EXxmm }, 0 },
8110   },
8111   /* VEX_W_XOP_09_C7_L_0 */
8112   {
8113     { "vphaddwq",	{ XM, EXxmm }, 0 },
8114   },
8115   /* VEX_W_XOP_09_CB_L_0 */
8116   {
8117     { "vphadddq",	{ XM, EXxmm }, 0 },
8118   },
8119   /* VEX_W_XOP_09_D1_L_0 */
8120   {
8121     { "vphaddubw",	{ XM, EXxmm }, 0 },
8122   },
8123   /* VEX_W_XOP_09_D2_L_0 */
8124   {
8125     { "vphaddubd",	{ XM, EXxmm }, 0 },
8126   },
8127   /* VEX_W_XOP_09_D3_L_0 */
8128   {
8129     { "vphaddubq",	{ XM, EXxmm }, 0 },
8130   },
8131   /* VEX_W_XOP_09_D6_L_0 */
8132   {
8133     { "vphadduwd",	{ XM, EXxmm }, 0 },
8134   },
8135   /* VEX_W_XOP_09_D7_L_0 */
8136   {
8137     { "vphadduwq",	{ XM, EXxmm }, 0 },
8138   },
8139   /* VEX_W_XOP_09_DB_L_0 */
8140   {
8141     { "vphaddudq",	{ XM, EXxmm }, 0 },
8142   },
8143   /* VEX_W_XOP_09_E1_L_0 */
8144   {
8145     { "vphsubbw",	{ XM, EXxmm }, 0 },
8146   },
8147   /* VEX_W_XOP_09_E2_L_0 */
8148   {
8149     { "vphsubwd",	{ XM, EXxmm }, 0 },
8150   },
8151   /* VEX_W_XOP_09_E3_L_0 */
8152   {
8153     { "vphsubdq",	{ XM, EXxmm }, 0 },
8154   },
8155 
8156 #include "i386-dis-evex-w.h"
8157 };
8158 
8159 static const struct dis386 mod_table[][2] = {
8160   {
8161     /* MOD_62_32BIT */
8162     { "bound{S|}",	{ Gv, Ma }, 0 },
8163     { EVEX_TABLE () },
8164   },
8165   {
8166     /* MOD_C4_32BIT */
8167     { "lesS",		{ Gv, Mp }, 0 },
8168     { VEX_C4_TABLE () },
8169   },
8170   {
8171     /* MOD_C5_32BIT */
8172     { "ldsS",		{ Gv, Mp }, 0 },
8173     { VEX_C5_TABLE () },
8174   },
8175   {
8176     /* MOD_0F01_REG_0 */
8177     { X86_64_TABLE (X86_64_0F01_REG_0) },
8178     { RM_TABLE (RM_0F01_REG_0) },
8179   },
8180   {
8181     /* MOD_0F01_REG_1 */
8182     { X86_64_TABLE (X86_64_0F01_REG_1) },
8183     { RM_TABLE (RM_0F01_REG_1) },
8184   },
8185   {
8186     /* MOD_0F01_REG_2 */
8187     { X86_64_TABLE (X86_64_0F01_REG_2) },
8188     { RM_TABLE (RM_0F01_REG_2) },
8189   },
8190   {
8191     /* MOD_0F01_REG_3 */
8192     { X86_64_TABLE (X86_64_0F01_REG_3) },
8193     { RM_TABLE (RM_0F01_REG_3) },
8194   },
8195   {
8196     /* MOD_0F01_REG_5 */
8197     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_0) },
8198     { RM_TABLE (RM_0F01_REG_5_MOD_3) },
8199   },
8200   {
8201     /* MOD_0F01_REG_7 */
8202     { "invlpg",		{ Mb }, 0 },
8203     { RM_TABLE (RM_0F01_REG_7_MOD_3) },
8204   },
8205   {
8206     /* MOD_0F12_PREFIX_0 */
8207     { "%XEVmovlpYX",	{ XM, Vex, EXq }, 0 },
8208     { "%XEVmovhlpY%XS",	{ XM, Vex, EXq }, 0 },
8209   },
8210   {
8211     /* MOD_0F16_PREFIX_0 */
8212     { "%XEVmovhpYX",	{ XM, Vex, EXq }, 0 },
8213     { "%XEVmovlhpY%XS",	{ XM, Vex, EXq }, 0 },
8214   },
8215   {
8216     /* MOD_0F18_REG_0 */
8217     { "prefetchnta",	{ Mb }, 0 },
8218     { "nopQ",		{ Ev }, 0 },
8219   },
8220   {
8221     /* MOD_0F18_REG_1 */
8222     { "prefetcht0",	{ Mb }, 0 },
8223     { "nopQ",		{ Ev }, 0 },
8224   },
8225   {
8226     /* MOD_0F18_REG_2 */
8227     { "prefetcht1",	{ Mb }, 0 },
8228     { "nopQ",		{ Ev }, 0 },
8229   },
8230   {
8231     /* MOD_0F18_REG_3 */
8232     { "prefetcht2",	{ Mb }, 0 },
8233     { "nopQ",		{ Ev }, 0 },
8234   },
8235   {
8236     /* MOD_0F18_REG_6 */
8237     { X86_64_TABLE (X86_64_0F18_REG_6_MOD_0) },
8238     { "nopQ",		{ Ev }, 0 },
8239   },
8240   {
8241     /* MOD_0F18_REG_7 */
8242     { X86_64_TABLE (X86_64_0F18_REG_7_MOD_0) },
8243     { "nopQ",		{ Ev }, 0 },
8244   },
8245   {
8246     /* MOD_0F1A_PREFIX_0 */
8247     { "bndldx",		{ Gbnd, Mv_bnd }, 0 },
8248     { "nopQ",		{ Ev }, 0 },
8249   },
8250   {
8251     /* MOD_0F1B_PREFIX_0 */
8252     { "bndstx",		{ Mv_bnd, Gbnd }, 0 },
8253     { "nopQ",		{ Ev }, 0 },
8254   },
8255   {
8256     /* MOD_0F1B_PREFIX_1 */
8257     { "bndmk",		{ Gbnd, Mv_bnd }, 0 },
8258     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8259   },
8260   {
8261     /* MOD_0F1C_PREFIX_0 */
8262     { REG_TABLE (REG_0F1C_P_0_MOD_0) },
8263     { "nopQ",		{ Ev }, 0 },
8264   },
8265   {
8266     /* MOD_0F1E_PREFIX_1 */
8267     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8268     { REG_TABLE (REG_0F1E_P_1_MOD_3) },
8269   },
8270   {
8271     /* MOD_0FAE_REG_0 */
8272     { "fxsave",		{ FXSAVE }, 0 },
8273     { PREFIX_TABLE (PREFIX_0FAE_REG_0_MOD_3) },
8274   },
8275   {
8276     /* MOD_0FAE_REG_1 */
8277     { "fxrstor",	{ FXSAVE }, 0 },
8278     { PREFIX_TABLE (PREFIX_0FAE_REG_1_MOD_3) },
8279   },
8280   {
8281     /* MOD_0FAE_REG_2 */
8282     { "ldmxcsr",	{ Md }, 0 },
8283     { PREFIX_TABLE (PREFIX_0FAE_REG_2_MOD_3) },
8284   },
8285   {
8286     /* MOD_0FAE_REG_3 */
8287     { "stmxcsr",	{ Md }, 0 },
8288     { PREFIX_TABLE (PREFIX_0FAE_REG_3_MOD_3) },
8289   },
8290   {
8291     /* MOD_0FAE_REG_4 */
8292     { PREFIX_TABLE (PREFIX_0FAE_REG_4_MOD_0) },
8293     { PREFIX_TABLE (PREFIX_0FAE_REG_4_MOD_3) },
8294   },
8295   {
8296     /* MOD_0FAE_REG_5 */
8297     { "xrstor",		{ FXSAVE }, PREFIX_OPCODE | PREFIX_REX2_ILLEGAL },
8298     { PREFIX_TABLE (PREFIX_0FAE_REG_5_MOD_3) },
8299   },
8300   {
8301     /* MOD_0FAE_REG_6 */
8302     { PREFIX_TABLE (PREFIX_0FAE_REG_6_MOD_0) },
8303     { PREFIX_TABLE (PREFIX_0FAE_REG_6_MOD_3) },
8304   },
8305   {
8306     /* MOD_0FAE_REG_7 */
8307     { PREFIX_TABLE (PREFIX_0FAE_REG_7_MOD_0) },
8308     { RM_TABLE (RM_0FAE_REG_7_MOD_3) },
8309   },
8310   {
8311     /* MOD_0FC7_REG_6 */
8312     { PREFIX_TABLE (PREFIX_0FC7_REG_6_MOD_0) },
8313     { PREFIX_TABLE (PREFIX_0FC7_REG_6_MOD_3) }
8314   },
8315   {
8316     /* MOD_0FC7_REG_7 */
8317     { "vmptrst",	{ Mq }, 0 },
8318     { PREFIX_TABLE (PREFIX_0FC7_REG_7_MOD_3) }
8319   },
8320   {
8321     /* MOD_0F38DC_PREFIX_1 */
8322     { "aesenc128kl",    { XM, M }, 0 },
8323     { "loadiwkey",      { XM, EXx }, 0 },
8324   },
8325   /* MOD_0F38F8 */
8326   {
8327     { PREFIX_TABLE (PREFIX_0F38F8_M_0) },
8328     { X86_64_TABLE (X86_64_0F38F8_M_1) },
8329   },
8330   {
8331     /* MOD_VEX_0F3849_X86_64_L_0_W_0 */
8332     { PREFIX_TABLE (PREFIX_VEX_0F3849_X86_64_L_0_W_0_M_0) },
8333     { PREFIX_TABLE (PREFIX_VEX_0F3849_X86_64_L_0_W_0_M_1) },
8334   },
8335 
8336 #include "i386-dis-evex-mod.h"
8337 };
8338 
8339 static const struct dis386 rm_table[][8] = {
8340   {
8341     /* RM_C6_REG_7 */
8342     { "xabort",		{ Skip_MODRM, Ib }, 0 },
8343   },
8344   {
8345     /* RM_C7_REG_7 */
8346     { "xbeginT",	{ Skip_MODRM, Jdqw }, 0 },
8347   },
8348   {
8349     /* RM_0F01_REG_0 */
8350     { "enclv",		{ Skip_MODRM }, 0 },
8351     { "vmcall",		{ Skip_MODRM }, 0 },
8352     { "vmlaunch",	{ Skip_MODRM }, 0 },
8353     { "vmresume",	{ Skip_MODRM }, 0 },
8354     { "vmxoff",		{ Skip_MODRM }, 0 },
8355     { "pconfig",	{ Skip_MODRM }, 0 },
8356     { PREFIX_TABLE (PREFIX_0F01_REG_0_MOD_3_RM_6) },
8357     { PREFIX_TABLE (PREFIX_0F01_REG_0_MOD_3_RM_7) },
8358   },
8359   {
8360     /* RM_0F01_REG_1 */
8361     { "monitor",	{ { OP_Monitor, 0 } }, 0 },
8362     { "mwait",		{ { OP_Mwait, 0 } }, 0 },
8363     { PREFIX_TABLE (PREFIX_0F01_REG_1_RM_2) },
8364     { "stac",		{ Skip_MODRM }, 0 },
8365     { PREFIX_TABLE (PREFIX_0F01_REG_1_RM_4) },
8366     { PREFIX_TABLE (PREFIX_0F01_REG_1_RM_5) },
8367     { PREFIX_TABLE (PREFIX_0F01_REG_1_RM_6) },
8368     { PREFIX_TABLE (PREFIX_0F01_REG_1_RM_7) },
8369   },
8370   {
8371     /* RM_0F01_REG_2 */
8372     { "xgetbv",		{ Skip_MODRM }, 0 },
8373     { "xsetbv",		{ Skip_MODRM }, 0 },
8374     { Bad_Opcode },
8375     { Bad_Opcode },
8376     { "vmfunc",		{ Skip_MODRM }, 0 },
8377     { "xend",		{ Skip_MODRM }, 0 },
8378     { "xtest",		{ Skip_MODRM }, 0 },
8379     { "enclu",		{ Skip_MODRM }, 0 },
8380   },
8381   {
8382     /* RM_0F01_REG_3 */
8383     { "vmrun",		{ Skip_MODRM }, 0 },
8384     { PREFIX_TABLE (PREFIX_0F01_REG_3_RM_1) },
8385     { "vmload",		{ Skip_MODRM }, 0 },
8386     { "vmsave",		{ Skip_MODRM }, 0 },
8387     { "stgi",		{ Skip_MODRM }, 0 },
8388     { "clgi",		{ Skip_MODRM }, 0 },
8389     { "skinit",		{ Skip_MODRM }, 0 },
8390     { "invlpga",	{ Skip_MODRM }, 0 },
8391   },
8392   {
8393     /* RM_0F01_REG_5_MOD_3 */
8394     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_3_RM_0) },
8395     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_3_RM_1) },
8396     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_3_RM_2) },
8397     { Bad_Opcode },
8398     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_3_RM_4) },
8399     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_3_RM_5) },
8400     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_3_RM_6) },
8401     { PREFIX_TABLE (PREFIX_0F01_REG_5_MOD_3_RM_7) },
8402   },
8403   {
8404     /* RM_0F01_REG_7_MOD_3 */
8405     { "swapgs",		{ Skip_MODRM }, 0  },
8406     { "rdtscp",		{ Skip_MODRM }, 0  },
8407     { PREFIX_TABLE (PREFIX_0F01_REG_7_MOD_3_RM_2) },
8408     { "mwaitx",		{ { OP_Mwait, eBX_reg } }, PREFIX_OPCODE },
8409     { "clzero",		{ Skip_MODRM }, 0  },
8410     { PREFIX_TABLE (PREFIX_0F01_REG_7_MOD_3_RM_5) },
8411     { PREFIX_TABLE (PREFIX_0F01_REG_7_MOD_3_RM_6) },
8412     { PREFIX_TABLE (PREFIX_0F01_REG_7_MOD_3_RM_7) },
8413   },
8414   {
8415     /* RM_0F1E_P_1_MOD_3_REG_7 */
8416     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8417     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8418     { "endbr64",	{ Skip_MODRM }, 0 },
8419     { "endbr32",	{ Skip_MODRM }, 0 },
8420     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8421     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8422     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8423     { "nopQ",		{ Ev }, PREFIX_IGNORED },
8424   },
8425   {
8426     /* RM_0FAE_REG_6_MOD_3 */
8427     { "mfence",		{ Skip_MODRM }, 0 },
8428   },
8429   {
8430     /* RM_0FAE_REG_7_MOD_3 */
8431     { "sfence",		{ Skip_MODRM }, 0 },
8432   },
8433   {
8434     /* RM_0F3A0F_P_1_R_0 */
8435     { "hreset",		{ Skip_MODRM, Ib }, 0 },
8436   },
8437   {
8438     /* RM_VEX_0F3849_X86_64_L_0_W_0_M_1_P_0_R_0 */
8439     { "tilerelease",	{ Skip_MODRM }, 0 },
8440   },
8441   {
8442     /* RM_VEX_0F3849_X86_64_L_0_W_0_M_1_P_3 */
8443     { "tilezero",	{ TMM, Skip_MODRM }, 0 },
8444   },
8445 };
8446 
8447 #define INTERNAL_DISASSEMBLER_ERROR _("<internal disassembler error>")
8448 
8449 /* The values used here must be non-zero, fit in 'unsigned char', and not be
8450    in conflict with actual prefix opcodes.  */
8451 #define REP_PREFIX	0x01
8452 #define XACQUIRE_PREFIX	0x02
8453 #define XRELEASE_PREFIX	0x03
8454 #define BND_PREFIX	0x04
8455 #define NOTRACK_PREFIX	0x05
8456 
8457 static enum {
8458   ckp_okay,
8459   ckp_bogus,
8460   ckp_fetch_error,
8461 }
8462 ckprefix (instr_info *ins)
8463 {
8464   int i, length;
8465   uint8_t newrex;
8466 
8467   i = 0;
8468   length = 0;
8469   /* The maximum instruction length is 15bytes.  */
8470   while (length < MAX_CODE_LENGTH - 1)
8471     {
8472       if (!fetch_code (ins->info, ins->codep + 1))
8473 	return ckp_fetch_error;
8474       newrex = 0;
8475       switch (*ins->codep)
8476 	{
8477 	/* REX prefixes family.  */
8478 	case 0x40:
8479 	case 0x41:
8480 	case 0x42:
8481 	case 0x43:
8482 	case 0x44:
8483 	case 0x45:
8484 	case 0x46:
8485 	case 0x47:
8486 	case 0x48:
8487 	case 0x49:
8488 	case 0x4a:
8489 	case 0x4b:
8490 	case 0x4c:
8491 	case 0x4d:
8492 	case 0x4e:
8493 	case 0x4f:
8494 	  if (ins->address_mode == mode_64bit)
8495 	    newrex = *ins->codep;
8496 	  else
8497 	    return ckp_okay;
8498 	  ins->last_rex_prefix = i;
8499 	  break;
8500 	/* REX2 must be the last prefix. */
8501 	case REX2_OPCODE:
8502 	  if (ins->address_mode == mode_64bit)
8503 	    {
8504 	      if (ins->last_rex_prefix >= 0)
8505 		return ckp_bogus;
8506 
8507 	      ins->codep++;
8508 	      if (!fetch_code (ins->info, ins->codep + 1))
8509 		return ckp_fetch_error;
8510 	      ins->rex2_payload = *ins->codep;
8511 	      ins->rex2 = ins->rex2_payload >> 4;
8512 	      ins->rex = (ins->rex2_payload & 0xf) | REX_OPCODE;
8513 	      ins->codep++;
8514 	      ins->last_rex2_prefix = i;
8515 	      ins->all_prefixes[i] = REX2_OPCODE;
8516 	    }
8517 	  return ckp_okay;
8518 	case 0xf3:
8519 	  ins->prefixes |= PREFIX_REPZ;
8520 	  ins->last_repz_prefix = i;
8521 	  break;
8522 	case 0xf2:
8523 	  ins->prefixes |= PREFIX_REPNZ;
8524 	  ins->last_repnz_prefix = i;
8525 	  break;
8526 	case 0xf0:
8527 	  ins->prefixes |= PREFIX_LOCK;
8528 	  ins->last_lock_prefix = i;
8529 	  break;
8530 	case 0x2e:
8531 	  ins->prefixes |= PREFIX_CS;
8532 	  ins->last_seg_prefix = i;
8533 	  if (ins->address_mode != mode_64bit)
8534 	    ins->active_seg_prefix = PREFIX_CS;
8535 	  break;
8536 	case 0x36:
8537 	  ins->prefixes |= PREFIX_SS;
8538 	  ins->last_seg_prefix = i;
8539 	  if (ins->address_mode != mode_64bit)
8540 	    ins->active_seg_prefix = PREFIX_SS;
8541 	  break;
8542 	case 0x3e:
8543 	  ins->prefixes |= PREFIX_DS;
8544 	  ins->last_seg_prefix = i;
8545 	  if (ins->address_mode != mode_64bit)
8546 	    ins->active_seg_prefix = PREFIX_DS;
8547 	  break;
8548 	case 0x26:
8549 	  ins->prefixes |= PREFIX_ES;
8550 	  ins->last_seg_prefix = i;
8551 	  if (ins->address_mode != mode_64bit)
8552 	    ins->active_seg_prefix = PREFIX_ES;
8553 	  break;
8554 	case 0x64:
8555 	  ins->prefixes |= PREFIX_FS;
8556 	  ins->last_seg_prefix = i;
8557 	  ins->active_seg_prefix = PREFIX_FS;
8558 	  break;
8559 	case 0x65:
8560 	  ins->prefixes |= PREFIX_GS;
8561 	  ins->last_seg_prefix = i;
8562 	  ins->active_seg_prefix = PREFIX_GS;
8563 	  break;
8564 	case 0x66:
8565 	  ins->prefixes |= PREFIX_DATA;
8566 	  ins->last_data_prefix = i;
8567 	  break;
8568 	case 0x67:
8569 	  ins->prefixes |= PREFIX_ADDR;
8570 	  ins->last_addr_prefix = i;
8571 	  break;
8572 	case FWAIT_OPCODE:
8573 	  /* fwait is really an instruction.  If there are prefixes
8574 	     before the fwait, they belong to the fwait, *not* to the
8575 	     following instruction.  */
8576 	  ins->fwait_prefix = i;
8577 	  if (ins->prefixes || ins->rex)
8578 	    {
8579 	      ins->prefixes |= PREFIX_FWAIT;
8580 	      ins->codep++;
8581 	      /* This ensures that the previous REX prefixes are noticed
8582 		 as unused prefixes, as in the return case below.  */
8583 	      return ins->rex ? ckp_bogus : ckp_okay;
8584 	    }
8585 	  ins->prefixes = PREFIX_FWAIT;
8586 	  break;
8587 	default:
8588 	  return ckp_okay;
8589 	}
8590       /* Rex is ignored when followed by another prefix.  */
8591       if (ins->rex)
8592 	return ckp_bogus;
8593       if (*ins->codep != FWAIT_OPCODE)
8594 	ins->all_prefixes[i++] = *ins->codep;
8595       ins->rex = newrex;
8596       ins->codep++;
8597       length++;
8598     }
8599   return ckp_bogus;
8600 }
8601 
8602 /* Return the name of the prefix byte PREF, or NULL if PREF is not a
8603    prefix byte.  */
8604 
8605 static const char *
8606 prefix_name (enum address_mode mode, uint8_t pref, int sizeflag)
8607 {
8608   static const char *rexes [16] =
8609     {
8610       "rex",		/* 0x40 */
8611       "rex.B",		/* 0x41 */
8612       "rex.X",		/* 0x42 */
8613       "rex.XB",		/* 0x43 */
8614       "rex.R",		/* 0x44 */
8615       "rex.RB",		/* 0x45 */
8616       "rex.RX",		/* 0x46 */
8617       "rex.RXB",	/* 0x47 */
8618       "rex.W",		/* 0x48 */
8619       "rex.WB",		/* 0x49 */
8620       "rex.WX",		/* 0x4a */
8621       "rex.WXB",	/* 0x4b */
8622       "rex.WR",		/* 0x4c */
8623       "rex.WRB",	/* 0x4d */
8624       "rex.WRX",	/* 0x4e */
8625       "rex.WRXB",	/* 0x4f */
8626     };
8627 
8628   switch (pref)
8629     {
8630     /* REX prefixes family.  */
8631     case 0x40:
8632     case 0x41:
8633     case 0x42:
8634     case 0x43:
8635     case 0x44:
8636     case 0x45:
8637     case 0x46:
8638     case 0x47:
8639     case 0x48:
8640     case 0x49:
8641     case 0x4a:
8642     case 0x4b:
8643     case 0x4c:
8644     case 0x4d:
8645     case 0x4e:
8646     case 0x4f:
8647       return rexes [pref - 0x40];
8648     case 0xf3:
8649       return "repz";
8650     case 0xf2:
8651       return "repnz";
8652     case 0xf0:
8653       return "lock";
8654     case 0x2e:
8655       return "cs";
8656     case 0x36:
8657       return "ss";
8658     case 0x3e:
8659       return "ds";
8660     case 0x26:
8661       return "es";
8662     case 0x64:
8663       return "fs";
8664     case 0x65:
8665       return "gs";
8666     case 0x66:
8667       return (sizeflag & DFLAG) ? "data16" : "data32";
8668     case 0x67:
8669       if (mode == mode_64bit)
8670 	return (sizeflag & AFLAG) ? "addr32" : "addr64";
8671       else
8672 	return (sizeflag & AFLAG) ? "addr16" : "addr32";
8673     case FWAIT_OPCODE:
8674       return "fwait";
8675     case REP_PREFIX:
8676       return "rep";
8677     case XACQUIRE_PREFIX:
8678       return "xacquire";
8679     case XRELEASE_PREFIX:
8680       return "xrelease";
8681     case BND_PREFIX:
8682       return "bnd";
8683     case NOTRACK_PREFIX:
8684       return "notrack";
8685     case REX2_OPCODE:
8686       return "rex2";
8687     default:
8688       return NULL;
8689     }
8690 }
8691 
8692 void
8693 print_i386_disassembler_options (FILE *stream)
8694 {
8695   fprintf (stream, _("\n\
8696 The following i386/x86-64 specific disassembler options are supported for use\n\
8697 with the -M switch (multiple options should be separated by commas):\n"));
8698 
8699   fprintf (stream, _("  x86-64      Disassemble in 64bit mode\n"));
8700   fprintf (stream, _("  i386        Disassemble in 32bit mode\n"));
8701   fprintf (stream, _("  i8086       Disassemble in 16bit mode\n"));
8702   fprintf (stream, _("  att         Display instruction in AT&T syntax\n"));
8703   fprintf (stream, _("  intel       Display instruction in Intel syntax\n"));
8704   fprintf (stream, _("  att-mnemonic  (AT&T syntax only)\n"
8705 		     "              Display instruction with AT&T mnemonic\n"));
8706   fprintf (stream, _("  intel-mnemonic  (AT&T syntax only)\n"
8707 		     "              Display instruction with Intel mnemonic\n"));
8708   fprintf (stream, _("  addr64      Assume 64bit address size\n"));
8709   fprintf (stream, _("  addr32      Assume 32bit address size\n"));
8710   fprintf (stream, _("  addr16      Assume 16bit address size\n"));
8711   fprintf (stream, _("  data32      Assume 32bit data size\n"));
8712   fprintf (stream, _("  data16      Assume 16bit data size\n"));
8713   fprintf (stream, _("  suffix      Always display instruction suffix in AT&T syntax\n"));
8714   fprintf (stream, _("  amd64       Display instruction in AMD64 ISA\n"));
8715   fprintf (stream, _("  intel64     Display instruction in Intel64 ISA\n"));
8716 }
8717 
8718 /* Bad opcode.  */
8719 static const struct dis386 bad_opcode = { "(bad)", { XX }, 0 };
8720 
8721 /* Fetch error indicator.  */
8722 static const struct dis386 err_opcode = { NULL, { XX }, 0 };
8723 
8724 static const struct dis386 map7_f8_opcode = { VEX_LEN_TABLE (VEX_LEN_MAP7_F8) };
8725 
8726 /* Get a pointer to struct dis386 with a valid name.  */
8727 
8728 static const struct dis386 *
8729 get_valid_dis386 (const struct dis386 *dp, instr_info *ins)
8730 {
8731   int vindex, vex_table_index;
8732 
8733   if (dp->name != NULL)
8734     return dp;
8735 
8736   switch (dp->op[0].bytemode)
8737     {
8738     case USE_REG_TABLE:
8739       dp = &reg_table[dp->op[1].bytemode][ins->modrm.reg];
8740       break;
8741 
8742     case USE_MOD_TABLE:
8743       vindex = ins->modrm.mod == 0x3 ? 1 : 0;
8744       dp = &mod_table[dp->op[1].bytemode][vindex];
8745       break;
8746 
8747     case USE_RM_TABLE:
8748       dp = &rm_table[dp->op[1].bytemode][ins->modrm.rm];
8749       break;
8750 
8751     case USE_PREFIX_TABLE:
8752     use_prefix_table:
8753       if (ins->need_vex)
8754 	{
8755 	  /* The prefix in VEX is implicit.  */
8756 	  switch (ins->vex.prefix)
8757 	    {
8758 	    case 0:
8759 	      vindex = 0;
8760 	      break;
8761 	    case REPE_PREFIX_OPCODE:
8762 	      vindex = 1;
8763 	      break;
8764 	    case DATA_PREFIX_OPCODE:
8765 	      vindex = 2;
8766 	      break;
8767 	    case REPNE_PREFIX_OPCODE:
8768 	      vindex = 3;
8769 	      break;
8770 	    default:
8771 	      abort ();
8772 	      break;
8773 	    }
8774 	}
8775       else
8776 	{
8777 	  int last_prefix = -1;
8778 	  int prefix = 0;
8779 	  vindex = 0;
8780 	  /* We check PREFIX_REPNZ and PREFIX_REPZ before PREFIX_DATA.
8781 	     When there are multiple PREFIX_REPNZ and PREFIX_REPZ, the
8782 	     last one wins.  */
8783 	  if ((ins->prefixes & (PREFIX_REPZ | PREFIX_REPNZ)) != 0)
8784 	    {
8785 	      if (ins->last_repz_prefix > ins->last_repnz_prefix)
8786 		{
8787 		  vindex = 1;
8788 		  prefix = PREFIX_REPZ;
8789 		  last_prefix = ins->last_repz_prefix;
8790 		}
8791 	      else
8792 		{
8793 		  vindex = 3;
8794 		  prefix = PREFIX_REPNZ;
8795 		  last_prefix = ins->last_repnz_prefix;
8796 		}
8797 
8798 	      /* Check if prefix should be ignored.  */
8799 	      if ((((prefix_table[dp->op[1].bytemode][vindex].prefix_requirement
8800 		     & PREFIX_IGNORED) >> PREFIX_IGNORED_SHIFT)
8801 		   & prefix) != 0
8802 		  && !prefix_table[dp->op[1].bytemode][vindex].name)
8803 		vindex = 0;
8804 	    }
8805 
8806 	  if (vindex == 0 && (ins->prefixes & PREFIX_DATA) != 0)
8807 	    {
8808 	      vindex = 2;
8809 	      prefix = PREFIX_DATA;
8810 	      last_prefix = ins->last_data_prefix;
8811 	    }
8812 
8813 	  if (vindex != 0)
8814 	    {
8815 	      ins->used_prefixes |= prefix;
8816 	      ins->all_prefixes[last_prefix] = 0;
8817 	    }
8818 	}
8819       dp = &prefix_table[dp->op[1].bytemode][vindex];
8820       break;
8821 
8822     case USE_X86_64_EVEX_FROM_VEX_TABLE:
8823     case USE_X86_64_EVEX_PFX_TABLE:
8824     case USE_X86_64_EVEX_W_TABLE:
8825     case USE_X86_64_EVEX_MEM_W_TABLE:
8826       ins->evex_type = evex_from_vex;
8827       /* EVEX from VEX instructions are 64-bit only and require that EVEX.z,
8828 	 EVEX.L'L, EVEX.b, and the lower 2 bits of EVEX.aaa must be 0.  */
8829       if (ins->address_mode != mode_64bit
8830 	  || (ins->vex.mask_register_specifier & 0x3) != 0
8831 	  || ins->vex.ll != 0
8832 	  || ins->vex.zeroing != 0
8833 	  || ins->vex.b)
8834 	return &bad_opcode;
8835 
8836       if (dp->op[0].bytemode == USE_X86_64_EVEX_PFX_TABLE)
8837 	goto use_prefix_table;
8838       if (dp->op[0].bytemode == USE_X86_64_EVEX_W_TABLE)
8839 	goto use_vex_w_table;
8840       if (dp->op[0].bytemode == USE_X86_64_EVEX_MEM_W_TABLE)
8841 	{
8842 	  if (ins->modrm.mod == 3)
8843 	    return &bad_opcode;
8844 	  goto use_vex_w_table;
8845 	}
8846 
8847       /* Fall through.  */
8848     case USE_X86_64_TABLE:
8849       vindex = ins->address_mode == mode_64bit ? 1 : 0;
8850       dp = &x86_64_table[dp->op[1].bytemode][vindex];
8851       break;
8852 
8853     case USE_3BYTE_TABLE:
8854       if (ins->last_rex2_prefix >= 0)
8855 	return &err_opcode;
8856       if (!fetch_code (ins->info, ins->codep + 2))
8857 	return &err_opcode;
8858       vindex = *ins->codep++;
8859       dp = &three_byte_table[dp->op[1].bytemode][vindex];
8860       ins->end_codep = ins->codep;
8861       if (!fetch_modrm (ins))
8862 	return &err_opcode;
8863       break;
8864 
8865     case USE_VEX_LEN_TABLE:
8866       if (!ins->need_vex)
8867 	abort ();
8868 
8869       switch (ins->vex.length)
8870 	{
8871 	case 128:
8872 	  vindex = 0;
8873 	  break;
8874 	case 512:
8875 	  /* This allows re-using in particular table entries where only
8876 	     128-bit operand size (VEX.L=0 / EVEX.L'L=0) are valid.  */
8877 	  if (ins->vex.evex)
8878 	    {
8879 	case 256:
8880 	      vindex = 1;
8881 	      break;
8882 	    }
8883 	/* Fall through.  */
8884 	default:
8885 	  abort ();
8886 	  break;
8887 	}
8888 
8889       dp = &vex_len_table[dp->op[1].bytemode][vindex];
8890       break;
8891 
8892     case USE_EVEX_LEN_TABLE:
8893       if (!ins->vex.evex)
8894 	abort ();
8895 
8896       switch (ins->vex.length)
8897 	{
8898 	case 128:
8899 	  vindex = 0;
8900 	  break;
8901 	case 256:
8902 	  vindex = 1;
8903 	  break;
8904 	case 512:
8905 	  vindex = 2;
8906 	  break;
8907 	default:
8908 	  abort ();
8909 	  break;
8910 	}
8911 
8912       dp = &evex_len_table[dp->op[1].bytemode][vindex];
8913       break;
8914 
8915     case USE_XOP_8F_TABLE:
8916       if (!fetch_code (ins->info, ins->codep + 3))
8917 	return &err_opcode;
8918       ins->rex = ~(*ins->codep >> 5) & 0x7;
8919 
8920       /* VEX_TABLE_INDEX is the mmmmm part of the XOP byte 1 "RCB.mmmmm".  */
8921       switch ((*ins->codep & 0x1f))
8922 	{
8923 	default:
8924 	  dp = &bad_opcode;
8925 	  return dp;
8926 	case 0x8:
8927 	  vex_table_index = XOP_08;
8928 	  break;
8929 	case 0x9:
8930 	  vex_table_index = XOP_09;
8931 	  break;
8932 	case 0xa:
8933 	  vex_table_index = XOP_0A;
8934 	  break;
8935 	}
8936       ins->codep++;
8937       ins->vex.w = *ins->codep & 0x80;
8938       if (ins->vex.w && ins->address_mode == mode_64bit)
8939 	ins->rex |= REX_W;
8940 
8941       ins->vex.register_specifier = (~(*ins->codep >> 3)) & 0xf;
8942       if (ins->address_mode != mode_64bit)
8943 	{
8944 	  /* In 16/32-bit mode REX_B is silently ignored.  */
8945 	  ins->rex &= ~REX_B;
8946 	}
8947 
8948       ins->vex.length = (*ins->codep & 0x4) ? 256 : 128;
8949       switch ((*ins->codep & 0x3))
8950 	{
8951 	case 0:
8952 	  break;
8953 	case 1:
8954 	  ins->vex.prefix = DATA_PREFIX_OPCODE;
8955 	  break;
8956 	case 2:
8957 	  ins->vex.prefix = REPE_PREFIX_OPCODE;
8958 	  break;
8959 	case 3:
8960 	  ins->vex.prefix = REPNE_PREFIX_OPCODE;
8961 	  break;
8962 	}
8963       ins->need_vex = 3;
8964       ins->codep++;
8965       vindex = *ins->codep++;
8966       dp = &xop_table[vex_table_index][vindex];
8967 
8968       ins->end_codep = ins->codep;
8969       if (!fetch_modrm (ins))
8970 	return &err_opcode;
8971 
8972       /* No XOP encoding so far allows for a non-zero embedded prefix. Avoid
8973 	 having to decode the bits for every otherwise valid encoding.  */
8974       if (ins->vex.prefix)
8975 	return &bad_opcode;
8976       break;
8977 
8978     case USE_VEX_C4_TABLE:
8979       /* VEX prefix.  */
8980       if (!fetch_code (ins->info, ins->codep + 3))
8981 	return &err_opcode;
8982       ins->rex = ~(*ins->codep >> 5) & 0x7;
8983       switch ((*ins->codep & 0x1f))
8984 	{
8985 	default:
8986 	  dp = &bad_opcode;
8987 	  return dp;
8988 	case 0x1:
8989 	  vex_table_index = VEX_0F;
8990 	  break;
8991 	case 0x2:
8992 	  vex_table_index = VEX_0F38;
8993 	  break;
8994 	case 0x3:
8995 	  vex_table_index = VEX_0F3A;
8996 	  break;
8997 	case 0x7:
8998 	  vex_table_index = VEX_MAP7;
8999 	  break;
9000 	}
9001       ins->codep++;
9002       ins->vex.w = *ins->codep & 0x80;
9003       if (ins->address_mode == mode_64bit)
9004 	{
9005 	  if (ins->vex.w)
9006 	    ins->rex |= REX_W;
9007 	}
9008       else
9009 	{
9010 	  /* For the 3-byte VEX prefix in 32-bit mode, the REX_B bit
9011 	     is ignored, other REX bits are 0 and the highest bit in
9012 	     VEX.vvvv is also ignored (but we mustn't clear it here).  */
9013 	  ins->rex = 0;
9014 	}
9015       ins->vex.register_specifier = (~(*ins->codep >> 3)) & 0xf;
9016       ins->vex.length = (*ins->codep & 0x4) ? 256 : 128;
9017       switch ((*ins->codep & 0x3))
9018 	{
9019 	case 0:
9020 	  break;
9021 	case 1:
9022 	  ins->vex.prefix = DATA_PREFIX_OPCODE;
9023 	  break;
9024 	case 2:
9025 	  ins->vex.prefix = REPE_PREFIX_OPCODE;
9026 	  break;
9027 	case 3:
9028 	  ins->vex.prefix = REPNE_PREFIX_OPCODE;
9029 	  break;
9030 	}
9031       ins->need_vex = 3;
9032       ins->codep++;
9033       vindex = *ins->codep++;
9034       if (vex_table_index != VEX_MAP7)
9035 	dp = &vex_table[vex_table_index][vindex];
9036       else if (vindex == 0xf8)
9037 	dp = &map7_f8_opcode;
9038       else
9039 	dp = &bad_opcode;
9040       ins->end_codep = ins->codep;
9041       /* There is no MODRM byte for VEX0F 77.  */
9042       if ((vex_table_index != VEX_0F || vindex != 0x77)
9043 	  && !fetch_modrm (ins))
9044 	return &err_opcode;
9045       break;
9046 
9047     case USE_VEX_C5_TABLE:
9048       /* VEX prefix.  */
9049       if (!fetch_code (ins->info, ins->codep + 2))
9050 	return &err_opcode;
9051       ins->rex = (*ins->codep & 0x80) ? 0 : REX_R;
9052 
9053       /* For the 2-byte VEX prefix in 32-bit mode, the highest bit in
9054 	 VEX.vvvv is 1.  */
9055       ins->vex.register_specifier = (~(*ins->codep >> 3)) & 0xf;
9056       ins->vex.length = (*ins->codep & 0x4) ? 256 : 128;
9057       switch ((*ins->codep & 0x3))
9058 	{
9059 	case 0:
9060 	  break;
9061 	case 1:
9062 	  ins->vex.prefix = DATA_PREFIX_OPCODE;
9063 	  break;
9064 	case 2:
9065 	  ins->vex.prefix = REPE_PREFIX_OPCODE;
9066 	  break;
9067 	case 3:
9068 	  ins->vex.prefix = REPNE_PREFIX_OPCODE;
9069 	  break;
9070 	}
9071       ins->need_vex = 2;
9072       ins->codep++;
9073       vindex = *ins->codep++;
9074       dp = &vex_table[VEX_0F][vindex];
9075       ins->end_codep = ins->codep;
9076       /* There is no MODRM byte for VEX 77.  */
9077       if (vindex != 0x77 && !fetch_modrm (ins))
9078 	return &err_opcode;
9079       break;
9080 
9081     case USE_VEX_W_TABLE:
9082     use_vex_w_table:
9083       if (!ins->need_vex)
9084 	abort ();
9085 
9086       dp = &vex_w_table[dp->op[1].bytemode][ins->vex.w];
9087       break;
9088 
9089     case USE_EVEX_TABLE:
9090       ins->two_source_ops = false;
9091       /* EVEX prefix.  */
9092       ins->vex.evex = true;
9093       if (!fetch_code (ins->info, ins->codep + 4))
9094 	return &err_opcode;
9095       /* The first byte after 0x62.  */
9096       if (*ins->codep & 0x8)
9097 	ins->rex2 |= REX_B;
9098       if (!(*ins->codep & 0x10))
9099 	ins->rex2 |= REX_R;
9100 
9101       ins->rex = ~(*ins->codep >> 5) & 0x7;
9102       switch (*ins->codep & 0x7)
9103 	{
9104 	default:
9105 	  return &bad_opcode;
9106 	case 0x1:
9107 	  vex_table_index = EVEX_0F;
9108 	  break;
9109 	case 0x2:
9110 	  vex_table_index = EVEX_0F38;
9111 	  break;
9112 	case 0x3:
9113 	  vex_table_index = EVEX_0F3A;
9114 	  break;
9115 	case 0x4:
9116 	  vex_table_index = EVEX_MAP4;
9117 	  ins->evex_type = evex_from_legacy;
9118 	  if (ins->address_mode != mode_64bit)
9119 	    return &bad_opcode;
9120 	  break;
9121 	case 0x5:
9122 	  vex_table_index = EVEX_MAP5;
9123 	  break;
9124 	case 0x6:
9125 	  vex_table_index = EVEX_MAP6;
9126 	  break;
9127 	case 0x7:
9128 	  vex_table_index = EVEX_MAP7;
9129 	  break;
9130 	}
9131 
9132       /* The second byte after 0x62.  */
9133       ins->codep++;
9134       ins->vex.w = *ins->codep & 0x80;
9135       if (ins->vex.w && ins->address_mode == mode_64bit)
9136 	ins->rex |= REX_W;
9137 
9138       ins->vex.register_specifier = (~(*ins->codep >> 3)) & 0xf;
9139 
9140       if (!(*ins->codep & 0x4))
9141 	ins->rex2 |= REX_X;
9142 
9143       switch ((*ins->codep & 0x3))
9144 	{
9145 	case 0:
9146 	  break;
9147 	case 1:
9148 	  ins->vex.prefix = DATA_PREFIX_OPCODE;
9149 	  break;
9150 	case 2:
9151 	  ins->vex.prefix = REPE_PREFIX_OPCODE;
9152 	  break;
9153 	case 3:
9154 	  ins->vex.prefix = REPNE_PREFIX_OPCODE;
9155 	  break;
9156 	}
9157 
9158       /* The third byte after 0x62.  */
9159       ins->codep++;
9160 
9161       /* Remember the static rounding bits.  */
9162       ins->vex.ll = (*ins->codep >> 5) & 3;
9163       ins->vex.b = *ins->codep & 0x10;
9164 
9165       ins->vex.v = *ins->codep & 0x8;
9166       ins->vex.mask_register_specifier = *ins->codep & 0x7;
9167       ins->vex.zeroing = *ins->codep & 0x80;
9168       /* Set the NF bit for EVEX-Promoted instructions, this bit will be cleared
9169 	 when it's an evex_default one.  */
9170       ins->vex.nf = *ins->codep & 0x4;
9171 
9172       if (ins->address_mode != mode_64bit)
9173 	{
9174 	  /* Report bad for !evex_default and when two fixed values of evex
9175 	     change..  */
9176 	  if (ins->evex_type != evex_default
9177 	      || (ins->rex2 & (REX_B | REX_X)))
9178 	    return &bad_opcode;
9179 	  /* In 16/32-bit mode silently ignore following bits.  */
9180 	  ins->rex &= ~REX_B;
9181 	  ins->rex2 &= ~REX_R;
9182 	}
9183 
9184       /* EVEX from legacy instructions, when the EVEX.ND bit is 0,
9185 	 all bits of EVEX.vvvv and EVEX.V' must be 1.  */
9186       if (ins->evex_type == evex_from_legacy && !ins->vex.nd
9187 	  && (ins->vex.register_specifier || !ins->vex.v))
9188 	return &bad_opcode;
9189 
9190       ins->need_vex = 4;
9191 
9192       /* EVEX from legacy instructions require that EVEX.z, EVEX.L’L and the
9193 	 lower 2 bits of EVEX.aaa must be 0.  */
9194       if (ins->evex_type == evex_from_legacy
9195 	  && ((ins->vex.mask_register_specifier & 0x3) != 0
9196 	      || ins->vex.ll != 0
9197 	      || ins->vex.zeroing != 0))
9198 	return &bad_opcode;
9199 
9200       ins->codep++;
9201       vindex = *ins->codep++;
9202       if (vex_table_index != EVEX_MAP7)
9203 	dp = &evex_table[vex_table_index][vindex];
9204       else if (vindex == 0xf8)
9205 	dp = &map7_f8_opcode;
9206       else
9207 	dp = &bad_opcode;
9208       ins->end_codep = ins->codep;
9209       if (!fetch_modrm (ins))
9210 	return &err_opcode;
9211 
9212       if (ins->modrm.mod == 3 && (ins->rex2 & REX_X))
9213 	return &bad_opcode;
9214 
9215       /* Set vector length. For EVEX-promoted instructions, evex.ll == 0b00,
9216 	 which has the same encoding as vex.length == 128 and they can share
9217 	 the same processing with vex.length in OP_VEX.  */
9218       if (ins->modrm.mod == 3 && ins->vex.b && ins->evex_type != evex_from_legacy)
9219 	ins->vex.length = 512;
9220       else
9221 	{
9222 	  switch (ins->vex.ll)
9223 	    {
9224 	    case 0x0:
9225 	      ins->vex.length = 128;
9226 	      break;
9227 	    case 0x1:
9228 	      ins->vex.length = 256;
9229 	      break;
9230 	    case 0x2:
9231 	      ins->vex.length = 512;
9232 	      break;
9233 	    default:
9234 	      return &bad_opcode;
9235 	    }
9236 	}
9237       break;
9238 
9239     case 0:
9240       dp = &bad_opcode;
9241       break;
9242 
9243     default:
9244       abort ();
9245     }
9246 
9247   if (dp->name != NULL)
9248     return dp;
9249   else
9250     return get_valid_dis386 (dp, ins);
9251 }
9252 
9253 static bool
9254 get_sib (instr_info *ins, int sizeflag)
9255 {
9256   /* If modrm.mod == 3, operand must be register.  */
9257   if (ins->need_modrm
9258       && ((sizeflag & AFLAG) || ins->address_mode == mode_64bit)
9259       && ins->modrm.mod != 3
9260       && ins->modrm.rm == 4)
9261     {
9262       if (!fetch_code (ins->info, ins->codep + 2))
9263 	return false;
9264       ins->sib.index = (ins->codep[1] >> 3) & 7;
9265       ins->sib.scale = (ins->codep[1] >> 6) & 3;
9266       ins->sib.base = ins->codep[1] & 7;
9267       ins->has_sib = true;
9268     }
9269   else
9270     ins->has_sib = false;
9271 
9272   return true;
9273 }
9274 
9275 /* Like oappend_with_style (below) but always with text style.  */
9276 
9277 static void
9278 oappend (instr_info *ins, const char *s)
9279 {
9280   oappend_with_style (ins, s, dis_style_text);
9281 }
9282 
9283 /* Like oappend (above), but S is a string starting with '%'.  In
9284    Intel syntax, the '%' is elided.  */
9285 
9286 static void
9287 oappend_register (instr_info *ins, const char *s)
9288 {
9289   oappend_with_style (ins, s + ins->intel_syntax, dis_style_register);
9290 }
9291 
9292 /* Wrap around a call to INS->info->fprintf_styled_func, printing FMT.
9293    STYLE is the default style to use in the fprintf_styled_func calls,
9294    however, FMT might include embedded style markers (see oappend_style),
9295    these embedded markers are not printed, but instead change the style
9296    used in the next fprintf_styled_func call.  */
9297 
9298 static void ATTRIBUTE_PRINTF_3
9299 i386_dis_printf (const disassemble_info *info, enum disassembler_style style,
9300 		 const char *fmt, ...)
9301 {
9302   va_list ap;
9303   enum disassembler_style curr_style = style;
9304   const char *start, *curr;
9305   char staging_area[40];
9306 
9307   va_start (ap, fmt);
9308   /* In particular print_insn()'s processing of op_txt[] can hand rather long
9309      strings here.  Bypass vsnprintf() in such cases to avoid capacity issues
9310      with the staging area.  */
9311   if (strcmp (fmt, "%s"))
9312     {
9313       int res = vsnprintf (staging_area, sizeof (staging_area), fmt, ap);
9314 
9315       va_end (ap);
9316 
9317       if (res < 0)
9318 	return;
9319 
9320       if ((size_t) res >= sizeof (staging_area))
9321 	abort ();
9322 
9323       start = curr = staging_area;
9324     }
9325   else
9326     {
9327       start = curr = va_arg (ap, const char *);
9328       va_end (ap);
9329     }
9330 
9331   do
9332     {
9333       if (*curr == '\0'
9334 	  || (*curr == STYLE_MARKER_CHAR
9335 	      && ISXDIGIT (*(curr + 1))
9336 	      && *(curr + 2) == STYLE_MARKER_CHAR))
9337 	{
9338 	  /* Output content between our START position and CURR.  */
9339 	  int len = curr - start;
9340 	  int n = (*info->fprintf_styled_func) (info->stream, curr_style,
9341 						"%.*s", len, start);
9342 	  if (n < 0)
9343 	    break;
9344 
9345 	  if (*curr == '\0')
9346 	    break;
9347 
9348 	  /* Skip over the initial STYLE_MARKER_CHAR.  */
9349 	  ++curr;
9350 
9351 	  /* Update the CURR_STYLE.  As there are less than 16 styles, it
9352 	     is possible, that if the input is corrupted in some way, that
9353 	     we might set CURR_STYLE to an invalid value.  Don't worry
9354 	     though, we check for this situation.  */
9355 	  if (*curr >= '0' && *curr <= '9')
9356 	    curr_style = (enum disassembler_style) (*curr - '0');
9357 	  else if (*curr >= 'a' && *curr <= 'f')
9358 	    curr_style = (enum disassembler_style) (*curr - 'a' + 10);
9359 	  else
9360 	    curr_style = dis_style_text;
9361 
9362 	  /* Check for an invalid style having been selected.  This should
9363 	     never happen, but it doesn't hurt to be a little paranoid.  */
9364 	  if (curr_style > dis_style_comment_start)
9365 	    curr_style = dis_style_text;
9366 
9367 	  /* Skip the hex character, and the closing STYLE_MARKER_CHAR.  */
9368 	  curr += 2;
9369 
9370 	  /* Reset the START to after the style marker.  */
9371 	  start = curr;
9372 	}
9373       else
9374 	++curr;
9375     }
9376   while (true);
9377 }
9378 
9379 static int
9380 print_insn (bfd_vma pc, disassemble_info *info, int intel_syntax)
9381 {
9382   const struct dis386 *dp;
9383   int i;
9384   int ret;
9385   char *op_txt[MAX_OPERANDS];
9386   int needcomma;
9387   bool intel_swap_2_3;
9388   int sizeflag, orig_sizeflag;
9389   const char *p;
9390   struct dis_private priv;
9391   int prefix_length;
9392   int op_count;
9393   instr_info ins = {
9394     .info = info,
9395     .intel_syntax = intel_syntax >= 0
9396 		    ? intel_syntax
9397 		    : (info->mach & bfd_mach_i386_intel_syntax) != 0,
9398     .intel_mnemonic = !SYSV386_COMPAT,
9399     .op_index[0 ... MAX_OPERANDS - 1] = -1,
9400     .start_pc = pc,
9401     .start_codep = priv.the_buffer,
9402     .codep = priv.the_buffer,
9403     .obufp = ins.obuf,
9404     .last_lock_prefix = -1,
9405     .last_repz_prefix = -1,
9406     .last_repnz_prefix = -1,
9407     .last_data_prefix = -1,
9408     .last_addr_prefix = -1,
9409     .last_rex_prefix = -1,
9410     .last_rex2_prefix = -1,
9411     .last_seg_prefix = -1,
9412     .fwait_prefix = -1,
9413   };
9414   char op_out[MAX_OPERANDS][MAX_OPERAND_BUFFER_SIZE];
9415 
9416   priv.orig_sizeflag = AFLAG | DFLAG;
9417   if ((info->mach & bfd_mach_i386_i386) != 0)
9418     ins.address_mode = mode_32bit;
9419   else if (info->mach == bfd_mach_i386_i8086)
9420     {
9421       ins.address_mode = mode_16bit;
9422       priv.orig_sizeflag = 0;
9423     }
9424   else
9425     ins.address_mode = mode_64bit;
9426 
9427   for (p = info->disassembler_options; p != NULL;)
9428     {
9429       if (startswith (p, "amd64"))
9430 	ins.isa64 = amd64;
9431       else if (startswith (p, "intel64"))
9432 	ins.isa64 = intel64;
9433       else if (startswith (p, "x86-64"))
9434 	{
9435 	  ins.address_mode = mode_64bit;
9436 	  priv.orig_sizeflag |= AFLAG | DFLAG;
9437 	}
9438       else if (startswith (p, "i386"))
9439 	{
9440 	  ins.address_mode = mode_32bit;
9441 	  priv.orig_sizeflag |= AFLAG | DFLAG;
9442 	}
9443       else if (startswith (p, "i8086"))
9444 	{
9445 	  ins.address_mode = mode_16bit;
9446 	  priv.orig_sizeflag &= ~(AFLAG | DFLAG);
9447 	}
9448       else if (startswith (p, "intel"))
9449 	{
9450 	  if (startswith (p + 5, "-mnemonic"))
9451 	    ins.intel_mnemonic = true;
9452 	  else
9453 	    ins.intel_syntax = 1;
9454 	}
9455       else if (startswith (p, "att"))
9456 	{
9457 	  ins.intel_syntax = 0;
9458 	  if (startswith (p + 3, "-mnemonic"))
9459 	    ins.intel_mnemonic = false;
9460 	}
9461       else if (startswith (p, "addr"))
9462 	{
9463 	  if (ins.address_mode == mode_64bit)
9464 	    {
9465 	      if (p[4] == '3' && p[5] == '2')
9466 		priv.orig_sizeflag &= ~AFLAG;
9467 	      else if (p[4] == '6' && p[5] == '4')
9468 		priv.orig_sizeflag |= AFLAG;
9469 	    }
9470 	  else
9471 	    {
9472 	      if (p[4] == '1' && p[5] == '6')
9473 		priv.orig_sizeflag &= ~AFLAG;
9474 	      else if (p[4] == '3' && p[5] == '2')
9475 		priv.orig_sizeflag |= AFLAG;
9476 	    }
9477 	}
9478       else if (startswith (p, "data"))
9479 	{
9480 	  if (p[4] == '1' && p[5] == '6')
9481 	    priv.orig_sizeflag &= ~DFLAG;
9482 	  else if (p[4] == '3' && p[5] == '2')
9483 	    priv.orig_sizeflag |= DFLAG;
9484 	}
9485       else if (startswith (p, "suffix"))
9486 	priv.orig_sizeflag |= SUFFIX_ALWAYS;
9487 
9488       p = strchr (p, ',');
9489       if (p != NULL)
9490 	p++;
9491     }
9492 
9493   if (ins.address_mode == mode_64bit && sizeof (bfd_vma) < 8)
9494     {
9495       i386_dis_printf (info, dis_style_text, _("64-bit address is disabled"));
9496       return -1;
9497     }
9498 
9499   if (ins.intel_syntax)
9500     {
9501       ins.open_char = '[';
9502       ins.close_char = ']';
9503       ins.separator_char = '+';
9504       ins.scale_char = '*';
9505     }
9506   else
9507     {
9508       ins.open_char = '(';
9509       ins.close_char =  ')';
9510       ins.separator_char = ',';
9511       ins.scale_char = ',';
9512     }
9513 
9514   /* The output looks better if we put 7 bytes on a line, since that
9515      puts most long word instructions on a single line.  */
9516   info->bytes_per_line = 7;
9517 
9518   info->private_data = &priv;
9519   priv.fetched = 0;
9520   priv.insn_start = pc;
9521 
9522   for (i = 0; i < MAX_OPERANDS; ++i)
9523     {
9524       op_out[i][0] = 0;
9525       ins.op_out[i] = op_out[i];
9526     }
9527 
9528   sizeflag = priv.orig_sizeflag;
9529 
9530   switch (ckprefix (&ins))
9531     {
9532     case ckp_okay:
9533       break;
9534 
9535     case ckp_bogus:
9536       /* Too many prefixes or unused REX prefixes.  */
9537       for (i = 0;
9538 	   i < (int) ARRAY_SIZE (ins.all_prefixes) && ins.all_prefixes[i];
9539 	   i++)
9540 	i386_dis_printf (info, dis_style_mnemonic, "%s%s",
9541 			 (i == 0 ? "" : " "),
9542 			 prefix_name (ins.address_mode, ins.all_prefixes[i],
9543 				      sizeflag));
9544       ret = i;
9545       goto out;
9546 
9547     case ckp_fetch_error:
9548       goto fetch_error_out;
9549     }
9550 
9551   ins.nr_prefixes = ins.codep - ins.start_codep;
9552 
9553   if (!fetch_code (info, ins.codep + 1))
9554     {
9555     fetch_error_out:
9556       ret = fetch_error (&ins);
9557       goto out;
9558     }
9559 
9560   ins.two_source_ops = (*ins.codep == 0x62 || *ins.codep == 0xc8);
9561 
9562   if ((ins.prefixes & PREFIX_FWAIT)
9563       && (*ins.codep < 0xd8 || *ins.codep > 0xdf))
9564     {
9565       /* Handle ins.prefixes before fwait.  */
9566       for (i = 0; i < ins.fwait_prefix && ins.all_prefixes[i];
9567 	   i++)
9568 	i386_dis_printf (info, dis_style_mnemonic, "%s ",
9569 			 prefix_name (ins.address_mode, ins.all_prefixes[i],
9570 				      sizeflag));
9571       i386_dis_printf (info, dis_style_mnemonic, "fwait");
9572       ret = i + 1;
9573       goto out;
9574     }
9575 
9576   /* REX2.M in rex2 prefix represents map0 or map1.  */
9577   if (ins.last_rex2_prefix < 0 ? *ins.codep == 0x0f : (ins.rex2 & REX2_M))
9578     {
9579       if (!ins.rex2)
9580 	{
9581 	  ins.codep++;
9582 	  if (!fetch_code (info, ins.codep + 1))
9583 	    goto fetch_error_out;
9584 	}
9585 
9586       dp = &dis386_twobyte[*ins.codep];
9587       ins.need_modrm = twobyte_has_modrm[*ins.codep];
9588     }
9589   else
9590     {
9591       dp = &dis386[*ins.codep];
9592       ins.need_modrm = onebyte_has_modrm[*ins.codep];
9593     }
9594   ins.codep++;
9595 
9596   /* Save sizeflag for printing the extra ins.prefixes later before updating
9597      it for mnemonic and operand processing.  The prefix names depend
9598      only on the address mode.  */
9599   orig_sizeflag = sizeflag;
9600   if (ins.prefixes & PREFIX_ADDR)
9601     sizeflag ^= AFLAG;
9602   if ((ins.prefixes & PREFIX_DATA))
9603     sizeflag ^= DFLAG;
9604 
9605   ins.end_codep = ins.codep;
9606   if (ins.need_modrm && !fetch_modrm (&ins))
9607     goto fetch_error_out;
9608 
9609   if (dp->name == NULL && dp->op[0].bytemode == FLOATCODE)
9610     {
9611       if (!get_sib (&ins, sizeflag)
9612 	  || !dofloat (&ins, sizeflag))
9613 	goto fetch_error_out;
9614     }
9615   else
9616     {
9617       dp = get_valid_dis386 (dp, &ins);
9618       if (dp == &err_opcode)
9619 	goto fetch_error_out;
9620 
9621       /* For APX instructions promoted from legacy maps 0/1, embedded prefix
9622 	 is interpreted as the operand size override.  */
9623       if (ins.evex_type == evex_from_legacy
9624 	  && ins.vex.prefix == DATA_PREFIX_OPCODE)
9625 	sizeflag ^= DFLAG;
9626 
9627       if(ins.evex_type == evex_default)
9628 	ins.vex.nf = false;
9629       else
9630 	/* For EVEX-promoted formats, we need to clear EVEX.NF (ccmp and ctest
9631 	   are cleared separately.) in mask_register_specifier and keep the low
9632 	   2 bits of mask_register_specifier to report errors for invalid cases
9633 	   .  */
9634 	ins.vex.mask_register_specifier &= 0x3;
9635 
9636       if (dp != NULL && putop (&ins, dp->name, sizeflag) == 0)
9637 	{
9638 	  if (!get_sib (&ins, sizeflag))
9639 	    goto fetch_error_out;
9640 	  for (i = 0; i < MAX_OPERANDS; ++i)
9641 	    {
9642 	      ins.obufp = ins.op_out[i];
9643 	      ins.op_ad = MAX_OPERANDS - 1 - i;
9644 	      if (dp->op[i].rtn
9645 		  && !dp->op[i].rtn (&ins, dp->op[i].bytemode, sizeflag))
9646 		goto fetch_error_out;
9647 	      /* For EVEX instruction after the last operand masking
9648 		 should be printed.  */
9649 	      if (i == 0 && ins.vex.evex)
9650 		{
9651 		  /* Don't print {%k0}.  */
9652 		  if (ins.vex.mask_register_specifier)
9653 		    {
9654 		      const char *reg_name
9655 			= att_names_mask[ins.vex.mask_register_specifier];
9656 
9657 		      oappend (&ins, "{");
9658 		      oappend_register (&ins, reg_name);
9659 		      oappend (&ins, "}");
9660 
9661 		      if (ins.vex.zeroing)
9662 			oappend (&ins, "{z}");
9663 		    }
9664 		  else if (ins.vex.zeroing)
9665 		    {
9666 		      oappend (&ins, "{bad}");
9667 		      continue;
9668 		    }
9669 
9670 		  /* Instructions with a mask register destination allow for
9671 		     zeroing-masking only (if any masking at all), which is
9672 		     _not_ expressed by EVEX.z.  */
9673 		  if (ins.vex.zeroing && dp->op[0].bytemode == mask_mode)
9674 		    ins.illegal_masking = true;
9675 
9676 		  /* S/G insns require a mask and don't allow
9677 		     zeroing-masking.  */
9678 		  if ((dp->op[0].bytemode == vex_vsib_d_w_dq_mode
9679 		       || dp->op[0].bytemode == vex_vsib_q_w_dq_mode)
9680 		      && (ins.vex.mask_register_specifier == 0
9681 			  || ins.vex.zeroing))
9682 		    ins.illegal_masking = true;
9683 
9684 		  if (ins.illegal_masking)
9685 		    oappend (&ins, "/(bad)");
9686 		}
9687 	    }
9688 	  /* vex.nf is cleared after being consumed.  */
9689 	  if (ins.vex.nf)
9690 	    oappend (&ins, "{bad-nf}");
9691 
9692 	  /* Check whether rounding control was enabled for an insn not
9693 	     supporting it, when evex.b is not treated as evex.nd.  */
9694 	  if (ins.modrm.mod == 3 && ins.vex.b && ins.evex_type == evex_default
9695 	      && !(ins.evex_used & EVEX_b_used))
9696 	    {
9697 	      for (i = 0; i < MAX_OPERANDS; ++i)
9698 		{
9699 		  ins.obufp = ins.op_out[i];
9700 		  if (*ins.obufp)
9701 		    continue;
9702 		  oappend (&ins, names_rounding[ins.vex.ll]);
9703 		  oappend (&ins, "bad}");
9704 		  break;
9705 		}
9706 	    }
9707 	}
9708     }
9709 
9710   /* Clear instruction information.  */
9711   info->insn_info_valid = 0;
9712   info->branch_delay_insns = 0;
9713   info->data_size = 0;
9714   info->insn_type = dis_noninsn;
9715   info->target = 0;
9716   info->target2 = 0;
9717 
9718   /* Reset jump operation indicator.  */
9719   ins.op_is_jump = false;
9720   {
9721     int jump_detection = 0;
9722 
9723     /* Extract flags.  */
9724     for (i = 0; i < MAX_OPERANDS; ++i)
9725       {
9726 	if ((dp->op[i].rtn == OP_J)
9727 	    || (dp->op[i].rtn == OP_indirE))
9728 	  jump_detection |= 1;
9729 	else if ((dp->op[i].rtn == BND_Fixup)
9730 		 || (!dp->op[i].rtn && !dp->op[i].bytemode))
9731 	  jump_detection |= 2;
9732 	else if ((dp->op[i].bytemode == cond_jump_mode)
9733 		 || (dp->op[i].bytemode == loop_jcxz_mode))
9734 	  jump_detection |= 4;
9735       }
9736 
9737     /* Determine if this is a jump or branch.  */
9738     if ((jump_detection & 0x3) == 0x3)
9739       {
9740 	ins.op_is_jump = true;
9741 	if (jump_detection & 0x4)
9742 	  info->insn_type = dis_condbranch;
9743 	else
9744 	  info->insn_type = (dp->name && !strncmp (dp->name, "call", 4))
9745 	    ? dis_jsr : dis_branch;
9746       }
9747   }
9748 
9749   /* If VEX.vvvv and EVEX.vvvv are unused, they must be all 1s, which
9750      are all 0s in inverted form.  */
9751   if (ins.need_vex && ins.vex.register_specifier != 0)
9752     {
9753       i386_dis_printf (info, dis_style_text, "(bad)");
9754       ret = ins.end_codep - priv.the_buffer;
9755       goto out;
9756     }
9757 
9758   if ((dp->prefix_requirement & PREFIX_REX2_ILLEGAL)
9759       && ins.last_rex2_prefix >= 0 && (ins.rex2 & REX2_SPECIAL) == 0)
9760     {
9761       i386_dis_printf (info, dis_style_text, "(bad)");
9762       ret = ins.end_codep - priv.the_buffer;
9763       goto out;
9764     }
9765 
9766   switch (dp->prefix_requirement & ~PREFIX_REX2_ILLEGAL)
9767     {
9768     case PREFIX_DATA:
9769       /* If only the data prefix is marked as mandatory, its absence renders
9770 	 the encoding invalid.  Most other PREFIX_OPCODE rules still apply.  */
9771       if (ins.need_vex ? !ins.vex.prefix : !(ins.prefixes & PREFIX_DATA))
9772 	{
9773 	  i386_dis_printf (info, dis_style_text, "(bad)");
9774 	  ret = ins.end_codep - priv.the_buffer;
9775 	  goto out;
9776 	}
9777       ins.used_prefixes |= PREFIX_DATA;
9778       /* Fall through.  */
9779     case PREFIX_OPCODE:
9780       /* If the mandatory PREFIX_REPZ/PREFIX_REPNZ/PREFIX_DATA prefix is
9781 	 unused, opcode is invalid.  Since the PREFIX_DATA prefix may be
9782 	 used by putop and MMX/SSE operand and may be overridden by the
9783 	 PREFIX_REPZ/PREFIX_REPNZ fix, we check the PREFIX_DATA prefix
9784 	 separately.  */
9785       if (((ins.need_vex
9786 	    ? ins.vex.prefix == REPE_PREFIX_OPCODE
9787 	      || ins.vex.prefix == REPNE_PREFIX_OPCODE
9788 	    : (ins.prefixes
9789 	       & (PREFIX_REPZ | PREFIX_REPNZ)) != 0)
9790 	   && (ins.used_prefixes
9791 	       & (PREFIX_REPZ | PREFIX_REPNZ)) == 0)
9792 	  || (((ins.need_vex
9793 		? ins.vex.prefix == DATA_PREFIX_OPCODE
9794 		: ((ins.prefixes
9795 		    & (PREFIX_REPZ | PREFIX_REPNZ | PREFIX_DATA))
9796 		   == PREFIX_DATA))
9797 	       && (ins.used_prefixes & PREFIX_DATA) == 0))
9798 	  || (ins.vex.evex && dp->prefix_requirement != PREFIX_DATA
9799 	      && !ins.vex.w != !(ins.used_prefixes & PREFIX_DATA)))
9800 	{
9801 	  i386_dis_printf (info, dis_style_text, "(bad)");
9802 	  ret = ins.end_codep - priv.the_buffer;
9803 	  goto out;
9804 	}
9805       break;
9806 
9807     case PREFIX_IGNORED:
9808       /* Zap data size and rep prefixes from used_prefixes and reinstate their
9809 	 origins in all_prefixes.  */
9810       ins.used_prefixes &= ~PREFIX_OPCODE;
9811       if (ins.last_data_prefix >= 0)
9812 	ins.all_prefixes[ins.last_data_prefix] = 0x66;
9813       if (ins.last_repz_prefix >= 0)
9814 	ins.all_prefixes[ins.last_repz_prefix] = 0xf3;
9815       if (ins.last_repnz_prefix >= 0)
9816 	ins.all_prefixes[ins.last_repnz_prefix] = 0xf2;
9817       break;
9818 
9819     case PREFIX_NP_OR_DATA:
9820       if (ins.vex.prefix == REPE_PREFIX_OPCODE
9821 	  || ins.vex.prefix == REPNE_PREFIX_OPCODE)
9822 	{
9823 	  i386_dis_printf (info, dis_style_text, "(bad)");
9824 	  ret = ins.end_codep - priv.the_buffer;
9825 	  goto out;
9826 	}
9827       break;
9828 
9829     case NO_PREFIX:
9830       if (ins.vex.prefix)
9831 	{
9832 	  i386_dis_printf (info, dis_style_text, "(bad)");
9833 	  ret = ins.end_codep - priv.the_buffer;
9834 	  goto out;
9835 	}
9836       break;
9837     }
9838 
9839   /* Check if the REX prefix is used.  */
9840   if ((ins.rex ^ ins.rex_used) == 0
9841       && !ins.need_vex && ins.last_rex_prefix >= 0)
9842     ins.all_prefixes[ins.last_rex_prefix] = 0;
9843 
9844   /* Check if the REX2 prefix is used.  */
9845   if (ins.last_rex2_prefix >= 0
9846       && ((ins.rex2 & REX2_SPECIAL)
9847 	  || (((ins.rex2 & 7) ^ (ins.rex2_used & 7)) == 0
9848 	      && (ins.rex ^ ins.rex_used) == 0
9849 	      && (ins.rex2 & 7))))
9850     ins.all_prefixes[ins.last_rex2_prefix] = 0;
9851 
9852   /* Check if the SEG prefix is used.  */
9853   if ((ins.prefixes & (PREFIX_CS | PREFIX_SS | PREFIX_DS | PREFIX_ES
9854 		       | PREFIX_FS | PREFIX_GS)) != 0
9855       && (ins.used_prefixes & ins.active_seg_prefix) != 0)
9856     ins.all_prefixes[ins.last_seg_prefix] = 0;
9857 
9858   /* Check if the ADDR prefix is used.  */
9859   if ((ins.prefixes & PREFIX_ADDR) != 0
9860       && (ins.used_prefixes & PREFIX_ADDR) != 0)
9861     ins.all_prefixes[ins.last_addr_prefix] = 0;
9862 
9863   /* Check if the DATA prefix is used.  */
9864   if ((ins.prefixes & PREFIX_DATA) != 0
9865       && (ins.used_prefixes & PREFIX_DATA) != 0
9866       && !ins.need_vex)
9867     ins.all_prefixes[ins.last_data_prefix] = 0;
9868 
9869   /* Print the extra ins.prefixes.  */
9870   prefix_length = 0;
9871   for (i = 0; i < (int) ARRAY_SIZE (ins.all_prefixes); i++)
9872     if (ins.all_prefixes[i])
9873       {
9874 	const char *name = prefix_name (ins.address_mode, ins.all_prefixes[i],
9875 					orig_sizeflag);
9876 
9877 	if (name == NULL)
9878 	  abort ();
9879 	prefix_length += strlen (name) + 1;
9880 	if (ins.all_prefixes[i] == REX2_OPCODE)
9881 	  i386_dis_printf (info, dis_style_mnemonic, "{%s 0x%x} ", name,
9882 			   (unsigned int) ins.rex2_payload);
9883 	else
9884 	  i386_dis_printf (info, dis_style_mnemonic, "%s ", name);
9885       }
9886 
9887   /* Check maximum code length.  */
9888   if ((ins.codep - ins.start_codep) > MAX_CODE_LENGTH)
9889     {
9890       i386_dis_printf (info, dis_style_text, "(bad)");
9891       ret = MAX_CODE_LENGTH;
9892       goto out;
9893     }
9894 
9895   /* Calculate the number of operands this instruction has.  */
9896   op_count = 0;
9897   for (i = 0; i < MAX_OPERANDS; ++i)
9898     if (*ins.op_out[i] != '\0')
9899       ++op_count;
9900 
9901   /* Calculate the number of spaces to print after the mnemonic.  */
9902   ins.obufp = ins.mnemonicendp;
9903   if (op_count > 0)
9904     {
9905       i = strlen (ins.obuf) + prefix_length;
9906       if (i < 7)
9907 	i = 7 - i;
9908       else
9909 	i = 1;
9910     }
9911   else
9912     i = 0;
9913 
9914   /* Print the instruction mnemonic along with any trailing whitespace.  */
9915   i386_dis_printf (info, dis_style_mnemonic, "%s%*s", ins.obuf, i, "");
9916 
9917   /* The enter and bound instructions are printed with operands in the same
9918      order as the intel book; everything else is printed in reverse order.  */
9919   intel_swap_2_3 = false;
9920   if (ins.intel_syntax || ins.two_source_ops)
9921     {
9922       for (i = 0; i < MAX_OPERANDS; ++i)
9923 	op_txt[i] = ins.op_out[i];
9924 
9925       if (ins.intel_syntax && dp && dp->op[2].rtn == OP_Rounding
9926           && dp->op[3].rtn == OP_E && dp->op[4].rtn == NULL)
9927 	{
9928 	  op_txt[2] = ins.op_out[3];
9929 	  op_txt[3] = ins.op_out[2];
9930 	  intel_swap_2_3 = true;
9931 	}
9932 
9933       for (i = 0; i < (MAX_OPERANDS >> 1); ++i)
9934 	{
9935 	  bool riprel;
9936 
9937 	  ins.op_ad = ins.op_index[i];
9938 	  ins.op_index[i] = ins.op_index[MAX_OPERANDS - 1 - i];
9939 	  ins.op_index[MAX_OPERANDS - 1 - i] = ins.op_ad;
9940 	  riprel = ins.op_riprel[i];
9941 	  ins.op_riprel[i] = ins.op_riprel[MAX_OPERANDS - 1 - i];
9942 	  ins.op_riprel[MAX_OPERANDS - 1 - i] = riprel;
9943 	}
9944     }
9945   else
9946     {
9947       for (i = 0; i < MAX_OPERANDS; ++i)
9948 	op_txt[MAX_OPERANDS - 1 - i] = ins.op_out[i];
9949     }
9950 
9951   needcomma = 0;
9952   for (i = 0; i < MAX_OPERANDS; ++i)
9953     if (*op_txt[i])
9954       {
9955 	/* In Intel syntax embedded rounding / SAE are not separate operands.
9956 	   Instead they're attached to the prior register operand.  Simply
9957 	   suppress emission of the comma to achieve that effect.  */
9958 	switch (i & -(ins.intel_syntax && dp))
9959 	  {
9960 	  case 2:
9961 	    if (dp->op[2].rtn == OP_Rounding && !intel_swap_2_3)
9962 	      needcomma = 0;
9963 	    break;
9964 	  case 3:
9965 	    if (dp->op[3].rtn == OP_Rounding || intel_swap_2_3)
9966 	      needcomma = 0;
9967 	    break;
9968 	  }
9969 	if (needcomma)
9970 	  i386_dis_printf (info, dis_style_text, ",");
9971 	if (ins.op_index[i] != -1 && !ins.op_riprel[i])
9972 	  {
9973 	    bfd_vma target = (bfd_vma) ins.op_address[ins.op_index[i]];
9974 
9975 	    if (ins.op_is_jump)
9976 	      {
9977 		info->insn_info_valid = 1;
9978 		info->branch_delay_insns = 0;
9979 		info->data_size = 0;
9980 		info->target = target;
9981 		info->target2 = 0;
9982 	      }
9983 	    (*info->print_address_func) (target, info);
9984 	  }
9985 	else
9986 	  i386_dis_printf (info, dis_style_text, "%s", op_txt[i]);
9987 	needcomma = 1;
9988       }
9989 
9990   for (i = 0; i < MAX_OPERANDS; i++)
9991     if (ins.op_index[i] != -1 && ins.op_riprel[i])
9992       {
9993 	i386_dis_printf (info, dis_style_comment_start, "        # ");
9994 	(*info->print_address_func)
9995 	  ((bfd_vma)(ins.start_pc + (ins.codep - ins.start_codep)
9996 		     + ins.op_address[ins.op_index[i]]),
9997 	  info);
9998 	break;
9999       }
10000   ret = ins.codep - priv.the_buffer;
10001  out:
10002   info->private_data = NULL;
10003   return ret;
10004 }
10005 
10006 /* Here for backwards compatibility.  When gdb stops using
10007    print_insn_i386_att and print_insn_i386_intel these functions can
10008    disappear, and print_insn_i386 be merged into print_insn.  */
10009 int
10010 print_insn_i386_att (bfd_vma pc, disassemble_info *info)
10011 {
10012   return print_insn (pc, info, 0);
10013 }
10014 
10015 int
10016 print_insn_i386_intel (bfd_vma pc, disassemble_info *info)
10017 {
10018   return print_insn (pc, info, 1);
10019 }
10020 
10021 int
10022 print_insn_i386 (bfd_vma pc, disassemble_info *info)
10023 {
10024   return print_insn (pc, info, -1);
10025 }
10026 
10027 static const char *float_mem[] = {
10028   /* d8 */
10029   "fadd{s|}",
10030   "fmul{s|}",
10031   "fcom{s|}",
10032   "fcomp{s|}",
10033   "fsub{s|}",
10034   "fsubr{s|}",
10035   "fdiv{s|}",
10036   "fdivr{s|}",
10037   /* d9 */
10038   "fld{s|}",
10039   "(bad)",
10040   "fst{s|}",
10041   "fstp{s|}",
10042   "fldenv{C|C}",
10043   "fldcw",
10044   "fNstenv{C|C}",
10045   "fNstcw",
10046   /* da */
10047   "fiadd{l|}",
10048   "fimul{l|}",
10049   "ficom{l|}",
10050   "ficomp{l|}",
10051   "fisub{l|}",
10052   "fisubr{l|}",
10053   "fidiv{l|}",
10054   "fidivr{l|}",
10055   /* db */
10056   "fild{l|}",
10057   "fisttp{l|}",
10058   "fist{l|}",
10059   "fistp{l|}",
10060   "(bad)",
10061   "fld{t|}",
10062   "(bad)",
10063   "fstp{t|}",
10064   /* dc */
10065   "fadd{l|}",
10066   "fmul{l|}",
10067   "fcom{l|}",
10068   "fcomp{l|}",
10069   "fsub{l|}",
10070   "fsubr{l|}",
10071   "fdiv{l|}",
10072   "fdivr{l|}",
10073   /* dd */
10074   "fld{l|}",
10075   "fisttp{ll|}",
10076   "fst{l||}",
10077   "fstp{l|}",
10078   "frstor{C|C}",
10079   "(bad)",
10080   "fNsave{C|C}",
10081   "fNstsw",
10082   /* de */
10083   "fiadd{s|}",
10084   "fimul{s|}",
10085   "ficom{s|}",
10086   "ficomp{s|}",
10087   "fisub{s|}",
10088   "fisubr{s|}",
10089   "fidiv{s|}",
10090   "fidivr{s|}",
10091   /* df */
10092   "fild{s|}",
10093   "fisttp{s|}",
10094   "fist{s|}",
10095   "fistp{s|}",
10096   "fbld",
10097   "fild{ll|}",
10098   "fbstp",
10099   "fistp{ll|}",
10100 };
10101 
10102 static const unsigned char float_mem_mode[] = {
10103   /* d8 */
10104   d_mode,
10105   d_mode,
10106   d_mode,
10107   d_mode,
10108   d_mode,
10109   d_mode,
10110   d_mode,
10111   d_mode,
10112   /* d9 */
10113   d_mode,
10114   0,
10115   d_mode,
10116   d_mode,
10117   0,
10118   w_mode,
10119   0,
10120   w_mode,
10121   /* da */
10122   d_mode,
10123   d_mode,
10124   d_mode,
10125   d_mode,
10126   d_mode,
10127   d_mode,
10128   d_mode,
10129   d_mode,
10130   /* db */
10131   d_mode,
10132   d_mode,
10133   d_mode,
10134   d_mode,
10135   0,
10136   t_mode,
10137   0,
10138   t_mode,
10139   /* dc */
10140   q_mode,
10141   q_mode,
10142   q_mode,
10143   q_mode,
10144   q_mode,
10145   q_mode,
10146   q_mode,
10147   q_mode,
10148   /* dd */
10149   q_mode,
10150   q_mode,
10151   q_mode,
10152   q_mode,
10153   0,
10154   0,
10155   0,
10156   w_mode,
10157   /* de */
10158   w_mode,
10159   w_mode,
10160   w_mode,
10161   w_mode,
10162   w_mode,
10163   w_mode,
10164   w_mode,
10165   w_mode,
10166   /* df */
10167   w_mode,
10168   w_mode,
10169   w_mode,
10170   w_mode,
10171   t_mode,
10172   q_mode,
10173   t_mode,
10174   q_mode
10175 };
10176 
10177 #define ST { OP_ST, 0 }
10178 #define STi { OP_STi, 0 }
10179 
10180 #define FGRPd9_2 NULL, { { NULL, 1 } }, 0
10181 #define FGRPd9_4 NULL, { { NULL, 2 } }, 0
10182 #define FGRPd9_5 NULL, { { NULL, 3 } }, 0
10183 #define FGRPd9_6 NULL, { { NULL, 4 } }, 0
10184 #define FGRPd9_7 NULL, { { NULL, 5 } }, 0
10185 #define FGRPda_5 NULL, { { NULL, 6 } }, 0
10186 #define FGRPdb_4 NULL, { { NULL, 7 } }, 0
10187 #define FGRPde_3 NULL, { { NULL, 8 } }, 0
10188 #define FGRPdf_4 NULL, { { NULL, 9 } }, 0
10189 
10190 static const struct dis386 float_reg[][8] = {
10191   /* d8 */
10192   {
10193     { "fadd",	{ ST, STi }, 0 },
10194     { "fmul",	{ ST, STi }, 0 },
10195     { "fcom",	{ STi }, 0 },
10196     { "fcomp",	{ STi }, 0 },
10197     { "fsub",	{ ST, STi }, 0 },
10198     { "fsubr",	{ ST, STi }, 0 },
10199     { "fdiv",	{ ST, STi }, 0 },
10200     { "fdivr",	{ ST, STi }, 0 },
10201   },
10202   /* d9 */
10203   {
10204     { "fld",	{ STi }, 0 },
10205     { "fxch",	{ STi }, 0 },
10206     { FGRPd9_2 },
10207     { Bad_Opcode },
10208     { FGRPd9_4 },
10209     { FGRPd9_5 },
10210     { FGRPd9_6 },
10211     { FGRPd9_7 },
10212   },
10213   /* da */
10214   {
10215     { "fcmovb",	{ ST, STi }, 0 },
10216     { "fcmove",	{ ST, STi }, 0 },
10217     { "fcmovbe",{ ST, STi }, 0 },
10218     { "fcmovu",	{ ST, STi }, 0 },
10219     { Bad_Opcode },
10220     { FGRPda_5 },
10221     { Bad_Opcode },
10222     { Bad_Opcode },
10223   },
10224   /* db */
10225   {
10226     { "fcmovnb",{ ST, STi }, 0 },
10227     { "fcmovne",{ ST, STi }, 0 },
10228     { "fcmovnbe",{ ST, STi }, 0 },
10229     { "fcmovnu",{ ST, STi }, 0 },
10230     { FGRPdb_4 },
10231     { "fucomi",	{ ST, STi }, 0 },
10232     { "fcomi",	{ ST, STi }, 0 },
10233     { Bad_Opcode },
10234   },
10235   /* dc */
10236   {
10237     { "fadd",	{ STi, ST }, 0 },
10238     { "fmul",	{ STi, ST }, 0 },
10239     { Bad_Opcode },
10240     { Bad_Opcode },
10241     { "fsub{!M|r}",	{ STi, ST }, 0 },
10242     { "fsub{M|}",	{ STi, ST }, 0 },
10243     { "fdiv{!M|r}",	{ STi, ST }, 0 },
10244     { "fdiv{M|}",	{ STi, ST }, 0 },
10245   },
10246   /* dd */
10247   {
10248     { "ffree",	{ STi }, 0 },
10249     { Bad_Opcode },
10250     { "fst",	{ STi }, 0 },
10251     { "fstp",	{ STi }, 0 },
10252     { "fucom",	{ STi }, 0 },
10253     { "fucomp",	{ STi }, 0 },
10254     { Bad_Opcode },
10255     { Bad_Opcode },
10256   },
10257   /* de */
10258   {
10259     { "faddp",	{ STi, ST }, 0 },
10260     { "fmulp",	{ STi, ST }, 0 },
10261     { Bad_Opcode },
10262     { FGRPde_3 },
10263     { "fsub{!M|r}p",	{ STi, ST }, 0 },
10264     { "fsub{M|}p",	{ STi, ST }, 0 },
10265     { "fdiv{!M|r}p",	{ STi, ST }, 0 },
10266     { "fdiv{M|}p",	{ STi, ST }, 0 },
10267   },
10268   /* df */
10269   {
10270     { "ffreep",	{ STi }, 0 },
10271     { Bad_Opcode },
10272     { Bad_Opcode },
10273     { Bad_Opcode },
10274     { FGRPdf_4 },
10275     { "fucomip", { ST, STi }, 0 },
10276     { "fcomip", { ST, STi }, 0 },
10277     { Bad_Opcode },
10278   },
10279 };
10280 
10281 static const char *const fgrps[][8] = {
10282   /* Bad opcode 0 */
10283   {
10284     "(bad)","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
10285   },
10286 
10287   /* d9_2  1 */
10288   {
10289     "fnop","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
10290   },
10291 
10292   /* d9_4  2 */
10293   {
10294     "fchs","fabs","(bad)","(bad)","ftst","fxam","(bad)","(bad)",
10295   },
10296 
10297   /* d9_5  3 */
10298   {
10299     "fld1","fldl2t","fldl2e","fldpi","fldlg2","fldln2","fldz","(bad)",
10300   },
10301 
10302   /* d9_6  4 */
10303   {
10304     "f2xm1","fyl2x","fptan","fpatan","fxtract","fprem1","fdecstp","fincstp",
10305   },
10306 
10307   /* d9_7  5 */
10308   {
10309     "fprem","fyl2xp1","fsqrt","fsincos","frndint","fscale","fsin","fcos",
10310   },
10311 
10312   /* da_5  6 */
10313   {
10314     "(bad)","fucompp","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
10315   },
10316 
10317   /* db_4  7 */
10318   {
10319     "fNeni(8087 only)","fNdisi(8087 only)","fNclex","fNinit",
10320     "fNsetpm(287 only)","frstpm(287 only)","(bad)","(bad)",
10321   },
10322 
10323   /* de_3  8 */
10324   {
10325     "(bad)","fcompp","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
10326   },
10327 
10328   /* df_4  9 */
10329   {
10330     "fNstsw","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
10331   },
10332 };
10333 
10334 static void
10335 swap_operand (instr_info *ins)
10336 {
10337   ins->mnemonicendp[0] = '.';
10338   ins->mnemonicendp[1] = 's';
10339   ins->mnemonicendp[2] = '\0';
10340   ins->mnemonicendp += 2;
10341 }
10342 
10343 static bool
10344 dofloat (instr_info *ins, int sizeflag)
10345 {
10346   const struct dis386 *dp;
10347   unsigned char floatop = ins->codep[-1];
10348 
10349   if (ins->modrm.mod != 3)
10350     {
10351       int fp_indx = (floatop - 0xd8) * 8 + ins->modrm.reg;
10352 
10353       putop (ins, float_mem[fp_indx], sizeflag);
10354       ins->obufp = ins->op_out[0];
10355       ins->op_ad = 2;
10356       return OP_E (ins, float_mem_mode[fp_indx], sizeflag);
10357     }
10358   /* Skip mod/rm byte.  */
10359   MODRM_CHECK;
10360   ins->codep++;
10361 
10362   dp = &float_reg[floatop - 0xd8][ins->modrm.reg];
10363   if (dp->name == NULL)
10364     {
10365       putop (ins, fgrps[dp->op[0].bytemode][ins->modrm.rm], sizeflag);
10366 
10367       /* Instruction fnstsw is only one with strange arg.  */
10368       if (floatop == 0xdf && ins->codep[-1] == 0xe0)
10369 	strcpy (ins->op_out[0], att_names16[0] + ins->intel_syntax);
10370     }
10371   else
10372     {
10373       putop (ins, dp->name, sizeflag);
10374 
10375       ins->obufp = ins->op_out[0];
10376       ins->op_ad = 2;
10377       if (dp->op[0].rtn
10378 	  && !dp->op[0].rtn (ins, dp->op[0].bytemode, sizeflag))
10379 	return false;
10380 
10381       ins->obufp = ins->op_out[1];
10382       ins->op_ad = 1;
10383       if (dp->op[1].rtn
10384 	  && !dp->op[1].rtn (ins, dp->op[1].bytemode, sizeflag))
10385 	return false;
10386     }
10387   return true;
10388 }
10389 
10390 static bool
10391 OP_ST (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
10392        int sizeflag ATTRIBUTE_UNUSED)
10393 {
10394   oappend_register (ins, "%st");
10395   return true;
10396 }
10397 
10398 static bool
10399 OP_STi (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
10400 	int sizeflag ATTRIBUTE_UNUSED)
10401 {
10402   char scratch[8];
10403   int res = snprintf (scratch, ARRAY_SIZE (scratch), "%%st(%d)", ins->modrm.rm);
10404 
10405   if (res < 0 || (size_t) res >= ARRAY_SIZE (scratch))
10406     abort ();
10407   oappend_register (ins, scratch);
10408   return true;
10409 }
10410 
10411 /* Capital letters in template are macros.  */
10412 static int
10413 putop (instr_info *ins, const char *in_template, int sizeflag)
10414 {
10415   const char *p;
10416   int alt = 0;
10417   int cond = 1;
10418   unsigned int l = 0, len = 0;
10419   char last[4];
10420   bool evex_printed = false;
10421 
10422   /* We don't want to add any prefix or suffix to (bad), so return early.  */
10423   if (!strncmp (in_template, "(bad)", 5))
10424     {
10425       oappend (ins, "(bad)");
10426       *ins->obufp = 0;
10427       ins->mnemonicendp = ins->obufp;
10428       return 0;
10429     }
10430 
10431   for (p = in_template; *p; p++)
10432     {
10433       if (len > l)
10434 	{
10435 	  if (l >= sizeof (last) || !ISUPPER (*p))
10436 	    abort ();
10437 	  last[l++] = *p;
10438 	  continue;
10439 	}
10440       switch (*p)
10441 	{
10442 	default:
10443 	  if (ins->evex_type == evex_from_legacy && !ins->vex.nd
10444 	      && !(ins->rex2 & 7) && !evex_printed)
10445 	    {
10446 	      oappend (ins, "{evex} ");
10447 	      evex_printed = true;
10448 	    }
10449 	  *ins->obufp++ = *p;
10450 	  break;
10451 	case '%':
10452 	  len++;
10453 	  break;
10454 	case '!':
10455 	  cond = 0;
10456 	  break;
10457 	case '{':
10458 	  if (ins->intel_syntax)
10459 	    {
10460 	      while (*++p != '|')
10461 		if (*p == '}' || *p == '\0')
10462 		  abort ();
10463 	      alt = 1;
10464 	    }
10465 	  break;
10466 	case '|':
10467 	  while (*++p != '}')
10468 	    {
10469 	      if (*p == '\0')
10470 		abort ();
10471 	    }
10472 	  break;
10473 	case '}':
10474 	  alt = 0;
10475 	  break;
10476 	case 'A':
10477 	  if (ins->intel_syntax)
10478 	    break;
10479 	  if ((ins->need_modrm && ins->modrm.mod != 3 && !ins->vex.nd)
10480 	      || (sizeflag & SUFFIX_ALWAYS))
10481 	    *ins->obufp++ = 'b';
10482 	  break;
10483 	case 'B':
10484 	  if (l == 0)
10485 	    {
10486 	    case_B:
10487 	      if (ins->intel_syntax)
10488 		break;
10489 	      if (sizeflag & SUFFIX_ALWAYS)
10490 		*ins->obufp++ = 'b';
10491 	    }
10492 	  else if (l == 1 && last[0] == 'L')
10493 	    {
10494 	      if (ins->address_mode == mode_64bit
10495 		  && !(ins->prefixes & PREFIX_ADDR))
10496 		{
10497 		  *ins->obufp++ = 'a';
10498 		  *ins->obufp++ = 'b';
10499 		  *ins->obufp++ = 's';
10500 		}
10501 
10502 	      goto case_B;
10503 	    }
10504 	  else
10505 	    abort ();
10506 	  break;
10507 	case 'C':
10508 	  if (ins->intel_syntax && !alt)
10509 	    break;
10510 	  if ((ins->prefixes & PREFIX_DATA) || (sizeflag & SUFFIX_ALWAYS))
10511 	    {
10512 	      if (sizeflag & DFLAG)
10513 		*ins->obufp++ = ins->intel_syntax ? 'd' : 'l';
10514 	      else
10515 		*ins->obufp++ = ins->intel_syntax ? 'w' : 's';
10516 	      ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10517 	    }
10518 	  break;
10519 	case 'D':
10520 	  if (l == 1)
10521 	    {
10522 	      switch (last[0])
10523 	      {
10524 	      case 'X':
10525 		if (!ins->vex.evex || ins->vex.w)
10526 		  *ins->obufp++ = 'd';
10527 		else
10528 		  oappend (ins, "{bad}");
10529 		break;
10530 	      default:
10531 		abort ();
10532 	      }
10533 	      break;
10534 	    }
10535 	  if (l)
10536 	    abort ();
10537 	  if (ins->intel_syntax || !(sizeflag & SUFFIX_ALWAYS))
10538 	    break;
10539 	  USED_REX (REX_W);
10540 	  if (ins->modrm.mod == 3)
10541 	    {
10542 	      if (ins->rex & REX_W)
10543 		*ins->obufp++ = 'q';
10544 	      else
10545 		{
10546 		  if (sizeflag & DFLAG)
10547 		    *ins->obufp++ = ins->intel_syntax ? 'd' : 'l';
10548 		  else
10549 		    *ins->obufp++ = 'w';
10550 		  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10551 		}
10552 	    }
10553 	  else
10554 	    *ins->obufp++ = 'w';
10555 	  break;
10556 	case 'E':
10557 	  if (l == 1)
10558 	    {
10559 	      switch (last[0])
10560 		{
10561 		case 'X':
10562 		  if (!ins->vex.evex || ins->vex.b || ins->vex.ll >= 2
10563 		      || (ins->rex2 & 7)
10564 		      || (ins->modrm.mod == 3 && (ins->rex & REX_X))
10565 		      || !ins->vex.v || ins->vex.mask_register_specifier)
10566 		    break;
10567 		  /* AVX512 extends a number of V*D insns to also have V*Q variants,
10568 		     merely distinguished by EVEX.W.  Look for a use of the
10569 		     respective macro.  */
10570 		  if (ins->vex.w)
10571 		    {
10572 		      const char *pct = strchr (p + 1, '%');
10573 
10574 		      if (pct != NULL && pct[1] == 'D' && pct[2] == 'Q')
10575 			break;
10576 		    }
10577 		  *ins->obufp++ = '{';
10578 		  *ins->obufp++ = 'e';
10579 		  *ins->obufp++ = 'v';
10580 		  *ins->obufp++ = 'e';
10581 		  *ins->obufp++ = 'x';
10582 		  *ins->obufp++ = '}';
10583 		  *ins->obufp++ = ' ';
10584 		  break;
10585 		case 'M':
10586 		  if (ins->modrm.mod != 3 && !(ins->rex2 & 7))
10587 		    oappend (ins, "{evex} ");
10588 		  evex_printed = true;
10589 		  break;
10590 		default:
10591 		  abort ();
10592 		}
10593 		break;
10594 	    }
10595 	  /* For jcxz/jecxz */
10596 	  if (ins->address_mode == mode_64bit)
10597 	    {
10598 	      if (sizeflag & AFLAG)
10599 		*ins->obufp++ = 'r';
10600 	      else
10601 		*ins->obufp++ = 'e';
10602 	    }
10603 	  else
10604 	    if (sizeflag & AFLAG)
10605 	      *ins->obufp++ = 'e';
10606 	  ins->used_prefixes |= (ins->prefixes & PREFIX_ADDR);
10607 	  break;
10608 	case 'F':
10609 	  if (l == 0)
10610 	    {
10611 	      if (ins->intel_syntax)
10612 		break;
10613 	      if ((ins->prefixes & PREFIX_ADDR) || (sizeflag & SUFFIX_ALWAYS))
10614 		{
10615 		  if (sizeflag & AFLAG)
10616 		    *ins->obufp++ = ins->address_mode == mode_64bit ? 'q' : 'l';
10617 		  else
10618 		    *ins->obufp++ = ins->address_mode == mode_64bit ? 'l' : 'w';
10619 		  ins->used_prefixes |= (ins->prefixes & PREFIX_ADDR);
10620 		}
10621 	    }
10622 	  else if (l == 1 && last[0] == 'C')
10623 	    break;
10624 	  else if (l == 1 && last[0] == 'N')
10625 	    {
10626 	      if (ins->vex.nf)
10627 		{
10628 		  oappend (ins, "{nf} ");
10629 		  /* This bit needs to be cleared after it is consumed.  */
10630 		  ins->vex.nf = false;
10631 		  evex_printed = true;
10632 		}
10633 	      else if (ins->evex_type == evex_from_vex && !(ins->rex2 & 7)
10634 		       && ins->vex.v)
10635 		{
10636 		  oappend (ins, "{evex} ");
10637 		  evex_printed = true;
10638 		}
10639 	    }
10640 	  else
10641 	    abort ();
10642 	  break;
10643 	case 'G':
10644 	  if (ins->intel_syntax || (ins->obufp[-1] != 's'
10645 				    && !(sizeflag & SUFFIX_ALWAYS)))
10646 	    break;
10647 	  if ((ins->rex & REX_W) || (sizeflag & DFLAG))
10648 	    *ins->obufp++ = 'l';
10649 	  else
10650 	    *ins->obufp++ = 'w';
10651 	  if (!(ins->rex & REX_W))
10652 	    ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10653 	  break;
10654 	case 'H':
10655 	  if (l == 0)
10656 	    {
10657 	      if (ins->intel_syntax)
10658 	        break;
10659 	      if ((ins->prefixes & (PREFIX_CS | PREFIX_DS)) == PREFIX_CS
10660 		  || (ins->prefixes & (PREFIX_CS | PREFIX_DS)) == PREFIX_DS)
10661 		{
10662 		  ins->used_prefixes |= ins->prefixes & (PREFIX_CS | PREFIX_DS);
10663 		  *ins->obufp++ = ',';
10664 		  *ins->obufp++ = 'p';
10665 
10666 		  /* Set active_seg_prefix even if not set in 64-bit mode
10667 		     because here it is a valid branch hint. */
10668 		  if (ins->prefixes & PREFIX_DS)
10669 		    {
10670 		      ins->active_seg_prefix = PREFIX_DS;
10671 		      *ins->obufp++ = 't';
10672 		    }
10673 		  else
10674 		    {
10675 		      ins->active_seg_prefix = PREFIX_CS;
10676 		      *ins->obufp++ = 'n';
10677 		    }
10678 		}
10679 	    }
10680 	  else if (l == 1 && last[0] == 'X')
10681 	    {
10682 	      if (!ins->vex.w)
10683 		*ins->obufp++ = 'h';
10684 	      else
10685 		oappend (ins, "{bad}");
10686 	    }
10687 	  else
10688 	    abort ();
10689 	  break;
10690 	case 'K':
10691 	  USED_REX (REX_W);
10692 	  if (ins->rex & REX_W)
10693 	    *ins->obufp++ = 'q';
10694 	  else
10695 	    *ins->obufp++ = 'd';
10696 	  break;
10697 	case 'L':
10698 	  if (ins->intel_syntax)
10699 	    break;
10700 	  if (sizeflag & SUFFIX_ALWAYS)
10701 	    {
10702 	      if (ins->rex & REX_W)
10703 		*ins->obufp++ = 'q';
10704 	      else
10705 		*ins->obufp++ = 'l';
10706 	    }
10707 	  break;
10708 	case 'M':
10709 	  if (ins->intel_mnemonic != cond)
10710 	    *ins->obufp++ = 'r';
10711 	  break;
10712 	case 'N':
10713 	  if ((ins->prefixes & PREFIX_FWAIT) == 0)
10714 	    *ins->obufp++ = 'n';
10715 	  else
10716 	    ins->used_prefixes |= PREFIX_FWAIT;
10717 	  break;
10718 	case 'O':
10719 	  USED_REX (REX_W);
10720 	  if (ins->rex & REX_W)
10721 	    *ins->obufp++ = 'o';
10722 	  else if (ins->intel_syntax && (sizeflag & DFLAG))
10723 	    *ins->obufp++ = 'q';
10724 	  else
10725 	    *ins->obufp++ = 'd';
10726 	  if (!(ins->rex & REX_W))
10727 	    ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10728 	  break;
10729 	case '@':
10730 	  if (ins->address_mode == mode_64bit
10731 	      && (ins->isa64 == intel64 || (ins->rex & REX_W)
10732 		  || !(ins->prefixes & PREFIX_DATA)))
10733 	    {
10734 	      if (sizeflag & SUFFIX_ALWAYS)
10735 		*ins->obufp++ = 'q';
10736 	      break;
10737 	    }
10738 	  /* Fall through.  */
10739 	case 'P':
10740 	  if (l == 0)
10741 	    {
10742 	      if (!cond && ins->last_rex2_prefix >= 0 && (ins->rex & REX_W))
10743 		{
10744 		  /* For pushp and popp, p is printed and do not print {rex2}
10745 		     for them.  */
10746 		  *ins->obufp++ = 'p';
10747 		  ins->rex2 |= REX2_SPECIAL;
10748 		  break;
10749 		}
10750 
10751 	      /* For "!P" print nothing else in Intel syntax.  */
10752 	      if (!cond && ins->intel_syntax)
10753 		break;
10754 
10755 	      if ((ins->modrm.mod == 3 || !cond)
10756 		  && !(sizeflag & SUFFIX_ALWAYS))
10757 		break;
10758 	  /* Fall through.  */
10759 	case 'T':
10760 	      if ((!(ins->rex & REX_W) && (ins->prefixes & PREFIX_DATA))
10761 		  || ((sizeflag & SUFFIX_ALWAYS)
10762 		      && ins->address_mode != mode_64bit))
10763 		{
10764 		  *ins->obufp++ = (sizeflag & DFLAG)
10765 				  ? ins->intel_syntax ? 'd' : 'l' : 'w';
10766 		  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10767 		}
10768 	      else if (sizeflag & SUFFIX_ALWAYS)
10769 		*ins->obufp++ = 'q';
10770 	    }
10771 	  else if (l == 1 && last[0] == 'L')
10772 	    {
10773 	      if ((ins->prefixes & PREFIX_DATA)
10774 		  || (ins->rex & REX_W)
10775 		  || (sizeflag & SUFFIX_ALWAYS))
10776 		{
10777 		  USED_REX (REX_W);
10778 		  if (ins->rex & REX_W)
10779 		    *ins->obufp++ = 'q';
10780 		  else
10781 		    {
10782 		      if (sizeflag & DFLAG)
10783 			*ins->obufp++ = ins->intel_syntax ? 'd' : 'l';
10784 		      else
10785 			*ins->obufp++ = 'w';
10786 		      ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10787 		    }
10788 		}
10789 	    }
10790 	  else
10791 	    abort ();
10792 	  break;
10793 	case 'Q':
10794 	  if (l == 0)
10795 	    {
10796 	      if (ins->intel_syntax && !alt)
10797 		break;
10798 	      USED_REX (REX_W);
10799 	      if ((ins->need_modrm && ins->modrm.mod != 3 && !ins->vex.nd)
10800 		  || (sizeflag & SUFFIX_ALWAYS))
10801 		{
10802 		  if (ins->rex & REX_W)
10803 		    *ins->obufp++ = 'q';
10804 		  else
10805 		    {
10806 		      if (sizeflag & DFLAG)
10807 			*ins->obufp++ = ins->intel_syntax ? 'd' : 'l';
10808 		      else
10809 			*ins->obufp++ = 'w';
10810 		      ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10811 		    }
10812 		}
10813 	    }
10814 	  else if (l == 1 && last[0] == 'D')
10815 	    *ins->obufp++ = ins->vex.w ? 'q' : 'd';
10816 	  else if (l == 1 && last[0] == 'L')
10817 	    {
10818 	      if (cond ? ins->modrm.mod == 3 && !(sizeflag & SUFFIX_ALWAYS)
10819 		       : ins->address_mode != mode_64bit)
10820 		break;
10821 	      if ((ins->rex & REX_W))
10822 		{
10823 		  USED_REX (REX_W);
10824 		  *ins->obufp++ = 'q';
10825 		}
10826 	      else if ((ins->address_mode == mode_64bit && cond)
10827 		      || (sizeflag & SUFFIX_ALWAYS))
10828 		*ins->obufp++ = ins->intel_syntax? 'd' : 'l';
10829 	    }
10830 	  else
10831 	    abort ();
10832 	  break;
10833 	case 'R':
10834 	  USED_REX (REX_W);
10835 	  if (ins->rex & REX_W)
10836 	    *ins->obufp++ = 'q';
10837 	  else if (sizeflag & DFLAG)
10838 	    {
10839 	      if (ins->intel_syntax)
10840 		  *ins->obufp++ = 'd';
10841 	      else
10842 		  *ins->obufp++ = 'l';
10843 	    }
10844 	  else
10845 	    *ins->obufp++ = 'w';
10846 	  if (ins->intel_syntax && !p[1]
10847 	      && ((ins->rex & REX_W) || (sizeflag & DFLAG)))
10848 	    *ins->obufp++ = 'e';
10849 	  if (!(ins->rex & REX_W))
10850 	    ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10851 	  break;
10852 	case 'S':
10853 	  if (l == 0)
10854 	    {
10855 	    case_S:
10856 	      if (ins->intel_syntax)
10857 		break;
10858 	      if (sizeflag & SUFFIX_ALWAYS)
10859 		{
10860 		  if (ins->rex & REX_W)
10861 		    *ins->obufp++ = 'q';
10862 		  else
10863 		    {
10864 		      if (sizeflag & DFLAG)
10865 			*ins->obufp++ = 'l';
10866 		      else
10867 			*ins->obufp++ = 'w';
10868 		      ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10869 		    }
10870 		}
10871 	      break;
10872 	    }
10873 	  if (l != 1)
10874 	    abort ();
10875 	  switch (last[0])
10876 	    {
10877 	    case 'L':
10878 	      if (ins->address_mode == mode_64bit
10879 		  && !(ins->prefixes & PREFIX_ADDR))
10880 		{
10881 		  *ins->obufp++ = 'a';
10882 		  *ins->obufp++ = 'b';
10883 		  *ins->obufp++ = 's';
10884 		}
10885 
10886 	      goto case_S;
10887 	    case 'X':
10888 	      if (!ins->vex.evex || !ins->vex.w)
10889 		*ins->obufp++ = 's';
10890 	      else
10891 		oappend (ins, "{bad}");
10892 	      break;
10893 	    default:
10894 	      abort ();
10895 	    }
10896 	  break;
10897 	case 'U':
10898 	  if (l == 1 && (last[0] == 'Z'))
10899 	    {
10900 	      /* Although IMUL/SETcc does not support NDD, the EVEX.ND bit is
10901 		 used to control whether its destination register has its upper
10902 		 bits zeroed.  */
10903 	      if (ins->vex.nd)
10904 		oappend (ins, "zu");
10905 	    }
10906 	  else
10907 	    abort ();
10908 	  break;
10909 	case 'V':
10910 	  if (l == 0)
10911 	    {
10912 	      if (ins->need_vex)
10913 		*ins->obufp++ = 'v';
10914 	    }
10915 	  else if (l == 1)
10916 	    {
10917 	      switch (last[0])
10918 		{
10919 		case 'X':
10920 		  if (ins->vex.evex)
10921 		    break;
10922 		  *ins->obufp++ = '{';
10923 		  *ins->obufp++ = 'v';
10924 		  *ins->obufp++ = 'e';
10925 		  *ins->obufp++ = 'x';
10926 		  *ins->obufp++ = '}';
10927 		  *ins->obufp++ = ' ';
10928 		  break;
10929 		case 'L':
10930 		  if (ins->rex & REX_W)
10931 		    {
10932 		      *ins->obufp++ = 'a';
10933 		      *ins->obufp++ = 'b';
10934 		      *ins->obufp++ = 's';
10935 		    }
10936 		  goto case_S;
10937 		default:
10938 		  abort ();
10939 		}
10940 	    }
10941 	  else
10942 	    abort ();
10943 	  break;
10944 	case 'W':
10945 	  if (l == 0)
10946 	    {
10947 	      /* operand size flag for cwtl, cbtw */
10948 	      USED_REX (REX_W);
10949 	      if (ins->rex & REX_W)
10950 		{
10951 		  if (ins->intel_syntax)
10952 		    *ins->obufp++ = 'd';
10953 		  else
10954 		    *ins->obufp++ = 'l';
10955 		}
10956 	      else if (sizeflag & DFLAG)
10957 		*ins->obufp++ = 'w';
10958 	      else
10959 		*ins->obufp++ = 'b';
10960 	      if (!(ins->rex & REX_W))
10961 		ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
10962 	    }
10963 	  else if (l == 1)
10964 	    {
10965 	      if (!ins->need_vex)
10966 		abort ();
10967 	      if (last[0] == 'X')
10968 		*ins->obufp++ = ins->vex.w ? 'd': 's';
10969 	      else if (last[0] == 'B')
10970 		*ins->obufp++ = ins->vex.w ? 'w': 'b';
10971 	      else
10972 		abort ();
10973 	    }
10974 	  else
10975 	    abort ();
10976 	  break;
10977 	case 'X':
10978 	  if (l != 0)
10979 	    abort ();
10980 	  if (ins->need_vex
10981 	      ? ins->vex.prefix == DATA_PREFIX_OPCODE
10982 	      : ins->prefixes & PREFIX_DATA)
10983 	    {
10984 	      *ins->obufp++ = 'd';
10985 	      ins->used_prefixes |= PREFIX_DATA;
10986 	    }
10987 	  else
10988 	    *ins->obufp++ = 's';
10989 	  break;
10990 	case 'Y':
10991 	  if (l == 0)
10992 	    {
10993 	      if (ins->vex.mask_register_specifier)
10994 		ins->illegal_masking = true;
10995 	    }
10996 	  else if (l == 1 && last[0] == 'X')
10997 	    {
10998 	      if (!ins->need_vex)
10999 		break;
11000 	      if (ins->intel_syntax
11001 		  || ((ins->modrm.mod == 3 || ins->vex.b)
11002 		      && !(sizeflag & SUFFIX_ALWAYS)))
11003 		break;
11004 	      switch (ins->vex.length)
11005 		{
11006 		case 128:
11007 		  *ins->obufp++ = 'x';
11008 		  break;
11009 		case 256:
11010 		  *ins->obufp++ = 'y';
11011 		  break;
11012 		case 512:
11013 		  if (!ins->vex.evex)
11014 		default:
11015 		    abort ();
11016 		}
11017 	    }
11018 	  else
11019 	    abort ();
11020 	  break;
11021 	case 'Z':
11022 	  if (l == 0)
11023 	    {
11024 	      /* These insns ignore ModR/M.mod: Force it to 3 for OP_E().  */
11025 	      ins->modrm.mod = 3;
11026 	      if (!ins->intel_syntax && (sizeflag & SUFFIX_ALWAYS))
11027 		*ins->obufp++ = ins->address_mode == mode_64bit ? 'q' : 'l';
11028 	    }
11029 	  else if (l == 1 && last[0] == 'X')
11030 	    {
11031 	      if (!ins->vex.evex)
11032 		abort ();
11033 	      if (ins->intel_syntax
11034 		  || ((ins->modrm.mod == 3 || ins->vex.b)
11035 		      && !(sizeflag & SUFFIX_ALWAYS)))
11036 		break;
11037 	      switch (ins->vex.length)
11038 		{
11039 		case 128:
11040 		  *ins->obufp++ = 'x';
11041 		  break;
11042 		case 256:
11043 		  *ins->obufp++ = 'y';
11044 		  break;
11045 		case 512:
11046 		  *ins->obufp++ = 'z';
11047 		  break;
11048 		default:
11049 		  abort ();
11050 		}
11051 	    }
11052 	  else
11053 	    abort ();
11054 	  break;
11055 	case '^':
11056 	  if (ins->intel_syntax)
11057 	    break;
11058 	  if (ins->isa64 == intel64 && (ins->rex & REX_W))
11059 	    {
11060 	      USED_REX (REX_W);
11061 	      *ins->obufp++ = 'q';
11062 	      break;
11063 	    }
11064 	  if ((ins->prefixes & PREFIX_DATA) || (sizeflag & SUFFIX_ALWAYS))
11065 	    {
11066 	      if (sizeflag & DFLAG)
11067 		*ins->obufp++ = 'l';
11068 	      else
11069 		*ins->obufp++ = 'w';
11070 	      ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11071 	    }
11072 	  break;
11073 	}
11074 
11075       if (len == l)
11076 	len = l = 0;
11077     }
11078   *ins->obufp = 0;
11079   ins->mnemonicendp = ins->obufp;
11080   return 0;
11081 }
11082 
11083 /* Add a style marker to *INS->obufp that encodes STYLE.  This assumes that
11084    the buffer pointed to by INS->obufp has space.  A style marker is made
11085    from the STYLE_MARKER_CHAR followed by STYLE converted to a single hex
11086    digit, followed by another STYLE_MARKER_CHAR.  This function assumes
11087    that the number of styles is not greater than 16.  */
11088 
11089 static void
11090 oappend_insert_style (instr_info *ins, enum disassembler_style style)
11091 {
11092   unsigned num = (unsigned) style;
11093 
11094   /* We currently assume that STYLE can be encoded as a single hex
11095      character.  If more styles are added then this might start to fail,
11096      and we'll need to expand this code.  */
11097   if (num > 0xf)
11098     abort ();
11099 
11100   *ins->obufp++ = STYLE_MARKER_CHAR;
11101   *ins->obufp++ = (num < 10 ? ('0' + num)
11102 		   : ((num < 16) ? ('a' + (num - 10)) : '0'));
11103   *ins->obufp++ = STYLE_MARKER_CHAR;
11104 
11105   /* This final null character is not strictly necessary, after inserting a
11106      style marker we should always be inserting some additional content.
11107      However, having the buffer null terminated doesn't cost much, and make
11108      it easier to debug what's going on.  Also, if we do ever forget to add
11109      any additional content after this style marker, then the buffer will
11110      still be well formed.  */
11111   *ins->obufp = '\0';
11112 }
11113 
11114 static void
11115 oappend_with_style (instr_info *ins, const char *s,
11116 		    enum disassembler_style style)
11117 {
11118   oappend_insert_style (ins, style);
11119   ins->obufp = stpcpy (ins->obufp, s);
11120 }
11121 
11122 /* Add a single character C to the buffer pointer to by INS->obufp, marking
11123    the style for the character as STYLE.  */
11124 
11125 static void
11126 oappend_char_with_style (instr_info *ins, const char c,
11127 			 enum disassembler_style style)
11128 {
11129   oappend_insert_style (ins, style);
11130   *ins->obufp++ = c;
11131   *ins->obufp = '\0';
11132 }
11133 
11134 /* Like oappend_char_with_style, but always uses dis_style_text.  */
11135 
11136 static void
11137 oappend_char (instr_info *ins, const char c)
11138 {
11139   oappend_char_with_style (ins, c, dis_style_text);
11140 }
11141 
11142 static void
11143 append_seg (instr_info *ins)
11144 {
11145   /* Only print the active segment register.  */
11146   if (!ins->active_seg_prefix)
11147     return;
11148 
11149   ins->used_prefixes |= ins->active_seg_prefix;
11150   switch (ins->active_seg_prefix)
11151     {
11152     case PREFIX_CS:
11153       oappend_register (ins, att_names_seg[1]);
11154       break;
11155     case PREFIX_DS:
11156       oappend_register (ins, att_names_seg[3]);
11157       break;
11158     case PREFIX_SS:
11159       oappend_register (ins, att_names_seg[2]);
11160       break;
11161     case PREFIX_ES:
11162       oappend_register (ins, att_names_seg[0]);
11163       break;
11164     case PREFIX_FS:
11165       oappend_register (ins, att_names_seg[4]);
11166       break;
11167     case PREFIX_GS:
11168       oappend_register (ins, att_names_seg[5]);
11169       break;
11170     default:
11171       break;
11172     }
11173   oappend_char (ins, ':');
11174 }
11175 
11176 static void
11177 print_operand_value (instr_info *ins, bfd_vma disp,
11178 		     enum disassembler_style style)
11179 {
11180   char tmp[30];
11181 
11182   if (ins->address_mode != mode_64bit)
11183     disp &= 0xffffffff;
11184   sprintf (tmp, "0x%" PRIx64, (uint64_t) disp);
11185   oappend_with_style (ins, tmp, style);
11186 }
11187 
11188 /* Like oappend, but called for immediate operands.  */
11189 
11190 static void
11191 oappend_immediate (instr_info *ins, bfd_vma imm)
11192 {
11193   if (!ins->intel_syntax)
11194     oappend_char_with_style (ins, '$', dis_style_immediate);
11195   print_operand_value (ins, imm, dis_style_immediate);
11196 }
11197 
11198 /* Put DISP in BUF as signed hex number.  */
11199 
11200 static void
11201 print_displacement (instr_info *ins, bfd_signed_vma val)
11202 {
11203   char tmp[30];
11204 
11205   if (val < 0)
11206     {
11207       oappend_char_with_style (ins, '-', dis_style_address_offset);
11208       val = (bfd_vma) 0 - val;
11209 
11210       /* Check for possible overflow.  */
11211       if (val < 0)
11212 	{
11213 	  switch (ins->address_mode)
11214 	    {
11215 	    case mode_64bit:
11216 	      oappend_with_style (ins, "0x8000000000000000",
11217 				  dis_style_address_offset);
11218 	      break;
11219 	    case mode_32bit:
11220 	      oappend_with_style (ins, "0x80000000",
11221 				  dis_style_address_offset);
11222 	      break;
11223 	    case mode_16bit:
11224 	      oappend_with_style (ins, "0x8000",
11225 				  dis_style_address_offset);
11226 	      break;
11227 	    }
11228 	  return;
11229 	}
11230     }
11231 
11232   sprintf (tmp, "0x%" PRIx64, (int64_t) val);
11233   oappend_with_style (ins, tmp, dis_style_address_offset);
11234 }
11235 
11236 static void
11237 intel_operand_size (instr_info *ins, int bytemode, int sizeflag)
11238 {
11239   /* Check if there is a broadcast, when evex.b is not treated as evex.nd.  */
11240   if (ins->vex.b && ins->evex_type == evex_default)
11241     {
11242       if (!ins->vex.no_broadcast)
11243 	switch (bytemode)
11244 	  {
11245 	  case x_mode:
11246 	  case evex_half_bcst_xmmq_mode:
11247 	    if (ins->vex.w)
11248 	      oappend (ins, "QWORD BCST ");
11249 	    else
11250 	      oappend (ins, "DWORD BCST ");
11251 	    break;
11252 	  case xh_mode:
11253 	  case evex_half_bcst_xmmqh_mode:
11254 	  case evex_half_bcst_xmmqdh_mode:
11255 	    oappend (ins, "WORD BCST ");
11256 	    break;
11257 	  default:
11258 	    ins->vex.no_broadcast = true;
11259 	    break;
11260 	  }
11261       return;
11262     }
11263   switch (bytemode)
11264     {
11265     case b_mode:
11266     case b_swap_mode:
11267     case db_mode:
11268       oappend (ins, "BYTE PTR ");
11269       break;
11270     case w_mode:
11271     case w_swap_mode:
11272     case dw_mode:
11273       oappend (ins, "WORD PTR ");
11274       break;
11275     case indir_v_mode:
11276       if (ins->address_mode == mode_64bit && ins->isa64 == intel64)
11277 	{
11278 	  oappend (ins, "QWORD PTR ");
11279 	  break;
11280 	}
11281       /* Fall through.  */
11282     case stack_v_mode:
11283       if (ins->address_mode == mode_64bit && ((sizeflag & DFLAG)
11284 					      || (ins->rex & REX_W)))
11285 	{
11286 	  oappend (ins, "QWORD PTR ");
11287 	  break;
11288 	}
11289       /* Fall through.  */
11290     case v_mode:
11291     case v_swap_mode:
11292     case dq_mode:
11293       USED_REX (REX_W);
11294       if (ins->rex & REX_W)
11295 	oappend (ins, "QWORD PTR ");
11296       else if (bytemode == dq_mode)
11297 	oappend (ins, "DWORD PTR ");
11298       else
11299 	{
11300 	  if (sizeflag & DFLAG)
11301 	    oappend (ins, "DWORD PTR ");
11302 	  else
11303 	    oappend (ins, "WORD PTR ");
11304 	  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11305 	}
11306       break;
11307     case z_mode:
11308       if ((ins->rex & REX_W) || (sizeflag & DFLAG))
11309 	*ins->obufp++ = 'D';
11310       oappend (ins, "WORD PTR ");
11311       if (!(ins->rex & REX_W))
11312 	ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11313       break;
11314     case a_mode:
11315       if (sizeflag & DFLAG)
11316 	oappend (ins, "QWORD PTR ");
11317       else
11318 	oappend (ins, "DWORD PTR ");
11319       ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11320       break;
11321     case movsxd_mode:
11322       if (!(sizeflag & DFLAG) && ins->isa64 == intel64)
11323 	oappend (ins, "WORD PTR ");
11324       else
11325 	oappend (ins, "DWORD PTR ");
11326       ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11327       break;
11328     case d_mode:
11329     case d_swap_mode:
11330       oappend (ins, "DWORD PTR ");
11331       break;
11332     case q_mode:
11333     case q_swap_mode:
11334       oappend (ins, "QWORD PTR ");
11335       break;
11336     case m_mode:
11337       if (ins->address_mode == mode_64bit)
11338 	oappend (ins, "QWORD PTR ");
11339       else
11340 	oappend (ins, "DWORD PTR ");
11341       break;
11342     case f_mode:
11343       if (sizeflag & DFLAG)
11344 	oappend (ins, "FWORD PTR ");
11345       else
11346 	oappend (ins, "DWORD PTR ");
11347       ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11348       break;
11349     case t_mode:
11350       oappend (ins, "TBYTE PTR ");
11351       break;
11352     case x_mode:
11353     case xh_mode:
11354     case x_swap_mode:
11355     case evex_x_gscat_mode:
11356     case evex_x_nobcst_mode:
11357     case bw_unit_mode:
11358       if (ins->need_vex)
11359 	{
11360 	  switch (ins->vex.length)
11361 	    {
11362 	    case 128:
11363 	      oappend (ins, "XMMWORD PTR ");
11364 	      break;
11365 	    case 256:
11366 	      oappend (ins, "YMMWORD PTR ");
11367 	      break;
11368 	    case 512:
11369 	      oappend (ins, "ZMMWORD PTR ");
11370 	      break;
11371 	    default:
11372 	      abort ();
11373 	    }
11374 	}
11375       else
11376 	oappend (ins, "XMMWORD PTR ");
11377       break;
11378     case xmm_mode:
11379       oappend (ins, "XMMWORD PTR ");
11380       break;
11381     case ymm_mode:
11382       oappend (ins, "YMMWORD PTR ");
11383       break;
11384     case xmmq_mode:
11385     case evex_half_bcst_xmmqh_mode:
11386     case evex_half_bcst_xmmq_mode:
11387       switch (ins->vex.length)
11388 	{
11389 	case 0:
11390 	case 128:
11391 	  oappend (ins, "QWORD PTR ");
11392 	  break;
11393 	case 256:
11394 	  oappend (ins, "XMMWORD PTR ");
11395 	  break;
11396 	case 512:
11397 	  oappend (ins, "YMMWORD PTR ");
11398 	  break;
11399 	default:
11400 	  abort ();
11401 	}
11402       break;
11403     case xmmdw_mode:
11404       if (!ins->need_vex)
11405 	abort ();
11406 
11407       switch (ins->vex.length)
11408 	{
11409 	case 128:
11410 	  oappend (ins, "WORD PTR ");
11411 	  break;
11412 	case 256:
11413 	  oappend (ins, "DWORD PTR ");
11414 	  break;
11415 	case 512:
11416 	  oappend (ins, "QWORD PTR ");
11417 	  break;
11418 	default:
11419 	  abort ();
11420 	}
11421       break;
11422     case xmmqd_mode:
11423     case evex_half_bcst_xmmqdh_mode:
11424       if (!ins->need_vex)
11425 	abort ();
11426 
11427       switch (ins->vex.length)
11428 	{
11429 	case 128:
11430 	  oappend (ins, "DWORD PTR ");
11431 	  break;
11432 	case 256:
11433 	  oappend (ins, "QWORD PTR ");
11434 	  break;
11435 	case 512:
11436 	  oappend (ins, "XMMWORD PTR ");
11437 	  break;
11438 	default:
11439 	  abort ();
11440 	}
11441       break;
11442     case ymmq_mode:
11443       if (!ins->need_vex)
11444 	abort ();
11445 
11446       switch (ins->vex.length)
11447 	{
11448 	case 128:
11449 	  oappend (ins, "QWORD PTR ");
11450 	  break;
11451 	case 256:
11452 	  oappend (ins, "YMMWORD PTR ");
11453 	  break;
11454 	case 512:
11455 	  oappend (ins, "ZMMWORD PTR ");
11456 	  break;
11457 	default:
11458 	  abort ();
11459 	}
11460       break;
11461     case o_mode:
11462       oappend (ins, "OWORD PTR ");
11463       break;
11464     case vex_vsib_d_w_dq_mode:
11465     case vex_vsib_q_w_dq_mode:
11466       if (!ins->need_vex)
11467 	abort ();
11468       if (ins->vex.w)
11469 	oappend (ins, "QWORD PTR ");
11470       else
11471 	oappend (ins, "DWORD PTR ");
11472       break;
11473     case mask_bd_mode:
11474       if (!ins->need_vex || ins->vex.length != 128)
11475 	abort ();
11476       if (ins->vex.w)
11477 	oappend (ins, "DWORD PTR ");
11478       else
11479 	oappend (ins, "BYTE PTR ");
11480       break;
11481     case mask_mode:
11482       if (!ins->need_vex)
11483 	abort ();
11484       if (ins->vex.w)
11485 	oappend (ins, "QWORD PTR ");
11486       else
11487 	oappend (ins, "WORD PTR ");
11488       break;
11489     case v_bnd_mode:
11490     case v_bndmk_mode:
11491     default:
11492       break;
11493     }
11494 }
11495 
11496 static void
11497 print_register (instr_info *ins, unsigned int reg, unsigned int rexmask,
11498 		int bytemode, int sizeflag)
11499 {
11500   const char (*names)[8];
11501 
11502   /* Masking is invalid for insns with GPR destination. Set the flag uniformly,
11503      as the consumer will inspect it only for the destination operand.  */
11504   if (bytemode != mask_mode && ins->vex.mask_register_specifier)
11505     ins->illegal_masking = true;
11506 
11507   USED_REX (rexmask);
11508   if (ins->rex & rexmask)
11509     reg += 8;
11510   if (ins->rex2 & rexmask)
11511     reg += 16;
11512 
11513   switch (bytemode)
11514     {
11515     case b_mode:
11516     case b_swap_mode:
11517       if (reg & 4)
11518 	USED_REX (0);
11519       if (ins->rex || ins->rex2)
11520 	names = att_names8rex;
11521       else
11522 	names = att_names8;
11523       break;
11524     case w_mode:
11525       names = att_names16;
11526       break;
11527     case d_mode:
11528     case dw_mode:
11529     case db_mode:
11530       names = att_names32;
11531       break;
11532     case q_mode:
11533       names = att_names64;
11534       break;
11535     case m_mode:
11536     case v_bnd_mode:
11537       names = ins->address_mode == mode_64bit ? att_names64 : att_names32;
11538       break;
11539     case bnd_mode:
11540     case bnd_swap_mode:
11541       if (reg > 0x3)
11542 	{
11543 	  oappend (ins, "(bad)");
11544 	  return;
11545 	}
11546       names = att_names_bnd;
11547       break;
11548     case indir_v_mode:
11549       if (ins->address_mode == mode_64bit && ins->isa64 == intel64)
11550 	{
11551 	  names = att_names64;
11552 	  break;
11553 	}
11554       /* Fall through.  */
11555     case stack_v_mode:
11556       if (ins->address_mode == mode_64bit && ((sizeflag & DFLAG)
11557 					      || (ins->rex & REX_W)))
11558 	{
11559 	  names = att_names64;
11560 	  break;
11561 	}
11562       bytemode = v_mode;
11563       /* Fall through.  */
11564     case v_mode:
11565     case v_swap_mode:
11566     case dq_mode:
11567       USED_REX (REX_W);
11568       if (ins->rex & REX_W)
11569 	names = att_names64;
11570       else if (bytemode != v_mode && bytemode != v_swap_mode)
11571 	names = att_names32;
11572       else
11573 	{
11574 	  if (sizeflag & DFLAG)
11575 	    names = att_names32;
11576 	  else
11577 	    names = att_names16;
11578 	  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11579 	}
11580       break;
11581     case movsxd_mode:
11582       if (!(sizeflag & DFLAG) && ins->isa64 == intel64)
11583 	names = att_names16;
11584       else
11585 	names = att_names32;
11586       ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
11587       break;
11588     case va_mode:
11589       names = (ins->address_mode == mode_64bit
11590 	       ? att_names64 : att_names32);
11591       if (!(ins->prefixes & PREFIX_ADDR))
11592 	names = (ins->address_mode == mode_16bit
11593 		     ? att_names16 : names);
11594       else
11595 	{
11596 	  /* Remove "addr16/addr32".  */
11597 	  ins->all_prefixes[ins->last_addr_prefix] = 0;
11598 	  names = (ins->address_mode != mode_32bit
11599 		       ? att_names32 : att_names16);
11600 	  ins->used_prefixes |= PREFIX_ADDR;
11601 	}
11602       break;
11603     case mask_bd_mode:
11604     case mask_mode:
11605       if (reg > 0x7)
11606 	{
11607 	  oappend (ins, "(bad)");
11608 	  return;
11609 	}
11610       names = att_names_mask;
11611       break;
11612     case 0:
11613       return;
11614     default:
11615       oappend (ins, INTERNAL_DISASSEMBLER_ERROR);
11616       return;
11617     }
11618   oappend_register (ins, names[reg]);
11619 }
11620 
11621 static bool
11622 get8s (instr_info *ins, bfd_vma *res)
11623 {
11624   if (!fetch_code (ins->info, ins->codep + 1))
11625     return false;
11626   *res = ((bfd_vma) *ins->codep++ ^ 0x80) - 0x80;
11627   return true;
11628 }
11629 
11630 static bool
11631 get16 (instr_info *ins, bfd_vma *res)
11632 {
11633   if (!fetch_code (ins->info, ins->codep + 2))
11634     return false;
11635   *res = *ins->codep++;
11636   *res |= (bfd_vma) *ins->codep++ << 8;
11637   return true;
11638 }
11639 
11640 static bool
11641 get16s (instr_info *ins, bfd_vma *res)
11642 {
11643   if (!get16 (ins, res))
11644     return false;
11645   *res = (*res ^ 0x8000) - 0x8000;
11646   return true;
11647 }
11648 
11649 static bool
11650 get32 (instr_info *ins, bfd_vma *res)
11651 {
11652   if (!fetch_code (ins->info, ins->codep + 4))
11653     return false;
11654   *res = *ins->codep++;
11655   *res |= (bfd_vma) *ins->codep++ << 8;
11656   *res |= (bfd_vma) *ins->codep++ << 16;
11657   *res |= (bfd_vma) *ins->codep++ << 24;
11658   return true;
11659 }
11660 
11661 static bool
11662 get32s (instr_info *ins, bfd_vma *res)
11663 {
11664   if (!get32 (ins, res))
11665     return false;
11666 
11667   *res = (*res ^ ((bfd_vma) 1 << 31)) - ((bfd_vma) 1 << 31);
11668 
11669   return true;
11670 }
11671 
11672 static bool
11673 get64 (instr_info *ins, uint64_t *res)
11674 {
11675   unsigned int a;
11676   unsigned int b;
11677 
11678   if (!fetch_code (ins->info, ins->codep + 8))
11679     return false;
11680   a = *ins->codep++;
11681   a |= (unsigned int) *ins->codep++ << 8;
11682   a |= (unsigned int) *ins->codep++ << 16;
11683   a |= (unsigned int) *ins->codep++ << 24;
11684   b = *ins->codep++;
11685   b |= (unsigned int) *ins->codep++ << 8;
11686   b |= (unsigned int) *ins->codep++ << 16;
11687   b |= (unsigned int) *ins->codep++ << 24;
11688   *res = a + ((uint64_t) b << 32);
11689   return true;
11690 }
11691 
11692 static void
11693 set_op (instr_info *ins, bfd_vma op, bool riprel)
11694 {
11695   ins->op_index[ins->op_ad] = ins->op_ad;
11696   if (ins->address_mode == mode_64bit)
11697     ins->op_address[ins->op_ad] = op;
11698   else /* Mask to get a 32-bit address.  */
11699     ins->op_address[ins->op_ad] = op & 0xffffffff;
11700   ins->op_riprel[ins->op_ad] = riprel;
11701 }
11702 
11703 static bool
11704 BadOp (instr_info *ins)
11705 {
11706   /* Throw away prefixes and 1st. opcode byte.  */
11707   struct dis_private *priv = ins->info->private_data;
11708 
11709   ins->codep = priv->the_buffer + ins->nr_prefixes + ins->need_vex + 1;
11710   ins->obufp = stpcpy (ins->obufp, "(bad)");
11711   return true;
11712 }
11713 
11714 static bool
11715 OP_Skip_MODRM (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
11716 	       int sizeflag ATTRIBUTE_UNUSED)
11717 {
11718   if (ins->modrm.mod != 3)
11719     return BadOp (ins);
11720 
11721   /* Skip mod/rm byte.  */
11722   MODRM_CHECK;
11723   ins->codep++;
11724   ins->has_skipped_modrm = true;
11725   return true;
11726 }
11727 
11728 static bool
11729 OP_E_memory (instr_info *ins, int bytemode, int sizeflag)
11730 {
11731   int add = (ins->rex & REX_B) ? 8 : 0;
11732   int riprel = 0;
11733   int shift;
11734 
11735   add += (ins->rex2 & REX_B) ? 16 : 0;
11736 
11737   /* Handles EVEX other than APX EVEX-promoted instructions.  */
11738   if (ins->vex.evex && ins->evex_type == evex_default)
11739     {
11740 
11741       /* Zeroing-masking is invalid for memory destinations. Set the flag
11742 	 uniformly, as the consumer will inspect it only for the destination
11743 	 operand.  */
11744       if (ins->vex.zeroing)
11745 	ins->illegal_masking = true;
11746 
11747       switch (bytemode)
11748 	{
11749 	case dw_mode:
11750 	case w_mode:
11751 	case w_swap_mode:
11752 	  shift = 1;
11753 	  break;
11754 	case db_mode:
11755 	case b_mode:
11756 	  shift = 0;
11757 	  break;
11758 	case dq_mode:
11759 	  if (ins->address_mode != mode_64bit)
11760 	    {
11761 	case d_mode:
11762 	case d_swap_mode:
11763 	      shift = 2;
11764 	      break;
11765 	    }
11766 	    /* fall through */
11767 	case vex_vsib_d_w_dq_mode:
11768 	case vex_vsib_q_w_dq_mode:
11769 	case evex_x_gscat_mode:
11770 	  shift = ins->vex.w ? 3 : 2;
11771 	  break;
11772 	case xh_mode:
11773 	case evex_half_bcst_xmmqh_mode:
11774 	case evex_half_bcst_xmmqdh_mode:
11775 	  if (ins->vex.b)
11776 	    {
11777 	      shift = ins->vex.w ? 2 : 1;
11778 	      break;
11779 	    }
11780 	  /* Fall through.  */
11781 	case x_mode:
11782 	case evex_half_bcst_xmmq_mode:
11783 	  if (ins->vex.b)
11784 	    {
11785 	      shift = ins->vex.w ? 3 : 2;
11786 	      break;
11787 	    }
11788 	  /* Fall through.  */
11789 	case xmmqd_mode:
11790 	case xmmdw_mode:
11791 	case xmmq_mode:
11792 	case ymmq_mode:
11793 	case evex_x_nobcst_mode:
11794 	case x_swap_mode:
11795 	  switch (ins->vex.length)
11796 	    {
11797 	    case 128:
11798 	      shift = 4;
11799 	      break;
11800 	    case 256:
11801 	      shift = 5;
11802 	      break;
11803 	    case 512:
11804 	      shift = 6;
11805 	      break;
11806 	    default:
11807 	      abort ();
11808 	    }
11809 	  /* Make necessary corrections to shift for modes that need it.  */
11810 	  if (bytemode == xmmq_mode
11811 	      || bytemode == evex_half_bcst_xmmqh_mode
11812 	      || bytemode == evex_half_bcst_xmmq_mode
11813 	      || (bytemode == ymmq_mode && ins->vex.length == 128))
11814 	    shift -= 1;
11815 	  else if (bytemode == xmmqd_mode
11816 	           || bytemode == evex_half_bcst_xmmqdh_mode)
11817 	    shift -= 2;
11818 	  else if (bytemode == xmmdw_mode)
11819 	    shift -= 3;
11820 	  break;
11821 	case ymm_mode:
11822 	  shift = 5;
11823 	  break;
11824 	case xmm_mode:
11825 	  shift = 4;
11826 	  break;
11827 	case q_mode:
11828 	case q_swap_mode:
11829 	  shift = 3;
11830 	  break;
11831 	case bw_unit_mode:
11832 	  shift = ins->vex.w ? 1 : 0;
11833 	  break;
11834 	default:
11835 	  abort ();
11836 	}
11837     }
11838   else
11839     shift = 0;
11840 
11841   USED_REX (REX_B);
11842   if (ins->intel_syntax)
11843     intel_operand_size (ins, bytemode, sizeflag);
11844   append_seg (ins);
11845 
11846   if ((sizeflag & AFLAG) || ins->address_mode == mode_64bit)
11847     {
11848       /* 32/64 bit address mode */
11849       bfd_vma disp = 0;
11850       int havedisp;
11851       int havebase;
11852       int needindex;
11853       int needaddr32;
11854       int base, rbase;
11855       int vindex = 0;
11856       int scale = 0;
11857       int addr32flag = !((sizeflag & AFLAG)
11858 			 || bytemode == v_bnd_mode
11859 			 || bytemode == v_bndmk_mode
11860 			 || bytemode == bnd_mode
11861 			 || bytemode == bnd_swap_mode);
11862       bool check_gather = false;
11863       const char (*indexes)[8] = NULL;
11864 
11865       havebase = 1;
11866       base = ins->modrm.rm;
11867 
11868       if (base == 4)
11869 	{
11870 	  vindex = ins->sib.index;
11871 	  USED_REX (REX_X);
11872 	  if (ins->rex & REX_X)
11873 	    vindex += 8;
11874 	  switch (bytemode)
11875 	    {
11876 	    case vex_vsib_d_w_dq_mode:
11877 	    case vex_vsib_q_w_dq_mode:
11878 	      if (!ins->need_vex)
11879 		abort ();
11880 	      if (ins->vex.evex)
11881 		{
11882 		  /* S/G EVEX insns require EVEX.X4 not to be set.  */
11883 		  if (ins->rex2 & REX_X)
11884 		    {
11885 		      oappend (ins, "(bad)");
11886 		      return true;
11887 		    }
11888 
11889 		  if (!ins->vex.v)
11890 		    vindex += 16;
11891 		  check_gather = ins->obufp == ins->op_out[1];
11892 		}
11893 
11894 	      switch (ins->vex.length)
11895 		{
11896 		case 128:
11897 		  indexes = att_names_xmm;
11898 		  break;
11899 		case 256:
11900 		  if (!ins->vex.w
11901 		      || bytemode == vex_vsib_q_w_dq_mode)
11902 		    indexes = att_names_ymm;
11903 		  else
11904 		    indexes = att_names_xmm;
11905 		  break;
11906 		case 512:
11907 		  if (!ins->vex.w
11908 		      || bytemode == vex_vsib_q_w_dq_mode)
11909 		    indexes = att_names_zmm;
11910 		  else
11911 		    indexes = att_names_ymm;
11912 		  break;
11913 		default:
11914 		  abort ();
11915 		}
11916 	      break;
11917 	    default:
11918 	      if (ins->rex2 & REX_X)
11919 		vindex += 16;
11920 
11921 	      if (vindex != 4)
11922 		indexes = ins->address_mode == mode_64bit && !addr32flag
11923 			  ? att_names64 : att_names32;
11924 	      break;
11925 	    }
11926 	  scale = ins->sib.scale;
11927 	  base = ins->sib.base;
11928 	  ins->codep++;
11929 	}
11930       else
11931 	{
11932 	  /* Check for mandatory SIB.  */
11933 	  if (bytemode == vex_vsib_d_w_dq_mode
11934 	      || bytemode == vex_vsib_q_w_dq_mode
11935 	      || bytemode == vex_sibmem_mode)
11936 	    {
11937 	      oappend (ins, "(bad)");
11938 	      return true;
11939 	    }
11940 	}
11941       rbase = base + add;
11942 
11943       switch (ins->modrm.mod)
11944 	{
11945 	case 0:
11946 	  if (base == 5)
11947 	    {
11948 	      havebase = 0;
11949 	      if (ins->address_mode == mode_64bit && !ins->has_sib)
11950 		riprel = 1;
11951 	      if (!get32s (ins, &disp))
11952 		return false;
11953 	      if (riprel && bytemode == v_bndmk_mode)
11954 		{
11955 		  oappend (ins, "(bad)");
11956 		  return true;
11957 		}
11958 	    }
11959 	  break;
11960 	case 1:
11961 	  if (!get8s (ins, &disp))
11962 	    return false;
11963 	  if (ins->vex.evex && shift > 0)
11964 	    disp <<= shift;
11965 	  break;
11966 	case 2:
11967 	  if (!get32s (ins, &disp))
11968 	    return false;
11969 	  break;
11970 	}
11971 
11972       needindex = 0;
11973       needaddr32 = 0;
11974       if (ins->has_sib
11975 	  && !havebase
11976 	  && !indexes
11977 	  && ins->address_mode != mode_16bit)
11978 	{
11979 	  if (ins->address_mode == mode_64bit)
11980 	    {
11981 	      if (addr32flag)
11982 		{
11983 		  /* Without base nor index registers, zero-extend the
11984 		     lower 32-bit displacement to 64 bits.  */
11985 		  disp &= 0xffffffff;
11986 		  needindex = 1;
11987 		}
11988 	      needaddr32 = 1;
11989 	    }
11990 	  else
11991 	    {
11992 	      /* In 32-bit mode, we need index register to tell [offset]
11993 		 from [eiz*1 + offset].  */
11994 	      needindex = 1;
11995 	    }
11996 	}
11997 
11998       havedisp = (havebase
11999 		  || needindex
12000 		  || (ins->has_sib && (indexes || scale != 0)));
12001 
12002       if (!ins->intel_syntax)
12003 	if (ins->modrm.mod != 0 || base == 5)
12004 	  {
12005 	    if (havedisp || riprel)
12006 	      print_displacement (ins, disp);
12007 	    else
12008 	      print_operand_value (ins, disp, dis_style_address_offset);
12009 	    if (riprel)
12010 	      {
12011 		set_op (ins, disp, true);
12012 		oappend_char (ins, '(');
12013 		oappend_with_style (ins, !addr32flag ? "%rip" : "%eip",
12014 				    dis_style_register);
12015 		oappend_char (ins, ')');
12016 	      }
12017 	  }
12018 
12019       if ((havebase || indexes || needindex || needaddr32 || riprel)
12020 	  && (ins->address_mode != mode_64bit
12021 	      || ((bytemode != v_bnd_mode)
12022 		  && (bytemode != v_bndmk_mode)
12023 		  && (bytemode != bnd_mode)
12024 		  && (bytemode != bnd_swap_mode))))
12025 	ins->used_prefixes |= PREFIX_ADDR;
12026 
12027       if (havedisp || (ins->intel_syntax && riprel))
12028 	{
12029 	  oappend_char (ins, ins->open_char);
12030 	  if (ins->intel_syntax && riprel)
12031 	    {
12032 	      set_op (ins, disp, true);
12033 	      oappend_with_style (ins, !addr32flag ? "rip" : "eip",
12034 				  dis_style_register);
12035 	    }
12036 	  if (havebase)
12037 	    oappend_register
12038 	      (ins,
12039 	       (ins->address_mode == mode_64bit && !addr32flag
12040 		? att_names64 : att_names32)[rbase]);
12041 	  if (ins->has_sib)
12042 	    {
12043 	      /* ESP/RSP won't allow index.  If base isn't ESP/RSP,
12044 		 print index to tell base + index from base.  */
12045 	      if (scale != 0
12046 		  || needindex
12047 		  || indexes
12048 		  || (havebase && base != ESP_REG_NUM))
12049 		{
12050 		  if (!ins->intel_syntax || havebase)
12051 		    oappend_char (ins, ins->separator_char);
12052 		  if (indexes)
12053 		    {
12054 		      if (ins->address_mode == mode_64bit || vindex < 16)
12055 			oappend_register (ins, indexes[vindex]);
12056 		      else
12057 			oappend (ins, "(bad)");
12058 		    }
12059 		  else
12060 		    oappend_register (ins,
12061 				      ins->address_mode == mode_64bit
12062 				      && !addr32flag
12063 				      ? att_index64
12064 				      : att_index32);
12065 
12066 		  oappend_char (ins, ins->scale_char);
12067 		  oappend_char_with_style (ins, '0' + (1 << scale),
12068 					   dis_style_immediate);
12069 		}
12070 	    }
12071 	  if (ins->intel_syntax
12072 	      && (disp || ins->modrm.mod != 0 || base == 5))
12073 	    {
12074 	      if (!havedisp || (bfd_signed_vma) disp >= 0)
12075 		  oappend_char (ins, '+');
12076 	      if (havedisp)
12077 		print_displacement (ins, disp);
12078 	      else
12079 		print_operand_value (ins, disp, dis_style_address_offset);
12080 	    }
12081 
12082 	  oappend_char (ins, ins->close_char);
12083 
12084 	  if (check_gather)
12085 	    {
12086 	      /* Both XMM/YMM/ZMM registers must be distinct.  */
12087 	      int modrm_reg = ins->modrm.reg;
12088 
12089 	      if (ins->rex & REX_R)
12090 	        modrm_reg += 8;
12091 	      if (ins->rex2 & REX_R)
12092 	        modrm_reg += 16;
12093 	      if (vindex == modrm_reg)
12094 		oappend (ins, "/(bad)");
12095 	    }
12096 	}
12097       else if (ins->intel_syntax)
12098 	{
12099 	  if (ins->modrm.mod != 0 || base == 5)
12100 	    {
12101 	      if (!ins->active_seg_prefix)
12102 		{
12103 		  oappend_register (ins, att_names_seg[ds_reg - es_reg]);
12104 		  oappend (ins, ":");
12105 		}
12106 	      print_operand_value (ins, disp, dis_style_text);
12107 	    }
12108 	}
12109     }
12110   else if (bytemode == v_bnd_mode
12111 	   || bytemode == v_bndmk_mode
12112 	   || bytemode == bnd_mode
12113 	   || bytemode == bnd_swap_mode
12114 	   || bytemode == vex_vsib_d_w_dq_mode
12115 	   || bytemode == vex_vsib_q_w_dq_mode)
12116     {
12117       oappend (ins, "(bad)");
12118       return true;
12119     }
12120   else
12121     {
12122       /* 16 bit address mode */
12123       bfd_vma disp = 0;
12124 
12125       ins->used_prefixes |= ins->prefixes & PREFIX_ADDR;
12126       switch (ins->modrm.mod)
12127 	{
12128 	case 0:
12129 	  if (ins->modrm.rm == 6)
12130 	    {
12131 	case 2:
12132 	      if (!get16s (ins, &disp))
12133 		return false;
12134 	    }
12135 	  break;
12136 	case 1:
12137 	  if (!get8s (ins, &disp))
12138 	    return false;
12139 	  if (ins->vex.evex && shift > 0)
12140 	    disp <<= shift;
12141 	  break;
12142 	}
12143 
12144       if (!ins->intel_syntax)
12145 	if (ins->modrm.mod != 0 || ins->modrm.rm == 6)
12146 	  print_displacement (ins, disp);
12147 
12148       if (ins->modrm.mod != 0 || ins->modrm.rm != 6)
12149 	{
12150 	  oappend_char (ins, ins->open_char);
12151 	  oappend (ins, ins->intel_syntax ? intel_index16[ins->modrm.rm]
12152 					  : att_index16[ins->modrm.rm]);
12153 	  if (ins->intel_syntax
12154 	      && (disp || ins->modrm.mod != 0 || ins->modrm.rm == 6))
12155 	    {
12156 	      if ((bfd_signed_vma) disp >= 0)
12157 		oappend_char (ins, '+');
12158 	      print_displacement (ins, disp);
12159 	    }
12160 
12161 	  oappend_char (ins, ins->close_char);
12162 	}
12163       else if (ins->intel_syntax)
12164 	{
12165 	  if (!ins->active_seg_prefix)
12166 	    {
12167 	      oappend_register (ins, att_names_seg[ds_reg - es_reg]);
12168 	      oappend (ins, ":");
12169 	    }
12170 	  print_operand_value (ins, disp & 0xffff, dis_style_text);
12171 	}
12172     }
12173   if (ins->vex.b && ins->evex_type == evex_default)
12174     {
12175       ins->evex_used |= EVEX_b_used;
12176 
12177       /* Broadcast can only ever be valid for memory sources.  */
12178       if (ins->obufp == ins->op_out[0])
12179 	ins->vex.no_broadcast = true;
12180 
12181       if (!ins->vex.no_broadcast
12182 	  && (!ins->intel_syntax || !(ins->evex_used & EVEX_len_used)))
12183 	{
12184 	  if (bytemode == xh_mode)
12185 	    {
12186 	      switch (ins->vex.length)
12187 		{
12188 		case 128:
12189 		  oappend (ins, "{1to8}");
12190 		  break;
12191 		case 256:
12192 		  oappend (ins, "{1to16}");
12193 		  break;
12194 		case 512:
12195 		  oappend (ins, "{1to32}");
12196 		  break;
12197 		default:
12198 		  abort ();
12199 		}
12200 	    }
12201 	  else if (bytemode == q_mode
12202 		   || bytemode == ymmq_mode)
12203 	    ins->vex.no_broadcast = true;
12204 	  else if (ins->vex.w
12205 		   || bytemode == evex_half_bcst_xmmqdh_mode
12206 		   || bytemode == evex_half_bcst_xmmq_mode)
12207 	    {
12208 	      switch (ins->vex.length)
12209 		{
12210 		case 128:
12211 		  oappend (ins, "{1to2}");
12212 		  break;
12213 		case 256:
12214 		  oappend (ins, "{1to4}");
12215 		  break;
12216 		case 512:
12217 		  oappend (ins, "{1to8}");
12218 		  break;
12219 		default:
12220 		  abort ();
12221 		}
12222 	    }
12223 	  else if (bytemode == x_mode
12224 		   || bytemode == evex_half_bcst_xmmqh_mode)
12225 	    {
12226 	      switch (ins->vex.length)
12227 		{
12228 		case 128:
12229 		  oappend (ins, "{1to4}");
12230 		  break;
12231 		case 256:
12232 		  oappend (ins, "{1to8}");
12233 		  break;
12234 		case 512:
12235 		  oappend (ins, "{1to16}");
12236 		  break;
12237 		default:
12238 		  abort ();
12239 		}
12240 	    }
12241 	  else
12242 	    ins->vex.no_broadcast = true;
12243 	}
12244       if (ins->vex.no_broadcast)
12245 	oappend (ins, "{bad}");
12246     }
12247 
12248   return true;
12249 }
12250 
12251 static bool
12252 OP_E (instr_info *ins, int bytemode, int sizeflag)
12253 {
12254   /* Skip mod/rm byte.  */
12255   MODRM_CHECK;
12256   if (!ins->has_skipped_modrm)
12257     {
12258       ins->codep++;
12259       ins->has_skipped_modrm = true;
12260     }
12261 
12262   if (ins->modrm.mod == 3)
12263     {
12264       if ((sizeflag & SUFFIX_ALWAYS)
12265 	  && (bytemode == b_swap_mode
12266 	      || bytemode == bnd_swap_mode
12267 	      || bytemode == v_swap_mode))
12268 	swap_operand (ins);
12269 
12270       print_register (ins, ins->modrm.rm, REX_B, bytemode, sizeflag);
12271       return true;
12272     }
12273 
12274   /* Masking is invalid for insns with GPR-like memory destination. Set the
12275      flag uniformly, as the consumer will inspect it only for the destination
12276      operand.  */
12277   if (ins->vex.mask_register_specifier)
12278     ins->illegal_masking = true;
12279 
12280   return OP_E_memory (ins, bytemode, sizeflag);
12281 }
12282 
12283 static bool
12284 OP_indirE (instr_info *ins, int bytemode, int sizeflag)
12285 {
12286   if (ins->modrm.mod == 3 && bytemode == f_mode)
12287     /* bad lcall/ljmp */
12288     return BadOp (ins);
12289   if (!ins->intel_syntax)
12290     oappend (ins, "*");
12291   return OP_E (ins, bytemode, sizeflag);
12292 }
12293 
12294 static bool
12295 OP_G (instr_info *ins, int bytemode, int sizeflag)
12296 {
12297   print_register (ins, ins->modrm.reg, REX_R, bytemode, sizeflag);
12298   return true;
12299 }
12300 
12301 static bool
12302 OP_REG (instr_info *ins, int code, int sizeflag)
12303 {
12304   const char *s;
12305   int add = 0;
12306 
12307   switch (code)
12308     {
12309     case es_reg: case ss_reg: case cs_reg:
12310     case ds_reg: case fs_reg: case gs_reg:
12311       oappend_register (ins, att_names_seg[code - es_reg]);
12312       return true;
12313     }
12314 
12315   USED_REX (REX_B);
12316   if (ins->rex & REX_B)
12317     add = 8;
12318   if (ins->rex2 & REX_B)
12319     add += 16;
12320 
12321   switch (code)
12322     {
12323     case ax_reg: case cx_reg: case dx_reg: case bx_reg:
12324     case sp_reg: case bp_reg: case si_reg: case di_reg:
12325       s = att_names16[code - ax_reg + add];
12326       break;
12327     case ah_reg: case ch_reg: case dh_reg: case bh_reg:
12328       USED_REX (0);
12329       /* Fall through.  */
12330     case al_reg: case cl_reg: case dl_reg: case bl_reg:
12331       if (ins->rex)
12332 	s = att_names8rex[code - al_reg + add];
12333       else
12334 	s = att_names8[code - al_reg];
12335       break;
12336     case rAX_reg: case rCX_reg: case rDX_reg: case rBX_reg:
12337     case rSP_reg: case rBP_reg: case rSI_reg: case rDI_reg:
12338       if (ins->address_mode == mode_64bit
12339 	  && ((sizeflag & DFLAG) || (ins->rex & REX_W)))
12340 	{
12341 	  s = att_names64[code - rAX_reg + add];
12342 	  break;
12343 	}
12344       code += eAX_reg - rAX_reg;
12345       /* Fall through.  */
12346     case eAX_reg: case eCX_reg: case eDX_reg: case eBX_reg:
12347     case eSP_reg: case eBP_reg: case eSI_reg: case eDI_reg:
12348       USED_REX (REX_W);
12349       if (ins->rex & REX_W)
12350 	s = att_names64[code - eAX_reg + add];
12351       else
12352 	{
12353 	  if (sizeflag & DFLAG)
12354 	    s = att_names32[code - eAX_reg + add];
12355 	  else
12356 	    s = att_names16[code - eAX_reg + add];
12357 	  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12358 	}
12359       break;
12360     default:
12361       oappend (ins, INTERNAL_DISASSEMBLER_ERROR);
12362       return true;
12363     }
12364   oappend_register (ins, s);
12365   return true;
12366 }
12367 
12368 static bool
12369 OP_IMREG (instr_info *ins, int code, int sizeflag)
12370 {
12371   const char *s;
12372 
12373   switch (code)
12374     {
12375     case indir_dx_reg:
12376       if (!ins->intel_syntax)
12377 	{
12378 	  oappend (ins, "(%dx)");
12379 	  return true;
12380 	}
12381       s = att_names16[dx_reg - ax_reg];
12382       break;
12383     case al_reg: case cl_reg:
12384       s = att_names8[code - al_reg];
12385       break;
12386     case eAX_reg:
12387       USED_REX (REX_W);
12388       if (ins->rex & REX_W)
12389 	{
12390 	  s = *att_names64;
12391 	  break;
12392 	}
12393       /* Fall through.  */
12394     case z_mode_ax_reg:
12395       if ((ins->rex & REX_W) || (sizeflag & DFLAG))
12396 	s = *att_names32;
12397       else
12398 	s = *att_names16;
12399       if (!(ins->rex & REX_W))
12400 	ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12401       break;
12402     default:
12403       oappend (ins, INTERNAL_DISASSEMBLER_ERROR);
12404       return true;
12405     }
12406   oappend_register (ins, s);
12407   return true;
12408 }
12409 
12410 static bool
12411 OP_I (instr_info *ins, int bytemode, int sizeflag)
12412 {
12413   bfd_vma op;
12414 
12415   switch (bytemode)
12416     {
12417     case b_mode:
12418       if (!fetch_code (ins->info, ins->codep + 1))
12419 	return false;
12420       op = *ins->codep++;
12421       break;
12422     case v_mode:
12423       USED_REX (REX_W);
12424       if (ins->rex & REX_W)
12425 	{
12426 	  if (!get32s (ins, &op))
12427 	    return false;
12428 	}
12429       else
12430 	{
12431 	  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12432 	  if (sizeflag & DFLAG)
12433 	    {
12434     case d_mode:
12435 	      if (!get32 (ins, &op))
12436 		return false;
12437 	    }
12438 	  else
12439 	    {
12440 	      /* Fall through.  */
12441     case w_mode:
12442 	      if (!get16 (ins, &op))
12443 		return false;
12444 	    }
12445 	}
12446       break;
12447     case const_1_mode:
12448       if (ins->intel_syntax)
12449 	oappend (ins, "1");
12450       else
12451 	oappend (ins, "$1");
12452       return true;
12453     default:
12454       oappend (ins, INTERNAL_DISASSEMBLER_ERROR);
12455       return true;
12456     }
12457 
12458   oappend_immediate (ins, op);
12459   return true;
12460 }
12461 
12462 static bool
12463 OP_I64 (instr_info *ins, int bytemode, int sizeflag)
12464 {
12465   uint64_t op;
12466 
12467   if (bytemode != v_mode || ins->address_mode != mode_64bit
12468       || !(ins->rex & REX_W))
12469     return OP_I (ins, bytemode, sizeflag);
12470 
12471   USED_REX (REX_W);
12472 
12473   if (!get64 (ins, &op))
12474     return false;
12475 
12476   oappend_immediate (ins, op);
12477   return true;
12478 }
12479 
12480 static bool
12481 OP_sI (instr_info *ins, int bytemode, int sizeflag)
12482 {
12483   bfd_vma op;
12484 
12485   switch (bytemode)
12486     {
12487     case b_mode:
12488     case b_T_mode:
12489       if (!get8s (ins, &op))
12490 	return false;
12491       if (bytemode == b_T_mode)
12492 	{
12493 	  if (ins->address_mode != mode_64bit
12494 	      || !((sizeflag & DFLAG) || (ins->rex & REX_W)))
12495 	    {
12496 	      /* The operand-size prefix is overridden by a REX prefix.  */
12497 	      if ((sizeflag & DFLAG) || (ins->rex & REX_W))
12498 		op &= 0xffffffff;
12499 	      else
12500 		op &= 0xffff;
12501 	  }
12502 	}
12503       else
12504 	{
12505 	  if (!(ins->rex & REX_W))
12506 	    {
12507 	      if (sizeflag & DFLAG)
12508 		op &= 0xffffffff;
12509 	      else
12510 		op &= 0xffff;
12511 	    }
12512 	}
12513       break;
12514     case v_mode:
12515       /* The operand-size prefix is overridden by a REX prefix.  */
12516       if (!(sizeflag & DFLAG) && !(ins->rex & REX_W))
12517 	{
12518 	  if (!get16 (ins, &op))
12519 	    return false;
12520 	}
12521       else if (!get32s (ins, &op))
12522 	return false;
12523       break;
12524     default:
12525       oappend (ins, INTERNAL_DISASSEMBLER_ERROR);
12526       return true;
12527     }
12528 
12529   oappend_immediate (ins, op);
12530   return true;
12531 }
12532 
12533 static bool
12534 OP_J (instr_info *ins, int bytemode, int sizeflag)
12535 {
12536   bfd_vma disp;
12537   bfd_vma mask = -1;
12538   bfd_vma segment = 0;
12539 
12540   switch (bytemode)
12541     {
12542     case b_mode:
12543       if (!get8s (ins, &disp))
12544 	return false;
12545       break;
12546     case v_mode:
12547     case dqw_mode:
12548       if ((sizeflag & DFLAG)
12549 	  || (ins->address_mode == mode_64bit
12550 	      && ((ins->isa64 == intel64 && bytemode != dqw_mode)
12551 		  || (ins->rex & REX_W))))
12552 	{
12553 	  if (!get32s (ins, &disp))
12554 	    return false;
12555 	}
12556       else
12557 	{
12558 	  if (!get16s (ins, &disp))
12559 	    return false;
12560 	  /* In 16bit mode, address is wrapped around at 64k within
12561 	     the same segment.  Otherwise, a data16 prefix on a jump
12562 	     instruction means that the pc is masked to 16 bits after
12563 	     the displacement is added!  */
12564 	  mask = 0xffff;
12565 	  if ((ins->prefixes & PREFIX_DATA) == 0)
12566 	    segment = ((ins->start_pc + (ins->codep - ins->start_codep))
12567 		       & ~((bfd_vma) 0xffff));
12568 	}
12569       if (ins->address_mode != mode_64bit
12570 	  || (ins->isa64 != intel64 && !(ins->rex & REX_W)))
12571 	ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12572       break;
12573     default:
12574       oappend (ins, INTERNAL_DISASSEMBLER_ERROR);
12575       return true;
12576     }
12577   disp = ((ins->start_pc + (ins->codep - ins->start_codep) + disp) & mask)
12578 	 | segment;
12579   set_op (ins, disp, false);
12580   print_operand_value (ins, disp, dis_style_text);
12581   return true;
12582 }
12583 
12584 static bool
12585 OP_SEG (instr_info *ins, int bytemode, int sizeflag)
12586 {
12587   if (bytemode == w_mode)
12588     {
12589       oappend_register (ins, att_names_seg[ins->modrm.reg]);
12590       return true;
12591     }
12592   return OP_E (ins, ins->modrm.mod == 3 ? bytemode : w_mode, sizeflag);
12593 }
12594 
12595 static bool
12596 OP_DIR (instr_info *ins, int dummy ATTRIBUTE_UNUSED, int sizeflag)
12597 {
12598   bfd_vma seg, offset;
12599   int res;
12600   char scratch[24];
12601 
12602   if (sizeflag & DFLAG)
12603     {
12604       if (!get32 (ins, &offset))
12605 	return false;;
12606     }
12607   else if (!get16 (ins, &offset))
12608     return false;
12609   if (!get16 (ins, &seg))
12610     return false;;
12611   ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12612 
12613   res = snprintf (scratch, ARRAY_SIZE (scratch),
12614 		  ins->intel_syntax ? "0x%x:0x%x" : "$0x%x,$0x%x",
12615 		  (unsigned) seg, (unsigned) offset);
12616   if (res < 0 || (size_t) res >= ARRAY_SIZE (scratch))
12617     abort ();
12618   oappend (ins, scratch);
12619   return true;
12620 }
12621 
12622 static bool
12623 OP_OFF (instr_info *ins, int bytemode, int sizeflag)
12624 {
12625   bfd_vma off;
12626 
12627   if (ins->intel_syntax && (sizeflag & SUFFIX_ALWAYS))
12628     intel_operand_size (ins, bytemode, sizeflag);
12629   append_seg (ins);
12630 
12631   if ((sizeflag & AFLAG) || ins->address_mode == mode_64bit)
12632     {
12633       if (!get32 (ins, &off))
12634 	return false;
12635     }
12636   else
12637     {
12638       if (!get16 (ins, &off))
12639 	return false;
12640     }
12641 
12642   if (ins->intel_syntax)
12643     {
12644       if (!ins->active_seg_prefix)
12645 	{
12646 	  oappend_register (ins, att_names_seg[ds_reg - es_reg]);
12647 	  oappend (ins, ":");
12648 	}
12649     }
12650   print_operand_value (ins, off, dis_style_address_offset);
12651   return true;
12652 }
12653 
12654 static bool
12655 OP_OFF64 (instr_info *ins, int bytemode, int sizeflag)
12656 {
12657   uint64_t off;
12658 
12659   if (ins->address_mode != mode_64bit
12660       || (ins->prefixes & PREFIX_ADDR))
12661     return OP_OFF (ins, bytemode, sizeflag);
12662 
12663   if (ins->intel_syntax && (sizeflag & SUFFIX_ALWAYS))
12664     intel_operand_size (ins, bytemode, sizeflag);
12665   append_seg (ins);
12666 
12667   if (!get64 (ins, &off))
12668     return false;
12669 
12670   if (ins->intel_syntax)
12671     {
12672       if (!ins->active_seg_prefix)
12673 	{
12674 	  oappend_register (ins, att_names_seg[ds_reg - es_reg]);
12675 	  oappend (ins, ":");
12676 	}
12677     }
12678   print_operand_value (ins, off, dis_style_address_offset);
12679   return true;
12680 }
12681 
12682 static void
12683 ptr_reg (instr_info *ins, int code, int sizeflag)
12684 {
12685   const char *s;
12686 
12687   *ins->obufp++ = ins->open_char;
12688   ins->used_prefixes |= (ins->prefixes & PREFIX_ADDR);
12689   if (ins->address_mode == mode_64bit)
12690     {
12691       if (!(sizeflag & AFLAG))
12692 	s = att_names32[code - eAX_reg];
12693       else
12694 	s = att_names64[code - eAX_reg];
12695     }
12696   else if (sizeflag & AFLAG)
12697     s = att_names32[code - eAX_reg];
12698   else
12699     s = att_names16[code - eAX_reg];
12700   oappend_register (ins, s);
12701   oappend_char (ins, ins->close_char);
12702 }
12703 
12704 static bool
12705 OP_ESreg (instr_info *ins, int code, int sizeflag)
12706 {
12707   if (ins->intel_syntax)
12708     {
12709       switch (ins->codep[-1])
12710 	{
12711 	case 0x6d:	/* insw/insl */
12712 	  intel_operand_size (ins, z_mode, sizeflag);
12713 	  break;
12714 	case 0xa5:	/* movsw/movsl/movsq */
12715 	case 0xa7:	/* cmpsw/cmpsl/cmpsq */
12716 	case 0xab:	/* stosw/stosl */
12717 	case 0xaf:	/* scasw/scasl */
12718 	  intel_operand_size (ins, v_mode, sizeflag);
12719 	  break;
12720 	default:
12721 	  intel_operand_size (ins, b_mode, sizeflag);
12722 	}
12723     }
12724   oappend_register (ins, att_names_seg[0]);
12725   oappend_char (ins, ':');
12726   ptr_reg (ins, code, sizeflag);
12727   return true;
12728 }
12729 
12730 static bool
12731 OP_DSreg (instr_info *ins, int code, int sizeflag)
12732 {
12733   if (ins->intel_syntax)
12734     {
12735       switch (ins->codep[-1])
12736 	{
12737 	case 0x6f:	/* outsw/outsl */
12738 	  intel_operand_size (ins, z_mode, sizeflag);
12739 	  break;
12740 	case 0xa5:	/* movsw/movsl/movsq */
12741 	case 0xa7:	/* cmpsw/cmpsl/cmpsq */
12742 	case 0xad:	/* lodsw/lodsl/lodsq */
12743 	  intel_operand_size (ins, v_mode, sizeflag);
12744 	  break;
12745 	default:
12746 	  intel_operand_size (ins, b_mode, sizeflag);
12747 	}
12748     }
12749   /* Set ins->active_seg_prefix to PREFIX_DS if it is unset so that the
12750      default segment register DS is printed.  */
12751   if (!ins->active_seg_prefix)
12752     ins->active_seg_prefix = PREFIX_DS;
12753   append_seg (ins);
12754   ptr_reg (ins, code, sizeflag);
12755   return true;
12756 }
12757 
12758 static bool
12759 OP_C (instr_info *ins, int dummy ATTRIBUTE_UNUSED,
12760       int sizeflag ATTRIBUTE_UNUSED)
12761 {
12762   int add, res;
12763   char scratch[8];
12764 
12765   if (ins->rex & REX_R)
12766     {
12767       USED_REX (REX_R);
12768       add = 8;
12769     }
12770   else if (ins->address_mode != mode_64bit && (ins->prefixes & PREFIX_LOCK))
12771     {
12772       ins->all_prefixes[ins->last_lock_prefix] = 0;
12773       ins->used_prefixes |= PREFIX_LOCK;
12774       add = 8;
12775     }
12776   else
12777     add = 0;
12778   res = snprintf (scratch, ARRAY_SIZE (scratch), "%%cr%d",
12779 		  ins->modrm.reg + add);
12780   if (res < 0 || (size_t) res >= ARRAY_SIZE (scratch))
12781     abort ();
12782   oappend_register (ins, scratch);
12783   return true;
12784 }
12785 
12786 static bool
12787 OP_D (instr_info *ins, int dummy ATTRIBUTE_UNUSED,
12788       int sizeflag ATTRIBUTE_UNUSED)
12789 {
12790   int add, res;
12791   char scratch[8];
12792 
12793   USED_REX (REX_R);
12794   if (ins->rex & REX_R)
12795     add = 8;
12796   else
12797     add = 0;
12798   res = snprintf (scratch, ARRAY_SIZE (scratch),
12799 		  ins->intel_syntax ? "dr%d" : "%%db%d",
12800 		  ins->modrm.reg + add);
12801   if (res < 0 || (size_t) res >= ARRAY_SIZE (scratch))
12802     abort ();
12803   oappend (ins, scratch);
12804   return true;
12805 }
12806 
12807 static bool
12808 OP_T (instr_info *ins, int dummy ATTRIBUTE_UNUSED,
12809       int sizeflag ATTRIBUTE_UNUSED)
12810 {
12811   int res;
12812   char scratch[8];
12813 
12814   res = snprintf (scratch, ARRAY_SIZE (scratch), "%%tr%d", ins->modrm.reg);
12815   if (res < 0 || (size_t) res >= ARRAY_SIZE (scratch))
12816     abort ();
12817   oappend_register (ins, scratch);
12818   return true;
12819 }
12820 
12821 static bool
12822 OP_MMX (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
12823 	int sizeflag ATTRIBUTE_UNUSED)
12824 {
12825   int reg = ins->modrm.reg;
12826   const char (*names)[8];
12827 
12828   ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12829   if (ins->prefixes & PREFIX_DATA)
12830     {
12831       names = att_names_xmm;
12832       USED_REX (REX_R);
12833       if (ins->rex & REX_R)
12834 	reg += 8;
12835     }
12836   else
12837     names = att_names_mm;
12838   oappend_register (ins, names[reg]);
12839   return true;
12840 }
12841 
12842 static void
12843 print_vector_reg (instr_info *ins, unsigned int reg, int bytemode)
12844 {
12845   const char (*names)[8];
12846 
12847   if (bytemode == xmmq_mode
12848       || bytemode == evex_half_bcst_xmmqh_mode
12849       || bytemode == evex_half_bcst_xmmq_mode)
12850     {
12851       switch (ins->vex.length)
12852 	{
12853 	case 0:
12854 	case 128:
12855 	case 256:
12856 	  names = att_names_xmm;
12857 	  break;
12858 	case 512:
12859 	  names = att_names_ymm;
12860 	  ins->evex_used |= EVEX_len_used;
12861 	  break;
12862 	default:
12863 	  abort ();
12864 	}
12865     }
12866   else if (bytemode == ymm_mode)
12867     names = att_names_ymm;
12868   else if (bytemode == tmm_mode)
12869     {
12870       if (reg >= 8)
12871 	{
12872 	  oappend (ins, "(bad)");
12873 	  return;
12874 	}
12875       names = att_names_tmm;
12876     }
12877   else if (ins->need_vex
12878 	   && bytemode != xmm_mode
12879 	   && bytemode != scalar_mode
12880 	   && bytemode != xmmdw_mode
12881 	   && bytemode != xmmqd_mode
12882 	   && bytemode != evex_half_bcst_xmmqdh_mode
12883 	   && bytemode != w_swap_mode
12884 	   && bytemode != b_mode
12885 	   && bytemode != w_mode
12886 	   && bytemode != d_mode
12887 	   && bytemode != q_mode)
12888     {
12889       ins->evex_used |= EVEX_len_used;
12890       switch (ins->vex.length)
12891 	{
12892 	case 128:
12893 	  names = att_names_xmm;
12894 	  break;
12895 	case 256:
12896 	  if (ins->vex.w
12897 	      || bytemode != vex_vsib_q_w_dq_mode)
12898 	    names = att_names_ymm;
12899 	  else
12900 	    names = att_names_xmm;
12901 	  break;
12902 	case 512:
12903 	  if (ins->vex.w
12904 	      || bytemode != vex_vsib_q_w_dq_mode)
12905 	    names = att_names_zmm;
12906 	  else
12907 	    names = att_names_ymm;
12908 	  break;
12909 	default:
12910 	  abort ();
12911 	}
12912     }
12913   else
12914     names = att_names_xmm;
12915   oappend_register (ins, names[reg]);
12916 }
12917 
12918 static bool
12919 OP_XMM (instr_info *ins, int bytemode, int sizeflag ATTRIBUTE_UNUSED)
12920 {
12921   unsigned int reg = ins->modrm.reg;
12922 
12923   USED_REX (REX_R);
12924   if (ins->rex & REX_R)
12925     reg += 8;
12926   if (ins->vex.evex)
12927     {
12928       if (ins->rex2 & REX_R)
12929 	reg += 16;
12930     }
12931 
12932   if (bytemode == tmm_mode)
12933     ins->modrm.reg = reg;
12934   else if (bytemode == scalar_mode)
12935     ins->vex.no_broadcast = true;
12936 
12937   print_vector_reg (ins, reg, bytemode);
12938   return true;
12939 }
12940 
12941 static bool
12942 OP_EM (instr_info *ins, int bytemode, int sizeflag)
12943 {
12944   int reg;
12945   const char (*names)[8];
12946 
12947   if (ins->modrm.mod != 3)
12948     {
12949       if (ins->intel_syntax
12950 	  && (bytemode == v_mode || bytemode == v_swap_mode))
12951 	{
12952 	  bytemode = (ins->prefixes & PREFIX_DATA) ? x_mode : q_mode;
12953 	  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12954 	}
12955       return OP_E (ins, bytemode, sizeflag);
12956     }
12957 
12958   if ((sizeflag & SUFFIX_ALWAYS) && bytemode == v_swap_mode)
12959     swap_operand (ins);
12960 
12961   /* Skip mod/rm byte.  */
12962   MODRM_CHECK;
12963   ins->codep++;
12964   ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12965   reg = ins->modrm.rm;
12966   if (ins->prefixes & PREFIX_DATA)
12967     {
12968       names = att_names_xmm;
12969       USED_REX (REX_B);
12970       if (ins->rex & REX_B)
12971 	reg += 8;
12972     }
12973   else
12974     names = att_names_mm;
12975   oappend_register (ins, names[reg]);
12976   return true;
12977 }
12978 
12979 /* cvt* are the only instructions in sse2 which have
12980    both SSE and MMX operands and also have 0x66 prefix
12981    in their opcode. 0x66 was originally used to differentiate
12982    between SSE and MMX instruction(operands). So we have to handle the
12983    cvt* separately using OP_EMC and OP_MXC */
12984 static bool
12985 OP_EMC (instr_info *ins, int bytemode, int sizeflag)
12986 {
12987   if (ins->modrm.mod != 3)
12988     {
12989       if (ins->intel_syntax && bytemode == v_mode)
12990 	{
12991 	  bytemode = (ins->prefixes & PREFIX_DATA) ? x_mode : q_mode;
12992 	  ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
12993 	}
12994       return OP_E (ins, bytemode, sizeflag);
12995     }
12996 
12997   /* Skip mod/rm byte.  */
12998   MODRM_CHECK;
12999   ins->codep++;
13000   ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
13001   oappend_register (ins, att_names_mm[ins->modrm.rm]);
13002   return true;
13003 }
13004 
13005 static bool
13006 OP_MXC (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13007 	int sizeflag ATTRIBUTE_UNUSED)
13008 {
13009   ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
13010   oappend_register (ins, att_names_mm[ins->modrm.reg]);
13011   return true;
13012 }
13013 
13014 static bool
13015 OP_EX (instr_info *ins, int bytemode, int sizeflag)
13016 {
13017   int reg;
13018 
13019   /* Skip mod/rm byte.  */
13020   MODRM_CHECK;
13021   ins->codep++;
13022 
13023   if (bytemode == dq_mode)
13024     bytemode = ins->vex.w ? q_mode : d_mode;
13025 
13026   if (ins->modrm.mod != 3)
13027     return OP_E_memory (ins, bytemode, sizeflag);
13028 
13029   reg = ins->modrm.rm;
13030   USED_REX (REX_B);
13031   if (ins->rex & REX_B)
13032     reg += 8;
13033   if (ins->rex2 & REX_B)
13034     reg += 16;
13035   if (ins->vex.evex)
13036     {
13037       USED_REX (REX_X);
13038       if ((ins->rex & REX_X))
13039 	reg += 16;
13040     }
13041 
13042   if ((sizeflag & SUFFIX_ALWAYS)
13043       && (bytemode == x_swap_mode
13044 	  || bytemode == w_swap_mode
13045 	  || bytemode == d_swap_mode
13046 	  || bytemode == q_swap_mode))
13047     swap_operand (ins);
13048 
13049   if (bytemode == tmm_mode)
13050     ins->modrm.rm = reg;
13051 
13052   print_vector_reg (ins, reg, bytemode);
13053   return true;
13054 }
13055 
13056 static bool
13057 OP_R (instr_info *ins, int bytemode, int sizeflag)
13058 {
13059   if (ins->modrm.mod != 3)
13060     return BadOp (ins);
13061 
13062   switch (bytemode)
13063     {
13064     case d_mode:
13065     case dq_mode:
13066     case q_mode:
13067     case mask_mode:
13068       return OP_E (ins, bytemode, sizeflag);
13069     case q_mm_mode:
13070       return OP_EM (ins, x_mode, sizeflag);
13071     case xmm_mode:
13072       if (ins->vex.length <= 128)
13073 	break;
13074       return BadOp (ins);
13075     }
13076 
13077   return OP_EX (ins, bytemode, sizeflag);
13078 }
13079 
13080 static bool
13081 OP_M (instr_info *ins, int bytemode, int sizeflag)
13082 {
13083   /* Skip mod/rm byte.  */
13084   MODRM_CHECK;
13085   ins->codep++;
13086 
13087   if (ins->modrm.mod == 3)
13088     /* bad bound,lea,lds,les,lfs,lgs,lss,cmpxchg8b,vmptrst modrm */
13089     return BadOp (ins);
13090 
13091   if (bytemode == x_mode)
13092     ins->vex.no_broadcast = true;
13093 
13094   return OP_E_memory (ins, bytemode, sizeflag);
13095 }
13096 
13097 static bool
13098 OP_0f07 (instr_info *ins, int bytemode, int sizeflag)
13099 {
13100   if (ins->modrm.mod != 3 || ins->modrm.rm != 0)
13101     return BadOp (ins);
13102   return OP_E (ins, bytemode, sizeflag);
13103 }
13104 
13105 /* NOP is an alias of "xchg %ax,%ax" in 16bit mode, "xchg %eax,%eax" in
13106    32bit mode and "xchg %rax,%rax" in 64bit mode.  */
13107 
13108 static bool
13109 NOP_Fixup (instr_info *ins, int opnd, int sizeflag)
13110 {
13111   if ((ins->prefixes & PREFIX_DATA) == 0 && (ins->rex & REX_B) == 0)
13112     {
13113       ins->mnemonicendp = stpcpy (ins->obuf, "nop");
13114       return true;
13115     }
13116   if (opnd == 0)
13117     return OP_REG (ins, eAX_reg, sizeflag);
13118   return OP_IMREG (ins, eAX_reg, sizeflag);
13119 }
13120 
13121 static const char *const Suffix3DNow[] = {
13122 /* 00 */	NULL,		NULL,		NULL,		NULL,
13123 /* 04 */	NULL,		NULL,		NULL,		NULL,
13124 /* 08 */	NULL,		NULL,		NULL,		NULL,
13125 /* 0C */	"pi2fw",	"pi2fd",	NULL,		NULL,
13126 /* 10 */	NULL,		NULL,		NULL,		NULL,
13127 /* 14 */	NULL,		NULL,		NULL,		NULL,
13128 /* 18 */	NULL,		NULL,		NULL,		NULL,
13129 /* 1C */	"pf2iw",	"pf2id",	NULL,		NULL,
13130 /* 20 */	NULL,		NULL,		NULL,		NULL,
13131 /* 24 */	NULL,		NULL,		NULL,		NULL,
13132 /* 28 */	NULL,		NULL,		NULL,		NULL,
13133 /* 2C */	NULL,		NULL,		NULL,		NULL,
13134 /* 30 */	NULL,		NULL,		NULL,		NULL,
13135 /* 34 */	NULL,		NULL,		NULL,		NULL,
13136 /* 38 */	NULL,		NULL,		NULL,		NULL,
13137 /* 3C */	NULL,		NULL,		NULL,		NULL,
13138 /* 40 */	NULL,		NULL,		NULL,		NULL,
13139 /* 44 */	NULL,		NULL,		NULL,		NULL,
13140 /* 48 */	NULL,		NULL,		NULL,		NULL,
13141 /* 4C */	NULL,		NULL,		NULL,		NULL,
13142 /* 50 */	NULL,		NULL,		NULL,		NULL,
13143 /* 54 */	NULL,		NULL,		NULL,		NULL,
13144 /* 58 */	NULL,		NULL,		NULL,		NULL,
13145 /* 5C */	NULL,		NULL,		NULL,		NULL,
13146 /* 60 */	NULL,		NULL,		NULL,		NULL,
13147 /* 64 */	NULL,		NULL,		NULL,		NULL,
13148 /* 68 */	NULL,		NULL,		NULL,		NULL,
13149 /* 6C */	NULL,		NULL,		NULL,		NULL,
13150 /* 70 */	NULL,		NULL,		NULL,		NULL,
13151 /* 74 */	NULL,		NULL,		NULL,		NULL,
13152 /* 78 */	NULL,		NULL,		NULL,		NULL,
13153 /* 7C */	NULL,		NULL,		NULL,		NULL,
13154 /* 80 */	NULL,		NULL,		NULL,		NULL,
13155 /* 84 */	NULL,		NULL,		NULL,		NULL,
13156 /* 88 */	NULL,		NULL,		"pfnacc",	NULL,
13157 /* 8C */	NULL,		NULL,		"pfpnacc",	NULL,
13158 /* 90 */	"pfcmpge",	NULL,		NULL,		NULL,
13159 /* 94 */	"pfmin",	NULL,		"pfrcp",	"pfrsqrt",
13160 /* 98 */	NULL,		NULL,		"pfsub",	NULL,
13161 /* 9C */	NULL,		NULL,		"pfadd",	NULL,
13162 /* A0 */	"pfcmpgt",	NULL,		NULL,		NULL,
13163 /* A4 */	"pfmax",	NULL,		"pfrcpit1",	"pfrsqit1",
13164 /* A8 */	NULL,		NULL,		"pfsubr",	NULL,
13165 /* AC */	NULL,		NULL,		"pfacc",	NULL,
13166 /* B0 */	"pfcmpeq",	NULL,		NULL,		NULL,
13167 /* B4 */	"pfmul",	NULL,		"pfrcpit2",	"pmulhrw",
13168 /* B8 */	NULL,		NULL,		NULL,		"pswapd",
13169 /* BC */	NULL,		NULL,		NULL,		"pavgusb",
13170 /* C0 */	NULL,		NULL,		NULL,		NULL,
13171 /* C4 */	NULL,		NULL,		NULL,		NULL,
13172 /* C8 */	NULL,		NULL,		NULL,		NULL,
13173 /* CC */	NULL,		NULL,		NULL,		NULL,
13174 /* D0 */	NULL,		NULL,		NULL,		NULL,
13175 /* D4 */	NULL,		NULL,		NULL,		NULL,
13176 /* D8 */	NULL,		NULL,		NULL,		NULL,
13177 /* DC */	NULL,		NULL,		NULL,		NULL,
13178 /* E0 */	NULL,		NULL,		NULL,		NULL,
13179 /* E4 */	NULL,		NULL,		NULL,		NULL,
13180 /* E8 */	NULL,		NULL,		NULL,		NULL,
13181 /* EC */	NULL,		NULL,		NULL,		NULL,
13182 /* F0 */	NULL,		NULL,		NULL,		NULL,
13183 /* F4 */	NULL,		NULL,		NULL,		NULL,
13184 /* F8 */	NULL,		NULL,		NULL,		NULL,
13185 /* FC */	NULL,		NULL,		NULL,		NULL,
13186 };
13187 
13188 static bool
13189 OP_3DNowSuffix (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13190 		int sizeflag ATTRIBUTE_UNUSED)
13191 {
13192   const char *mnemonic;
13193 
13194   if (!fetch_code (ins->info, ins->codep + 1))
13195     return false;
13196   /* AMD 3DNow! instructions are specified by an opcode suffix in the
13197      place where an 8-bit immediate would normally go.  ie. the last
13198      byte of the instruction.  */
13199   ins->obufp = ins->mnemonicendp;
13200   mnemonic = Suffix3DNow[*ins->codep++];
13201   if (mnemonic)
13202     ins->obufp = stpcpy (ins->obufp, mnemonic);
13203   else
13204     {
13205       /* Since a variable sized ins->modrm/ins->sib chunk is between the start
13206 	 of the opcode (0x0f0f) and the opcode suffix, we need to do
13207 	 all the ins->modrm processing first, and don't know until now that
13208 	 we have a bad opcode.  This necessitates some cleaning up.  */
13209       ins->op_out[0][0] = '\0';
13210       ins->op_out[1][0] = '\0';
13211       BadOp (ins);
13212     }
13213   ins->mnemonicendp = ins->obufp;
13214   return true;
13215 }
13216 
13217 static const struct op simd_cmp_op[] =
13218 {
13219   { STRING_COMMA_LEN ("eq") },
13220   { STRING_COMMA_LEN ("lt") },
13221   { STRING_COMMA_LEN ("le") },
13222   { STRING_COMMA_LEN ("unord") },
13223   { STRING_COMMA_LEN ("neq") },
13224   { STRING_COMMA_LEN ("nlt") },
13225   { STRING_COMMA_LEN ("nle") },
13226   { STRING_COMMA_LEN ("ord") }
13227 };
13228 
13229 static const struct op vex_cmp_op[] =
13230 {
13231   { STRING_COMMA_LEN ("eq_uq") },
13232   { STRING_COMMA_LEN ("nge") },
13233   { STRING_COMMA_LEN ("ngt") },
13234   { STRING_COMMA_LEN ("false") },
13235   { STRING_COMMA_LEN ("neq_oq") },
13236   { STRING_COMMA_LEN ("ge") },
13237   { STRING_COMMA_LEN ("gt") },
13238   { STRING_COMMA_LEN ("true") },
13239   { STRING_COMMA_LEN ("eq_os") },
13240   { STRING_COMMA_LEN ("lt_oq") },
13241   { STRING_COMMA_LEN ("le_oq") },
13242   { STRING_COMMA_LEN ("unord_s") },
13243   { STRING_COMMA_LEN ("neq_us") },
13244   { STRING_COMMA_LEN ("nlt_uq") },
13245   { STRING_COMMA_LEN ("nle_uq") },
13246   { STRING_COMMA_LEN ("ord_s") },
13247   { STRING_COMMA_LEN ("eq_us") },
13248   { STRING_COMMA_LEN ("nge_uq") },
13249   { STRING_COMMA_LEN ("ngt_uq") },
13250   { STRING_COMMA_LEN ("false_os") },
13251   { STRING_COMMA_LEN ("neq_os") },
13252   { STRING_COMMA_LEN ("ge_oq") },
13253   { STRING_COMMA_LEN ("gt_oq") },
13254   { STRING_COMMA_LEN ("true_us") },
13255 };
13256 
13257 static bool
13258 CMP_Fixup (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13259 	   int sizeflag ATTRIBUTE_UNUSED)
13260 {
13261   unsigned int cmp_type;
13262 
13263   if (!fetch_code (ins->info, ins->codep + 1))
13264     return false;
13265   cmp_type = *ins->codep++;
13266   if (cmp_type < ARRAY_SIZE (simd_cmp_op))
13267     {
13268       char suffix[3];
13269       char *p = ins->mnemonicendp - 2;
13270       suffix[0] = p[0];
13271       suffix[1] = p[1];
13272       suffix[2] = '\0';
13273       sprintf (p, "%s%s", simd_cmp_op[cmp_type].name, suffix);
13274       ins->mnemonicendp += simd_cmp_op[cmp_type].len;
13275     }
13276   else if (ins->need_vex
13277 	   && cmp_type < ARRAY_SIZE (simd_cmp_op) + ARRAY_SIZE (vex_cmp_op))
13278     {
13279       char suffix[3];
13280       char *p = ins->mnemonicendp - 2;
13281       suffix[0] = p[0];
13282       suffix[1] = p[1];
13283       suffix[2] = '\0';
13284       cmp_type -= ARRAY_SIZE (simd_cmp_op);
13285       sprintf (p, "%s%s", vex_cmp_op[cmp_type].name, suffix);
13286       ins->mnemonicendp += vex_cmp_op[cmp_type].len;
13287     }
13288   else
13289     {
13290       /* We have a reserved extension byte.  Output it directly.  */
13291       oappend_immediate (ins, cmp_type);
13292     }
13293   return true;
13294 }
13295 
13296 static bool
13297 OP_Mwait (instr_info *ins, int bytemode, int sizeflag ATTRIBUTE_UNUSED)
13298 {
13299   /* mwait %eax,%ecx / mwaitx %eax,%ecx,%ebx  */
13300   if (!ins->intel_syntax)
13301     {
13302       strcpy (ins->op_out[0], att_names32[0] + ins->intel_syntax);
13303       strcpy (ins->op_out[1], att_names32[1] + ins->intel_syntax);
13304       if (bytemode == eBX_reg)
13305 	strcpy (ins->op_out[2], att_names32[3] + ins->intel_syntax);
13306       ins->two_source_ops = true;
13307     }
13308   /* Skip mod/rm byte.  */
13309   MODRM_CHECK;
13310   ins->codep++;
13311   return true;
13312 }
13313 
13314 static bool
13315 OP_Monitor (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13316 	    int sizeflag ATTRIBUTE_UNUSED)
13317 {
13318   /* monitor %{e,r,}ax,%ecx,%edx"  */
13319   if (!ins->intel_syntax)
13320     {
13321       const char (*names)[8] = (ins->address_mode == mode_64bit
13322 				? att_names64 : att_names32);
13323 
13324       if (ins->prefixes & PREFIX_ADDR)
13325 	{
13326 	  /* Remove "addr16/addr32".  */
13327 	  ins->all_prefixes[ins->last_addr_prefix] = 0;
13328 	  names = (ins->address_mode != mode_32bit
13329 		   ? att_names32 : att_names16);
13330 	  ins->used_prefixes |= PREFIX_ADDR;
13331 	}
13332       else if (ins->address_mode == mode_16bit)
13333 	names = att_names16;
13334       strcpy (ins->op_out[0], names[0] + ins->intel_syntax);
13335       strcpy (ins->op_out[1], att_names32[1] + ins->intel_syntax);
13336       strcpy (ins->op_out[2], att_names32[2] + ins->intel_syntax);
13337       ins->two_source_ops = true;
13338     }
13339   /* Skip mod/rm byte.  */
13340   MODRM_CHECK;
13341   ins->codep++;
13342   return true;
13343 }
13344 
13345 static bool
13346 REP_Fixup (instr_info *ins, int bytemode, int sizeflag)
13347 {
13348   /* The 0xf3 prefix should be displayed as "rep" for ins, outs, movs,
13349      lods and stos.  */
13350   if (ins->prefixes & PREFIX_REPZ)
13351     ins->all_prefixes[ins->last_repz_prefix] = REP_PREFIX;
13352 
13353   switch (bytemode)
13354     {
13355     case al_reg:
13356     case eAX_reg:
13357     case indir_dx_reg:
13358       return OP_IMREG (ins, bytemode, sizeflag);
13359     case eDI_reg:
13360       return OP_ESreg (ins, bytemode, sizeflag);
13361     case eSI_reg:
13362       return OP_DSreg (ins, bytemode, sizeflag);
13363     default:
13364       abort ();
13365       break;
13366     }
13367   return true;
13368 }
13369 
13370 static bool
13371 SEP_Fixup (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13372 	   int sizeflag ATTRIBUTE_UNUSED)
13373 {
13374   if (ins->isa64 != amd64)
13375     return true;
13376 
13377   ins->obufp = ins->obuf;
13378   BadOp (ins);
13379   ins->mnemonicendp = ins->obufp;
13380   ++ins->codep;
13381   return true;
13382 }
13383 
13384 /* For BND-prefixed instructions 0xF2 prefix should be displayed as
13385    "bnd".  */
13386 
13387 static bool
13388 BND_Fixup (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13389 	   int sizeflag ATTRIBUTE_UNUSED)
13390 {
13391   if (ins->prefixes & PREFIX_REPNZ)
13392     ins->all_prefixes[ins->last_repnz_prefix] = BND_PREFIX;
13393   return true;
13394 }
13395 
13396 /* For NOTRACK-prefixed instructions, 0x3E prefix should be displayed as
13397    "notrack".  */
13398 
13399 static bool
13400 NOTRACK_Fixup (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13401 	       int sizeflag ATTRIBUTE_UNUSED)
13402 {
13403   /* Since active_seg_prefix is not set in 64-bit mode, check whether
13404      we've seen a PREFIX_DS.  */
13405   if ((ins->prefixes & PREFIX_DS) != 0
13406       && (ins->address_mode != mode_64bit || ins->last_data_prefix < 0))
13407     {
13408       /* NOTRACK prefix is only valid on indirect branch instructions.
13409 	 NB: DATA prefix is unsupported for Intel64.  */
13410       ins->active_seg_prefix = 0;
13411       ins->all_prefixes[ins->last_seg_prefix] = NOTRACK_PREFIX;
13412     }
13413   return true;
13414 }
13415 
13416 /* Similar to OP_E.  But the 0xf2/0xf3 ins->prefixes should be displayed as
13417    "xacquire"/"xrelease" for memory operand if there is a LOCK prefix.
13418  */
13419 
13420 static bool
13421 HLE_Fixup1 (instr_info *ins, int bytemode, int sizeflag)
13422 {
13423   if (ins->modrm.mod != 3
13424       && (ins->prefixes & PREFIX_LOCK) != 0)
13425     {
13426       if (ins->prefixes & PREFIX_REPZ)
13427 	ins->all_prefixes[ins->last_repz_prefix] = XRELEASE_PREFIX;
13428       if (ins->prefixes & PREFIX_REPNZ)
13429 	ins->all_prefixes[ins->last_repnz_prefix] = XACQUIRE_PREFIX;
13430     }
13431 
13432   return OP_E (ins, bytemode, sizeflag);
13433 }
13434 
13435 /* Similar to OP_E.  But the 0xf2/0xf3 ins->prefixes should be displayed as
13436    "xacquire"/"xrelease" for memory operand.  No check for LOCK prefix.
13437  */
13438 
13439 static bool
13440 HLE_Fixup2 (instr_info *ins, int bytemode, int sizeflag)
13441 {
13442   if (ins->modrm.mod != 3)
13443     {
13444       if (ins->prefixes & PREFIX_REPZ)
13445 	ins->all_prefixes[ins->last_repz_prefix] = XRELEASE_PREFIX;
13446       if (ins->prefixes & PREFIX_REPNZ)
13447 	ins->all_prefixes[ins->last_repnz_prefix] = XACQUIRE_PREFIX;
13448     }
13449 
13450   return OP_E (ins, bytemode, sizeflag);
13451 }
13452 
13453 /* Similar to OP_E.  But the 0xf3 prefixes should be displayed as
13454    "xrelease" for memory operand.  No check for LOCK prefix.   */
13455 
13456 static bool
13457 HLE_Fixup3 (instr_info *ins, int bytemode, int sizeflag)
13458 {
13459   if (ins->modrm.mod != 3
13460       && ins->last_repz_prefix > ins->last_repnz_prefix
13461       && (ins->prefixes & PREFIX_REPZ) != 0)
13462     ins->all_prefixes[ins->last_repz_prefix] = XRELEASE_PREFIX;
13463 
13464   return OP_E (ins, bytemode, sizeflag);
13465 }
13466 
13467 static bool
13468 CMPXCHG8B_Fixup (instr_info *ins, int bytemode, int sizeflag)
13469 {
13470   USED_REX (REX_W);
13471   if (ins->rex & REX_W)
13472     {
13473       /* Change cmpxchg8b to cmpxchg16b.  */
13474       char *p = ins->mnemonicendp - 2;
13475       ins->mnemonicendp = stpcpy (p, "16b");
13476       bytemode = o_mode;
13477     }
13478   else if ((ins->prefixes & PREFIX_LOCK) != 0)
13479     {
13480       if (ins->prefixes & PREFIX_REPZ)
13481 	ins->all_prefixes[ins->last_repz_prefix] = XRELEASE_PREFIX;
13482       if (ins->prefixes & PREFIX_REPNZ)
13483 	ins->all_prefixes[ins->last_repnz_prefix] = XACQUIRE_PREFIX;
13484     }
13485 
13486   return OP_M (ins, bytemode, sizeflag);
13487 }
13488 
13489 static bool
13490 XMM_Fixup (instr_info *ins, int reg, int sizeflag ATTRIBUTE_UNUSED)
13491 {
13492   const char (*names)[8] = att_names_xmm;
13493 
13494   if (ins->need_vex)
13495     {
13496       switch (ins->vex.length)
13497 	{
13498 	case 128:
13499 	  break;
13500 	case 256:
13501 	  names = att_names_ymm;
13502 	  break;
13503 	default:
13504 	  abort ();
13505 	}
13506     }
13507   oappend_register (ins, names[reg]);
13508   return true;
13509 }
13510 
13511 static bool
13512 FXSAVE_Fixup (instr_info *ins, int bytemode, int sizeflag)
13513 {
13514   /* Add proper suffix to "fxsave" and "fxrstor".  */
13515   USED_REX (REX_W);
13516   if (ins->rex & REX_W)
13517     {
13518       char *p = ins->mnemonicendp;
13519       *p++ = '6';
13520       *p++ = '4';
13521       *p = '\0';
13522       ins->mnemonicendp = p;
13523     }
13524   return OP_M (ins, bytemode, sizeflag);
13525 }
13526 
13527 /* Display the destination register operand for instructions with
13528    VEX. */
13529 
13530 static bool
13531 OP_VEX (instr_info *ins, int bytemode, int sizeflag ATTRIBUTE_UNUSED)
13532 {
13533   int reg, modrm_reg, sib_index = -1;
13534   const char (*names)[8];
13535 
13536   if (!ins->need_vex)
13537     return true;
13538 
13539   if (ins->evex_type == evex_from_legacy)
13540     {
13541       ins->evex_used |= EVEX_b_used;
13542       if (!ins->vex.nd)
13543 	return true;
13544     }
13545 
13546   reg = ins->vex.register_specifier;
13547   ins->vex.register_specifier = 0;
13548   if (ins->address_mode != mode_64bit)
13549     {
13550       if (ins->vex.evex && !ins->vex.v)
13551 	{
13552 	  oappend (ins, "(bad)");
13553 	  return true;
13554 	}
13555 
13556       reg &= 7;
13557     }
13558   else if (ins->vex.evex && !ins->vex.v)
13559     reg += 16;
13560 
13561   switch (bytemode)
13562     {
13563     case scalar_mode:
13564       oappend_register (ins, att_names_xmm[reg]);
13565       return true;
13566 
13567     case vex_vsib_d_w_dq_mode:
13568     case vex_vsib_q_w_dq_mode:
13569       /* This must be the 3rd operand.  */
13570       if (ins->obufp != ins->op_out[2])
13571 	abort ();
13572       if (ins->vex.length == 128
13573 	  || (bytemode != vex_vsib_d_w_dq_mode
13574 	      && !ins->vex.w))
13575 	oappend_register (ins, att_names_xmm[reg]);
13576       else
13577 	oappend_register (ins, att_names_ymm[reg]);
13578 
13579       /* All 3 XMM/YMM registers must be distinct.  */
13580       modrm_reg = ins->modrm.reg;
13581       if (ins->rex & REX_R)
13582 	modrm_reg += 8;
13583 
13584       if (ins->has_sib && ins->modrm.rm == 4)
13585 	{
13586 	  sib_index = ins->sib.index;
13587 	  if (ins->rex & REX_X)
13588 	    sib_index += 8;
13589 	}
13590 
13591       if (reg == modrm_reg || reg == sib_index)
13592 	strcpy (ins->obufp, "/(bad)");
13593       if (modrm_reg == sib_index || modrm_reg == reg)
13594 	strcat (ins->op_out[0], "/(bad)");
13595       if (sib_index == modrm_reg || sib_index == reg)
13596 	strcat (ins->op_out[1], "/(bad)");
13597 
13598       return true;
13599 
13600     case tmm_mode:
13601       /* All 3 TMM registers must be distinct.  */
13602       if (reg >= 8)
13603 	oappend (ins, "(bad)");
13604       else
13605 	{
13606 	  /* This must be the 3rd operand.  */
13607 	  if (ins->obufp != ins->op_out[2])
13608 	    abort ();
13609 	  oappend_register (ins, att_names_tmm[reg]);
13610 	  if (reg == ins->modrm.reg || reg == ins->modrm.rm)
13611 	    strcpy (ins->obufp, "/(bad)");
13612 	}
13613 
13614       if (ins->modrm.reg == ins->modrm.rm || ins->modrm.reg == reg
13615 	  || ins->modrm.rm == reg)
13616 	{
13617 	  if (ins->modrm.reg <= 8
13618 	      && (ins->modrm.reg == ins->modrm.rm || ins->modrm.reg == reg))
13619 	    strcat (ins->op_out[0], "/(bad)");
13620 	  if (ins->modrm.rm <= 8
13621 	      && (ins->modrm.rm == ins->modrm.reg || ins->modrm.rm == reg))
13622 	    strcat (ins->op_out[1], "/(bad)");
13623 	}
13624 
13625       return true;
13626     }
13627 
13628   switch (ins->vex.length)
13629     {
13630     case 128:
13631       switch (bytemode)
13632 	{
13633 	case x_mode:
13634 	  names = att_names_xmm;
13635 	  ins->evex_used |= EVEX_len_used;
13636 	  break;
13637 	case v_mode:
13638 	case dq_mode:
13639 	  if (ins->rex & REX_W)
13640 	    names = att_names64;
13641 	  else if (bytemode == v_mode
13642 		   && !(sizeflag & DFLAG))
13643 	    names = att_names16;
13644 	  else
13645 	    names = att_names32;
13646 	  break;
13647 	case b_mode:
13648 	  names = att_names8rex;
13649 	  break;
13650 	case q_mode:
13651 	  names = att_names64;
13652 	  break;
13653 	case mask_bd_mode:
13654 	case mask_mode:
13655 	  if (reg > 0x7)
13656 	    {
13657 	      oappend (ins, "(bad)");
13658 	      return true;
13659 	    }
13660 	  names = att_names_mask;
13661 	  break;
13662 	default:
13663 	  abort ();
13664 	  return true;
13665 	}
13666       break;
13667     case 256:
13668       switch (bytemode)
13669 	{
13670 	case x_mode:
13671 	  names = att_names_ymm;
13672 	  ins->evex_used |= EVEX_len_used;
13673 	  break;
13674 	case mask_bd_mode:
13675 	case mask_mode:
13676 	  if (reg <= 0x7)
13677 	    {
13678 	      names = att_names_mask;
13679 	      break;
13680 	    }
13681 	  /* Fall through.  */
13682 	default:
13683 	  /* See PR binutils/20893 for a reproducer.  */
13684 	  oappend (ins, "(bad)");
13685 	  return true;
13686 	}
13687       break;
13688     case 512:
13689       names = att_names_zmm;
13690       ins->evex_used |= EVEX_len_used;
13691       break;
13692     default:
13693       abort ();
13694       break;
13695     }
13696   oappend_register (ins, names[reg]);
13697   return true;
13698 }
13699 
13700 static bool
13701 OP_VexR (instr_info *ins, int bytemode, int sizeflag)
13702 {
13703   if (ins->modrm.mod == 3)
13704     return OP_VEX (ins, bytemode, sizeflag);
13705   return true;
13706 }
13707 
13708 static bool
13709 OP_VexW (instr_info *ins, int bytemode, int sizeflag)
13710 {
13711   OP_VEX (ins, bytemode, sizeflag);
13712 
13713   if (ins->vex.w)
13714     {
13715       /* Swap 2nd and 3rd operands.  */
13716       char *tmp = ins->op_out[2];
13717 
13718       ins->op_out[2] = ins->op_out[1];
13719       ins->op_out[1] = tmp;
13720     }
13721   return true;
13722 }
13723 
13724 static bool
13725 OP_REG_VexI4 (instr_info *ins, int bytemode, int sizeflag ATTRIBUTE_UNUSED)
13726 {
13727   int reg;
13728   const char (*names)[8] = att_names_xmm;
13729 
13730   if (!fetch_code (ins->info, ins->codep + 1))
13731     return false;
13732   reg = *ins->codep++;
13733 
13734   if (bytemode != x_mode && bytemode != scalar_mode)
13735     abort ();
13736 
13737   reg >>= 4;
13738   if (ins->address_mode != mode_64bit)
13739     reg &= 7;
13740 
13741   if (bytemode == x_mode && ins->vex.length == 256)
13742     names = att_names_ymm;
13743 
13744   oappend_register (ins, names[reg]);
13745 
13746   if (ins->vex.w)
13747     {
13748       /* Swap 3rd and 4th operands.  */
13749       char *tmp = ins->op_out[3];
13750 
13751       ins->op_out[3] = ins->op_out[2];
13752       ins->op_out[2] = tmp;
13753     }
13754   return true;
13755 }
13756 
13757 static bool
13758 OP_VexI4 (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13759 	  int sizeflag ATTRIBUTE_UNUSED)
13760 {
13761   oappend_immediate (ins, ins->codep[-1] & 0xf);
13762   return true;
13763 }
13764 
13765 static bool
13766 VPCMP_Fixup (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13767 	     int sizeflag ATTRIBUTE_UNUSED)
13768 {
13769   unsigned int cmp_type;
13770 
13771   if (!ins->vex.evex)
13772     abort ();
13773 
13774   if (!fetch_code (ins->info, ins->codep + 1))
13775     return false;
13776   cmp_type = *ins->codep++;
13777   /* There are aliases for immediates 0, 1, 2, 4, 5, 6.
13778      If it's the case, print suffix, otherwise - print the immediate.  */
13779   if (cmp_type < ARRAY_SIZE (simd_cmp_op)
13780       && cmp_type != 3
13781       && cmp_type != 7)
13782     {
13783       char suffix[3];
13784       char *p = ins->mnemonicendp - 2;
13785 
13786       /* vpcmp* can have both one- and two-lettered suffix.  */
13787       if (p[0] == 'p')
13788 	{
13789 	  p++;
13790 	  suffix[0] = p[0];
13791 	  suffix[1] = '\0';
13792 	}
13793       else
13794 	{
13795 	  suffix[0] = p[0];
13796 	  suffix[1] = p[1];
13797 	  suffix[2] = '\0';
13798 	}
13799 
13800       sprintf (p, "%s%s", simd_cmp_op[cmp_type].name, suffix);
13801       ins->mnemonicendp += simd_cmp_op[cmp_type].len;
13802     }
13803   else
13804     {
13805       /* We have a reserved extension byte.  Output it directly.  */
13806       oappend_immediate (ins, cmp_type);
13807     }
13808   return true;
13809 }
13810 
13811 static const struct op xop_cmp_op[] =
13812 {
13813   { STRING_COMMA_LEN ("lt") },
13814   { STRING_COMMA_LEN ("le") },
13815   { STRING_COMMA_LEN ("gt") },
13816   { STRING_COMMA_LEN ("ge") },
13817   { STRING_COMMA_LEN ("eq") },
13818   { STRING_COMMA_LEN ("neq") },
13819   { STRING_COMMA_LEN ("false") },
13820   { STRING_COMMA_LEN ("true") }
13821 };
13822 
13823 static bool
13824 VPCOM_Fixup (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13825 	     int sizeflag ATTRIBUTE_UNUSED)
13826 {
13827   unsigned int cmp_type;
13828 
13829   if (!fetch_code (ins->info, ins->codep + 1))
13830     return false;
13831   cmp_type = *ins->codep++;
13832   if (cmp_type < ARRAY_SIZE (xop_cmp_op))
13833     {
13834       char suffix[3];
13835       char *p = ins->mnemonicendp - 2;
13836 
13837       /* vpcom* can have both one- and two-lettered suffix.  */
13838       if (p[0] == 'm')
13839 	{
13840 	  p++;
13841 	  suffix[0] = p[0];
13842 	  suffix[1] = '\0';
13843 	}
13844       else
13845 	{
13846 	  suffix[0] = p[0];
13847 	  suffix[1] = p[1];
13848 	  suffix[2] = '\0';
13849 	}
13850 
13851       sprintf (p, "%s%s", xop_cmp_op[cmp_type].name, suffix);
13852       ins->mnemonicendp += xop_cmp_op[cmp_type].len;
13853     }
13854   else
13855     {
13856       /* We have a reserved extension byte.  Output it directly.  */
13857       oappend_immediate (ins, cmp_type);
13858     }
13859   return true;
13860 }
13861 
13862 static const struct op pclmul_op[] =
13863 {
13864   { STRING_COMMA_LEN ("lql") },
13865   { STRING_COMMA_LEN ("hql") },
13866   { STRING_COMMA_LEN ("lqh") },
13867   { STRING_COMMA_LEN ("hqh") }
13868 };
13869 
13870 static bool
13871 PCLMUL_Fixup (instr_info *ins, int bytemode ATTRIBUTE_UNUSED,
13872 	      int sizeflag ATTRIBUTE_UNUSED)
13873 {
13874   unsigned int pclmul_type;
13875 
13876   if (!fetch_code (ins->info, ins->codep + 1))
13877     return false;
13878   pclmul_type = *ins->codep++;
13879   switch (pclmul_type)
13880     {
13881     case 0x10:
13882       pclmul_type = 2;
13883       break;
13884     case 0x11:
13885       pclmul_type = 3;
13886       break;
13887     default:
13888       break;
13889     }
13890   if (pclmul_type < ARRAY_SIZE (pclmul_op))
13891     {
13892       char suffix[4];
13893       char *p = ins->mnemonicendp - 3;
13894       suffix[0] = p[0];
13895       suffix[1] = p[1];
13896       suffix[2] = p[2];
13897       suffix[3] = '\0';
13898       sprintf (p, "%s%s", pclmul_op[pclmul_type].name, suffix);
13899       ins->mnemonicendp += pclmul_op[pclmul_type].len;
13900     }
13901   else
13902     {
13903       /* We have a reserved extension byte.  Output it directly.  */
13904       oappend_immediate (ins, pclmul_type);
13905     }
13906   return true;
13907 }
13908 
13909 static bool
13910 MOVSXD_Fixup (instr_info *ins, int bytemode, int sizeflag)
13911 {
13912   /* Add proper suffix to "movsxd".  */
13913   char *p = ins->mnemonicendp;
13914 
13915   switch (bytemode)
13916     {
13917     case movsxd_mode:
13918       if (!ins->intel_syntax)
13919 	{
13920 	  USED_REX (REX_W);
13921 	  if (ins->rex & REX_W)
13922 	    {
13923 	      *p++ = 'l';
13924 	      *p++ = 'q';
13925 	      break;
13926 	    }
13927 	}
13928 
13929       *p++ = 'x';
13930       *p++ = 'd';
13931       break;
13932     default:
13933       oappend (ins, INTERNAL_DISASSEMBLER_ERROR);
13934       break;
13935     }
13936 
13937   ins->mnemonicendp = p;
13938   *p = '\0';
13939   return OP_E (ins, bytemode, sizeflag);
13940 }
13941 
13942 static bool
13943 DistinctDest_Fixup (instr_info *ins, int bytemode, int sizeflag)
13944 {
13945   unsigned int reg = ins->vex.register_specifier;
13946   unsigned int modrm_reg = ins->modrm.reg;
13947   unsigned int modrm_rm = ins->modrm.rm;
13948 
13949   /* Calc destination register number.  */
13950   if (ins->rex & REX_R)
13951     modrm_reg += 8;
13952   if (ins->rex2 & REX_R)
13953     modrm_reg += 16;
13954 
13955   /* Calc src1 register number.  */
13956   if (ins->address_mode != mode_64bit)
13957     reg &= 7;
13958   else if (ins->vex.evex && !ins->vex.v)
13959     reg += 16;
13960 
13961   /* Calc src2 register number.  */
13962   if (ins->modrm.mod == 3)
13963     {
13964       if (ins->rex & REX_B)
13965         modrm_rm += 8;
13966       if (ins->rex & REX_X)
13967         modrm_rm += 16;
13968     }
13969 
13970   /* Destination and source registers must be distinct, output bad if
13971      dest == src1 or dest == src2.  */
13972   if (modrm_reg == reg
13973       || (ins->modrm.mod == 3
13974 	  && modrm_reg == modrm_rm))
13975     {
13976       oappend (ins, "(bad)");
13977       return true;
13978     }
13979   return OP_XMM (ins, bytemode, sizeflag);
13980 }
13981 
13982 static bool
13983 OP_Rounding (instr_info *ins, int bytemode, int sizeflag ATTRIBUTE_UNUSED)
13984 {
13985   if (ins->modrm.mod != 3 || !ins->vex.b)
13986     return true;
13987 
13988   switch (bytemode)
13989     {
13990     case evex_rounding_64_mode:
13991       if (ins->address_mode != mode_64bit || !ins->vex.w)
13992         return true;
13993       /* Fall through.  */
13994     case evex_rounding_mode:
13995       ins->evex_used |= EVEX_b_used;
13996       oappend (ins, names_rounding[ins->vex.ll]);
13997       break;
13998     case evex_sae_mode:
13999       ins->evex_used |= EVEX_b_used;
14000       oappend (ins, "{");
14001       break;
14002     default:
14003       abort ();
14004     }
14005   oappend (ins, "sae}");
14006   return true;
14007 }
14008 
14009 static bool
14010 PREFETCHI_Fixup (instr_info *ins, int bytemode, int sizeflag)
14011 {
14012   if (ins->modrm.mod != 0 || ins->modrm.rm != 5)
14013     {
14014       if (ins->intel_syntax)
14015 	{
14016 	  ins->mnemonicendp = stpcpy (ins->obuf, "nop   ");
14017 	}
14018       else
14019 	{
14020 	  USED_REX (REX_W);
14021 	  if (ins->rex & REX_W)
14022 	    ins->mnemonicendp = stpcpy (ins->obuf, "nopq  ");
14023 	  else
14024 	    {
14025 	      if (sizeflag & DFLAG)
14026 		ins->mnemonicendp = stpcpy (ins->obuf, "nopl  ");
14027 	      else
14028 		ins->mnemonicendp = stpcpy (ins->obuf, "nopw  ");
14029 	      ins->used_prefixes |= (ins->prefixes & PREFIX_DATA);
14030 	    }
14031 	}
14032       bytemode = v_mode;
14033     }
14034 
14035   return OP_M (ins, bytemode, sizeflag);
14036 }
14037 
14038 static bool
14039 PUSH2_POP2_Fixup (instr_info *ins, int bytemode, int sizeflag)
14040 {
14041   if (ins->modrm.mod != 3)
14042     return true;
14043 
14044   unsigned int vvvv_reg = ins->vex.register_specifier
14045     | (!ins->vex.v << 4);
14046   unsigned int rm_reg = ins->modrm.rm + (ins->rex & REX_B ? 8 : 0)
14047     + (ins->rex2 & REX_B ? 16 : 0);
14048 
14049   /* Push2/Pop2 cannot use RSP and Pop2 cannot pop two same registers.  */
14050   if (!ins->vex.nd || vvvv_reg == 0x4 || rm_reg == 0x4
14051       || (!ins->modrm.reg
14052 	  && vvvv_reg == rm_reg))
14053     {
14054       oappend (ins, "(bad)");
14055       return true;
14056     }
14057 
14058   return OP_VEX (ins, bytemode, sizeflag);
14059 }
14060 
14061 static bool
14062 JMPABS_Fixup (instr_info *ins, int bytemode, int sizeflag)
14063 {
14064   if (ins->last_rex2_prefix >= 0)
14065     {
14066       uint64_t op;
14067 
14068       if ((ins->prefixes & (PREFIX_OPCODE | PREFIX_ADDR | PREFIX_LOCK)) != 0x0
14069 	  || (ins->rex & REX_W) != 0x0)
14070 	{
14071 	  oappend (ins, "(bad)");
14072 	  return true;
14073 	}
14074 
14075       if (bytemode == eAX_reg)
14076 	return true;
14077 
14078       if (!get64 (ins, &op))
14079 	return false;
14080 
14081       ins->mnemonicendp = stpcpy (ins->obuf, "jmpabs");
14082       ins->rex2 |= REX2_SPECIAL;
14083       oappend_immediate (ins, op);
14084 
14085       return true;
14086     }
14087 
14088   if (bytemode == eAX_reg)
14089     return OP_IMREG (ins, bytemode, sizeflag);
14090   return OP_OFF64 (ins, bytemode, sizeflag);
14091 }
14092