1 /* Print i386 instructions for GDB, the GNU debugger.
2 Copyright 1988, 1989, 1991, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
3 2001, 2002, 2003, 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
5 This file is part of the GNU opcodes library.
7 This library is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3, or (at your option)
12 It is distributed in the hope that it will be useful, but WITHOUT
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
15 License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20 MA 02110-1301, USA. */
23 /* 80386 instruction printer by Pace Willisson (pace@prep.ai.mit.edu)
25 modified by John Hassey (hassey@dg-rtp.dg.com)
26 x86-64 support added by Jan Hubicka (jh@suse.cz)
27 VIA PadLock support by Michal Ludvig (mludvig@suse.cz). */
29 /* The main tables describing the instructions is essentially a copy
30 of the "Opcode Map" chapter (Appendix A) of the Intel 80386
31 Programmers Manual. Usually, there is a capital letter, followed
32 by a small letter. The capital letter tell the addressing mode,
33 and the small letter tells about the operand size. Refer to
34 the Intel manual for details. */
39 #include "opcode/i386.h"
40 #include "libiberty.h"
44 static int fetch_data (struct disassemble_info
*, bfd_byte
*);
45 static void ckprefix (void);
46 static const char *prefix_name (int, int);
47 static int print_insn (bfd_vma
, disassemble_info
*);
48 static void dofloat (int);
49 static void OP_ST (int, int);
50 static void OP_STi (int, int);
51 static int putop (const char *, int);
52 static void oappend (const char *);
53 static void append_seg (void);
54 static void OP_indirE (int, int);
55 static void print_operand_value (char *, int, bfd_vma
);
56 static void OP_E_extended (int, int, int);
57 static void print_displacement (char *, bfd_vma
);
58 static void OP_E (int, int);
59 static void OP_G (int, int);
60 static bfd_vma
get64 (void);
61 static bfd_signed_vma
get32 (void);
62 static bfd_signed_vma
get32s (void);
63 static int get16 (void);
64 static void set_op (bfd_vma
, int);
65 static void OP_Skip_MODRM (int, int);
66 static void OP_REG (int, int);
67 static void OP_IMREG (int, int);
68 static void OP_I (int, int);
69 static void OP_I64 (int, int);
70 static void OP_sI (int, int);
71 static void OP_J (int, int);
72 static void OP_SEG (int, int);
73 static void OP_DIR (int, int);
74 static void OP_OFF (int, int);
75 static void OP_OFF64 (int, int);
76 static void ptr_reg (int, int);
77 static void OP_ESreg (int, int);
78 static void OP_DSreg (int, int);
79 static void OP_C (int, int);
80 static void OP_D (int, int);
81 static void OP_T (int, int);
82 static void OP_R (int, int);
83 static void OP_MMX (int, int);
84 static void OP_XMM (int, int);
85 static void OP_EM (int, int);
86 static void OP_EX (int, int);
87 static void OP_EMC (int,int);
88 static void OP_MXC (int,int);
89 static void OP_MS (int, int);
90 static void OP_XS (int, int);
91 static void OP_M (int, int);
92 static void OP_0f07 (int, int);
93 static void OP_Monitor (int, int);
94 static void OP_Mwait (int, int);
95 static void NOP_Fixup1 (int, int);
96 static void NOP_Fixup2 (int, int);
97 static void OP_3DNowSuffix (int, int);
98 static void OP_SIMD_Suffix (int, int);
99 static void BadOp (void);
100 static void REP_Fixup (int, int);
101 static void CMPXCHG8B_Fixup (int, int);
102 static void XMM_Fixup (int, int);
103 static void CRC32_Fixup (int, int);
104 static void print_drex_arg (unsigned int, int, int);
105 static void OP_DREX4 (int, int);
106 static void OP_DREX3 (int, int);
107 static void OP_DREX_ICMP (int, int);
108 static void OP_DREX_FCMP (int, int);
111 /* Points to first byte not fetched. */
112 bfd_byte
*max_fetched
;
113 bfd_byte the_buffer
[MAX_MNEM_SIZE
];
126 enum address_mode address_mode
;
128 /* Flags for the prefixes for the current instruction. See below. */
131 /* REX prefix the current instruction. See below. */
133 /* Bits of REX we've already used. */
135 /* Mark parts used in the REX prefix. When we are testing for
136 empty prefix (for 8bit register REX extension), just mask it
137 out. Otherwise test for REX bit is excuse for existence of REX
138 only in case value is nonzero. */
139 #define USED_REX(value) \
144 rex_used |= (value) | REX_OPCODE; \
147 rex_used |= REX_OPCODE; \
150 /* Special 'registers' for DREX handling */
151 #define DREX_REG_UNKNOWN 1000 /* not initialized */
152 #define DREX_REG_MEMORY 1001 /* use MODRM/SIB/OFFSET memory */
154 /* The DREX byte has the following fields:
155 Bits 7-4 -- DREX.Dest, xmm destination register
156 Bit 3 -- DREX.OC0, operand config bit defines operand order
157 Bit 2 -- DREX.R, equivalent to REX_R bit, to extend ModRM register
158 Bit 1 -- DREX.X, equivalent to REX_X bit, to extend SIB index field
159 Bit 0 -- DREX.W, equivalent to REX_B bit, to extend ModRM r/m field,
160 SIB base field, or opcode reg field. */
161 #define DREX_XMM(drex) ((drex >> 4) & 0xf)
162 #define DREX_OC0(drex) ((drex >> 3) & 0x1)
164 /* Flags for prefixes which we somehow handled when printing the
165 current instruction. */
166 static int used_prefixes
;
168 /* Flags stored in PREFIXES. */
169 #define PREFIX_REPZ 1
170 #define PREFIX_REPNZ 2
171 #define PREFIX_LOCK 4
173 #define PREFIX_SS 0x10
174 #define PREFIX_DS 0x20
175 #define PREFIX_ES 0x40
176 #define PREFIX_FS 0x80
177 #define PREFIX_GS 0x100
178 #define PREFIX_DATA 0x200
179 #define PREFIX_ADDR 0x400
180 #define PREFIX_FWAIT 0x800
182 /* Make sure that bytes from INFO->PRIVATE_DATA->BUFFER (inclusive)
183 to ADDR (exclusive) are valid. Returns 1 for success, longjmps
185 #define FETCH_DATA(info, addr) \
186 ((addr) <= ((struct dis_private *) (info->private_data))->max_fetched \
187 ? 1 : fetch_data ((info), (addr)))
190 fetch_data (struct disassemble_info
*info
, bfd_byte
*addr
)
193 struct dis_private
*priv
= (struct dis_private
*) info
->private_data
;
194 bfd_vma start
= priv
->insn_start
+ (priv
->max_fetched
- priv
->the_buffer
);
196 if (addr
<= priv
->the_buffer
+ MAX_MNEM_SIZE
)
197 status
= (*info
->read_memory_func
) (start
,
199 addr
- priv
->max_fetched
,
205 /* If we did manage to read at least one byte, then
206 print_insn_i386 will do something sensible. Otherwise, print
207 an error. We do that here because this is where we know
209 if (priv
->max_fetched
== priv
->the_buffer
)
210 (*info
->memory_error_func
) (status
, start
, info
);
211 longjmp (priv
->bailout
, 1);
214 priv
->max_fetched
= addr
;
218 #define XX { NULL, 0 }
220 #define Eb { OP_E, b_mode }
221 #define Ev { OP_E, v_mode }
222 #define Ed { OP_E, d_mode }
223 #define Edq { OP_E, dq_mode }
224 #define Edqw { OP_E, dqw_mode }
225 #define Edqb { OP_E, dqb_mode }
226 #define Edqd { OP_E, dqd_mode }
227 #define Eq { OP_E, q_mode }
228 #define indirEv { OP_indirE, stack_v_mode }
229 #define indirEp { OP_indirE, f_mode }
230 #define stackEv { OP_E, stack_v_mode }
231 #define Em { OP_E, m_mode }
232 #define Ew { OP_E, w_mode }
233 #define M { OP_M, 0 } /* lea, lgdt, etc. */
234 #define Ma { OP_M, v_mode }
235 #define Mb { OP_M, b_mode }
236 #define Md { OP_M, d_mode }
237 #define Mp { OP_M, f_mode } /* 32 or 48 bit memory operand for LDS, LES etc */
238 #define Mq { OP_M, q_mode }
239 #define Gb { OP_G, b_mode }
240 #define Gv { OP_G, v_mode }
241 #define Gd { OP_G, d_mode }
242 #define Gdq { OP_G, dq_mode }
243 #define Gm { OP_G, m_mode }
244 #define Gw { OP_G, w_mode }
245 #define Rd { OP_R, d_mode }
246 #define Rm { OP_R, m_mode }
247 #define Ib { OP_I, b_mode }
248 #define sIb { OP_sI, b_mode } /* sign extened byte */
249 #define Iv { OP_I, v_mode }
250 #define Iq { OP_I, q_mode }
251 #define Iv64 { OP_I64, v_mode }
252 #define Iw { OP_I, w_mode }
253 #define I1 { OP_I, const_1_mode }
254 #define Jb { OP_J, b_mode }
255 #define Jv { OP_J, v_mode }
256 #define Cm { OP_C, m_mode }
257 #define Dm { OP_D, m_mode }
258 #define Td { OP_T, d_mode }
259 #define Skip_MODRM { OP_Skip_MODRM, 0 }
261 #define RMeAX { OP_REG, eAX_reg }
262 #define RMeBX { OP_REG, eBX_reg }
263 #define RMeCX { OP_REG, eCX_reg }
264 #define RMeDX { OP_REG, eDX_reg }
265 #define RMeSP { OP_REG, eSP_reg }
266 #define RMeBP { OP_REG, eBP_reg }
267 #define RMeSI { OP_REG, eSI_reg }
268 #define RMeDI { OP_REG, eDI_reg }
269 #define RMrAX { OP_REG, rAX_reg }
270 #define RMrBX { OP_REG, rBX_reg }
271 #define RMrCX { OP_REG, rCX_reg }
272 #define RMrDX { OP_REG, rDX_reg }
273 #define RMrSP { OP_REG, rSP_reg }
274 #define RMrBP { OP_REG, rBP_reg }
275 #define RMrSI { OP_REG, rSI_reg }
276 #define RMrDI { OP_REG, rDI_reg }
277 #define RMAL { OP_REG, al_reg }
278 #define RMAL { OP_REG, al_reg }
279 #define RMCL { OP_REG, cl_reg }
280 #define RMDL { OP_REG, dl_reg }
281 #define RMBL { OP_REG, bl_reg }
282 #define RMAH { OP_REG, ah_reg }
283 #define RMCH { OP_REG, ch_reg }
284 #define RMDH { OP_REG, dh_reg }
285 #define RMBH { OP_REG, bh_reg }
286 #define RMAX { OP_REG, ax_reg }
287 #define RMDX { OP_REG, dx_reg }
289 #define eAX { OP_IMREG, eAX_reg }
290 #define eBX { OP_IMREG, eBX_reg }
291 #define eCX { OP_IMREG, eCX_reg }
292 #define eDX { OP_IMREG, eDX_reg }
293 #define eSP { OP_IMREG, eSP_reg }
294 #define eBP { OP_IMREG, eBP_reg }
295 #define eSI { OP_IMREG, eSI_reg }
296 #define eDI { OP_IMREG, eDI_reg }
297 #define AL { OP_IMREG, al_reg }
298 #define CL { OP_IMREG, cl_reg }
299 #define DL { OP_IMREG, dl_reg }
300 #define BL { OP_IMREG, bl_reg }
301 #define AH { OP_IMREG, ah_reg }
302 #define CH { OP_IMREG, ch_reg }
303 #define DH { OP_IMREG, dh_reg }
304 #define BH { OP_IMREG, bh_reg }
305 #define AX { OP_IMREG, ax_reg }
306 #define DX { OP_IMREG, dx_reg }
307 #define zAX { OP_IMREG, z_mode_ax_reg }
308 #define indirDX { OP_IMREG, indir_dx_reg }
310 #define Sw { OP_SEG, w_mode }
311 #define Sv { OP_SEG, v_mode }
312 #define Ap { OP_DIR, 0 }
313 #define Ob { OP_OFF64, b_mode }
314 #define Ov { OP_OFF64, v_mode }
315 #define Xb { OP_DSreg, eSI_reg }
316 #define Xv { OP_DSreg, eSI_reg }
317 #define Xz { OP_DSreg, eSI_reg }
318 #define Yb { OP_ESreg, eDI_reg }
319 #define Yv { OP_ESreg, eDI_reg }
320 #define DSBX { OP_DSreg, eBX_reg }
322 #define es { OP_REG, es_reg }
323 #define ss { OP_REG, ss_reg }
324 #define cs { OP_REG, cs_reg }
325 #define ds { OP_REG, ds_reg }
326 #define fs { OP_REG, fs_reg }
327 #define gs { OP_REG, gs_reg }
329 #define MX { OP_MMX, 0 }
330 #define XM { OP_XMM, 0 }
331 #define EM { OP_EM, v_mode }
332 #define EMd { OP_EM, d_mode }
333 #define EMx { OP_EM, x_mode }
334 #define EXw { OP_EX, w_mode }
335 #define EXd { OP_EX, d_mode }
336 #define EXq { OP_EX, q_mode }
337 #define EXx { OP_EX, x_mode }
338 #define MS { OP_MS, v_mode }
339 #define XS { OP_XS, v_mode }
340 #define EMCq { OP_EMC, q_mode }
341 #define MXC { OP_MXC, 0 }
342 #define OPSUF { OP_3DNowSuffix, 0 }
343 #define OPSIMD { OP_SIMD_Suffix, 0 }
344 #define XMM0 { XMM_Fixup, 0 }
346 /* Used handle "rep" prefix for string instructions. */
347 #define Xbr { REP_Fixup, eSI_reg }
348 #define Xvr { REP_Fixup, eSI_reg }
349 #define Ybr { REP_Fixup, eDI_reg }
350 #define Yvr { REP_Fixup, eDI_reg }
351 #define Yzr { REP_Fixup, eDI_reg }
352 #define indirDXr { REP_Fixup, indir_dx_reg }
353 #define ALr { REP_Fixup, al_reg }
354 #define eAXr { REP_Fixup, eAX_reg }
356 #define cond_jump_flag { NULL, cond_jump_mode }
357 #define loop_jcxz_flag { NULL, loop_jcxz_mode }
359 /* bits in sizeflag */
360 #define SUFFIX_ALWAYS 4
364 #define b_mode 1 /* byte operand */
365 #define v_mode 2 /* operand size depends on prefixes */
366 #define w_mode 3 /* word operand */
367 #define d_mode 4 /* double word operand */
368 #define q_mode 5 /* quad word operand */
369 #define t_mode 6 /* ten-byte operand */
370 #define x_mode 7 /* 16-byte XMM operand */
371 #define m_mode 8 /* d_mode in 32bit, q_mode in 64bit mode. */
372 #define cond_jump_mode 9
373 #define loop_jcxz_mode 10
374 #define dq_mode 11 /* operand size depends on REX prefixes. */
375 #define dqw_mode 12 /* registers like dq_mode, memory like w_mode. */
376 #define f_mode 13 /* 4- or 6-byte pointer operand */
377 #define const_1_mode 14
378 #define stack_v_mode 15 /* v_mode for stack-related opcodes. */
379 #define z_mode 16 /* non-quad operand size depends on prefixes */
380 #define o_mode 17 /* 16-byte operand */
381 #define dqb_mode 18 /* registers like dq_mode, memory like b_mode. */
382 #define dqd_mode 19 /* registers like dq_mode, memory like d_mode. */
384 /* Flags that are OR'ed into the bytemode field to pass extra information. */
385 #define DREX_OC1 0x4000 /* OC1 bit set */
386 #define DREX_NO_OC0 0x2000 /* OC0 bit not used */
387 #define DREX_MASK 0x6000 /* mask to delete */
432 #define z_mode_ax_reg 149
433 #define indir_dx_reg 150
436 #define USE_REG_TABLE 2
437 #define USE_MOD_TABLE 3
438 #define USE_RM_TABLE 4
439 #define USE_PREFIX_TABLE 5
440 #define USE_X86_64_TABLE 6
441 #define USE_3BYTE_TABLE 7
443 #define FLOAT NULL, { { NULL, FLOATCODE } }
445 #define DIS386(T, I) NULL, { { NULL, (T)}, { NULL, (I) } }
446 #define REG_TABLE(I) DIS386 (USE_REG_TABLE, (I))
447 #define MOD_TABLE(I) DIS386 (USE_MOD_TABLE, (I))
448 #define RM_TABLE(I) DIS386 (USE_RM_TABLE, (I))
449 #define PREFIX_TABLE(I) DIS386 (USE_PREFIX_TABLE, (I))
450 #define X86_64_TABLE(I) DIS386 (USE_X86_64_TABLE, (I))
451 #define THREE_BYTE_TABLE(I) DIS386 (USE_3BYTE_TABLE, (I))
454 #define REG_81 (REG_80 + 1)
455 #define REG_82 (REG_81 + 1)
456 #define REG_8F (REG_82 + 1)
457 #define REG_C0 (REG_8F + 1)
458 #define REG_C1 (REG_C0 + 1)
459 #define REG_C6 (REG_C1 + 1)
460 #define REG_C7 (REG_C6 + 1)
461 #define REG_D0 (REG_C7 + 1)
462 #define REG_D1 (REG_D0 + 1)
463 #define REG_D2 (REG_D1 + 1)
464 #define REG_D3 (REG_D2 + 1)
465 #define REG_F6 (REG_D3 + 1)
466 #define REG_F7 (REG_F6 + 1)
467 #define REG_FE (REG_F7 + 1)
468 #define REG_FF (REG_FE + 1)
469 #define REG_0F00 (REG_FF + 1)
470 #define REG_0F01 (REG_0F00 + 1)
471 #define REG_0F0E (REG_0F01 + 1)
472 #define REG_0F18 (REG_0F0E + 1)
473 #define REG_0F71 (REG_0F18 + 1)
474 #define REG_0F72 (REG_0F71 + 1)
475 #define REG_0F73 (REG_0F72 + 1)
476 #define REG_0FA6 (REG_0F73 + 1)
477 #define REG_0FA7 (REG_0FA6 + 1)
478 #define REG_0FAE (REG_0FA7 + 1)
479 #define REG_0FBA (REG_0FAE + 1)
480 #define REG_0FC7 (REG_0FBA + 1)
483 #define MOD_0F13 (MOD_8D + 1)
484 #define MOD_0F17 (MOD_0F13 + 1)
485 #define MOD_0F20 (MOD_0F17 + 1)
486 #define MOD_0F21 (MOD_0F20 + 1)
487 #define MOD_0F22 (MOD_0F21 + 1)
488 #define MOD_0F23 (MOD_0F22 + 1)
489 #define MOD_0F24 (MOD_0F23 + 1)
490 #define MOD_0F26 (MOD_0F24 + 1)
491 #define MOD_0FB2 (MOD_0F26 + 1)
492 #define MOD_0FB4 (MOD_0FB2 + 1)
493 #define MOD_0FB5 (MOD_0FB4 + 1)
494 #define MOD_0F01_REG_0 (MOD_0FB5 + 1)
495 #define MOD_0F01_REG_1 (MOD_0F01_REG_0 + 1)
496 #define MOD_0F01_REG_2 (MOD_0F01_REG_1 + 1)
497 #define MOD_0F01_REG_3 (MOD_0F01_REG_2 + 1)
498 #define MOD_0F01_REG_7 (MOD_0F01_REG_3 + 1)
499 #define MOD_0F18_REG_0 (MOD_0F01_REG_7 + 1)
500 #define MOD_0F18_REG_1 (MOD_0F18_REG_0 + 1)
501 #define MOD_0F18_REG_2 (MOD_0F18_REG_1 + 1)
502 #define MOD_0F18_REG_3 (MOD_0F18_REG_2 + 1)
503 #define MOD_0F71_REG_2 (MOD_0F18_REG_3 + 1)
504 #define MOD_0F71_REG_4 (MOD_0F71_REG_2 + 1)
505 #define MOD_0F71_REG_6 (MOD_0F71_REG_4 + 1)
506 #define MOD_0F72_REG_2 (MOD_0F71_REG_6 + 1)
507 #define MOD_0F72_REG_4 (MOD_0F72_REG_2 + 1)
508 #define MOD_0F72_REG_6 (MOD_0F72_REG_4 + 1)
509 #define MOD_0F73_REG_2 (MOD_0F72_REG_6 + 1)
510 #define MOD_0F73_REG_3 (MOD_0F73_REG_2 + 1)
511 #define MOD_0F73_REG_6 (MOD_0F73_REG_3 + 1)
512 #define MOD_0F73_REG_7 (MOD_0F73_REG_6 + 1)
513 #define MOD_0FAE_REG_0 (MOD_0F73_REG_7 + 1)
514 #define MOD_0FAE_REG_1 (MOD_0FAE_REG_0 + 1)
515 #define MOD_0FAE_REG_2 (MOD_0FAE_REG_1 + 1)
516 #define MOD_0FAE_REG_3 (MOD_0FAE_REG_2 + 1)
517 #define MOD_0FAE_REG_5 (MOD_0FAE_REG_3 + 1)
518 #define MOD_0FAE_REG_6 (MOD_0FAE_REG_5 + 1)
519 #define MOD_0FAE_REG_7 (MOD_0FAE_REG_6 + 1)
520 #define MOD_0FC7_REG_6 (MOD_0FAE_REG_7 + 1)
521 #define MOD_0FC7_REG_7 (MOD_0FC7_REG_6 + 1)
522 #define MOD_0F12_PREFIX_0 (MOD_0FC7_REG_7 + 1)
523 #define MOD_0F16_PREFIX_0 (MOD_0F12_PREFIX_0 + 1)
524 #define MOD_0FF0_PREFIX_3 (MOD_0F16_PREFIX_0 + 1)
525 #define MOD_62_32BIT (MOD_0FF0_PREFIX_3 + 1)
526 #define MOD_C4_32BIT (MOD_62_32BIT + 1)
527 #define MOD_C5_32BIT (MOD_C4_32BIT + 1)
529 #define RM_0F01_REG_0 0
530 #define RM_0F01_REG_1 (RM_0F01_REG_0 + 1)
531 #define RM_0F01_REG_3 (RM_0F01_REG_1 + 1)
532 #define RM_0F01_REG_7 (RM_0F01_REG_3 + 1)
533 #define RM_0FAE_REG_5 (RM_0F01_REG_7 + 1)
534 #define RM_0FAE_REG_6 (RM_0FAE_REG_5 + 1)
535 #define RM_0FAE_REG_7 (RM_0FAE_REG_6 + 1)
538 #define PREFIX_0F10 (PREFIX_90 + 1)
539 #define PREFIX_0F11 (PREFIX_0F10 + 1)
540 #define PREFIX_0F12 (PREFIX_0F11 + 1)
541 #define PREFIX_0F16 (PREFIX_0F12 + 1)
542 #define PREFIX_0F2A (PREFIX_0F16 + 1)
543 #define PREFIX_0F2B (PREFIX_0F2A + 1)
544 #define PREFIX_0F2C (PREFIX_0F2B + 1)
545 #define PREFIX_0F2D (PREFIX_0F2C + 1)
546 #define PREFIX_0F2E (PREFIX_0F2D + 1)
547 #define PREFIX_0F2F (PREFIX_0F2E + 1)
548 #define PREFIX_0F51 (PREFIX_0F2F + 1)
549 #define PREFIX_0F52 (PREFIX_0F51 + 1)
550 #define PREFIX_0F53 (PREFIX_0F52 + 1)
551 #define PREFIX_0F58 (PREFIX_0F53 + 1)
552 #define PREFIX_0F59 (PREFIX_0F58 + 1)
553 #define PREFIX_0F5A (PREFIX_0F59 + 1)
554 #define PREFIX_0F5B (PREFIX_0F5A + 1)
555 #define PREFIX_0F5C (PREFIX_0F5B + 1)
556 #define PREFIX_0F5D (PREFIX_0F5C + 1)
557 #define PREFIX_0F5E (PREFIX_0F5D + 1)
558 #define PREFIX_0F5F (PREFIX_0F5E + 1)
559 #define PREFIX_0F60 (PREFIX_0F5F + 1)
560 #define PREFIX_0F61 (PREFIX_0F60 + 1)
561 #define PREFIX_0F62 (PREFIX_0F61 + 1)
562 #define PREFIX_0F6C (PREFIX_0F62 + 1)
563 #define PREFIX_0F6D (PREFIX_0F6C + 1)
564 #define PREFIX_0F6F (PREFIX_0F6D + 1)
565 #define PREFIX_0F70 (PREFIX_0F6F + 1)
566 #define PREFIX_0F78 (PREFIX_0F70 + 1)
567 #define PREFIX_0F79 (PREFIX_0F78 + 1)
568 #define PREFIX_0F7C (PREFIX_0F79 + 1)
569 #define PREFIX_0F7D (PREFIX_0F7C + 1)
570 #define PREFIX_0F7E (PREFIX_0F7D + 1)
571 #define PREFIX_0F7F (PREFIX_0F7E + 1)
572 #define PREFIX_0FB8 (PREFIX_0F7F + 1)
573 #define PREFIX_0FBD (PREFIX_0FB8 + 1)
574 #define PREFIX_0FC2 (PREFIX_0FBD + 1)
575 #define PREFIX_0FD0 (PREFIX_0FC2 + 1)
576 #define PREFIX_0FD6 (PREFIX_0FD0 + 1)
577 #define PREFIX_0FE6 (PREFIX_0FD6 + 1)
578 #define PREFIX_0FE7 (PREFIX_0FE6 + 1)
579 #define PREFIX_0FF0 (PREFIX_0FE7 + 1)
580 #define PREFIX_0FF7 (PREFIX_0FF0 + 1)
581 #define PREFIX_0F3810 (PREFIX_0FF7 + 1)
582 #define PREFIX_0F3814 (PREFIX_0F3810 + 1)
583 #define PREFIX_0F3815 (PREFIX_0F3814 + 1)
584 #define PREFIX_0F3817 (PREFIX_0F3815 + 1)
585 #define PREFIX_0F3820 (PREFIX_0F3817 + 1)
586 #define PREFIX_0F3821 (PREFIX_0F3820 + 1)
587 #define PREFIX_0F3822 (PREFIX_0F3821 + 1)
588 #define PREFIX_0F3823 (PREFIX_0F3822 + 1)
589 #define PREFIX_0F3824 (PREFIX_0F3823 + 1)
590 #define PREFIX_0F3825 (PREFIX_0F3824 + 1)
591 #define PREFIX_0F3828 (PREFIX_0F3825 + 1)
592 #define PREFIX_0F3829 (PREFIX_0F3828 + 1)
593 #define PREFIX_0F382A (PREFIX_0F3829 + 1)
594 #define PREFIX_0F382B (PREFIX_0F382A + 1)
595 #define PREFIX_0F3830 (PREFIX_0F382B + 1)
596 #define PREFIX_0F3831 (PREFIX_0F3830 + 1)
597 #define PREFIX_0F3832 (PREFIX_0F3831 + 1)
598 #define PREFIX_0F3833 (PREFIX_0F3832 + 1)
599 #define PREFIX_0F3834 (PREFIX_0F3833 + 1)
600 #define PREFIX_0F3835 (PREFIX_0F3834 + 1)
601 #define PREFIX_0F3837 (PREFIX_0F3835 + 1)
602 #define PREFIX_0F3838 (PREFIX_0F3837 + 1)
603 #define PREFIX_0F3839 (PREFIX_0F3838 + 1)
604 #define PREFIX_0F383A (PREFIX_0F3839 + 1)
605 #define PREFIX_0F383B (PREFIX_0F383A + 1)
606 #define PREFIX_0F383C (PREFIX_0F383B + 1)
607 #define PREFIX_0F383D (PREFIX_0F383C + 1)
608 #define PREFIX_0F383E (PREFIX_0F383D + 1)
609 #define PREFIX_0F383F (PREFIX_0F383E + 1)
610 #define PREFIX_0F3840 (PREFIX_0F383F + 1)
611 #define PREFIX_0F3841 (PREFIX_0F3840 + 1)
612 #define PREFIX_0F38F0 (PREFIX_0F3841 + 1)
613 #define PREFIX_0F38F1 (PREFIX_0F38F0 + 1)
614 #define PREFIX_0F3A08 (PREFIX_0F38F1 + 1)
615 #define PREFIX_0F3A09 (PREFIX_0F3A08 + 1)
616 #define PREFIX_0F3A0A (PREFIX_0F3A09 + 1)
617 #define PREFIX_0F3A0B (PREFIX_0F3A0A + 1)
618 #define PREFIX_0F3A0C (PREFIX_0F3A0B + 1)
619 #define PREFIX_0F3A0D (PREFIX_0F3A0C + 1)
620 #define PREFIX_0F3A0E (PREFIX_0F3A0D + 1)
621 #define PREFIX_0F3A14 (PREFIX_0F3A0E + 1)
622 #define PREFIX_0F3A15 (PREFIX_0F3A14 + 1)
623 #define PREFIX_0F3A16 (PREFIX_0F3A15 + 1)
624 #define PREFIX_0F3A17 (PREFIX_0F3A16 + 1)
625 #define PREFIX_0F3A20 (PREFIX_0F3A17 + 1)
626 #define PREFIX_0F3A21 (PREFIX_0F3A20 + 1)
627 #define PREFIX_0F3A22 (PREFIX_0F3A21 + 1)
628 #define PREFIX_0F3A40 (PREFIX_0F3A22 + 1)
629 #define PREFIX_0F3A41 (PREFIX_0F3A40 + 1)
630 #define PREFIX_0F3A42 (PREFIX_0F3A41 + 1)
631 #define PREFIX_0F3A60 (PREFIX_0F3A42 + 1)
632 #define PREFIX_0F3A61 (PREFIX_0F3A60 + 1)
633 #define PREFIX_0F3A62 (PREFIX_0F3A61 + 1)
634 #define PREFIX_0F3A63 (PREFIX_0F3A62 + 1)
635 #define PREFIX_0F73_REG_3 (PREFIX_0F3A63 + 1)
636 #define PREFIX_0F73_REG_7 (PREFIX_0F73_REG_3 + 1)
637 #define PREFIX_0FC7_REG_6 (PREFIX_0F73_REG_7 + 1)
640 #define X86_64_07 (X86_64_06 + 1)
641 #define X86_64_0D (X86_64_07 + 1)
642 #define X86_64_16 (X86_64_0D + 1)
643 #define X86_64_17 (X86_64_16 + 1)
644 #define X86_64_1E (X86_64_17 + 1)
645 #define X86_64_1F (X86_64_1E + 1)
646 #define X86_64_27 (X86_64_1F + 1)
647 #define X86_64_2F (X86_64_27 + 1)
648 #define X86_64_37 (X86_64_2F + 1)
649 #define X86_64_3F (X86_64_37 + 1)
650 #define X86_64_60 (X86_64_3F + 1)
651 #define X86_64_61 (X86_64_60 + 1)
652 #define X86_64_62 (X86_64_61 + 1)
653 #define X86_64_63 (X86_64_62 + 1)
654 #define X86_64_6D (X86_64_63 + 1)
655 #define X86_64_6F (X86_64_6D + 1)
656 #define X86_64_9A (X86_64_6F + 1)
657 #define X86_64_C4 (X86_64_9A + 1)
658 #define X86_64_C5 (X86_64_C4 + 1)
659 #define X86_64_CE (X86_64_C5 + 1)
660 #define X86_64_D4 (X86_64_CE + 1)
661 #define X86_64_D5 (X86_64_D4 + 1)
662 #define X86_64_EA (X86_64_D5 + 1)
663 #define X86_64_0F01_REG_0 (X86_64_EA + 1)
664 #define X86_64_0F01_REG_1 (X86_64_0F01_REG_0 + 1)
665 #define X86_64_0F01_REG_2 (X86_64_0F01_REG_1 + 1)
666 #define X86_64_0F01_REG_3 (X86_64_0F01_REG_2 + 1)
668 #define THREE_BYTE_0F24 0
669 #define THREE_BYTE_0F25 (THREE_BYTE_0F24 + 1)
670 #define THREE_BYTE_0F38 (THREE_BYTE_0F25 + 1)
671 #define THREE_BYTE_0F3A (THREE_BYTE_0F38 + 1)
672 #define THREE_BYTE_0F7A (THREE_BYTE_0F3A + 1)
673 #define THREE_BYTE_0FBA (THREE_BYTE_0F7A + 1)
675 typedef void (*op_rtn
) (int bytemode
, int sizeflag
);
686 /* Upper case letters in the instruction names here are macros.
687 'A' => print 'b' if no register operands or suffix_always is true
688 'B' => print 'b' if suffix_always is true
689 'C' => print 's' or 'l' ('w' or 'd' in Intel mode) depending on operand
691 'D' => print 'w' if no register operands or 'w', 'l' or 'q', if
692 . suffix_always is true
693 'E' => print 'e' if 32-bit form of jcxz
694 'F' => print 'w' or 'l' depending on address size prefix (loop insns)
695 'G' => print 'w' or 'l' depending on operand size prefix (i/o insns)
696 'H' => print ",pt" or ",pn" branch hint
697 'I' => honor following macro letter even in Intel mode (implemented only
698 . for some of the macro letters)
700 'K' => print 'd' or 'q' if rex prefix is present.
701 'L' => print 'l' if suffix_always is true
702 'N' => print 'n' if instruction has no wait "prefix"
703 'O' => print 'd' or 'o' (or 'q' in Intel mode)
704 'P' => print 'w', 'l' or 'q' if instruction has an operand size prefix,
705 . or suffix_always is true. print 'q' if rex prefix is present.
706 'Q' => print 'w', 'l' or 'q' if no register operands or suffix_always
708 'R' => print 'w', 'l' or 'q' ('d' for 'l' and 'e' in Intel mode)
709 'S' => print 'w', 'l' or 'q' if suffix_always is true
710 'T' => print 'q' in 64bit mode and behave as 'P' otherwise
711 'U' => print 'q' in 64bit mode and behave as 'Q' otherwise
712 'V' => print 'q' in 64bit mode and behave as 'S' otherwise
713 'W' => print 'b', 'w' or 'l' ('d' in Intel mode)
714 'X' => print 's', 'd' depending on data16 prefix (for XMM)
715 'Y' => 'q' if instruction has an REX 64bit overwrite prefix
716 'Z' => print 'q' in 64bit mode and behave as 'L' otherwise
718 Many of the above letters print nothing in Intel mode. See "putop"
721 Braces '{' and '}', and vertical bars '|', indicate alternative
722 mnemonic strings for AT&T and Intel. */
724 static const struct dis386 dis386
[] = {
726 { "addB", { Eb
, Gb
} },
727 { "addS", { Ev
, Gv
} },
728 { "addB", { Gb
, Eb
} },
729 { "addS", { Gv
, Ev
} },
730 { "addB", { AL
, Ib
} },
731 { "addS", { eAX
, Iv
} },
732 { X86_64_TABLE (X86_64_06
) },
733 { X86_64_TABLE (X86_64_07
) },
735 { "orB", { Eb
, Gb
} },
736 { "orS", { Ev
, Gv
} },
737 { "orB", { Gb
, Eb
} },
738 { "orS", { Gv
, Ev
} },
739 { "orB", { AL
, Ib
} },
740 { "orS", { eAX
, Iv
} },
741 { X86_64_TABLE (X86_64_0D
) },
742 { "(bad)", { XX
} }, /* 0x0f extended opcode escape */
744 { "adcB", { Eb
, Gb
} },
745 { "adcS", { Ev
, Gv
} },
746 { "adcB", { Gb
, Eb
} },
747 { "adcS", { Gv
, Ev
} },
748 { "adcB", { AL
, Ib
} },
749 { "adcS", { eAX
, Iv
} },
750 { X86_64_TABLE (X86_64_16
) },
751 { X86_64_TABLE (X86_64_17
) },
753 { "sbbB", { Eb
, Gb
} },
754 { "sbbS", { Ev
, Gv
} },
755 { "sbbB", { Gb
, Eb
} },
756 { "sbbS", { Gv
, Ev
} },
757 { "sbbB", { AL
, Ib
} },
758 { "sbbS", { eAX
, Iv
} },
759 { X86_64_TABLE (X86_64_1E
) },
760 { X86_64_TABLE (X86_64_1F
) },
762 { "andB", { Eb
, Gb
} },
763 { "andS", { Ev
, Gv
} },
764 { "andB", { Gb
, Eb
} },
765 { "andS", { Gv
, Ev
} },
766 { "andB", { AL
, Ib
} },
767 { "andS", { eAX
, Iv
} },
768 { "(bad)", { XX
} }, /* SEG ES prefix */
769 { X86_64_TABLE (X86_64_27
) },
771 { "subB", { Eb
, Gb
} },
772 { "subS", { Ev
, Gv
} },
773 { "subB", { Gb
, Eb
} },
774 { "subS", { Gv
, Ev
} },
775 { "subB", { AL
, Ib
} },
776 { "subS", { eAX
, Iv
} },
777 { "(bad)", { XX
} }, /* SEG CS prefix */
778 { X86_64_TABLE (X86_64_2F
) },
780 { "xorB", { Eb
, Gb
} },
781 { "xorS", { Ev
, Gv
} },
782 { "xorB", { Gb
, Eb
} },
783 { "xorS", { Gv
, Ev
} },
784 { "xorB", { AL
, Ib
} },
785 { "xorS", { eAX
, Iv
} },
786 { "(bad)", { XX
} }, /* SEG SS prefix */
787 { X86_64_TABLE (X86_64_37
) },
789 { "cmpB", { Eb
, Gb
} },
790 { "cmpS", { Ev
, Gv
} },
791 { "cmpB", { Gb
, Eb
} },
792 { "cmpS", { Gv
, Ev
} },
793 { "cmpB", { AL
, Ib
} },
794 { "cmpS", { eAX
, Iv
} },
795 { "(bad)", { XX
} }, /* SEG DS prefix */
796 { X86_64_TABLE (X86_64_3F
) },
798 { "inc{S|}", { RMeAX
} },
799 { "inc{S|}", { RMeCX
} },
800 { "inc{S|}", { RMeDX
} },
801 { "inc{S|}", { RMeBX
} },
802 { "inc{S|}", { RMeSP
} },
803 { "inc{S|}", { RMeBP
} },
804 { "inc{S|}", { RMeSI
} },
805 { "inc{S|}", { RMeDI
} },
807 { "dec{S|}", { RMeAX
} },
808 { "dec{S|}", { RMeCX
} },
809 { "dec{S|}", { RMeDX
} },
810 { "dec{S|}", { RMeBX
} },
811 { "dec{S|}", { RMeSP
} },
812 { "dec{S|}", { RMeBP
} },
813 { "dec{S|}", { RMeSI
} },
814 { "dec{S|}", { RMeDI
} },
816 { "pushV", { RMrAX
} },
817 { "pushV", { RMrCX
} },
818 { "pushV", { RMrDX
} },
819 { "pushV", { RMrBX
} },
820 { "pushV", { RMrSP
} },
821 { "pushV", { RMrBP
} },
822 { "pushV", { RMrSI
} },
823 { "pushV", { RMrDI
} },
825 { "popV", { RMrAX
} },
826 { "popV", { RMrCX
} },
827 { "popV", { RMrDX
} },
828 { "popV", { RMrBX
} },
829 { "popV", { RMrSP
} },
830 { "popV", { RMrBP
} },
831 { "popV", { RMrSI
} },
832 { "popV", { RMrDI
} },
834 { X86_64_TABLE (X86_64_60
) },
835 { X86_64_TABLE (X86_64_61
) },
836 { X86_64_TABLE (X86_64_62
) },
837 { X86_64_TABLE (X86_64_63
) },
838 { "(bad)", { XX
} }, /* seg fs */
839 { "(bad)", { XX
} }, /* seg gs */
840 { "(bad)", { XX
} }, /* op size prefix */
841 { "(bad)", { XX
} }, /* adr size prefix */
844 { "imulS", { Gv
, Ev
, Iv
} },
845 { "pushT", { sIb
} },
846 { "imulS", { Gv
, Ev
, sIb
} },
847 { "ins{b|}", { Ybr
, indirDX
} },
848 { X86_64_TABLE (X86_64_6D
) },
849 { "outs{b|}", { indirDXr
, Xb
} },
850 { X86_64_TABLE (X86_64_6F
) },
852 { "joH", { Jb
, XX
, cond_jump_flag
} },
853 { "jnoH", { Jb
, XX
, cond_jump_flag
} },
854 { "jbH", { Jb
, XX
, cond_jump_flag
} },
855 { "jaeH", { Jb
, XX
, cond_jump_flag
} },
856 { "jeH", { Jb
, XX
, cond_jump_flag
} },
857 { "jneH", { Jb
, XX
, cond_jump_flag
} },
858 { "jbeH", { Jb
, XX
, cond_jump_flag
} },
859 { "jaH", { Jb
, XX
, cond_jump_flag
} },
861 { "jsH", { Jb
, XX
, cond_jump_flag
} },
862 { "jnsH", { Jb
, XX
, cond_jump_flag
} },
863 { "jpH", { Jb
, XX
, cond_jump_flag
} },
864 { "jnpH", { Jb
, XX
, cond_jump_flag
} },
865 { "jlH", { Jb
, XX
, cond_jump_flag
} },
866 { "jgeH", { Jb
, XX
, cond_jump_flag
} },
867 { "jleH", { Jb
, XX
, cond_jump_flag
} },
868 { "jgH", { Jb
, XX
, cond_jump_flag
} },
870 { REG_TABLE (REG_80
) },
871 { REG_TABLE (REG_81
) },
873 { REG_TABLE (REG_82
) },
874 { "testB", { Eb
, Gb
} },
875 { "testS", { Ev
, Gv
} },
876 { "xchgB", { Eb
, Gb
} },
877 { "xchgS", { Ev
, Gv
} },
879 { "movB", { Eb
, Gb
} },
880 { "movS", { Ev
, Gv
} },
881 { "movB", { Gb
, Eb
} },
882 { "movS", { Gv
, Ev
} },
883 { "movD", { Sv
, Sw
} },
884 { MOD_TABLE (MOD_8D
) },
885 { "movD", { Sw
, Sv
} },
886 { REG_TABLE (REG_8F
) },
888 { PREFIX_TABLE (PREFIX_90
) },
889 { "xchgS", { RMeCX
, eAX
} },
890 { "xchgS", { RMeDX
, eAX
} },
891 { "xchgS", { RMeBX
, eAX
} },
892 { "xchgS", { RMeSP
, eAX
} },
893 { "xchgS", { RMeBP
, eAX
} },
894 { "xchgS", { RMeSI
, eAX
} },
895 { "xchgS", { RMeDI
, eAX
} },
897 { "cW{t|}R", { XX
} },
898 { "cR{t|}O", { XX
} },
899 { X86_64_TABLE (X86_64_9A
) },
900 { "(bad)", { XX
} }, /* fwait */
901 { "pushfT", { XX
} },
906 { "movB", { AL
, Ob
} },
907 { "movS", { eAX
, Ov
} },
908 { "movB", { Ob
, AL
} },
909 { "movS", { Ov
, eAX
} },
910 { "movs{b|}", { Ybr
, Xb
} },
911 { "movs{R|}", { Yvr
, Xv
} },
912 { "cmps{b|}", { Xb
, Yb
} },
913 { "cmps{R|}", { Xv
, Yv
} },
915 { "testB", { AL
, Ib
} },
916 { "testS", { eAX
, Iv
} },
917 { "stosB", { Ybr
, AL
} },
918 { "stosS", { Yvr
, eAX
} },
919 { "lodsB", { ALr
, Xb
} },
920 { "lodsS", { eAXr
, Xv
} },
921 { "scasB", { AL
, Yb
} },
922 { "scasS", { eAX
, Yv
} },
924 { "movB", { RMAL
, Ib
} },
925 { "movB", { RMCL
, Ib
} },
926 { "movB", { RMDL
, Ib
} },
927 { "movB", { RMBL
, Ib
} },
928 { "movB", { RMAH
, Ib
} },
929 { "movB", { RMCH
, Ib
} },
930 { "movB", { RMDH
, Ib
} },
931 { "movB", { RMBH
, Ib
} },
933 { "movS", { RMeAX
, Iv64
} },
934 { "movS", { RMeCX
, Iv64
} },
935 { "movS", { RMeDX
, Iv64
} },
936 { "movS", { RMeBX
, Iv64
} },
937 { "movS", { RMeSP
, Iv64
} },
938 { "movS", { RMeBP
, Iv64
} },
939 { "movS", { RMeSI
, Iv64
} },
940 { "movS", { RMeDI
, Iv64
} },
942 { REG_TABLE (REG_C0
) },
943 { REG_TABLE (REG_C1
) },
946 { X86_64_TABLE (X86_64_C4
) },
947 { X86_64_TABLE (X86_64_C5
) },
948 { REG_TABLE (REG_C6
) },
949 { REG_TABLE (REG_C7
) },
951 { "enterT", { Iw
, Ib
} },
952 { "leaveT", { XX
} },
957 { X86_64_TABLE (X86_64_CE
) },
960 { REG_TABLE (REG_D0
) },
961 { REG_TABLE (REG_D1
) },
962 { REG_TABLE (REG_D2
) },
963 { REG_TABLE (REG_D3
) },
964 { X86_64_TABLE (X86_64_D4
) },
965 { X86_64_TABLE (X86_64_D5
) },
967 { "xlat", { DSBX
} },
978 { "loopneFH", { Jb
, XX
, loop_jcxz_flag
} },
979 { "loopeFH", { Jb
, XX
, loop_jcxz_flag
} },
980 { "loopFH", { Jb
, XX
, loop_jcxz_flag
} },
981 { "jEcxzH", { Jb
, XX
, loop_jcxz_flag
} },
982 { "inB", { AL
, Ib
} },
983 { "inG", { zAX
, Ib
} },
984 { "outB", { Ib
, AL
} },
985 { "outG", { Ib
, zAX
} },
989 { X86_64_TABLE (X86_64_EA
) },
991 { "inB", { AL
, indirDX
} },
992 { "inG", { zAX
, indirDX
} },
993 { "outB", { indirDX
, AL
} },
994 { "outG", { indirDX
, zAX
} },
996 { "(bad)", { XX
} }, /* lock prefix */
998 { "(bad)", { XX
} }, /* repne */
999 { "(bad)", { XX
} }, /* repz */
1002 { REG_TABLE (REG_F6
) },
1003 { REG_TABLE (REG_F7
) },
1011 { REG_TABLE (REG_FE
) },
1012 { REG_TABLE (REG_FF
) },
1015 static const struct dis386 dis386_twobyte
[] = {
1017 { REG_TABLE (REG_0F00
) },
1018 { REG_TABLE (REG_0F01
) },
1019 { "larS", { Gv
, Ew
} },
1020 { "lslS", { Gv
, Ew
} },
1021 { "(bad)", { XX
} },
1022 { "syscall", { XX
} },
1024 { "sysretP", { XX
} },
1027 { "wbinvd", { XX
} },
1028 { "(bad)", { XX
} },
1030 { "(bad)", { XX
} },
1031 { REG_TABLE (REG_0F0E
) },
1032 { "femms", { XX
} },
1033 { "", { MX
, EM
, OPSUF
} }, /* See OP_3DNowSuffix. */
1035 { PREFIX_TABLE (PREFIX_0F10
) },
1036 { PREFIX_TABLE (PREFIX_0F11
) },
1037 { PREFIX_TABLE (PREFIX_0F12
) },
1038 { MOD_TABLE (MOD_0F13
) },
1039 { "unpcklpX", { XM
, EXq
} },
1040 { "unpckhpX", { XM
, EXq
} },
1041 { PREFIX_TABLE (PREFIX_0F16
) },
1042 { MOD_TABLE (MOD_0F17
) },
1044 { REG_TABLE (REG_0F18
) },
1045 { "(bad)", { XX
} },
1046 { "(bad)", { XX
} },
1047 { "(bad)", { XX
} },
1048 { "(bad)", { XX
} },
1049 { "(bad)", { XX
} },
1050 { "(bad)", { XX
} },
1053 { MOD_TABLE (MOD_0F20
) },
1054 { MOD_TABLE (MOD_0F21
) },
1055 { MOD_TABLE (MOD_0F22
) },
1056 { MOD_TABLE (MOD_0F23
) },
1057 { MOD_TABLE (MOD_0F24
) },
1058 { THREE_BYTE_TABLE (THREE_BYTE_0F25
) },
1059 { MOD_TABLE (MOD_0F26
) },
1060 { "(bad)", { XX
} },
1062 { "movapX", { XM
, EXx
} },
1063 { "movapX", { EXx
, XM
} },
1064 { PREFIX_TABLE (PREFIX_0F2A
) },
1065 { PREFIX_TABLE (PREFIX_0F2B
) },
1066 { PREFIX_TABLE (PREFIX_0F2C
) },
1067 { PREFIX_TABLE (PREFIX_0F2D
) },
1068 { PREFIX_TABLE (PREFIX_0F2E
) },
1069 { PREFIX_TABLE (PREFIX_0F2F
) },
1071 { "wrmsr", { XX
} },
1072 { "rdtsc", { XX
} },
1073 { "rdmsr", { XX
} },
1074 { "rdpmc", { XX
} },
1075 { "sysenter", { XX
} },
1076 { "sysexit", { XX
} },
1077 { "(bad)", { XX
} },
1078 { "(bad)", { XX
} },
1080 { THREE_BYTE_TABLE (THREE_BYTE_0F38
) },
1081 { "(bad)", { XX
} },
1082 { THREE_BYTE_TABLE (THREE_BYTE_0F3A
) },
1083 { "(bad)", { XX
} },
1084 { "(bad)", { XX
} },
1085 { "(bad)", { XX
} },
1086 { "(bad)", { XX
} },
1087 { "(bad)", { XX
} },
1089 { "cmovo", { Gv
, Ev
} },
1090 { "cmovno", { Gv
, Ev
} },
1091 { "cmovb", { Gv
, Ev
} },
1092 { "cmovae", { Gv
, Ev
} },
1093 { "cmove", { Gv
, Ev
} },
1094 { "cmovne", { Gv
, Ev
} },
1095 { "cmovbe", { Gv
, Ev
} },
1096 { "cmova", { Gv
, Ev
} },
1098 { "cmovs", { Gv
, Ev
} },
1099 { "cmovns", { Gv
, Ev
} },
1100 { "cmovp", { Gv
, Ev
} },
1101 { "cmovnp", { Gv
, Ev
} },
1102 { "cmovl", { Gv
, Ev
} },
1103 { "cmovge", { Gv
, Ev
} },
1104 { "cmovle", { Gv
, Ev
} },
1105 { "cmovg", { Gv
, Ev
} },
1107 { "movmskpX", { Gdq
, XS
} },
1108 { PREFIX_TABLE (PREFIX_0F51
) },
1109 { PREFIX_TABLE (PREFIX_0F52
) },
1110 { PREFIX_TABLE (PREFIX_0F53
) },
1111 { "andpX", { XM
, EXx
} },
1112 { "andnpX", { XM
, EXx
} },
1113 { "orpX", { XM
, EXx
} },
1114 { "xorpX", { XM
, EXx
} },
1116 { PREFIX_TABLE (PREFIX_0F58
) },
1117 { PREFIX_TABLE (PREFIX_0F59
) },
1118 { PREFIX_TABLE (PREFIX_0F5A
) },
1119 { PREFIX_TABLE (PREFIX_0F5B
) },
1120 { PREFIX_TABLE (PREFIX_0F5C
) },
1121 { PREFIX_TABLE (PREFIX_0F5D
) },
1122 { PREFIX_TABLE (PREFIX_0F5E
) },
1123 { PREFIX_TABLE (PREFIX_0F5F
) },
1125 { PREFIX_TABLE (PREFIX_0F60
) },
1126 { PREFIX_TABLE (PREFIX_0F61
) },
1127 { PREFIX_TABLE (PREFIX_0F62
) },
1128 { "packsswb", { MX
, EM
} },
1129 { "pcmpgtb", { MX
, EM
} },
1130 { "pcmpgtw", { MX
, EM
} },
1131 { "pcmpgtd", { MX
, EM
} },
1132 { "packuswb", { MX
, EM
} },
1134 { "punpckhbw", { MX
, EM
} },
1135 { "punpckhwd", { MX
, EM
} },
1136 { "punpckhdq", { MX
, EM
} },
1137 { "packssdw", { MX
, EM
} },
1138 { PREFIX_TABLE (PREFIX_0F6C
) },
1139 { PREFIX_TABLE (PREFIX_0F6D
) },
1140 { "movK", { MX
, Edq
} },
1141 { PREFIX_TABLE (PREFIX_0F6F
) },
1143 { PREFIX_TABLE (PREFIX_0F70
) },
1144 { REG_TABLE (REG_0F71
) },
1145 { REG_TABLE (REG_0F72
) },
1146 { REG_TABLE (REG_0F73
) },
1147 { "pcmpeqb", { MX
, EM
} },
1148 { "pcmpeqw", { MX
, EM
} },
1149 { "pcmpeqd", { MX
, EM
} },
1152 { PREFIX_TABLE (PREFIX_0F78
) },
1153 { PREFIX_TABLE (PREFIX_0F79
) },
1154 { THREE_BYTE_TABLE (THREE_BYTE_0F7A
) },
1155 { THREE_BYTE_TABLE (THREE_BYTE_0FBA
) },
1156 { PREFIX_TABLE (PREFIX_0F7C
) },
1157 { PREFIX_TABLE (PREFIX_0F7D
) },
1158 { PREFIX_TABLE (PREFIX_0F7E
) },
1159 { PREFIX_TABLE (PREFIX_0F7F
) },
1161 { "joH", { Jv
, XX
, cond_jump_flag
} },
1162 { "jnoH", { Jv
, XX
, cond_jump_flag
} },
1163 { "jbH", { Jv
, XX
, cond_jump_flag
} },
1164 { "jaeH", { Jv
, XX
, cond_jump_flag
} },
1165 { "jeH", { Jv
, XX
, cond_jump_flag
} },
1166 { "jneH", { Jv
, XX
, cond_jump_flag
} },
1167 { "jbeH", { Jv
, XX
, cond_jump_flag
} },
1168 { "jaH", { Jv
, XX
, cond_jump_flag
} },
1170 { "jsH", { Jv
, XX
, cond_jump_flag
} },
1171 { "jnsH", { Jv
, XX
, cond_jump_flag
} },
1172 { "jpH", { Jv
, XX
, cond_jump_flag
} },
1173 { "jnpH", { Jv
, XX
, cond_jump_flag
} },
1174 { "jlH", { Jv
, XX
, cond_jump_flag
} },
1175 { "jgeH", { Jv
, XX
, cond_jump_flag
} },
1176 { "jleH", { Jv
, XX
, cond_jump_flag
} },
1177 { "jgH", { Jv
, XX
, cond_jump_flag
} },
1180 { "setno", { Eb
} },
1182 { "setae", { Eb
} },
1184 { "setne", { Eb
} },
1185 { "setbe", { Eb
} },
1189 { "setns", { Eb
} },
1191 { "setnp", { Eb
} },
1193 { "setge", { Eb
} },
1194 { "setle", { Eb
} },
1197 { "pushT", { fs
} },
1199 { "cpuid", { XX
} },
1200 { "btS", { Ev
, Gv
} },
1201 { "shldS", { Ev
, Gv
, Ib
} },
1202 { "shldS", { Ev
, Gv
, CL
} },
1203 { REG_TABLE (REG_0FA6
) },
1204 { REG_TABLE (REG_0FA7
) },
1206 { "pushT", { gs
} },
1209 { "btsS", { Ev
, Gv
} },
1210 { "shrdS", { Ev
, Gv
, Ib
} },
1211 { "shrdS", { Ev
, Gv
, CL
} },
1212 { REG_TABLE (REG_0FAE
) },
1213 { "imulS", { Gv
, Ev
} },
1215 { "cmpxchgB", { Eb
, Gb
} },
1216 { "cmpxchgS", { Ev
, Gv
} },
1217 { MOD_TABLE (MOD_0FB2
) },
1218 { "btrS", { Ev
, Gv
} },
1219 { MOD_TABLE (MOD_0FB4
) },
1220 { MOD_TABLE (MOD_0FB5
) },
1221 { "movz{bR|x}", { Gv
, Eb
} },
1222 { "movz{wR|x}", { Gv
, Ew
} }, /* yes, there really is movzww ! */
1224 { PREFIX_TABLE (PREFIX_0FB8
) },
1226 { REG_TABLE (REG_0FBA
) },
1227 { "btcS", { Ev
, Gv
} },
1228 { "bsfS", { Gv
, Ev
} },
1229 { PREFIX_TABLE (PREFIX_0FBD
) },
1230 { "movs{bR|x}", { Gv
, Eb
} },
1231 { "movs{wR|x}", { Gv
, Ew
} }, /* yes, there really is movsww ! */
1233 { "xaddB", { Eb
, Gb
} },
1234 { "xaddS", { Ev
, Gv
} },
1235 { PREFIX_TABLE (PREFIX_0FC2
) },
1236 { "movntiS", { Ev
, Gv
} },
1237 { "pinsrw", { MX
, Edqw
, Ib
} },
1238 { "pextrw", { Gdq
, MS
, Ib
} },
1239 { "shufpX", { XM
, EXx
, Ib
} },
1240 { REG_TABLE (REG_0FC7
) },
1242 { "bswap", { RMeAX
} },
1243 { "bswap", { RMeCX
} },
1244 { "bswap", { RMeDX
} },
1245 { "bswap", { RMeBX
} },
1246 { "bswap", { RMeSP
} },
1247 { "bswap", { RMeBP
} },
1248 { "bswap", { RMeSI
} },
1249 { "bswap", { RMeDI
} },
1251 { PREFIX_TABLE (PREFIX_0FD0
) },
1252 { "psrlw", { MX
, EM
} },
1253 { "psrld", { MX
, EM
} },
1254 { "psrlq", { MX
, EM
} },
1255 { "paddq", { MX
, EM
} },
1256 { "pmullw", { MX
, EM
} },
1257 { PREFIX_TABLE (PREFIX_0FD6
) },
1258 { "pmovmskb", { Gdq
, MS
} },
1260 { "psubusb", { MX
, EM
} },
1261 { "psubusw", { MX
, EM
} },
1262 { "pminub", { MX
, EM
} },
1263 { "pand", { MX
, EM
} },
1264 { "paddusb", { MX
, EM
} },
1265 { "paddusw", { MX
, EM
} },
1266 { "pmaxub", { MX
, EM
} },
1267 { "pandn", { MX
, EM
} },
1269 { "pavgb", { MX
, EM
} },
1270 { "psraw", { MX
, EM
} },
1271 { "psrad", { MX
, EM
} },
1272 { "pavgw", { MX
, EM
} },
1273 { "pmulhuw", { MX
, EM
} },
1274 { "pmulhw", { MX
, EM
} },
1275 { PREFIX_TABLE (PREFIX_0FE6
) },
1276 { PREFIX_TABLE (PREFIX_0FE7
) },
1278 { "psubsb", { MX
, EM
} },
1279 { "psubsw", { MX
, EM
} },
1280 { "pminsw", { MX
, EM
} },
1281 { "por", { MX
, EM
} },
1282 { "paddsb", { MX
, EM
} },
1283 { "paddsw", { MX
, EM
} },
1284 { "pmaxsw", { MX
, EM
} },
1285 { "pxor", { MX
, EM
} },
1287 { PREFIX_TABLE (PREFIX_0FF0
) },
1288 { "psllw", { MX
, EM
} },
1289 { "pslld", { MX
, EM
} },
1290 { "psllq", { MX
, EM
} },
1291 { "pmuludq", { MX
, EM
} },
1292 { "pmaddwd", { MX
, EM
} },
1293 { "psadbw", { MX
, EM
} },
1294 { PREFIX_TABLE (PREFIX_0FF7
) },
1296 { "psubb", { MX
, EM
} },
1297 { "psubw", { MX
, EM
} },
1298 { "psubd", { MX
, EM
} },
1299 { "psubq", { MX
, EM
} },
1300 { "paddb", { MX
, EM
} },
1301 { "paddw", { MX
, EM
} },
1302 { "paddd", { MX
, EM
} },
1303 { "(bad)", { XX
} },
1306 static const unsigned char onebyte_has_modrm
[256] = {
1307 /* 0 1 2 3 4 5 6 7 8 9 a b c d e f */
1308 /* ------------------------------- */
1309 /* 00 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 00 */
1310 /* 10 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 10 */
1311 /* 20 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 20 */
1312 /* 30 */ 1,1,1,1,0,0,0,0,1,1,1,1,0,0,0,0, /* 30 */
1313 /* 40 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 40 */
1314 /* 50 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 50 */
1315 /* 60 */ 0,0,1,1,0,0,0,0,0,1,0,1,0,0,0,0, /* 60 */
1316 /* 70 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 70 */
1317 /* 80 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 80 */
1318 /* 90 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 90 */
1319 /* a0 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* a0 */
1320 /* b0 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* b0 */
1321 /* c0 */ 1,1,0,0,1,1,1,1,0,0,0,0,0,0,0,0, /* c0 */
1322 /* d0 */ 1,1,1,1,0,0,0,0,1,1,1,1,1,1,1,1, /* d0 */
1323 /* e0 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* e0 */
1324 /* f0 */ 0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,1 /* f0 */
1325 /* ------------------------------- */
1326 /* 0 1 2 3 4 5 6 7 8 9 a b c d e f */
1329 static const unsigned char twobyte_has_modrm
[256] = {
1330 /* 0 1 2 3 4 5 6 7 8 9 a b c d e f */
1331 /* ------------------------------- */
1332 /* 00 */ 1,1,1,1,0,0,0,0,0,0,0,0,0,1,0,1, /* 0f */
1333 /* 10 */ 1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,1, /* 1f */
1334 /* 20 */ 1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1, /* 2f */
1335 /* 30 */ 0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0, /* 3f */
1336 /* 40 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 4f */
1337 /* 50 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 5f */
1338 /* 60 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 6f */
1339 /* 70 */ 1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1, /* 7f */
1340 /* 80 */ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 8f */
1341 /* 90 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* 9f */
1342 /* a0 */ 0,0,0,1,1,1,1,1,0,0,0,1,1,1,1,1, /* af */
1343 /* b0 */ 1,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1, /* bf */
1344 /* c0 */ 1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0, /* cf */
1345 /* d0 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* df */
1346 /* e0 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, /* ef */
1347 /* f0 */ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0 /* ff */
1348 /* ------------------------------- */
1349 /* 0 1 2 3 4 5 6 7 8 9 a b c d e f */
1352 static char obuf
[100];
1354 static char scratchbuf
[100];
1355 static unsigned char *start_codep
;
1356 static unsigned char *insn_codep
;
1357 static unsigned char *codep
;
1358 static const char *lock_prefix
;
1359 static const char *data_prefix
;
1360 static const char *addr_prefix
;
1361 static const char *repz_prefix
;
1362 static const char *repnz_prefix
;
1363 static disassemble_info
*the_info
;
1371 static unsigned char need_modrm
;
1373 /* If we are accessing mod/rm/reg without need_modrm set, then the
1374 values are stale. Hitting this abort likely indicates that you
1375 need to update onebyte_has_modrm or twobyte_has_modrm. */
1376 #define MODRM_CHECK if (!need_modrm) abort ()
1378 static const char **names64
;
1379 static const char **names32
;
1380 static const char **names16
;
1381 static const char **names8
;
1382 static const char **names8rex
;
1383 static const char **names_seg
;
1384 static const char *index64
;
1385 static const char *index32
;
1386 static const char **index16
;
1388 static const char *intel_names64
[] = {
1389 "rax", "rcx", "rdx", "rbx", "rsp", "rbp", "rsi", "rdi",
1390 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"
1392 static const char *intel_names32
[] = {
1393 "eax", "ecx", "edx", "ebx", "esp", "ebp", "esi", "edi",
1394 "r8d", "r9d", "r10d", "r11d", "r12d", "r13d", "r14d", "r15d"
1396 static const char *intel_names16
[] = {
1397 "ax", "cx", "dx", "bx", "sp", "bp", "si", "di",
1398 "r8w", "r9w", "r10w", "r11w", "r12w", "r13w", "r14w", "r15w"
1400 static const char *intel_names8
[] = {
1401 "al", "cl", "dl", "bl", "ah", "ch", "dh", "bh",
1403 static const char *intel_names8rex
[] = {
1404 "al", "cl", "dl", "bl", "spl", "bpl", "sil", "dil",
1405 "r8b", "r9b", "r10b", "r11b", "r12b", "r13b", "r14b", "r15b"
1407 static const char *intel_names_seg
[] = {
1408 "es", "cs", "ss", "ds", "fs", "gs", "?", "?",
1410 static const char *intel_index64
= "riz";
1411 static const char *intel_index32
= "eiz";
1412 static const char *intel_index16
[] = {
1413 "bx+si", "bx+di", "bp+si", "bp+di", "si", "di", "bp", "bx"
1416 static const char *att_names64
[] = {
1417 "%rax", "%rcx", "%rdx", "%rbx", "%rsp", "%rbp", "%rsi", "%rdi",
1418 "%r8", "%r9", "%r10", "%r11", "%r12", "%r13", "%r14", "%r15"
1420 static const char *att_names32
[] = {
1421 "%eax", "%ecx", "%edx", "%ebx", "%esp", "%ebp", "%esi", "%edi",
1422 "%r8d", "%r9d", "%r10d", "%r11d", "%r12d", "%r13d", "%r14d", "%r15d"
1424 static const char *att_names16
[] = {
1425 "%ax", "%cx", "%dx", "%bx", "%sp", "%bp", "%si", "%di",
1426 "%r8w", "%r9w", "%r10w", "%r11w", "%r12w", "%r13w", "%r14w", "%r15w"
1428 static const char *att_names8
[] = {
1429 "%al", "%cl", "%dl", "%bl", "%ah", "%ch", "%dh", "%bh",
1431 static const char *att_names8rex
[] = {
1432 "%al", "%cl", "%dl", "%bl", "%spl", "%bpl", "%sil", "%dil",
1433 "%r8b", "%r9b", "%r10b", "%r11b", "%r12b", "%r13b", "%r14b", "%r15b"
1435 static const char *att_names_seg
[] = {
1436 "%es", "%cs", "%ss", "%ds", "%fs", "%gs", "%?", "%?",
1438 static const char *att_index64
= "%riz";
1439 static const char *att_index32
= "%eiz";
1440 static const char *att_index16
[] = {
1441 "%bx,%si", "%bx,%di", "%bp,%si", "%bp,%di", "%si", "%di", "%bp", "%bx"
1444 static const struct dis386 reg_table
[][8] = {
1447 { "addA", { Eb
, Ib
} },
1448 { "orA", { Eb
, Ib
} },
1449 { "adcA", { Eb
, Ib
} },
1450 { "sbbA", { Eb
, Ib
} },
1451 { "andA", { Eb
, Ib
} },
1452 { "subA", { Eb
, Ib
} },
1453 { "xorA", { Eb
, Ib
} },
1454 { "cmpA", { Eb
, Ib
} },
1458 { "addQ", { Ev
, Iv
} },
1459 { "orQ", { Ev
, Iv
} },
1460 { "adcQ", { Ev
, Iv
} },
1461 { "sbbQ", { Ev
, Iv
} },
1462 { "andQ", { Ev
, Iv
} },
1463 { "subQ", { Ev
, Iv
} },
1464 { "xorQ", { Ev
, Iv
} },
1465 { "cmpQ", { Ev
, Iv
} },
1469 { "addQ", { Ev
, sIb
} },
1470 { "orQ", { Ev
, sIb
} },
1471 { "adcQ", { Ev
, sIb
} },
1472 { "sbbQ", { Ev
, sIb
} },
1473 { "andQ", { Ev
, sIb
} },
1474 { "subQ", { Ev
, sIb
} },
1475 { "xorQ", { Ev
, sIb
} },
1476 { "cmpQ", { Ev
, sIb
} },
1480 { "popU", { stackEv
} },
1481 { "(bad)", { XX
} },
1482 { "(bad)", { XX
} },
1483 { "(bad)", { XX
} },
1484 { "(bad)", { XX
} },
1485 { "(bad)", { XX
} },
1486 { "(bad)", { XX
} },
1487 { "(bad)", { XX
} },
1491 { "rolA", { Eb
, Ib
} },
1492 { "rorA", { Eb
, Ib
} },
1493 { "rclA", { Eb
, Ib
} },
1494 { "rcrA", { Eb
, Ib
} },
1495 { "shlA", { Eb
, Ib
} },
1496 { "shrA", { Eb
, Ib
} },
1497 { "(bad)", { XX
} },
1498 { "sarA", { Eb
, Ib
} },
1502 { "rolQ", { Ev
, Ib
} },
1503 { "rorQ", { Ev
, Ib
} },
1504 { "rclQ", { Ev
, Ib
} },
1505 { "rcrQ", { Ev
, Ib
} },
1506 { "shlQ", { Ev
, Ib
} },
1507 { "shrQ", { Ev
, Ib
} },
1508 { "(bad)", { XX
} },
1509 { "sarQ", { Ev
, Ib
} },
1513 { "movA", { Eb
, Ib
} },
1514 { "(bad)", { XX
} },
1515 { "(bad)", { XX
} },
1516 { "(bad)", { XX
} },
1517 { "(bad)", { XX
} },
1518 { "(bad)", { XX
} },
1519 { "(bad)", { XX
} },
1520 { "(bad)", { XX
} },
1524 { "movQ", { Ev
, Iv
} },
1525 { "(bad)", { XX
} },
1526 { "(bad)", { XX
} },
1527 { "(bad)", { XX
} },
1528 { "(bad)", { XX
} },
1529 { "(bad)", { XX
} },
1530 { "(bad)", { XX
} },
1531 { "(bad)", { XX
} },
1535 { "rolA", { Eb
, I1
} },
1536 { "rorA", { Eb
, I1
} },
1537 { "rclA", { Eb
, I1
} },
1538 { "rcrA", { Eb
, I1
} },
1539 { "shlA", { Eb
, I1
} },
1540 { "shrA", { Eb
, I1
} },
1541 { "(bad)", { XX
} },
1542 { "sarA", { Eb
, I1
} },
1546 { "rolQ", { Ev
, I1
} },
1547 { "rorQ", { Ev
, I1
} },
1548 { "rclQ", { Ev
, I1
} },
1549 { "rcrQ", { Ev
, I1
} },
1550 { "shlQ", { Ev
, I1
} },
1551 { "shrQ", { Ev
, I1
} },
1552 { "(bad)", { XX
} },
1553 { "sarQ", { Ev
, I1
} },
1557 { "rolA", { Eb
, CL
} },
1558 { "rorA", { Eb
, CL
} },
1559 { "rclA", { Eb
, CL
} },
1560 { "rcrA", { Eb
, CL
} },
1561 { "shlA", { Eb
, CL
} },
1562 { "shrA", { Eb
, CL
} },
1563 { "(bad)", { XX
} },
1564 { "sarA", { Eb
, CL
} },
1568 { "rolQ", { Ev
, CL
} },
1569 { "rorQ", { Ev
, CL
} },
1570 { "rclQ", { Ev
, CL
} },
1571 { "rcrQ", { Ev
, CL
} },
1572 { "shlQ", { Ev
, CL
} },
1573 { "shrQ", { Ev
, CL
} },
1574 { "(bad)", { XX
} },
1575 { "sarQ", { Ev
, CL
} },
1579 { "testA", { Eb
, Ib
} },
1580 { "(bad)", { Eb
} },
1583 { "mulA", { Eb
} }, /* Don't print the implicit %al register, */
1584 { "imulA", { Eb
} }, /* to distinguish these opcodes from other */
1585 { "divA", { Eb
} }, /* mul/imul opcodes. Do the same for div */
1586 { "idivA", { Eb
} }, /* and idiv for consistency. */
1590 { "testQ", { Ev
, Iv
} },
1591 { "(bad)", { XX
} },
1594 { "mulQ", { Ev
} }, /* Don't print the implicit register. */
1595 { "imulQ", { Ev
} },
1597 { "idivQ", { Ev
} },
1603 { "(bad)", { XX
} },
1604 { "(bad)", { XX
} },
1605 { "(bad)", { XX
} },
1606 { "(bad)", { XX
} },
1607 { "(bad)", { XX
} },
1608 { "(bad)", { XX
} },
1614 { "callT", { indirEv
} },
1615 { "JcallT", { indirEp
} },
1616 { "jmpT", { indirEv
} },
1617 { "JjmpT", { indirEp
} },
1618 { "pushU", { stackEv
} },
1619 { "(bad)", { XX
} },
1623 { "sldtD", { Sv
} },
1629 { "(bad)", { XX
} },
1630 { "(bad)", { XX
} },
1634 { MOD_TABLE (MOD_0F01_REG_0
) },
1635 { MOD_TABLE (MOD_0F01_REG_1
) },
1636 { MOD_TABLE (MOD_0F01_REG_2
) },
1637 { MOD_TABLE (MOD_0F01_REG_3
) },
1638 { "smswD", { Sv
} },
1639 { "(bad)", { XX
} },
1641 { MOD_TABLE (MOD_0F01_REG_7
) },
1645 { "prefetch", { Eb
} },
1646 { "prefetchw", { Eb
} },
1647 { "(bad)", { XX
} },
1648 { "(bad)", { XX
} },
1649 { "(bad)", { XX
} },
1650 { "(bad)", { XX
} },
1651 { "(bad)", { XX
} },
1652 { "(bad)", { XX
} },
1656 { MOD_TABLE (MOD_0F18_REG_0
) },
1657 { MOD_TABLE (MOD_0F18_REG_1
) },
1658 { MOD_TABLE (MOD_0F18_REG_2
) },
1659 { MOD_TABLE (MOD_0F18_REG_3
) },
1660 { "(bad)", { XX
} },
1661 { "(bad)", { XX
} },
1662 { "(bad)", { XX
} },
1663 { "(bad)", { XX
} },
1667 { "(bad)", { XX
} },
1668 { "(bad)", { XX
} },
1669 { MOD_TABLE (MOD_0F71_REG_2
) },
1670 { "(bad)", { XX
} },
1671 { MOD_TABLE (MOD_0F71_REG_4
) },
1672 { "(bad)", { XX
} },
1673 { MOD_TABLE (MOD_0F71_REG_6
) },
1674 { "(bad)", { XX
} },
1678 { "(bad)", { XX
} },
1679 { "(bad)", { XX
} },
1680 { MOD_TABLE (MOD_0F72_REG_2
) },
1681 { "(bad)", { XX
} },
1682 { MOD_TABLE (MOD_0F72_REG_4
) },
1683 { "(bad)", { XX
} },
1684 { MOD_TABLE (MOD_0F72_REG_6
) },
1685 { "(bad)", { XX
} },
1689 { "(bad)", { XX
} },
1690 { "(bad)", { XX
} },
1691 { MOD_TABLE (MOD_0F73_REG_2
) },
1692 { MOD_TABLE (MOD_0F73_REG_3
) },
1693 { "(bad)", { XX
} },
1694 { "(bad)", { XX
} },
1695 { MOD_TABLE (MOD_0F73_REG_6
) },
1696 { MOD_TABLE (MOD_0F73_REG_7
) },
1700 { "montmul", { { OP_0f07
, 0 } } },
1701 { "xsha1", { { OP_0f07
, 0 } } },
1702 { "xsha256", { { OP_0f07
, 0 } } },
1703 { "(bad)", { { OP_0f07
, 0 } } },
1704 { "(bad)", { { OP_0f07
, 0 } } },
1705 { "(bad)", { { OP_0f07
, 0 } } },
1706 { "(bad)", { { OP_0f07
, 0 } } },
1707 { "(bad)", { { OP_0f07
, 0 } } },
1711 { "xstore-rng", { { OP_0f07
, 0 } } },
1712 { "xcrypt-ecb", { { OP_0f07
, 0 } } },
1713 { "xcrypt-cbc", { { OP_0f07
, 0 } } },
1714 { "xcrypt-ctr", { { OP_0f07
, 0 } } },
1715 { "xcrypt-cfb", { { OP_0f07
, 0 } } },
1716 { "xcrypt-ofb", { { OP_0f07
, 0 } } },
1717 { "(bad)", { { OP_0f07
, 0 } } },
1718 { "(bad)", { { OP_0f07
, 0 } } },
1722 { MOD_TABLE (MOD_0FAE_REG_0
) },
1723 { MOD_TABLE (MOD_0FAE_REG_1
) },
1724 { MOD_TABLE (MOD_0FAE_REG_2
) },
1725 { MOD_TABLE (MOD_0FAE_REG_3
) },
1726 { "(bad)", { XX
} },
1727 { MOD_TABLE (MOD_0FAE_REG_5
) },
1728 { MOD_TABLE (MOD_0FAE_REG_6
) },
1729 { MOD_TABLE (MOD_0FAE_REG_7
) },
1733 { "(bad)", { XX
} },
1734 { "(bad)", { XX
} },
1735 { "(bad)", { XX
} },
1736 { "(bad)", { XX
} },
1737 { "btQ", { Ev
, Ib
} },
1738 { "btsQ", { Ev
, Ib
} },
1739 { "btrQ", { Ev
, Ib
} },
1740 { "btcQ", { Ev
, Ib
} },
1744 { "(bad)", { XX
} },
1745 { "cmpxchg8b", { { CMPXCHG8B_Fixup
, q_mode
} } },
1746 { "(bad)", { XX
} },
1747 { "(bad)", { XX
} },
1748 { "(bad)", { XX
} },
1749 { "(bad)", { XX
} },
1750 { MOD_TABLE (MOD_0FC7_REG_6
) },
1751 { MOD_TABLE (MOD_0FC7_REG_7
) },
1755 static const struct dis386 prefix_table
[][4] = {
1758 { "xchgS", { { NOP_Fixup1
, eAX_reg
}, { NOP_Fixup2
, eAX_reg
} } },
1759 { "pause", { XX
} },
1760 { "xchgS", { { NOP_Fixup1
, eAX_reg
}, { NOP_Fixup2
, eAX_reg
} } },
1761 { "(bad)", { XX
} },
1766 { "movups", { XM
, EXx
} },
1767 { "movss", { XM
, EXd
} },
1768 { "movupd", { XM
, EXx
} },
1769 { "movsd", { XM
, EXq
} },
1774 { "movups", { EXx
, XM
} },
1775 { "movss", { EXd
, XM
} },
1776 { "movupd", { EXx
, XM
} },
1777 { "movsd", { EXq
, XM
} },
1782 { MOD_TABLE (MOD_0F12_PREFIX_0
) },
1783 { "movsldup", { XM
, EXx
} },
1784 { "movlpd", { XM
, EXq
} },
1785 { "movddup", { XM
, EXq
} },
1790 { MOD_TABLE (MOD_0F16_PREFIX_0
) },
1791 { "movshdup", { XM
, EXx
} },
1792 { "movhpd", { XM
, EXq
} },
1793 { "(bad)", { XM
, EXq
} },
1798 { "cvtpi2ps", { XM
, EMCq
} },
1799 { "cvtsi2ssY", { XM
, Ev
} },
1800 { "cvtpi2pd", { XM
, EMCq
} },
1801 { "cvtsi2sdY", { XM
, Ev
} },
1806 {"movntps", { Ev
, XM
} },
1807 {"movntss", { Ed
, XM
} },
1808 {"movntpd", { Ev
, XM
} },
1809 {"movntsd", { Eq
, XM
} },
1814 { "cvttps2pi", { MXC
, EXq
} },
1815 { "cvttss2siY", { Gv
, EXd
} },
1816 { "cvttpd2pi", { MXC
, EXx
} },
1817 { "cvttsd2siY", { Gv
, EXq
} },
1822 { "cvtps2pi", { MXC
, EXq
} },
1823 { "cvtss2siY", { Gv
, EXd
} },
1824 { "cvtpd2pi", { MXC
, EXx
} },
1825 { "cvtsd2siY", { Gv
, EXq
} },
1830 { "ucomiss",{ XM
, EXd
} },
1831 { "(bad)", { XX
} },
1832 { "ucomisd",{ XM
, EXq
} },
1833 { "(bad)", { XX
} },
1838 { "comiss", { XM
, EXd
} },
1839 { "(bad)", { XX
} },
1840 { "comisd", { XM
, EXq
} },
1841 { "(bad)", { XX
} },
1846 { "sqrtps", { XM
, EXx
} },
1847 { "sqrtss", { XM
, EXd
} },
1848 { "sqrtpd", { XM
, EXx
} },
1849 { "sqrtsd", { XM
, EXq
} },
1854 { "rsqrtps",{ XM
, EXx
} },
1855 { "rsqrtss",{ XM
, EXd
} },
1856 { "(bad)", { XM
, EXx
} },
1857 { "(bad)", { XM
, EXx
} },
1862 { "rcpps", { XM
, EXx
} },
1863 { "rcpss", { XM
, EXd
} },
1864 { "(bad)", { XM
, EXx
} },
1865 { "(bad)", { XM
, EXx
} },
1870 { "addps", { XM
, EXx
} },
1871 { "addss", { XM
, EXd
} },
1872 { "addpd", { XM
, EXx
} },
1873 { "addsd", { XM
, EXq
} },
1878 { "mulps", { XM
, EXx
} },
1879 { "mulss", { XM
, EXd
} },
1880 { "mulpd", { XM
, EXx
} },
1881 { "mulsd", { XM
, EXq
} },
1886 { "cvtps2pd", { XM
, EXq
} },
1887 { "cvtss2sd", { XM
, EXd
} },
1888 { "cvtpd2ps", { XM
, EXx
} },
1889 { "cvtsd2ss", { XM
, EXq
} },
1894 { "cvtdq2ps", { XM
, EXx
} },
1895 { "cvttps2dq", { XM
, EXx
} },
1896 { "cvtps2dq", { XM
, EXx
} },
1897 { "(bad)", { XM
, EXx
} },
1902 { "subps", { XM
, EXx
} },
1903 { "subss", { XM
, EXd
} },
1904 { "subpd", { XM
, EXx
} },
1905 { "subsd", { XM
, EXq
} },
1910 { "minps", { XM
, EXx
} },
1911 { "minss", { XM
, EXd
} },
1912 { "minpd", { XM
, EXx
} },
1913 { "minsd", { XM
, EXq
} },
1918 { "divps", { XM
, EXx
} },
1919 { "divss", { XM
, EXd
} },
1920 { "divpd", { XM
, EXx
} },
1921 { "divsd", { XM
, EXq
} },
1926 { "maxps", { XM
, EXx
} },
1927 { "maxss", { XM
, EXd
} },
1928 { "maxpd", { XM
, EXx
} },
1929 { "maxsd", { XM
, EXq
} },
1934 { "punpcklbw",{ MX
, EMd
} },
1935 { "(bad)", { XX
} },
1936 { "punpcklbw",{ MX
, EMx
} },
1937 { "(bad)", { XX
} },
1942 { "punpcklwd",{ MX
, EMd
} },
1943 { "(bad)", { XX
} },
1944 { "punpcklwd",{ MX
, EMx
} },
1945 { "(bad)", { XX
} },
1950 { "punpckldq",{ MX
, EMd
} },
1951 { "(bad)", { XX
} },
1952 { "punpckldq",{ MX
, EMx
} },
1953 { "(bad)", { XX
} },
1958 { "(bad)", { MX
, EXx
} },
1959 { "(bad)", { XM
, EXx
} },
1960 { "punpcklqdq", { XM
, EXx
} },
1961 { "(bad)", { XM
, EXx
} },
1966 { "(bad)", { MX
, EXx
} },
1967 { "(bad)", { XM
, EXx
} },
1968 { "punpckhqdq", { XM
, EXx
} },
1969 { "(bad)", { XM
, EXx
} },
1974 { "movq", { MX
, EM
} },
1975 { "movdqu", { XM
, EXx
} },
1976 { "movdqa", { XM
, EXx
} },
1977 { "(bad)", { XM
, EXx
} },
1982 { "pshufw", { MX
, EM
, Ib
} },
1983 { "pshufhw",{ XM
, EXx
, Ib
} },
1984 { "pshufd", { XM
, EXx
, Ib
} },
1985 { "pshuflw",{ XM
, EXx
, Ib
} },
1990 {"vmread", { Em
, Gm
} },
1992 {"extrq", { XS
, Ib
, Ib
} },
1993 {"insertq", { XM
, XS
, Ib
, Ib
} },
1998 {"vmwrite", { Gm
, Em
} },
2000 {"extrq", { XM
, XS
} },
2001 {"insertq", { XM
, XS
} },
2006 { "(bad)", { MX
, EXx
} },
2007 { "(bad)", { XM
, EXx
} },
2008 { "haddpd", { XM
, EXx
} },
2009 { "haddps", { XM
, EXx
} },
2014 { "(bad)", { MX
, EXx
} },
2015 { "(bad)", { XM
, EXx
} },
2016 { "hsubpd", { XM
, EXx
} },
2017 { "hsubps", { XM
, EXx
} },
2022 { "movK", { Edq
, MX
} },
2023 { "movq", { XM
, EXq
} },
2024 { "movK", { Edq
, XM
} },
2025 { "(bad)", { Ed
, XM
} },
2030 { "movq", { EM
, MX
} },
2031 { "movdqu", { EXx
, XM
} },
2032 { "movdqa", { EXx
, XM
} },
2033 { "(bad)", { EXx
, XM
} },
2038 { "(bad)", { XX
} },
2039 { "popcntS", { Gv
, Ev
} },
2040 { "(bad)", { XX
} },
2041 { "(bad)", { XX
} },
2046 { "bsrS", { Gv
, Ev
} },
2047 { "lzcntS", { Gv
, Ev
} },
2048 { "bsrS", { Gv
, Ev
} },
2049 { "(bad)", { XX
} },
2054 { "", { XM
, EXx
, OPSIMD
} }, /* See OP_SIMD_SUFFIX. */
2055 { "", { XM
, EXd
, OPSIMD
} },
2056 { "", { XM
, EXx
, OPSIMD
} },
2057 { "", { XM
, EXq
, OPSIMD
} },
2062 { "(bad)", { MX
, EXx
} },
2063 { "(bad)", { XM
, EXx
} },
2064 { "addsubpd", { XM
, EXx
} },
2065 { "addsubps", { XM
, EXx
} },
2070 { "(bad)", { EXx
, XM
} },
2071 { "movq2dq",{ XM
, MS
} },
2072 { "movq", { EXq
, XM
} },
2073 { "movdq2q",{ MX
, XS
} },
2078 { "(bad)", { XM
, EXx
} },
2079 { "cvtdq2pd", { XM
, EXq
} },
2080 { "cvttpd2dq", { XM
, EXx
} },
2081 { "cvtpd2dq", { XM
, EXx
} },
2086 { "movntq", { EM
, MX
} },
2087 { "(bad)", { EM
, XM
} },
2088 { "movntdq",{ EM
, XM
} },
2089 { "(bad)", { EM
, XM
} },
2094 { "(bad)", { XM
, EXx
} },
2095 { "(bad)", { XM
, EXx
} },
2096 { "(bad)", { XM
, EXx
} },
2097 { MOD_TABLE (MOD_0FF0_PREFIX_3
) },
2102 { "maskmovq", { MX
, MS
} },
2103 { "(bad)", { XM
, EXx
} },
2104 { "maskmovdqu", { XM
, XS
} },
2105 { "(bad)", { XM
, EXx
} },
2110 { "(bad)", { XX
} },
2111 { "(bad)", { XX
} },
2112 { "pblendvb", {XM
, EXx
, XMM0
} },
2113 { "(bad)", { XX
} },
2118 { "(bad)", { XX
} },
2119 { "(bad)", { XX
} },
2120 { "blendvps", {XM
, EXx
, XMM0
} },
2121 { "(bad)", { XX
} },
2126 { "(bad)", { XX
} },
2127 { "(bad)", { XX
} },
2128 { "blendvpd", { XM
, EXx
, XMM0
} },
2129 { "(bad)", { XX
} },
2134 { "(bad)", { XX
} },
2135 { "(bad)", { XX
} },
2136 { "ptest", { XM
, EXx
} },
2137 { "(bad)", { XX
} },
2142 { "(bad)", { XX
} },
2143 { "(bad)", { XX
} },
2144 { "pmovsxbw", { XM
, EXq
} },
2145 { "(bad)", { XX
} },
2150 { "(bad)", { XX
} },
2151 { "(bad)", { XX
} },
2152 { "pmovsxbd", { XM
, EXd
} },
2153 { "(bad)", { XX
} },
2158 { "(bad)", { XX
} },
2159 { "(bad)", { XX
} },
2160 { "pmovsxbq", { XM
, EXw
} },
2161 { "(bad)", { XX
} },
2166 { "(bad)", { XX
} },
2167 { "(bad)", { XX
} },
2168 { "pmovsxwd", { XM
, EXq
} },
2169 { "(bad)", { XX
} },
2174 { "(bad)", { XX
} },
2175 { "(bad)", { XX
} },
2176 { "pmovsxwq", { XM
, EXd
} },
2177 { "(bad)", { XX
} },
2182 { "(bad)", { XX
} },
2183 { "(bad)", { XX
} },
2184 { "pmovsxdq", { XM
, EXq
} },
2185 { "(bad)", { XX
} },
2190 { "(bad)", { XX
} },
2191 { "(bad)", { XX
} },
2192 { "pmuldq", { XM
, EXx
} },
2193 { "(bad)", { XX
} },
2198 { "(bad)", { XX
} },
2199 { "(bad)", { XX
} },
2200 { "pcmpeqq", { XM
, EXx
} },
2201 { "(bad)", { XX
} },
2206 { "(bad)", { XX
} },
2207 { "(bad)", { XX
} },
2208 { "movntdqa", { XM
, EM
} },
2209 { "(bad)", { XX
} },
2214 { "(bad)", { XX
} },
2215 { "(bad)", { XX
} },
2216 { "packusdw", { XM
, EXx
} },
2217 { "(bad)", { XX
} },
2222 { "(bad)", { XX
} },
2223 { "(bad)", { XX
} },
2224 { "pmovzxbw", { XM
, EXq
} },
2225 { "(bad)", { XX
} },
2230 { "(bad)", { XX
} },
2231 { "(bad)", { XX
} },
2232 { "pmovzxbd", { XM
, EXd
} },
2233 { "(bad)", { XX
} },
2238 { "(bad)", { XX
} },
2239 { "(bad)", { XX
} },
2240 { "pmovzxbq", { XM
, EXw
} },
2241 { "(bad)", { XX
} },
2246 { "(bad)", { XX
} },
2247 { "(bad)", { XX
} },
2248 { "pmovzxwd", { XM
, EXq
} },
2249 { "(bad)", { XX
} },
2254 { "(bad)", { XX
} },
2255 { "(bad)", { XX
} },
2256 { "pmovzxwq", { XM
, EXd
} },
2257 { "(bad)", { XX
} },
2262 { "(bad)", { XX
} },
2263 { "(bad)", { XX
} },
2264 { "pmovzxdq", { XM
, EXq
} },
2265 { "(bad)", { XX
} },
2270 { "(bad)", { XX
} },
2271 { "(bad)", { XX
} },
2272 { "pcmpgtq", { XM
, EXx
} },
2273 { "(bad)", { XX
} },
2278 { "(bad)", { XX
} },
2279 { "(bad)", { XX
} },
2280 { "pminsb", { XM
, EXx
} },
2281 { "(bad)", { XX
} },
2286 { "(bad)", { XX
} },
2287 { "(bad)", { XX
} },
2288 { "pminsd", { XM
, EXx
} },
2289 { "(bad)", { XX
} },
2294 { "(bad)", { XX
} },
2295 { "(bad)", { XX
} },
2296 { "pminuw", { XM
, EXx
} },
2297 { "(bad)", { XX
} },
2302 { "(bad)", { XX
} },
2303 { "(bad)", { XX
} },
2304 { "pminud", { XM
, EXx
} },
2305 { "(bad)", { XX
} },
2310 { "(bad)", { XX
} },
2311 { "(bad)", { XX
} },
2312 { "pmaxsb", { XM
, EXx
} },
2313 { "(bad)", { XX
} },
2318 { "(bad)", { XX
} },
2319 { "(bad)", { XX
} },
2320 { "pmaxsd", { XM
, EXx
} },
2321 { "(bad)", { XX
} },
2326 { "(bad)", { XX
} },
2327 { "(bad)", { XX
} },
2328 { "pmaxuw", { XM
, EXx
} },
2329 { "(bad)", { XX
} },
2334 { "(bad)", { XX
} },
2335 { "(bad)", { XX
} },
2336 { "pmaxud", { XM
, EXx
} },
2337 { "(bad)", { XX
} },
2342 { "(bad)", { XX
} },
2343 { "(bad)", { XX
} },
2344 { "pmulld", { XM
, EXx
} },
2345 { "(bad)", { XX
} },
2350 { "(bad)", { XX
} },
2351 { "(bad)", { XX
} },
2352 { "phminposuw", { XM
, EXx
} },
2353 { "(bad)", { XX
} },
2358 { "(bad)", { XX
} },
2359 { "(bad)", { XX
} },
2360 { "(bad)", { XX
} },
2361 { "crc32", { Gdq
, { CRC32_Fixup
, b_mode
} } },
2366 { "(bad)", { XX
} },
2367 { "(bad)", { XX
} },
2368 { "(bad)", { XX
} },
2369 { "crc32", { Gdq
, { CRC32_Fixup
, v_mode
} } },
2374 { "(bad)", { XX
} },
2375 { "(bad)", { XX
} },
2376 { "roundps", { XM
, EXx
, Ib
} },
2377 { "(bad)", { XX
} },
2382 { "(bad)", { XX
} },
2383 { "(bad)", { XX
} },
2384 { "roundpd", { XM
, EXx
, Ib
} },
2385 { "(bad)", { XX
} },
2390 { "(bad)", { XX
} },
2391 { "(bad)", { XX
} },
2392 { "roundss", { XM
, EXd
, Ib
} },
2393 { "(bad)", { XX
} },
2398 { "(bad)", { XX
} },
2399 { "(bad)", { XX
} },
2400 { "roundsd", { XM
, EXq
, Ib
} },
2401 { "(bad)", { XX
} },
2406 { "(bad)", { XX
} },
2407 { "(bad)", { XX
} },
2408 { "blendps", { XM
, EXx
, Ib
} },
2409 { "(bad)", { XX
} },
2414 { "(bad)", { XX
} },
2415 { "(bad)", { XX
} },
2416 { "blendpd", { XM
, EXx
, Ib
} },
2417 { "(bad)", { XX
} },
2422 { "(bad)", { XX
} },
2423 { "(bad)", { XX
} },
2424 { "pblendw", { XM
, EXx
, Ib
} },
2425 { "(bad)", { XX
} },
2430 { "(bad)", { XX
} },
2431 { "(bad)", { XX
} },
2432 { "pextrb", { Edqb
, XM
, Ib
} },
2433 { "(bad)", { XX
} },
2438 { "(bad)", { XX
} },
2439 { "(bad)", { XX
} },
2440 { "pextrw", { Edqw
, XM
, Ib
} },
2441 { "(bad)", { XX
} },
2446 { "(bad)", { XX
} },
2447 { "(bad)", { XX
} },
2448 { "pextrK", { Edq
, XM
, Ib
} },
2449 { "(bad)", { XX
} },
2454 { "(bad)", { XX
} },
2455 { "(bad)", { XX
} },
2456 { "extractps", { Edqd
, XM
, Ib
} },
2457 { "(bad)", { XX
} },
2462 { "(bad)", { XX
} },
2463 { "(bad)", { XX
} },
2464 { "pinsrb", { XM
, Edqb
, Ib
} },
2465 { "(bad)", { XX
} },
2470 { "(bad)", { XX
} },
2471 { "(bad)", { XX
} },
2472 { "insertps", { XM
, EXd
, Ib
} },
2473 { "(bad)", { XX
} },
2478 { "(bad)", { XX
} },
2479 { "(bad)", { XX
} },
2480 { "pinsrK", { XM
, Edq
, Ib
} },
2481 { "(bad)", { XX
} },
2486 { "(bad)", { XX
} },
2487 { "(bad)", { XX
} },
2488 { "dpps", { XM
, EXx
, Ib
} },
2489 { "(bad)", { XX
} },
2494 { "(bad)", { XX
} },
2495 { "(bad)", { XX
} },
2496 { "dppd", { XM
, EXx
, Ib
} },
2497 { "(bad)", { XX
} },
2502 { "(bad)", { XX
} },
2503 { "(bad)", { XX
} },
2504 { "mpsadbw", { XM
, EXx
, Ib
} },
2505 { "(bad)", { XX
} },
2510 { "(bad)", { XX
} },
2511 { "(bad)", { XX
} },
2512 { "pcmpestrm", { XM
, EXx
, Ib
} },
2513 { "(bad)", { XX
} },
2518 { "(bad)", { XX
} },
2519 { "(bad)", { XX
} },
2520 { "pcmpestri", { XM
, EXx
, Ib
} },
2521 { "(bad)", { XX
} },
2526 { "(bad)", { XX
} },
2527 { "(bad)", { XX
} },
2528 { "pcmpistrm", { XM
, EXx
, Ib
} },
2529 { "(bad)", { XX
} },
2534 { "(bad)", { XX
} },
2535 { "(bad)", { XX
} },
2536 { "pcmpistri", { XM
, EXx
, Ib
} },
2537 { "(bad)", { XX
} },
2540 /* PREFIX_0F73_REG_3 */
2542 { "(bad)", { XX
} },
2543 { "(bad)", { XX
} },
2544 { "psrldq", { MS
, Ib
} },
2545 { "(bad)", { XX
} },
2548 /* PREFIX_0F73_REG_7 */
2550 { "(bad)", { XX
} },
2551 { "(bad)", { XX
} },
2552 { "pslldq", { MS
, Ib
} },
2553 { "(bad)", { XX
} },
2556 /*PREFIX_0FC7_REG_6 */
2558 { "vmptrld",{ Mq
} },
2559 { "vmxon", { Mq
} },
2560 { "vmclear",{ Mq
} },
2561 { "(bad)", { XX
} },
2565 static const struct dis386 x86_64_table
[][2] = {
2568 { "push{T|}", { es
} },
2569 { "(bad)", { XX
} },
2574 { "pop{T|}", { es
} },
2575 { "(bad)", { XX
} },
2580 { "push{T|}", { cs
} },
2581 { "(bad)", { XX
} },
2586 { "push{T|}", { ss
} },
2587 { "(bad)", { XX
} },
2592 { "pop{T|}", { ss
} },
2593 { "(bad)", { XX
} },
2598 { "push{T|}", { ds
} },
2599 { "(bad)", { XX
} },
2604 { "pop{T|}", { ds
} },
2605 { "(bad)", { XX
} },
2611 { "(bad)", { XX
} },
2617 { "(bad)", { XX
} },
2623 { "(bad)", { XX
} },
2629 { "(bad)", { XX
} },
2634 { "pusha{P|}", { XX
} },
2635 { "(bad)", { XX
} },
2640 { "popa{P|}", { XX
} },
2641 { "(bad)", { XX
} },
2646 { MOD_TABLE (MOD_62_32BIT
) },
2647 { "(bad)", { XX
} },
2652 { "arpl", { Ew
, Gw
} },
2653 { "movs{lq|xd}", { Gv
, Ed
} },
2658 { "ins{R|}", { Yzr
, indirDX
} },
2659 { "ins{G|}", { Yzr
, indirDX
} },
2664 { "outs{R|}", { indirDXr
, Xz
} },
2665 { "outs{G|}", { indirDXr
, Xz
} },
2670 { "Jcall{T|}", { Ap
} },
2671 { "(bad)", { XX
} },
2676 { MOD_TABLE (MOD_C4_32BIT
) },
2677 { "(bad)", { XX
} },
2682 { MOD_TABLE (MOD_C5_32BIT
) },
2683 { "(bad)", { XX
} },
2689 { "(bad)", { XX
} },
2695 { "(bad)", { XX
} },
2701 { "(bad)", { XX
} },
2706 { "Jjmp{T|}", { Ap
} },
2707 { "(bad)", { XX
} },
2710 /* X86_64_0F01_REG_0 */
2712 { "sgdt{Q|IQ}", { M
} },
2716 /* X86_64_0F01_REG_1 */
2718 { "sidt{Q|IQ}", { M
} },
2722 /* X86_64_0F01_REG_2 */
2724 { "lgdt{Q|Q}", { M
} },
2728 /* X86_64_0F01_REG_3 */
2730 { "lidt{Q|Q}", { M
} },
2735 static const struct dis386 three_byte_table
[][256] = {
2736 /* THREE_BYTE_0F24 */
2739 { "fmaddps", { { OP_DREX4
, q_mode
} } },
2740 { "fmaddpd", { { OP_DREX4
, q_mode
} } },
2741 { "fmaddss", { { OP_DREX4
, w_mode
} } },
2742 { "fmaddsd", { { OP_DREX4
, d_mode
} } },
2743 { "fmaddps", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2744 { "fmaddpd", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2745 { "fmaddss", { { OP_DREX4
, DREX_OC1
+ w_mode
} } },
2746 { "fmaddsd", { { OP_DREX4
, DREX_OC1
+ d_mode
} } },
2748 { "fmsubps", { { OP_DREX4
, q_mode
} } },
2749 { "fmsubpd", { { OP_DREX4
, q_mode
} } },
2750 { "fmsubss", { { OP_DREX4
, w_mode
} } },
2751 { "fmsubsd", { { OP_DREX4
, d_mode
} } },
2752 { "fmsubps", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2753 { "fmsubpd", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2754 { "fmsubss", { { OP_DREX4
, DREX_OC1
+ w_mode
} } },
2755 { "fmsubsd", { { OP_DREX4
, DREX_OC1
+ d_mode
} } },
2757 { "fnmaddps", { { OP_DREX4
, q_mode
} } },
2758 { "fnmaddpd", { { OP_DREX4
, q_mode
} } },
2759 { "fnmaddss", { { OP_DREX4
, w_mode
} } },
2760 { "fnmaddsd", { { OP_DREX4
, d_mode
} } },
2761 { "fnmaddps", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2762 { "fnmaddpd", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2763 { "fnmaddss", { { OP_DREX4
, DREX_OC1
+ w_mode
} } },
2764 { "fnmaddsd", { { OP_DREX4
, DREX_OC1
+ d_mode
} } },
2766 { "fnmsubps", { { OP_DREX4
, q_mode
} } },
2767 { "fnmsubpd", { { OP_DREX4
, q_mode
} } },
2768 { "fnmsubss", { { OP_DREX4
, w_mode
} } },
2769 { "fnmsubsd", { { OP_DREX4
, d_mode
} } },
2770 { "fnmsubps", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2771 { "fnmsubpd", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2772 { "fnmsubss", { { OP_DREX4
, DREX_OC1
+ w_mode
} } },
2773 { "fnmsubsd", { { OP_DREX4
, DREX_OC1
+ d_mode
} } },
2775 { "permps", { { OP_DREX4
, q_mode
} } },
2776 { "permpd", { { OP_DREX4
, q_mode
} } },
2777 { "pcmov", { { OP_DREX4
, q_mode
} } },
2778 { "pperm", { { OP_DREX4
, q_mode
} } },
2779 { "permps", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2780 { "permpd", { { OP_DREX4
, DREX_OC1
+ q_mode
} } },
2781 { "pcmov", { { OP_DREX4
, DREX_OC1
+ w_mode
} } },
2782 { "pperm", { { OP_DREX4
, DREX_OC1
+ d_mode
} } },
2784 { "(bad)", { XX
} },
2785 { "(bad)", { XX
} },
2786 { "(bad)", { XX
} },
2787 { "(bad)", { XX
} },
2788 { "(bad)", { XX
} },
2789 { "(bad)", { XX
} },
2790 { "(bad)", { XX
} },
2791 { "(bad)", { XX
} },
2793 { "(bad)", { XX
} },
2794 { "(bad)", { XX
} },
2795 { "(bad)", { XX
} },
2796 { "(bad)", { XX
} },
2797 { "(bad)", { XX
} },
2798 { "(bad)", { XX
} },
2799 { "(bad)", { XX
} },
2800 { "(bad)", { XX
} },
2802 { "(bad)", { XX
} },
2803 { "(bad)", { XX
} },
2804 { "(bad)", { XX
} },
2805 { "(bad)", { XX
} },
2806 { "(bad)", { XX
} },
2807 { "(bad)", { XX
} },
2808 { "(bad)", { XX
} },
2809 { "(bad)", { XX
} },
2811 { "protb", { { OP_DREX3
, q_mode
} } },
2812 { "protw", { { OP_DREX3
, q_mode
} } },
2813 { "protd", { { OP_DREX3
, q_mode
} } },
2814 { "protq", { { OP_DREX3
, q_mode
} } },
2815 { "pshlb", { { OP_DREX3
, q_mode
} } },
2816 { "pshlw", { { OP_DREX3
, q_mode
} } },
2817 { "pshld", { { OP_DREX3
, q_mode
} } },
2818 { "pshlq", { { OP_DREX3
, q_mode
} } },
2820 { "pshab", { { OP_DREX3
, q_mode
} } },
2821 { "pshaw", { { OP_DREX3
, q_mode
} } },
2822 { "pshad", { { OP_DREX3
, q_mode
} } },
2823 { "pshaq", { { OP_DREX3
, q_mode
} } },
2824 { "(bad)", { XX
} },
2825 { "(bad)", { XX
} },
2826 { "(bad)", { XX
} },
2827 { "(bad)", { XX
} },
2829 { "(bad)", { XX
} },
2830 { "(bad)", { XX
} },
2831 { "(bad)", { XX
} },
2832 { "(bad)", { XX
} },
2833 { "(bad)", { XX
} },
2834 { "(bad)", { XX
} },
2835 { "(bad)", { XX
} },
2836 { "(bad)", { XX
} },
2838 { "(bad)", { XX
} },
2839 { "(bad)", { XX
} },
2840 { "(bad)", { XX
} },
2841 { "(bad)", { XX
} },
2842 { "(bad)", { XX
} },
2843 { "(bad)", { XX
} },
2844 { "(bad)", { XX
} },
2845 { "(bad)", { XX
} },
2847 { "(bad)", { XX
} },
2848 { "(bad)", { XX
} },
2849 { "(bad)", { XX
} },
2850 { "(bad)", { XX
} },
2851 { "(bad)", { XX
} },
2852 { "(bad)", { XX
} },
2853 { "(bad)", { XX
} },
2854 { "(bad)", { XX
} },
2856 { "(bad)", { XX
} },
2857 { "(bad)", { XX
} },
2858 { "(bad)", { XX
} },
2859 { "(bad)", { XX
} },
2860 { "(bad)", { XX
} },
2861 { "(bad)", { XX
} },
2862 { "(bad)", { XX
} },
2863 { "(bad)", { XX
} },
2865 { "(bad)", { XX
} },
2866 { "(bad)", { XX
} },
2867 { "(bad)", { XX
} },
2868 { "(bad)", { XX
} },
2869 { "(bad)", { XX
} },
2870 { "(bad)", { XX
} },
2871 { "(bad)", { XX
} },
2872 { "(bad)", { XX
} },
2874 { "(bad)", { XX
} },
2875 { "(bad)", { XX
} },
2876 { "(bad)", { XX
} },
2877 { "(bad)", { XX
} },
2878 { "(bad)", { XX
} },
2879 { "(bad)", { XX
} },
2880 { "(bad)", { XX
} },
2881 { "(bad)", { XX
} },
2883 { "(bad)", { XX
} },
2884 { "(bad)", { XX
} },
2885 { "(bad)", { XX
} },
2886 { "(bad)", { XX
} },
2887 { "(bad)", { XX
} },
2888 { "pmacssww", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2889 { "pmacsswd", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2890 { "pmacssdql", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2892 { "(bad)", { XX
} },
2893 { "(bad)", { XX
} },
2894 { "(bad)", { XX
} },
2895 { "(bad)", { XX
} },
2896 { "(bad)", { XX
} },
2897 { "(bad)", { XX
} },
2898 { "pmacssdd", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2899 { "pmacssdqh", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2901 { "(bad)", { XX
} },
2902 { "(bad)", { XX
} },
2903 { "(bad)", { XX
} },
2904 { "(bad)", { XX
} },
2905 { "(bad)", { XX
} },
2906 { "pmacsww", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2907 { "pmacswd", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2908 { "pmacsdql", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2910 { "(bad)", { XX
} },
2911 { "(bad)", { XX
} },
2912 { "(bad)", { XX
} },
2913 { "(bad)", { XX
} },
2914 { "(bad)", { XX
} },
2915 { "(bad)", { XX
} },
2916 { "pmacsdd", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2917 { "pmacsdqh", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2919 { "(bad)", { XX
} },
2920 { "(bad)", { XX
} },
2921 { "(bad)", { XX
} },
2922 { "(bad)", { XX
} },
2923 { "(bad)", { XX
} },
2924 { "(bad)", { XX
} },
2925 { "pmadcsswd", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2926 { "(bad)", { XX
} },
2928 { "(bad)", { XX
} },
2929 { "(bad)", { XX
} },
2930 { "(bad)", { XX
} },
2931 { "(bad)", { XX
} },
2932 { "(bad)", { XX
} },
2933 { "(bad)", { XX
} },
2934 { "(bad)", { XX
} },
2935 { "(bad)", { XX
} },
2937 { "(bad)", { XX
} },
2938 { "(bad)", { XX
} },
2939 { "(bad)", { XX
} },
2940 { "(bad)", { XX
} },
2941 { "(bad)", { XX
} },
2942 { "(bad)", { XX
} },
2943 { "pmadcswd", { { OP_DREX4
, DREX_OC1
+ DREX_NO_OC0
+ q_mode
} } },
2944 { "(bad)", { XX
} },
2946 { "(bad)", { XX
} },
2947 { "(bad)", { XX
} },
2948 { "(bad)", { XX
} },
2949 { "(bad)", { XX
} },
2950 { "(bad)", { XX
} },
2951 { "(bad)", { XX
} },
2952 { "(bad)", { XX
} },
2953 { "(bad)", { XX
} },
2955 { "(bad)", { XX
} },
2956 { "(bad)", { XX
} },
2957 { "(bad)", { XX
} },
2958 { "(bad)", { XX
} },
2959 { "(bad)", { XX
} },
2960 { "(bad)", { XX
} },
2961 { "(bad)", { XX
} },
2962 { "(bad)", { XX
} },
2964 { "(bad)", { XX
} },
2965 { "(bad)", { XX
} },
2966 { "(bad)", { XX
} },
2967 { "(bad)", { XX
} },
2968 { "(bad)", { XX
} },
2969 { "(bad)", { XX
} },
2970 { "(bad)", { XX
} },
2971 { "(bad)", { XX
} },
2973 { "(bad)", { XX
} },
2974 { "(bad)", { XX
} },
2975 { "(bad)", { XX
} },
2976 { "(bad)", { XX
} },
2977 { "(bad)", { XX
} },
2978 { "(bad)", { XX
} },
2979 { "(bad)", { XX
} },
2980 { "(bad)", { XX
} },
2982 { "(bad)", { XX
} },
2983 { "(bad)", { XX
} },
2984 { "(bad)", { XX
} },
2985 { "(bad)", { XX
} },
2986 { "(bad)", { XX
} },
2987 { "(bad)", { XX
} },
2988 { "(bad)", { XX
} },
2989 { "(bad)", { XX
} },
2991 { "(bad)", { XX
} },
2992 { "(bad)", { XX
} },
2993 { "(bad)", { XX
} },
2994 { "(bad)", { XX
} },
2995 { "(bad)", { XX
} },
2996 { "(bad)", { XX
} },
2997 { "(bad)", { XX
} },
2998 { "(bad)", { XX
} },
3000 { "(bad)", { XX
} },
3001 { "(bad)", { XX
} },
3002 { "(bad)", { XX
} },
3003 { "(bad)", { XX
} },
3004 { "(bad)", { XX
} },
3005 { "(bad)", { XX
} },
3006 { "(bad)", { XX
} },
3007 { "(bad)", { XX
} },
3009 { "(bad)", { XX
} },
3010 { "(bad)", { XX
} },
3011 { "(bad)", { XX
} },
3012 { "(bad)", { XX
} },
3013 { "(bad)", { XX
} },
3014 { "(bad)", { XX
} },
3015 { "(bad)", { XX
} },
3016 { "(bad)", { XX
} },
3018 { "(bad)", { XX
} },
3019 { "(bad)", { XX
} },
3020 { "(bad)", { XX
} },
3021 { "(bad)", { XX
} },
3022 { "(bad)", { XX
} },
3023 { "(bad)", { XX
} },
3024 { "(bad)", { XX
} },
3025 { "(bad)", { XX
} },
3027 /* THREE_BYTE_0F25 */
3030 { "(bad)", { XX
} },
3031 { "(bad)", { XX
} },
3032 { "(bad)", { XX
} },
3033 { "(bad)", { XX
} },
3034 { "(bad)", { XX
} },
3035 { "(bad)", { XX
} },
3036 { "(bad)", { XX
} },
3037 { "(bad)", { XX
} },
3039 { "(bad)", { XX
} },
3040 { "(bad)", { XX
} },
3041 { "(bad)", { XX
} },
3042 { "(bad)", { XX
} },
3043 { "(bad)", { XX
} },
3044 { "(bad)", { XX
} },
3045 { "(bad)", { XX
} },
3046 { "(bad)", { XX
} },
3048 { "(bad)", { XX
} },
3049 { "(bad)", { XX
} },
3050 { "(bad)", { XX
} },
3051 { "(bad)", { XX
} },
3052 { "(bad)", { XX
} },
3053 { "(bad)", { XX
} },
3054 { "(bad)", { XX
} },
3055 { "(bad)", { XX
} },
3057 { "(bad)", { XX
} },
3058 { "(bad)", { XX
} },
3059 { "(bad)", { XX
} },
3060 { "(bad)", { XX
} },
3061 { "(bad)", { XX
} },
3062 { "(bad)", { XX
} },
3063 { "(bad)", { XX
} },
3064 { "(bad)", { XX
} },
3066 { "(bad)", { XX
} },
3067 { "(bad)", { XX
} },
3068 { "(bad)", { XX
} },
3069 { "(bad)", { XX
} },
3070 { "(bad)", { XX
} },
3071 { "(bad)", { XX
} },
3072 { "(bad)", { XX
} },
3073 { "(bad)", { XX
} },
3075 { "(bad)", { XX
} },
3076 { "(bad)", { XX
} },
3077 { "(bad)", { XX
} },
3078 { "(bad)", { XX
} },
3079 { "comps", { { OP_DREX3
, q_mode
}, { OP_DREX_FCMP
, b_mode
} } },
3080 { "compd", { { OP_DREX3
, q_mode
}, { OP_DREX_FCMP
, b_mode
} } },
3081 { "comss", { { OP_DREX3
, w_mode
}, { OP_DREX_FCMP
, b_mode
} } },
3082 { "comsd", { { OP_DREX3
, d_mode
}, { OP_DREX_FCMP
, b_mode
} } },
3084 { "(bad)", { XX
} },
3085 { "(bad)", { XX
} },
3086 { "(bad)", { XX
} },
3087 { "(bad)", { XX
} },
3088 { "(bad)", { XX
} },
3089 { "(bad)", { XX
} },
3090 { "(bad)", { XX
} },
3091 { "(bad)", { XX
} },
3093 { "(bad)", { XX
} },
3094 { "(bad)", { XX
} },
3095 { "(bad)", { XX
} },
3096 { "(bad)", { XX
} },
3097 { "(bad)", { XX
} },
3098 { "(bad)", { XX
} },
3099 { "(bad)", { XX
} },
3100 { "(bad)", { XX
} },
3102 { "(bad)", { XX
} },
3103 { "(bad)", { XX
} },
3104 { "(bad)", { XX
} },
3105 { "(bad)", { XX
} },
3106 { "(bad)", { XX
} },
3107 { "(bad)", { XX
} },
3108 { "(bad)", { XX
} },
3109 { "(bad)", { XX
} },
3111 { "(bad)", { XX
} },
3112 { "(bad)", { XX
} },
3113 { "(bad)", { XX
} },
3114 { "(bad)", { XX
} },
3115 { "pcomb", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3116 { "pcomw", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3117 { "pcomd", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3118 { "pcomq", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3120 { "(bad)", { XX
} },
3121 { "(bad)", { XX
} },
3122 { "(bad)", { XX
} },
3123 { "(bad)", { XX
} },
3124 { "(bad)", { XX
} },
3125 { "(bad)", { XX
} },
3126 { "(bad)", { XX
} },
3127 { "(bad)", { XX
} },
3129 { "(bad)", { XX
} },
3130 { "(bad)", { XX
} },
3131 { "(bad)", { XX
} },
3132 { "(bad)", { XX
} },
3133 { "(bad)", { XX
} },
3134 { "(bad)", { XX
} },
3135 { "(bad)", { XX
} },
3136 { "(bad)", { XX
} },
3138 { "(bad)", { XX
} },
3139 { "(bad)", { XX
} },
3140 { "(bad)", { XX
} },
3141 { "(bad)", { XX
} },
3142 { "(bad)", { XX
} },
3143 { "(bad)", { XX
} },
3144 { "(bad)", { XX
} },
3145 { "(bad)", { XX
} },
3147 { "(bad)", { XX
} },
3148 { "(bad)", { XX
} },
3149 { "(bad)", { XX
} },
3150 { "(bad)", { XX
} },
3151 { "pcomub", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3152 { "pcomuw", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3153 { "pcomud", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3154 { "pcomuq", { { OP_DREX3
, q_mode
}, { OP_DREX_ICMP
, b_mode
} } },
3156 { "(bad)", { XX
} },
3157 { "(bad)", { XX
} },
3158 { "(bad)", { XX
} },
3159 { "(bad)", { XX
} },
3160 { "(bad)", { XX
} },
3161 { "(bad)", { XX
} },
3162 { "(bad)", { XX
} },
3163 { "(bad)", { XX
} },
3165 { "(bad)", { XX
} },
3166 { "(bad)", { XX
} },
3167 { "(bad)", { XX
} },
3168 { "(bad)", { XX
} },
3169 { "(bad)", { XX
} },
3170 { "(bad)", { XX
} },
3171 { "(bad)", { XX
} },
3172 { "(bad)", { XX
} },
3174 { "(bad)", { XX
} },
3175 { "(bad)", { XX
} },
3176 { "(bad)", { XX
} },
3177 { "(bad)", { XX
} },
3178 { "(bad)", { XX
} },
3179 { "(bad)", { XX
} },
3180 { "(bad)", { XX
} },
3181 { "(bad)", { XX
} },
3183 { "(bad)", { XX
} },
3184 { "(bad)", { XX
} },
3185 { "(bad)", { XX
} },
3186 { "(bad)", { XX
} },
3187 { "(bad)", { XX
} },
3188 { "(bad)", { XX
} },
3189 { "(bad)", { XX
} },
3190 { "(bad)", { XX
} },
3192 { "(bad)", { XX
} },
3193 { "(bad)", { XX
} },
3194 { "(bad)", { XX
} },
3195 { "(bad)", { XX
} },
3196 { "(bad)", { XX
} },
3197 { "(bad)", { XX
} },
3198 { "(bad)", { XX
} },
3199 { "(bad)", { XX
} },
3201 { "(bad)", { XX
} },
3202 { "(bad)", { XX
} },
3203 { "(bad)", { XX
} },
3204 { "(bad)", { XX
} },
3205 { "(bad)", { XX
} },
3206 { "(bad)", { XX
} },
3207 { "(bad)", { XX
} },
3208 { "(bad)", { XX
} },
3210 { "(bad)", { XX
} },
3211 { "(bad)", { XX
} },
3212 { "(bad)", { XX
} },
3213 { "(bad)", { XX
} },
3214 { "(bad)", { XX
} },
3215 { "(bad)", { XX
} },
3216 { "(bad)", { XX
} },
3217 { "(bad)", { XX
} },
3219 { "(bad)", { XX
} },
3220 { "(bad)", { XX
} },
3221 { "(bad)", { XX
} },
3222 { "(bad)", { XX
} },
3223 { "(bad)", { XX
} },
3224 { "(bad)", { XX
} },
3225 { "(bad)", { XX
} },
3226 { "(bad)", { XX
} },
3228 { "(bad)", { XX
} },
3229 { "(bad)", { XX
} },
3230 { "(bad)", { XX
} },
3231 { "(bad)", { XX
} },
3232 { "(bad)", { XX
} },
3233 { "(bad)", { XX
} },
3234 { "(bad)", { XX
} },
3235 { "(bad)", { XX
} },
3237 { "(bad)", { XX
} },
3238 { "(bad)", { XX
} },
3239 { "(bad)", { XX
} },
3240 { "(bad)", { XX
} },
3241 { "(bad)", { XX
} },
3242 { "(bad)", { XX
} },
3243 { "(bad)", { XX
} },
3244 { "(bad)", { XX
} },
3246 { "(bad)", { XX
} },
3247 { "(bad)", { XX
} },
3248 { "(bad)", { XX
} },
3249 { "(bad)", { XX
} },
3250 { "(bad)", { XX
} },
3251 { "(bad)", { XX
} },
3252 { "(bad)", { XX
} },
3253 { "(bad)", { XX
} },
3255 { "(bad)", { XX
} },
3256 { "(bad)", { XX
} },
3257 { "(bad)", { XX
} },
3258 { "(bad)", { XX
} },
3259 { "(bad)", { XX
} },
3260 { "(bad)", { XX
} },
3261 { "(bad)", { XX
} },
3262 { "(bad)", { XX
} },
3264 { "(bad)", { XX
} },
3265 { "(bad)", { XX
} },
3266 { "(bad)", { XX
} },
3267 { "(bad)", { XX
} },
3268 { "(bad)", { XX
} },
3269 { "(bad)", { XX
} },
3270 { "(bad)", { XX
} },
3271 { "(bad)", { XX
} },
3273 { "(bad)", { XX
} },
3274 { "(bad)", { XX
} },
3275 { "(bad)", { XX
} },
3276 { "(bad)", { XX
} },
3277 { "(bad)", { XX
} },
3278 { "(bad)", { XX
} },
3279 { "(bad)", { XX
} },
3280 { "(bad)", { XX
} },
3282 { "(bad)", { XX
} },
3283 { "(bad)", { XX
} },
3284 { "(bad)", { XX
} },
3285 { "(bad)", { XX
} },
3286 { "(bad)", { XX
} },
3287 { "(bad)", { XX
} },
3288 { "(bad)", { XX
} },
3289 { "(bad)", { XX
} },
3291 { "(bad)", { XX
} },
3292 { "(bad)", { XX
} },
3293 { "(bad)", { XX
} },
3294 { "(bad)", { XX
} },
3295 { "(bad)", { XX
} },
3296 { "(bad)", { XX
} },
3297 { "(bad)", { XX
} },
3298 { "(bad)", { XX
} },
3300 { "(bad)", { XX
} },
3301 { "(bad)", { XX
} },
3302 { "(bad)", { XX
} },
3303 { "(bad)", { XX
} },
3304 { "(bad)", { XX
} },
3305 { "(bad)", { XX
} },
3306 { "(bad)", { XX
} },
3307 { "(bad)", { XX
} },
3309 { "(bad)", { XX
} },
3310 { "(bad)", { XX
} },
3311 { "(bad)", { XX
} },
3312 { "(bad)", { XX
} },
3313 { "(bad)", { XX
} },
3314 { "(bad)", { XX
} },
3315 { "(bad)", { XX
} },
3316 { "(bad)", { XX
} },
3318 /* THREE_BYTE_0F38 */
3321 { "pshufb", { MX
, EM
} },
3322 { "phaddw", { MX
, EM
} },
3323 { "phaddd", { MX
, EM
} },
3324 { "phaddsw", { MX
, EM
} },
3325 { "pmaddubsw", { MX
, EM
} },
3326 { "phsubw", { MX
, EM
} },
3327 { "phsubd", { MX
, EM
} },
3328 { "phsubsw", { MX
, EM
} },
3330 { "psignb", { MX
, EM
} },
3331 { "psignw", { MX
, EM
} },
3332 { "psignd", { MX
, EM
} },
3333 { "pmulhrsw", { MX
, EM
} },
3334 { "(bad)", { XX
} },
3335 { "(bad)", { XX
} },
3336 { "(bad)", { XX
} },
3337 { "(bad)", { XX
} },
3339 { PREFIX_TABLE (PREFIX_0F3810
) },
3340 { "(bad)", { XX
} },
3341 { "(bad)", { XX
} },
3342 { "(bad)", { XX
} },
3343 { PREFIX_TABLE (PREFIX_0F3814
) },
3344 { PREFIX_TABLE (PREFIX_0F3815
) },
3345 { "(bad)", { XX
} },
3346 { PREFIX_TABLE (PREFIX_0F3817
) },
3348 { "(bad)", { XX
} },
3349 { "(bad)", { XX
} },
3350 { "(bad)", { XX
} },
3351 { "(bad)", { XX
} },
3352 { "pabsb", { MX
, EM
} },
3353 { "pabsw", { MX
, EM
} },
3354 { "pabsd", { MX
, EM
} },
3355 { "(bad)", { XX
} },
3357 { PREFIX_TABLE (PREFIX_0F3820
) },
3358 { PREFIX_TABLE (PREFIX_0F3821
) },
3359 { PREFIX_TABLE (PREFIX_0F3822
) },
3360 { PREFIX_TABLE (PREFIX_0F3823
) },
3361 { PREFIX_TABLE (PREFIX_0F3824
) },
3362 { PREFIX_TABLE (PREFIX_0F3825
) },
3363 { "(bad)", { XX
} },
3364 { "(bad)", { XX
} },
3366 { PREFIX_TABLE (PREFIX_0F3828
) },
3367 { PREFIX_TABLE (PREFIX_0F3829
) },
3368 { PREFIX_TABLE (PREFIX_0F382A
) },
3369 { PREFIX_TABLE (PREFIX_0F382B
) },
3370 { "(bad)", { XX
} },
3371 { "(bad)", { XX
} },
3372 { "(bad)", { XX
} },
3373 { "(bad)", { XX
} },
3375 { PREFIX_TABLE (PREFIX_0F3830
) },
3376 { PREFIX_TABLE (PREFIX_0F3831
) },
3377 { PREFIX_TABLE (PREFIX_0F3832
) },
3378 { PREFIX_TABLE (PREFIX_0F3833
) },
3379 { PREFIX_TABLE (PREFIX_0F3834
) },
3380 { PREFIX_TABLE (PREFIX_0F3835
) },
3381 { "(bad)", { XX
} },
3382 { PREFIX_TABLE (PREFIX_0F3837
) },
3384 { PREFIX_TABLE (PREFIX_0F3838
) },
3385 { PREFIX_TABLE (PREFIX_0F3839
) },
3386 { PREFIX_TABLE (PREFIX_0F383A
) },
3387 { PREFIX_TABLE (PREFIX_0F383B
) },
3388 { PREFIX_TABLE (PREFIX_0F383C
) },
3389 { PREFIX_TABLE (PREFIX_0F383D
) },
3390 { PREFIX_TABLE (PREFIX_0F383E
) },
3391 { PREFIX_TABLE (PREFIX_0F383F
) },
3393 { PREFIX_TABLE (PREFIX_0F3840
) },
3394 { PREFIX_TABLE (PREFIX_0F3841
) },
3395 { "(bad)", { XX
} },
3396 { "(bad)", { XX
} },
3397 { "(bad)", { XX
} },
3398 { "(bad)", { XX
} },
3399 { "(bad)", { XX
} },
3400 { "(bad)", { XX
} },
3402 { "(bad)", { XX
} },
3403 { "(bad)", { XX
} },
3404 { "(bad)", { XX
} },
3405 { "(bad)", { XX
} },
3406 { "(bad)", { XX
} },
3407 { "(bad)", { XX
} },
3408 { "(bad)", { XX
} },
3409 { "(bad)", { XX
} },
3411 { "(bad)", { XX
} },
3412 { "(bad)", { XX
} },
3413 { "(bad)", { XX
} },
3414 { "(bad)", { XX
} },
3415 { "(bad)", { XX
} },
3416 { "(bad)", { XX
} },
3417 { "(bad)", { XX
} },
3418 { "(bad)", { XX
} },
3420 { "(bad)", { XX
} },
3421 { "(bad)", { XX
} },
3422 { "(bad)", { XX
} },
3423 { "(bad)", { XX
} },
3424 { "(bad)", { XX
} },
3425 { "(bad)", { XX
} },
3426 { "(bad)", { XX
} },
3427 { "(bad)", { XX
} },
3429 { "(bad)", { XX
} },
3430 { "(bad)", { XX
} },
3431 { "(bad)", { XX
} },
3432 { "(bad)", { XX
} },
3433 { "(bad)", { XX
} },
3434 { "(bad)", { XX
} },
3435 { "(bad)", { XX
} },
3436 { "(bad)", { XX
} },
3438 { "(bad)", { XX
} },
3439 { "(bad)", { XX
} },
3440 { "(bad)", { XX
} },
3441 { "(bad)", { XX
} },
3442 { "(bad)", { XX
} },
3443 { "(bad)", { XX
} },
3444 { "(bad)", { XX
} },
3445 { "(bad)", { XX
} },
3447 { "(bad)", { XX
} },
3448 { "(bad)", { XX
} },
3449 { "(bad)", { XX
} },
3450 { "(bad)", { XX
} },
3451 { "(bad)", { XX
} },
3452 { "(bad)", { XX
} },
3453 { "(bad)", { XX
} },
3454 { "(bad)", { XX
} },
3456 { "(bad)", { XX
} },
3457 { "(bad)", { XX
} },
3458 { "(bad)", { XX
} },
3459 { "(bad)", { XX
} },
3460 { "(bad)", { XX
} },
3461 { "(bad)", { XX
} },
3462 { "(bad)", { XX
} },
3463 { "(bad)", { XX
} },
3465 { "(bad)", { XX
} },
3466 { "(bad)", { XX
} },
3467 { "(bad)", { XX
} },
3468 { "(bad)", { XX
} },
3469 { "(bad)", { XX
} },
3470 { "(bad)", { XX
} },
3471 { "(bad)", { XX
} },
3472 { "(bad)", { XX
} },
3474 { "(bad)", { XX
} },
3475 { "(bad)", { XX
} },
3476 { "(bad)", { XX
} },
3477 { "(bad)", { XX
} },
3478 { "(bad)", { XX
} },
3479 { "(bad)", { XX
} },
3480 { "(bad)", { XX
} },
3481 { "(bad)", { XX
} },
3483 { "(bad)", { XX
} },
3484 { "(bad)", { XX
} },
3485 { "(bad)", { XX
} },
3486 { "(bad)", { XX
} },
3487 { "(bad)", { XX
} },
3488 { "(bad)", { XX
} },
3489 { "(bad)", { XX
} },
3490 { "(bad)", { XX
} },
3492 { "(bad)", { XX
} },
3493 { "(bad)", { XX
} },
3494 { "(bad)", { XX
} },
3495 { "(bad)", { XX
} },
3496 { "(bad)", { XX
} },
3497 { "(bad)", { XX
} },
3498 { "(bad)", { XX
} },
3499 { "(bad)", { XX
} },
3501 { "(bad)", { XX
} },
3502 { "(bad)", { XX
} },
3503 { "(bad)", { XX
} },
3504 { "(bad)", { XX
} },
3505 { "(bad)", { XX
} },
3506 { "(bad)", { XX
} },
3507 { "(bad)", { XX
} },
3508 { "(bad)", { XX
} },
3510 { "(bad)", { XX
} },
3511 { "(bad)", { XX
} },
3512 { "(bad)", { XX
} },
3513 { "(bad)", { XX
} },
3514 { "(bad)", { XX
} },
3515 { "(bad)", { XX
} },
3516 { "(bad)", { XX
} },
3517 { "(bad)", { XX
} },
3519 { "(bad)", { XX
} },
3520 { "(bad)", { XX
} },
3521 { "(bad)", { XX
} },
3522 { "(bad)", { XX
} },
3523 { "(bad)", { XX
} },
3524 { "(bad)", { XX
} },
3525 { "(bad)", { XX
} },
3526 { "(bad)", { XX
} },
3528 { "(bad)", { XX
} },
3529 { "(bad)", { XX
} },
3530 { "(bad)", { XX
} },
3531 { "(bad)", { XX
} },
3532 { "(bad)", { XX
} },
3533 { "(bad)", { XX
} },
3534 { "(bad)", { XX
} },
3535 { "(bad)", { XX
} },
3537 { "(bad)", { XX
} },
3538 { "(bad)", { XX
} },
3539 { "(bad)", { XX
} },
3540 { "(bad)", { XX
} },
3541 { "(bad)", { XX
} },
3542 { "(bad)", { XX
} },
3543 { "(bad)", { XX
} },
3544 { "(bad)", { XX
} },
3546 { "(bad)", { XX
} },
3547 { "(bad)", { XX
} },
3548 { "(bad)", { XX
} },
3549 { "(bad)", { XX
} },
3550 { "(bad)", { XX
} },
3551 { "(bad)", { XX
} },
3552 { "(bad)", { XX
} },
3553 { "(bad)", { XX
} },
3555 { "(bad)", { XX
} },
3556 { "(bad)", { XX
} },
3557 { "(bad)", { XX
} },
3558 { "(bad)", { XX
} },
3559 { "(bad)", { XX
} },
3560 { "(bad)", { XX
} },
3561 { "(bad)", { XX
} },
3562 { "(bad)", { XX
} },
3564 { "(bad)", { XX
} },
3565 { "(bad)", { XX
} },
3566 { "(bad)", { XX
} },
3567 { "(bad)", { XX
} },
3568 { "(bad)", { XX
} },
3569 { "(bad)", { XX
} },
3570 { "(bad)", { XX
} },
3571 { "(bad)", { XX
} },
3573 { "(bad)", { XX
} },
3574 { "(bad)", { XX
} },
3575 { "(bad)", { XX
} },
3576 { "(bad)", { XX
} },
3577 { "(bad)", { XX
} },
3578 { "(bad)", { XX
} },
3579 { "(bad)", { XX
} },
3580 { "(bad)", { XX
} },
3582 { "(bad)", { XX
} },
3583 { "(bad)", { XX
} },
3584 { "(bad)", { XX
} },
3585 { "(bad)", { XX
} },
3586 { "(bad)", { XX
} },
3587 { "(bad)", { XX
} },
3588 { "(bad)", { XX
} },
3589 { "(bad)", { XX
} },
3591 { PREFIX_TABLE (PREFIX_0F38F0
) },
3592 { PREFIX_TABLE (PREFIX_0F38F1
) },
3593 { "(bad)", { XX
} },
3594 { "(bad)", { XX
} },
3595 { "(bad)", { XX
} },
3596 { "(bad)", { XX
} },
3597 { "(bad)", { XX
} },
3598 { "(bad)", { XX
} },
3600 { "(bad)", { XX
} },
3601 { "(bad)", { XX
} },
3602 { "(bad)", { XX
} },
3603 { "(bad)", { XX
} },
3604 { "(bad)", { XX
} },
3605 { "(bad)", { XX
} },
3606 { "(bad)", { XX
} },
3607 { "(bad)", { XX
} },
3609 /* THREE_BYTE_0F3A */
3612 { "(bad)", { XX
} },
3613 { "(bad)", { XX
} },
3614 { "(bad)", { XX
} },
3615 { "(bad)", { XX
} },
3616 { "(bad)", { XX
} },
3617 { "(bad)", { XX
} },
3618 { "(bad)", { XX
} },
3619 { "(bad)", { XX
} },
3621 { PREFIX_TABLE (PREFIX_0F3A08
) },
3622 { PREFIX_TABLE (PREFIX_0F3A09
) },
3623 { PREFIX_TABLE (PREFIX_0F3A0A
) },
3624 { PREFIX_TABLE (PREFIX_0F3A0B
) },
3625 { PREFIX_TABLE (PREFIX_0F3A0C
) },
3626 { PREFIX_TABLE (PREFIX_0F3A0D
) },
3627 { PREFIX_TABLE (PREFIX_0F3A0E
) },
3628 { "palignr", { MX
, EM
, Ib
} },
3630 { "(bad)", { XX
} },
3631 { "(bad)", { XX
} },
3632 { "(bad)", { XX
} },
3633 { "(bad)", { XX
} },
3634 { PREFIX_TABLE (PREFIX_0F3A14
) },
3635 { PREFIX_TABLE (PREFIX_0F3A15
) },
3636 { PREFIX_TABLE (PREFIX_0F3A16
) },
3637 { PREFIX_TABLE (PREFIX_0F3A17
) },
3639 { "(bad)", { XX
} },
3640 { "(bad)", { XX
} },
3641 { "(bad)", { XX
} },
3642 { "(bad)", { XX
} },
3643 { "(bad)", { XX
} },
3644 { "(bad)", { XX
} },
3645 { "(bad)", { XX
} },
3646 { "(bad)", { XX
} },
3648 { PREFIX_TABLE (PREFIX_0F3A20
) },
3649 { PREFIX_TABLE (PREFIX_0F3A21
) },
3650 { PREFIX_TABLE (PREFIX_0F3A22
) },
3651 { "(bad)", { XX
} },
3652 { "(bad)", { XX
} },
3653 { "(bad)", { XX
} },
3654 { "(bad)", { XX
} },
3655 { "(bad)", { XX
} },
3657 { "(bad)", { XX
} },
3658 { "(bad)", { XX
} },
3659 { "(bad)", { XX
} },
3660 { "(bad)", { XX
} },
3661 { "(bad)", { XX
} },
3662 { "(bad)", { XX
} },
3663 { "(bad)", { XX
} },
3664 { "(bad)", { XX
} },
3666 { "(bad)", { XX
} },
3667 { "(bad)", { XX
} },
3668 { "(bad)", { XX
} },
3669 { "(bad)", { XX
} },
3670 { "(bad)", { XX
} },
3671 { "(bad)", { XX
} },
3672 { "(bad)", { XX
} },
3673 { "(bad)", { XX
} },
3675 { "(bad)", { XX
} },
3676 { "(bad)", { XX
} },
3677 { "(bad)", { XX
} },
3678 { "(bad)", { XX
} },
3679 { "(bad)", { XX
} },
3680 { "(bad)", { XX
} },
3681 { "(bad)", { XX
} },
3682 { "(bad)", { XX
} },
3684 { PREFIX_TABLE (PREFIX_0F3A40
) },
3685 { PREFIX_TABLE (PREFIX_0F3A41
) },
3686 { PREFIX_TABLE (PREFIX_0F3A42
) },
3687 { "(bad)", { XX
} },
3688 { "(bad)", { XX
} },
3689 { "(bad)", { XX
} },
3690 { "(bad)", { XX
} },
3691 { "(bad)", { XX
} },
3693 { "(bad)", { XX
} },
3694 { "(bad)", { XX
} },
3695 { "(bad)", { XX
} },
3696 { "(bad)", { XX
} },
3697 { "(bad)", { XX
} },
3698 { "(bad)", { XX
} },
3699 { "(bad)", { XX
} },
3700 { "(bad)", { XX
} },
3702 { "(bad)", { XX
} },
3703 { "(bad)", { XX
} },
3704 { "(bad)", { XX
} },
3705 { "(bad)", { XX
} },
3706 { "(bad)", { XX
} },
3707 { "(bad)", { XX
} },
3708 { "(bad)", { XX
} },
3709 { "(bad)", { XX
} },
3711 { "(bad)", { XX
} },
3712 { "(bad)", { XX
} },
3713 { "(bad)", { XX
} },
3714 { "(bad)", { XX
} },
3715 { "(bad)", { XX
} },
3716 { "(bad)", { XX
} },
3717 { "(bad)", { XX
} },
3718 { "(bad)", { XX
} },
3720 { PREFIX_TABLE (PREFIX_0F3A60
) },
3721 { PREFIX_TABLE (PREFIX_0F3A61
) },
3722 { PREFIX_TABLE (PREFIX_0F3A62
) },
3723 { PREFIX_TABLE (PREFIX_0F3A63
) },
3724 { "(bad)", { XX
} },
3725 { "(bad)", { XX
} },
3726 { "(bad)", { XX
} },
3727 { "(bad)", { XX
} },
3729 { "(bad)", { XX
} },
3730 { "(bad)", { XX
} },
3731 { "(bad)", { XX
} },
3732 { "(bad)", { XX
} },
3733 { "(bad)", { XX
} },
3734 { "(bad)", { XX
} },
3735 { "(bad)", { XX
} },
3736 { "(bad)", { XX
} },
3738 { "(bad)", { XX
} },
3739 { "(bad)", { XX
} },
3740 { "(bad)", { XX
} },
3741 { "(bad)", { XX
} },
3742 { "(bad)", { XX
} },
3743 { "(bad)", { XX
} },
3744 { "(bad)", { XX
} },
3745 { "(bad)", { XX
} },
3747 { "(bad)", { XX
} },
3748 { "(bad)", { XX
} },
3749 { "(bad)", { XX
} },
3750 { "(bad)", { XX
} },
3751 { "(bad)", { XX
} },
3752 { "(bad)", { XX
} },
3753 { "(bad)", { XX
} },
3754 { "(bad)", { XX
} },
3756 { "(bad)", { XX
} },
3757 { "(bad)", { XX
} },
3758 { "(bad)", { XX
} },
3759 { "(bad)", { XX
} },
3760 { "(bad)", { XX
} },
3761 { "(bad)", { XX
} },
3762 { "(bad)", { XX
} },
3763 { "(bad)", { XX
} },
3765 { "(bad)", { XX
} },
3766 { "(bad)", { XX
} },
3767 { "(bad)", { XX
} },
3768 { "(bad)", { XX
} },
3769 { "(bad)", { XX
} },
3770 { "(bad)", { XX
} },
3771 { "(bad)", { XX
} },
3772 { "(bad)", { XX
} },
3774 { "(bad)", { XX
} },
3775 { "(bad)", { XX
} },
3776 { "(bad)", { XX
} },
3777 { "(bad)", { XX
} },
3778 { "(bad)", { XX
} },
3779 { "(bad)", { XX
} },
3780 { "(bad)", { XX
} },
3781 { "(bad)", { XX
} },
3783 { "(bad)", { XX
} },
3784 { "(bad)", { XX
} },
3785 { "(bad)", { XX
} },
3786 { "(bad)", { XX
} },
3787 { "(bad)", { XX
} },
3788 { "(bad)", { XX
} },
3789 { "(bad)", { XX
} },
3790 { "(bad)", { XX
} },
3792 { "(bad)", { XX
} },
3793 { "(bad)", { XX
} },
3794 { "(bad)", { XX
} },
3795 { "(bad)", { XX
} },
3796 { "(bad)", { XX
} },
3797 { "(bad)", { XX
} },
3798 { "(bad)", { XX
} },
3799 { "(bad)", { XX
} },
3801 { "(bad)", { XX
} },
3802 { "(bad)", { XX
} },
3803 { "(bad)", { XX
} },
3804 { "(bad)", { XX
} },
3805 { "(bad)", { XX
} },
3806 { "(bad)", { XX
} },
3807 { "(bad)", { XX
} },
3808 { "(bad)", { XX
} },
3810 { "(bad)", { XX
} },
3811 { "(bad)", { XX
} },
3812 { "(bad)", { XX
} },
3813 { "(bad)", { XX
} },
3814 { "(bad)", { XX
} },
3815 { "(bad)", { XX
} },
3816 { "(bad)", { XX
} },
3817 { "(bad)", { XX
} },
3819 { "(bad)", { XX
} },
3820 { "(bad)", { XX
} },
3821 { "(bad)", { XX
} },
3822 { "(bad)", { XX
} },
3823 { "(bad)", { XX
} },
3824 { "(bad)", { XX
} },
3825 { "(bad)", { XX
} },
3826 { "(bad)", { XX
} },
3828 { "(bad)", { XX
} },
3829 { "(bad)", { XX
} },
3830 { "(bad)", { XX
} },
3831 { "(bad)", { XX
} },
3832 { "(bad)", { XX
} },
3833 { "(bad)", { XX
} },
3834 { "(bad)", { XX
} },
3835 { "(bad)", { XX
} },
3837 { "(bad)", { XX
} },
3838 { "(bad)", { XX
} },
3839 { "(bad)", { XX
} },
3840 { "(bad)", { XX
} },
3841 { "(bad)", { XX
} },
3842 { "(bad)", { XX
} },
3843 { "(bad)", { XX
} },
3844 { "(bad)", { XX
} },
3846 { "(bad)", { XX
} },
3847 { "(bad)", { XX
} },
3848 { "(bad)", { XX
} },
3849 { "(bad)", { XX
} },
3850 { "(bad)", { XX
} },
3851 { "(bad)", { XX
} },
3852 { "(bad)", { XX
} },
3853 { "(bad)", { XX
} },
3855 { "(bad)", { XX
} },
3856 { "(bad)", { XX
} },
3857 { "(bad)", { XX
} },
3858 { "(bad)", { XX
} },
3859 { "(bad)", { XX
} },
3860 { "(bad)", { XX
} },
3861 { "(bad)", { XX
} },
3862 { "(bad)", { XX
} },
3864 { "(bad)", { XX
} },
3865 { "(bad)", { XX
} },
3866 { "(bad)", { XX
} },
3867 { "(bad)", { XX
} },
3868 { "(bad)", { XX
} },
3869 { "(bad)", { XX
} },
3870 { "(bad)", { XX
} },
3871 { "(bad)", { XX
} },
3873 { "(bad)", { XX
} },
3874 { "(bad)", { XX
} },
3875 { "(bad)", { XX
} },
3876 { "(bad)", { XX
} },
3877 { "(bad)", { XX
} },
3878 { "(bad)", { XX
} },
3879 { "(bad)", { XX
} },
3880 { "(bad)", { XX
} },
3882 { "(bad)", { XX
} },
3883 { "(bad)", { XX
} },
3884 { "(bad)", { XX
} },
3885 { "(bad)", { XX
} },
3886 { "(bad)", { XX
} },
3887 { "(bad)", { XX
} },
3888 { "(bad)", { XX
} },
3889 { "(bad)", { XX
} },
3891 { "(bad)", { XX
} },
3892 { "(bad)", { XX
} },
3893 { "(bad)", { XX
} },
3894 { "(bad)", { XX
} },
3895 { "(bad)", { XX
} },
3896 { "(bad)", { XX
} },
3897 { "(bad)", { XX
} },
3898 { "(bad)", { XX
} },
3900 /* THREE_BYTE_SSE5_0F7A */
3903 { "(bad)", { XX
} },
3904 { "(bad)", { XX
} },
3905 { "(bad)", { XX
} },
3906 { "(bad)", { XX
} },
3907 { "(bad)", { XX
} },
3908 { "(bad)", { XX
} },
3909 { "(bad)", { XX
} },
3910 { "(bad)", { XX
} },
3912 { "(bad)", { XX
} },
3913 { "(bad)", { XX
} },
3914 { "(bad)", { XX
} },
3915 { "(bad)", { XX
} },
3916 { "(bad)", { XX
} },
3917 { "(bad)", { XX
} },
3918 { "(bad)", { XX
} },
3919 { "(bad)", { XX
} },
3921 { "frczps", { XM
, EXq
} },
3922 { "frczpd", { XM
, EXq
} },
3923 { "frczss", { XM
, EXq
} },
3924 { "frczsd", { XM
, EXq
} },
3925 { "(bad)", { XX
} },
3926 { "(bad)", { XX
} },
3927 { "(bad)", { XX
} },
3928 { "(bad)", { XX
} },
3930 { "(bad)", { XX
} },
3931 { "(bad)", { XX
} },
3932 { "(bad)", { XX
} },
3933 { "(bad)", { XX
} },
3934 { "(bad)", { XX
} },
3935 { "(bad)", { XX
} },
3936 { "(bad)", { XX
} },
3937 { "(bad)", { XX
} },
3939 { "ptest", { XX
} },
3940 { "(bad)", { XX
} },
3941 { "(bad)", { XX
} },
3942 { "(bad)", { XX
} },
3943 { "(bad)", { XX
} },
3944 { "(bad)", { XX
} },
3945 { "(bad)", { XX
} },
3946 { "(bad)", { XX
} },
3948 { "(bad)", { XX
} },
3949 { "(bad)", { XX
} },
3950 { "(bad)", { XX
} },
3951 { "(bad)", { XX
} },
3952 { "(bad)", { XX
} },
3953 { "(bad)", { XX
} },
3954 { "(bad)", { XX
} },
3955 { "(bad)", { XX
} },
3957 { "cvtph2ps", { XM
, EXd
} },
3958 { "cvtps2ph", { EXd
, XM
} },
3959 { "(bad)", { XX
} },
3960 { "(bad)", { XX
} },
3961 { "(bad)", { XX
} },
3962 { "(bad)", { XX
} },
3963 { "(bad)", { XX
} },
3964 { "(bad)", { XX
} },
3966 { "(bad)", { XX
} },
3967 { "(bad)", { XX
} },
3968 { "(bad)", { XX
} },
3969 { "(bad)", { XX
} },
3970 { "(bad)", { XX
} },
3971 { "(bad)", { XX
} },
3972 { "(bad)", { XX
} },
3973 { "(bad)", { XX
} },
3975 { "(bad)", { XX
} },
3976 { "phaddbw", { XM
, EXq
} },
3977 { "phaddbd", { XM
, EXq
} },
3978 { "phaddbq", { XM
, EXq
} },
3979 { "(bad)", { XX
} },
3980 { "(bad)", { XX
} },
3981 { "phaddwd", { XM
, EXq
} },
3982 { "phaddwq", { XM
, EXq
} },
3984 { "(bad)", { XX
} },
3985 { "(bad)", { XX
} },
3986 { "(bad)", { XX
} },
3987 { "phadddq", { XM
, EXq
} },
3988 { "(bad)", { XX
} },
3989 { "(bad)", { XX
} },
3990 { "(bad)", { XX
} },
3991 { "(bad)", { XX
} },
3993 { "(bad)", { XX
} },
3994 { "phaddubw", { XM
, EXq
} },
3995 { "phaddubd", { XM
, EXq
} },
3996 { "phaddubq", { XM
, EXq
} },
3997 { "(bad)", { XX
} },
3998 { "(bad)", { XX
} },
3999 { "phadduwd", { XM
, EXq
} },
4000 { "phadduwq", { XM
, EXq
} },
4002 { "(bad)", { XX
} },
4003 { "(bad)", { XX
} },
4004 { "(bad)", { XX
} },
4005 { "phaddudq", { XM
, EXq
} },
4006 { "(bad)", { XX
} },
4007 { "(bad)", { XX
} },
4008 { "(bad)", { XX
} },
4009 { "(bad)", { XX
} },
4011 { "(bad)", { XX
} },
4012 { "phsubbw", { XM
, EXq
} },
4013 { "phsubbd", { XM
, EXq
} },
4014 { "phsubbq", { XM
, EXq
} },
4015 { "(bad)", { XX
} },
4016 { "(bad)", { XX
} },
4017 { "(bad)", { XX
} },
4018 { "(bad)", { XX
} },
4020 { "(bad)", { XX
} },
4021 { "(bad)", { XX
} },
4022 { "(bad)", { XX
} },
4023 { "(bad)", { XX
} },
4024 { "(bad)", { XX
} },
4025 { "(bad)", { XX
} },
4026 { "(bad)", { XX
} },
4027 { "(bad)", { XX
} },
4029 { "(bad)", { XX
} },
4030 { "(bad)", { XX
} },
4031 { "(bad)", { XX
} },
4032 { "(bad)", { XX
} },
4033 { "(bad)", { XX
} },
4034 { "(bad)", { XX
} },
4035 { "(bad)", { XX
} },
4036 { "(bad)", { XX
} },
4038 { "(bad)", { XX
} },
4039 { "(bad)", { XX
} },
4040 { "(bad)", { XX
} },
4041 { "(bad)", { XX
} },
4042 { "(bad)", { XX
} },
4043 { "(bad)", { XX
} },
4044 { "(bad)", { XX
} },
4045 { "(bad)", { XX
} },
4047 { "(bad)", { XX
} },
4048 { "(bad)", { XX
} },
4049 { "(bad)", { XX
} },
4050 { "(bad)", { XX
} },
4051 { "(bad)", { XX
} },
4052 { "(bad)", { XX
} },
4053 { "(bad)", { XX
} },
4054 { "(bad)", { XX
} },
4056 { "(bad)", { XX
} },
4057 { "(bad)", { XX
} },
4058 { "(bad)", { XX
} },
4059 { "(bad)", { XX
} },
4060 { "(bad)", { XX
} },
4061 { "(bad)", { XX
} },
4062 { "(bad)", { XX
} },
4063 { "(bad)", { XX
} },
4065 { "(bad)", { XX
} },
4066 { "(bad)", { XX
} },
4067 { "(bad)", { XX
} },
4068 { "(bad)", { XX
} },
4069 { "(bad)", { XX
} },
4070 { "(bad)", { XX
} },
4071 { "(bad)", { XX
} },
4072 { "(bad)", { XX
} },
4074 { "(bad)", { XX
} },
4075 { "(bad)", { XX
} },
4076 { "(bad)", { XX
} },
4077 { "(bad)", { XX
} },
4078 { "(bad)", { XX
} },
4079 { "(bad)", { XX
} },
4080 { "(bad)", { XX
} },
4081 { "(bad)", { XX
} },
4083 { "(bad)", { XX
} },
4084 { "(bad)", { XX
} },
4085 { "(bad)", { XX
} },
4086 { "(bad)", { XX
} },
4087 { "(bad)", { XX
} },
4088 { "(bad)", { XX
} },
4089 { "(bad)", { XX
} },
4090 { "(bad)", { XX
} },
4092 { "(bad)", { XX
} },
4093 { "(bad)", { XX
} },
4094 { "(bad)", { XX
} },
4095 { "(bad)", { XX
} },
4096 { "(bad)", { XX
} },
4097 { "(bad)", { XX
} },
4098 { "(bad)", { XX
} },
4099 { "(bad)", { XX
} },
4101 { "(bad)", { XX
} },
4102 { "(bad)", { XX
} },
4103 { "(bad)", { XX
} },
4104 { "(bad)", { XX
} },
4105 { "(bad)", { XX
} },
4106 { "(bad)", { XX
} },
4107 { "(bad)", { XX
} },
4108 { "(bad)", { XX
} },
4110 { "(bad)", { XX
} },
4111 { "(bad)", { XX
} },
4112 { "(bad)", { XX
} },
4113 { "(bad)", { XX
} },
4114 { "(bad)", { XX
} },
4115 { "(bad)", { XX
} },
4116 { "(bad)", { XX
} },
4117 { "(bad)", { XX
} },
4119 { "(bad)", { XX
} },
4120 { "(bad)", { XX
} },
4121 { "(bad)", { XX
} },
4122 { "(bad)", { XX
} },
4123 { "(bad)", { XX
} },
4124 { "(bad)", { XX
} },
4125 { "(bad)", { XX
} },
4126 { "(bad)", { XX
} },
4128 { "(bad)", { XX
} },
4129 { "(bad)", { XX
} },
4130 { "(bad)", { XX
} },
4131 { "(bad)", { XX
} },
4132 { "(bad)", { XX
} },
4133 { "(bad)", { XX
} },
4134 { "(bad)", { XX
} },
4135 { "(bad)", { XX
} },
4137 { "(bad)", { XX
} },
4138 { "(bad)", { XX
} },
4139 { "(bad)", { XX
} },
4140 { "(bad)", { XX
} },
4141 { "(bad)", { XX
} },
4142 { "(bad)", { XX
} },
4143 { "(bad)", { XX
} },
4144 { "(bad)", { XX
} },
4146 { "(bad)", { XX
} },
4147 { "(bad)", { XX
} },
4148 { "(bad)", { XX
} },
4149 { "(bad)", { XX
} },
4150 { "(bad)", { XX
} },
4151 { "(bad)", { XX
} },
4152 { "(bad)", { XX
} },
4153 { "(bad)", { XX
} },
4155 { "(bad)", { XX
} },
4156 { "(bad)", { XX
} },
4157 { "(bad)", { XX
} },
4158 { "(bad)", { XX
} },
4159 { "(bad)", { XX
} },
4160 { "(bad)", { XX
} },
4161 { "(bad)", { XX
} },
4162 { "(bad)", { XX
} },
4164 { "(bad)", { XX
} },
4165 { "(bad)", { XX
} },
4166 { "(bad)", { XX
} },
4167 { "(bad)", { XX
} },
4168 { "(bad)", { XX
} },
4169 { "(bad)", { XX
} },
4170 { "(bad)", { XX
} },
4171 { "(bad)", { XX
} },
4173 { "(bad)", { XX
} },
4174 { "(bad)", { XX
} },
4175 { "(bad)", { XX
} },
4176 { "(bad)", { XX
} },
4177 { "(bad)", { XX
} },
4178 { "(bad)", { XX
} },
4179 { "(bad)", { XX
} },
4180 { "(bad)", { XX
} },
4182 { "(bad)", { XX
} },
4183 { "(bad)", { XX
} },
4184 { "(bad)", { XX
} },
4185 { "(bad)", { XX
} },
4186 { "(bad)", { XX
} },
4187 { "(bad)", { XX
} },
4188 { "(bad)", { XX
} },
4189 { "(bad)", { XX
} },
4191 /* THREE_BYTE_SSE5_0F7B */
4194 { "(bad)", { XX
} },
4195 { "(bad)", { XX
} },
4196 { "(bad)", { XX
} },
4197 { "(bad)", { XX
} },
4198 { "(bad)", { XX
} },
4199 { "(bad)", { XX
} },
4200 { "(bad)", { XX
} },
4201 { "(bad)", { XX
} },
4203 { "(bad)", { XX
} },
4204 { "(bad)", { XX
} },
4205 { "(bad)", { XX
} },
4206 { "(bad)", { XX
} },
4207 { "(bad)", { XX
} },
4208 { "(bad)", { XX
} },
4209 { "(bad)", { XX
} },
4210 { "(bad)", { XX
} },
4212 { "(bad)", { XX
} },
4213 { "(bad)", { XX
} },
4214 { "(bad)", { XX
} },
4215 { "(bad)", { XX
} },
4216 { "(bad)", { XX
} },
4217 { "(bad)", { XX
} },
4218 { "(bad)", { XX
} },
4219 { "(bad)", { XX
} },
4221 { "(bad)", { XX
} },
4222 { "(bad)", { XX
} },
4223 { "(bad)", { XX
} },
4224 { "(bad)", { XX
} },
4225 { "(bad)", { XX
} },
4226 { "(bad)", { XX
} },
4227 { "(bad)", { XX
} },
4228 { "(bad)", { XX
} },
4230 { "(bad)", { XX
} },
4231 { "(bad)", { XX
} },
4232 { "(bad)", { XX
} },
4233 { "(bad)", { XX
} },
4234 { "(bad)", { XX
} },
4235 { "(bad)", { XX
} },
4236 { "(bad)", { XX
} },
4237 { "(bad)", { XX
} },
4239 { "(bad)", { XX
} },
4240 { "(bad)", { XX
} },
4241 { "(bad)", { XX
} },
4242 { "(bad)", { XX
} },
4243 { "(bad)", { XX
} },
4244 { "(bad)", { XX
} },
4245 { "(bad)", { XX
} },
4246 { "(bad)", { XX
} },
4248 { "(bad)", { XX
} },
4249 { "(bad)", { XX
} },
4250 { "(bad)", { XX
} },
4251 { "(bad)", { XX
} },
4252 { "(bad)", { XX
} },
4253 { "(bad)", { XX
} },
4254 { "(bad)", { XX
} },
4255 { "(bad)", { XX
} },
4257 { "(bad)", { XX
} },
4258 { "(bad)", { XX
} },
4259 { "(bad)", { XX
} },
4260 { "(bad)", { XX
} },
4261 { "(bad)", { XX
} },
4262 { "(bad)", { XX
} },
4263 { "(bad)", { XX
} },
4264 { "(bad)", { XX
} },
4266 { "protb", { XM
, EXq
, Ib
} },
4267 { "protw", { XM
, EXq
, Ib
} },
4268 { "protd", { XM
, EXq
, Ib
} },
4269 { "protq", { XM
, EXq
, Ib
} },
4270 { "pshlb", { XM
, EXq
, Ib
} },
4271 { "pshlw", { XM
, EXq
, Ib
} },
4272 { "pshld", { XM
, EXq
, Ib
} },
4273 { "pshlq", { XM
, EXq
, Ib
} },
4275 { "pshab", { XM
, EXq
, Ib
} },
4276 { "pshaw", { XM
, EXq
, Ib
} },
4277 { "pshad", { XM
, EXq
, Ib
} },
4278 { "pshaq", { XM
, EXq
, Ib
} },
4279 { "(bad)", { XX
} },
4280 { "(bad)", { XX
} },
4281 { "(bad)", { XX
} },
4282 { "(bad)", { XX
} },
4284 { "(bad)", { XX
} },
4285 { "(bad)", { XX
} },
4286 { "(bad)", { XX
} },
4287 { "(bad)", { XX
} },
4288 { "(bad)", { XX
} },
4289 { "(bad)", { XX
} },
4290 { "(bad)", { XX
} },
4291 { "(bad)", { XX
} },
4293 { "(bad)", { XX
} },
4294 { "(bad)", { XX
} },
4295 { "(bad)", { XX
} },
4296 { "(bad)", { XX
} },
4297 { "(bad)", { XX
} },
4298 { "(bad)", { XX
} },
4299 { "(bad)", { XX
} },
4300 { "(bad)", { XX
} },
4302 { "(bad)", { XX
} },
4303 { "(bad)", { XX
} },
4304 { "(bad)", { XX
} },
4305 { "(bad)", { XX
} },
4306 { "(bad)", { XX
} },
4307 { "(bad)", { XX
} },
4308 { "(bad)", { XX
} },
4309 { "(bad)", { XX
} },
4311 { "(bad)", { XX
} },
4312 { "(bad)", { XX
} },
4313 { "(bad)", { XX
} },
4314 { "(bad)", { XX
} },
4315 { "(bad)", { XX
} },
4316 { "(bad)", { XX
} },
4317 { "(bad)", { XX
} },
4318 { "(bad)", { XX
} },
4320 { "(bad)", { XX
} },
4321 { "(bad)", { XX
} },
4322 { "(bad)", { XX
} },
4323 { "(bad)", { XX
} },
4324 { "(bad)", { XX
} },
4325 { "(bad)", { XX
} },
4326 { "(bad)", { XX
} },
4327 { "(bad)", { XX
} },
4329 { "(bad)", { XX
} },
4330 { "(bad)", { XX
} },
4331 { "(bad)", { XX
} },
4332 { "(bad)", { XX
} },
4333 { "(bad)", { XX
} },
4334 { "(bad)", { XX
} },
4335 { "(bad)", { XX
} },
4336 { "(bad)", { XX
} },
4338 { "(bad)", { XX
} },
4339 { "(bad)", { XX
} },
4340 { "(bad)", { XX
} },
4341 { "(bad)", { XX
} },
4342 { "(bad)", { XX
} },
4343 { "(bad)", { XX
} },
4344 { "(bad)", { XX
} },
4345 { "(bad)", { XX
} },
4347 { "(bad)", { XX
} },
4348 { "(bad)", { XX
} },
4349 { "(bad)", { XX
} },
4350 { "(bad)", { XX
} },
4351 { "(bad)", { XX
} },
4352 { "(bad)", { XX
} },
4353 { "(bad)", { XX
} },
4354 { "(bad)", { XX
} },
4356 { "(bad)", { XX
} },
4357 { "(bad)", { XX
} },
4358 { "(bad)", { XX
} },
4359 { "(bad)", { XX
} },
4360 { "(bad)", { XX
} },
4361 { "(bad)", { XX
} },
4362 { "(bad)", { XX
} },
4363 { "(bad)", { XX
} },
4365 { "(bad)", { XX
} },
4366 { "(bad)", { XX
} },
4367 { "(bad)", { XX
} },
4368 { "(bad)", { XX
} },
4369 { "(bad)", { XX
} },
4370 { "(bad)", { XX
} },
4371 { "(bad)", { XX
} },
4372 { "(bad)", { XX
} },
4374 { "(bad)", { XX
} },
4375 { "(bad)", { XX
} },
4376 { "(bad)", { XX
} },
4377 { "(bad)", { XX
} },
4378 { "(bad)", { XX
} },
4379 { "(bad)", { XX
} },
4380 { "(bad)", { XX
} },
4381 { "(bad)", { XX
} },
4383 { "(bad)", { XX
} },
4384 { "(bad)", { XX
} },
4385 { "(bad)", { XX
} },
4386 { "(bad)", { XX
} },
4387 { "(bad)", { XX
} },
4388 { "(bad)", { XX
} },
4389 { "(bad)", { XX
} },
4390 { "(bad)", { XX
} },
4392 { "(bad)", { XX
} },
4393 { "(bad)", { XX
} },
4394 { "(bad)", { XX
} },
4395 { "(bad)", { XX
} },
4396 { "(bad)", { XX
} },
4397 { "(bad)", { XX
} },
4398 { "(bad)", { XX
} },
4399 { "(bad)", { XX
} },
4401 { "(bad)", { XX
} },
4402 { "(bad)", { XX
} },
4403 { "(bad)", { XX
} },
4404 { "(bad)", { XX
} },
4405 { "(bad)", { XX
} },
4406 { "(bad)", { XX
} },
4407 { "(bad)", { XX
} },
4408 { "(bad)", { XX
} },
4410 { "(bad)", { XX
} },
4411 { "(bad)", { XX
} },
4412 { "(bad)", { XX
} },
4413 { "(bad)", { XX
} },
4414 { "(bad)", { XX
} },
4415 { "(bad)", { XX
} },
4416 { "(bad)", { XX
} },
4417 { "(bad)", { XX
} },
4419 { "(bad)", { XX
} },
4420 { "(bad)", { XX
} },
4421 { "(bad)", { XX
} },
4422 { "(bad)", { XX
} },
4423 { "(bad)", { XX
} },
4424 { "(bad)", { XX
} },
4425 { "(bad)", { XX
} },
4426 { "(bad)", { XX
} },
4428 { "(bad)", { XX
} },
4429 { "(bad)", { XX
} },
4430 { "(bad)", { XX
} },
4431 { "(bad)", { XX
} },
4432 { "(bad)", { XX
} },
4433 { "(bad)", { XX
} },
4434 { "(bad)", { XX
} },
4435 { "(bad)", { XX
} },
4437 { "(bad)", { XX
} },
4438 { "(bad)", { XX
} },
4439 { "(bad)", { XX
} },
4440 { "(bad)", { XX
} },
4441 { "(bad)", { XX
} },
4442 { "(bad)", { XX
} },
4443 { "(bad)", { XX
} },
4444 { "(bad)", { XX
} },
4446 { "(bad)", { XX
} },
4447 { "(bad)", { XX
} },
4448 { "(bad)", { XX
} },
4449 { "(bad)", { XX
} },
4450 { "(bad)", { XX
} },
4451 { "(bad)", { XX
} },
4452 { "(bad)", { XX
} },
4453 { "(bad)", { XX
} },
4455 { "(bad)", { XX
} },
4456 { "(bad)", { XX
} },
4457 { "(bad)", { XX
} },
4458 { "(bad)", { XX
} },
4459 { "(bad)", { XX
} },
4460 { "(bad)", { XX
} },
4461 { "(bad)", { XX
} },
4462 { "(bad)", { XX
} },
4464 { "(bad)", { XX
} },
4465 { "(bad)", { XX
} },
4466 { "(bad)", { XX
} },
4467 { "(bad)", { XX
} },
4468 { "(bad)", { XX
} },
4469 { "(bad)", { XX
} },
4470 { "(bad)", { XX
} },
4471 { "(bad)", { XX
} },
4473 { "(bad)", { XX
} },
4474 { "(bad)", { XX
} },
4475 { "(bad)", { XX
} },
4476 { "(bad)", { XX
} },
4477 { "(bad)", { XX
} },
4478 { "(bad)", { XX
} },
4479 { "(bad)", { XX
} },
4480 { "(bad)", { XX
} },
4484 static const struct dis386 mod_table
[][2] = {
4487 { "leaS", { Gv
, M
} },
4488 { "(bad)", { XX
} },
4492 { "movlpX", { EXq
, XM
} },
4493 { "(bad)", { XX
} },
4497 { "movhpX", { EXq
, XM
} },
4498 { "(bad)", { XX
} },
4502 { "(bad)", { XX
} },
4503 { "movZ", { Rm
, Cm
} },
4507 { "(bad)", { XX
} },
4508 { "movZ", { Rm
, Dm
} },
4512 { "(bad)", { XX
} },
4513 { "movZ", { Cm
, Rm
} },
4517 { "(bad)", { XX
} },
4518 { "movZ", { Dm
, Rm
} },
4522 { THREE_BYTE_TABLE (THREE_BYTE_0F24
) },
4523 { "movL", { Rd
, Td
} },
4527 { "(bad)", { XX
} },
4528 { "movL", { Td
, Rd
} },
4532 { "lssS", { Gv
, Mp
} },
4533 { "(bad)", { XX
} },
4537 { "lfsS", { Gv
, Mp
} },
4538 { "(bad)", { XX
} },
4542 { "lgsS", { Gv
, Mp
} },
4543 { "(bad)", { XX
} },
4546 /* MOD_0F01_REG_0 */
4547 { X86_64_TABLE (X86_64_0F01_REG_0
) },
4548 { RM_TABLE (RM_0F01_REG_0
) },
4551 /* MOD_0F01_REG_1 */
4552 { X86_64_TABLE (X86_64_0F01_REG_1
) },
4553 { RM_TABLE (RM_0F01_REG_1
) },
4556 /* MOD_0F01_REG_2 */
4557 { X86_64_TABLE (X86_64_0F01_REG_2
) },
4558 { "(bad)", { XX
} },
4561 /* MOD_0F01_REG_3 */
4562 { X86_64_TABLE (X86_64_0F01_REG_3
) },
4563 { RM_TABLE (RM_0F01_REG_3
) },
4566 /* MOD_0F01_REG_7 */
4567 { "invlpg", { Mb
} },
4568 { RM_TABLE (RM_0F01_REG_7
) },
4571 /* MOD_0F18_REG_0 */
4572 { "prefetchnta", { Mb
} },
4573 { "(bad)", { XX
} },
4576 /* MOD_0F18_REG_1 */
4577 { "prefetcht0", { Mb
} },
4578 { "(bad)", { XX
} },
4581 /* MOD_0F18_REG_2 */
4582 { "prefetcht1", { Mb
} },
4583 { "(bad)", { XX
} },
4586 /* MOD_0F18_REG_3 */
4587 { "prefetcht2", { Mb
} },
4588 { "(bad)", { XX
} },
4591 /* MOD_0F71_REG_2 */
4592 { "(bad)", { XX
} },
4593 { "psrlw", { MS
, Ib
} },
4596 /* MOD_0F71_REG_4 */
4597 { "(bad)", { XX
} },
4598 { "psraw", { MS
, Ib
} },
4601 /* MOD_0F71_REG_6 */
4602 { "(bad)", { XX
} },
4603 { "psllw", { MS
, Ib
} },
4606 /* MOD_0F72_REG_2 */
4607 { "(bad)", { XX
} },
4608 { "psrld", { MS
, Ib
} },
4611 /* MOD_0F72_REG_4 */
4612 { "(bad)", { XX
} },
4613 { "psrad", { MS
, Ib
} },
4616 /* MOD_0F72_REG_6 */
4617 { "(bad)", { XX
} },
4618 { "pslld", { MS
, Ib
} },
4621 /* MOD_0F73_REG_2 */
4622 { "(bad)", { XX
} },
4623 { "psrlq", { MS
, Ib
} },
4626 /* MOD_0F73_REG_3 */
4627 { "(bad)", { XX
} },
4628 { PREFIX_TABLE (PREFIX_0F73_REG_3
) },
4631 /* MOD_0F73_REG_6 */
4632 { "(bad)", { XX
} },
4633 { "psllq", { MS
, Ib
} },
4636 /* MOD_0F73_REG_7 */
4637 { "(bad)", { XX
} },
4638 { PREFIX_TABLE (PREFIX_0F73_REG_7
) },
4641 /* MOD_0FAE_REG_0 */
4642 { "fxsave", { M
} },
4643 { "(bad)", { XX
} },
4646 /* MOD_0FAE_REG_1 */
4647 { "fxrstor", { M
} },
4648 { "(bad)", { XX
} },
4651 /* MOD_0FAE_REG_2 */
4652 { "ldmxcsr", { Md
} },
4653 { "(bad)", { XX
} },
4656 /* MOD_0FAE_REG_3 */
4657 { "stmxcsr", { Md
} },
4658 { "(bad)", { XX
} },
4661 /* MOD_0FAE_REG_5 */
4662 { "(bad)", { XX
} },
4663 { RM_TABLE (RM_0FAE_REG_5
) },
4666 /* MOD_0FAE_REG_6 */
4667 { "(bad)", { XX
} },
4668 { RM_TABLE (RM_0FAE_REG_6
) },
4671 /* MOD_0FAE_REG_7 */
4672 { "clflush", { Mb
} },
4673 { RM_TABLE (RM_0FAE_REG_7
) },
4676 /* MOD_0FC7_REG_6 */
4677 { PREFIX_TABLE (PREFIX_0FC7_REG_6
) },
4678 { "(bad)", { XX
} },
4681 /* MOD_0FC7_REG_7 */
4682 { "vmptrst", { Mq
} },
4683 { "(bad)", { XX
} },
4686 /* MOD_0F12_PREFIX_0 */
4687 { "movlpX", { XM
, EXq
} },
4688 { "movhlpX", { XM
, EXq
} },
4691 /* MOD_0F16_PREFIX_0 */
4692 { "movhpX", { XM
, EXq
} },
4693 { "movlhpX", { XM
, EXq
} },
4696 /* MOD_0FF0_PREFIX_3 */
4697 { "lddqu", { XM
, M
} },
4698 { "(bad)", { XX
} },
4702 { "bound{S|}", { Gv
, Ma
} },
4703 { "(bad)", { XX
} },
4707 { "lesS", { Gv
, Mp
} },
4708 { "(bad)", { XX
} },
4712 { "ldsS", { Gv
, Mp
} },
4713 { "(bad)", { XX
} },
4717 static const struct dis386 rm_table
[][8] = {
4720 { "(bad)", { XX
} },
4721 { "vmcall", { Skip_MODRM
} },
4722 { "vmlaunch", { Skip_MODRM
} },
4723 { "vmresume", { Skip_MODRM
} },
4724 { "vmxoff", { Skip_MODRM
} },
4725 { "(bad)", { XX
} },
4726 { "(bad)", { XX
} },
4727 { "(bad)", { XX
} },
4731 { "monitor", { { OP_Monitor
, 0 } } },
4732 { "mwait", { { OP_Mwait
, 0 } } },
4733 { "(bad)", { XX
} },
4734 { "(bad)", { XX
} },
4735 { "(bad)", { XX
} },
4736 { "(bad)", { XX
} },
4737 { "(bad)", { XX
} },
4738 { "(bad)", { XX
} },
4742 { "vmrun", { Skip_MODRM
} },
4743 { "vmmcall", { Skip_MODRM
} },
4744 { "vmload", { Skip_MODRM
} },
4745 { "vmsave", { Skip_MODRM
} },
4746 { "stgi", { Skip_MODRM
} },
4747 { "clgi", { Skip_MODRM
} },
4748 { "skinit", { Skip_MODRM
} },
4749 { "invlpga", { Skip_MODRM
} },
4753 { "swapgs", { Skip_MODRM
} },
4754 { "rdtscp", { Skip_MODRM
} },
4755 { "(bad)", { XX
} },
4756 { "(bad)", { XX
} },
4757 { "(bad)", { XX
} },
4758 { "(bad)", { XX
} },
4759 { "(bad)", { XX
} },
4760 { "(bad)", { XX
} },
4764 { "lfence", { Skip_MODRM
} },
4765 { "(bad)", { XX
} },
4766 { "(bad)", { XX
} },
4767 { "(bad)", { XX
} },
4768 { "(bad)", { XX
} },
4769 { "(bad)", { XX
} },
4770 { "(bad)", { XX
} },
4771 { "(bad)", { XX
} },
4775 { "mfence", { Skip_MODRM
} },
4776 { "(bad)", { XX
} },
4777 { "(bad)", { XX
} },
4778 { "(bad)", { XX
} },
4779 { "(bad)", { XX
} },
4780 { "(bad)", { XX
} },
4781 { "(bad)", { XX
} },
4782 { "(bad)", { XX
} },
4786 { "sfence", { Skip_MODRM
} },
4787 { "(bad)", { XX
} },
4788 { "(bad)", { XX
} },
4789 { "(bad)", { XX
} },
4790 { "(bad)", { XX
} },
4791 { "(bad)", { XX
} },
4792 { "(bad)", { XX
} },
4793 { "(bad)", { XX
} },
4797 #define INTERNAL_DISASSEMBLER_ERROR _("<internal disassembler error>")
4809 FETCH_DATA (the_info
, codep
+ 1);
4813 /* REX prefixes family. */
4830 if (address_mode
== mode_64bit
)
4836 prefixes
|= PREFIX_REPZ
;
4839 prefixes
|= PREFIX_REPNZ
;
4842 prefixes
|= PREFIX_LOCK
;
4845 prefixes
|= PREFIX_CS
;
4848 prefixes
|= PREFIX_SS
;
4851 prefixes
|= PREFIX_DS
;
4854 prefixes
|= PREFIX_ES
;
4857 prefixes
|= PREFIX_FS
;
4860 prefixes
|= PREFIX_GS
;
4863 prefixes
|= PREFIX_DATA
;
4866 prefixes
|= PREFIX_ADDR
;
4869 /* fwait is really an instruction. If there are prefixes
4870 before the fwait, they belong to the fwait, *not* to the
4871 following instruction. */
4872 if (prefixes
|| rex
)
4874 prefixes
|= PREFIX_FWAIT
;
4878 prefixes
= PREFIX_FWAIT
;
4883 /* Rex is ignored when followed by another prefix. */
4894 /* Return the name of the prefix byte PREF, or NULL if PREF is not a
4898 prefix_name (int pref
, int sizeflag
)
4900 static const char *rexes
[16] =
4905 "rex.XB", /* 0x43 */
4907 "rex.RB", /* 0x45 */
4908 "rex.RX", /* 0x46 */
4909 "rex.RXB", /* 0x47 */
4911 "rex.WB", /* 0x49 */
4912 "rex.WX", /* 0x4a */
4913 "rex.WXB", /* 0x4b */
4914 "rex.WR", /* 0x4c */
4915 "rex.WRB", /* 0x4d */
4916 "rex.WRX", /* 0x4e */
4917 "rex.WRXB", /* 0x4f */
4922 /* REX prefixes family. */
4939 return rexes
[pref
- 0x40];
4959 return (sizeflag
& DFLAG
) ? "data16" : "data32";
4961 if (address_mode
== mode_64bit
)
4962 return (sizeflag
& AFLAG
) ? "addr32" : "addr64";
4964 return (sizeflag
& AFLAG
) ? "addr16" : "addr32";
4972 static char op_out
[MAX_OPERANDS
][100];
4973 static int op_ad
, op_index
[MAX_OPERANDS
];
4974 static int two_source_ops
;
4975 static bfd_vma op_address
[MAX_OPERANDS
];
4976 static bfd_vma op_riprel
[MAX_OPERANDS
];
4977 static bfd_vma start_pc
;
4980 * On the 386's of 1988, the maximum length of an instruction is 15 bytes.
4981 * (see topic "Redundant prefixes" in the "Differences from 8086"
4982 * section of the "Virtual 8086 Mode" chapter.)
4983 * 'pc' should be the address of this instruction, it will
4984 * be used to print the target address if this is a relative jump or call
4985 * The function returns the length of this instruction in bytes.
4988 static char intel_syntax
;
4989 static char open_char
;
4990 static char close_char
;
4991 static char separator_char
;
4992 static char scale_char
;
4994 /* Here for backwards compatibility. When gdb stops using
4995 print_insn_i386_att and print_insn_i386_intel these functions can
4996 disappear, and print_insn_i386 be merged into print_insn. */
4998 print_insn_i386_att (bfd_vma pc
, disassemble_info
*info
)
5002 return print_insn (pc
, info
);
5006 print_insn_i386_intel (bfd_vma pc
, disassemble_info
*info
)
5010 return print_insn (pc
, info
);
5014 print_insn_i386 (bfd_vma pc
, disassemble_info
*info
)
5018 return print_insn (pc
, info
);
5022 print_i386_disassembler_options (FILE *stream
)
5024 fprintf (stream
, _("\n\
5025 The following i386/x86-64 specific disassembler options are supported for use\n\
5026 with the -M switch (multiple options should be separated by commas):\n"));
5028 fprintf (stream
, _(" x86-64 Disassemble in 64bit mode\n"));
5029 fprintf (stream
, _(" i386 Disassemble in 32bit mode\n"));
5030 fprintf (stream
, _(" i8086 Disassemble in 16bit mode\n"));
5031 fprintf (stream
, _(" att Display instruction in AT&T syntax\n"));
5032 fprintf (stream
, _(" intel Display instruction in Intel syntax\n"));
5033 fprintf (stream
, _(" addr64 Assume 64bit address size\n"));
5034 fprintf (stream
, _(" addr32 Assume 32bit address size\n"));
5035 fprintf (stream
, _(" addr16 Assume 16bit address size\n"));
5036 fprintf (stream
, _(" data32 Assume 32bit data size\n"));
5037 fprintf (stream
, _(" data16 Assume 16bit data size\n"));
5038 fprintf (stream
, _(" suffix Always display instruction suffix in AT&T syntax\n"));
5041 /* Get a pointer to struct dis386 with a valid name. */
5043 static const struct dis386
*
5044 get_valid_dis386 (const struct dis386
*dp
, disassemble_info
*info
)
5048 if (dp
->name
!= NULL
)
5051 switch (dp
->op
[0].bytemode
)
5054 dp
= ®_table
[dp
->op
[1].bytemode
][modrm
.reg
];
5058 index
= modrm
.mod
== 0x3 ? 1 : 0;
5059 dp
= &mod_table
[dp
->op
[1].bytemode
][index
];
5063 dp
= &rm_table
[dp
->op
[1].bytemode
][modrm
.rm
];
5066 case USE_PREFIX_TABLE
:
5068 used_prefixes
|= (prefixes
& PREFIX_REPZ
);
5069 if (prefixes
& PREFIX_REPZ
)
5076 /* We should check PREFIX_REPNZ and PREFIX_REPZ before
5078 used_prefixes
|= (prefixes
& PREFIX_REPNZ
);
5079 if (prefixes
& PREFIX_REPNZ
)
5082 repnz_prefix
= NULL
;
5086 used_prefixes
|= (prefixes
& PREFIX_DATA
);
5087 if (prefixes
& PREFIX_DATA
)
5094 dp
= &prefix_table
[dp
->op
[1].bytemode
][index
];
5097 case USE_X86_64_TABLE
:
5098 index
= address_mode
== mode_64bit
? 1 : 0;
5099 dp
= &x86_64_table
[dp
->op
[1].bytemode
][index
];
5102 case USE_3BYTE_TABLE
:
5103 FETCH_DATA (info
, codep
+ 2);
5105 dp
= &three_byte_table
[dp
->op
[1].bytemode
][index
];
5106 modrm
.mod
= (*codep
>> 6) & 3;
5107 modrm
.reg
= (*codep
>> 3) & 7;
5108 modrm
.rm
= *codep
& 7;
5112 oappend (INTERNAL_DISASSEMBLER_ERROR
);
5116 if (dp
->name
!= NULL
)
5119 return get_valid_dis386 (dp
, info
);
5123 print_insn (bfd_vma pc
, disassemble_info
*info
)
5125 const struct dis386
*dp
;
5127 char *op_txt
[MAX_OPERANDS
];
5131 struct dis_private priv
;
5133 char prefix_obuf
[32];
5136 if (info
->mach
== bfd_mach_x86_64_intel_syntax
5137 || info
->mach
== bfd_mach_x86_64
)
5138 address_mode
= mode_64bit
;
5140 address_mode
= mode_32bit
;
5142 if (intel_syntax
== (char) -1)
5143 intel_syntax
= (info
->mach
== bfd_mach_i386_i386_intel_syntax
5144 || info
->mach
== bfd_mach_x86_64_intel_syntax
);
5146 if (info
->mach
== bfd_mach_i386_i386
5147 || info
->mach
== bfd_mach_x86_64
5148 || info
->mach
== bfd_mach_i386_i386_intel_syntax
5149 || info
->mach
== bfd_mach_x86_64_intel_syntax
)
5150 priv
.orig_sizeflag
= AFLAG
| DFLAG
;
5151 else if (info
->mach
== bfd_mach_i386_i8086
)
5152 priv
.orig_sizeflag
= 0;
5156 for (p
= info
->disassembler_options
; p
!= NULL
; )
5158 if (CONST_STRNEQ (p
, "x86-64"))
5160 address_mode
= mode_64bit
;
5161 priv
.orig_sizeflag
= AFLAG
| DFLAG
;
5163 else if (CONST_STRNEQ (p
, "i386"))
5165 address_mode
= mode_32bit
;
5166 priv
.orig_sizeflag
= AFLAG
| DFLAG
;
5168 else if (CONST_STRNEQ (p
, "i8086"))
5170 address_mode
= mode_16bit
;
5171 priv
.orig_sizeflag
= 0;
5173 else if (CONST_STRNEQ (p
, "intel"))
5177 else if (CONST_STRNEQ (p
, "att"))
5181 else if (CONST_STRNEQ (p
, "addr"))
5183 if (address_mode
== mode_64bit
)
5185 if (p
[4] == '3' && p
[5] == '2')
5186 priv
.orig_sizeflag
&= ~AFLAG
;
5187 else if (p
[4] == '6' && p
[5] == '4')
5188 priv
.orig_sizeflag
|= AFLAG
;
5192 if (p
[4] == '1' && p
[5] == '6')
5193 priv
.orig_sizeflag
&= ~AFLAG
;
5194 else if (p
[4] == '3' && p
[5] == '2')
5195 priv
.orig_sizeflag
|= AFLAG
;
5198 else if (CONST_STRNEQ (p
, "data"))
5200 if (p
[4] == '1' && p
[5] == '6')
5201 priv
.orig_sizeflag
&= ~DFLAG
;
5202 else if (p
[4] == '3' && p
[5] == '2')
5203 priv
.orig_sizeflag
|= DFLAG
;
5205 else if (CONST_STRNEQ (p
, "suffix"))
5206 priv
.orig_sizeflag
|= SUFFIX_ALWAYS
;
5208 p
= strchr (p
, ',');
5215 names64
= intel_names64
;
5216 names32
= intel_names32
;
5217 names16
= intel_names16
;
5218 names8
= intel_names8
;
5219 names8rex
= intel_names8rex
;
5220 names_seg
= intel_names_seg
;
5221 index64
= intel_index64
;
5222 index32
= intel_index32
;
5223 index16
= intel_index16
;
5226 separator_char
= '+';
5231 names64
= att_names64
;
5232 names32
= att_names32
;
5233 names16
= att_names16
;
5234 names8
= att_names8
;
5235 names8rex
= att_names8rex
;
5236 names_seg
= att_names_seg
;
5237 index64
= att_index64
;
5238 index32
= att_index32
;
5239 index16
= att_index16
;
5242 separator_char
= ',';
5246 /* The output looks better if we put 7 bytes on a line, since that
5247 puts most long word instructions on a single line. */
5248 info
->bytes_per_line
= 7;
5250 info
->private_data
= &priv
;
5251 priv
.max_fetched
= priv
.the_buffer
;
5252 priv
.insn_start
= pc
;
5255 for (i
= 0; i
< MAX_OPERANDS
; ++i
)
5263 start_codep
= priv
.the_buffer
;
5264 codep
= priv
.the_buffer
;
5266 if (setjmp (priv
.bailout
) != 0)
5270 /* Getting here means we tried for data but didn't get it. That
5271 means we have an incomplete instruction of some sort. Just
5272 print the first byte as a prefix or a .byte pseudo-op. */
5273 if (codep
> priv
.the_buffer
)
5275 name
= prefix_name (priv
.the_buffer
[0], priv
.orig_sizeflag
);
5277 (*info
->fprintf_func
) (info
->stream
, "%s", name
);
5280 /* Just print the first byte as a .byte instruction. */
5281 (*info
->fprintf_func
) (info
->stream
, ".byte 0x%x",
5282 (unsigned int) priv
.the_buffer
[0]);
5295 sizeflag
= priv
.orig_sizeflag
;
5297 FETCH_DATA (info
, codep
+ 1);
5298 two_source_ops
= (*codep
== 0x62) || (*codep
== 0xc8);
5300 if (((prefixes
& PREFIX_FWAIT
)
5301 && ((*codep
< 0xd8) || (*codep
> 0xdf)))
5302 || (rex
&& rex_used
))
5306 /* fwait not followed by floating point instruction, or rex followed
5307 by other prefixes. Print the first prefix. */
5308 name
= prefix_name (priv
.the_buffer
[0], priv
.orig_sizeflag
);
5310 name
= INTERNAL_DISASSEMBLER_ERROR
;
5311 (*info
->fprintf_func
) (info
->stream
, "%s", name
);
5318 unsigned char threebyte
;
5319 FETCH_DATA (info
, codep
+ 2);
5320 threebyte
= *++codep
;
5321 dp
= &dis386_twobyte
[threebyte
];
5322 need_modrm
= twobyte_has_modrm
[*codep
];
5327 dp
= &dis386
[*codep
];
5328 need_modrm
= onebyte_has_modrm
[*codep
];
5332 if ((prefixes
& PREFIX_REPZ
))
5334 repz_prefix
= "repz ";
5335 used_prefixes
|= PREFIX_REPZ
;
5340 if ((prefixes
& PREFIX_REPNZ
))
5342 repnz_prefix
= "repnz ";
5343 used_prefixes
|= PREFIX_REPNZ
;
5346 repnz_prefix
= NULL
;
5348 if ((prefixes
& PREFIX_LOCK
))
5350 lock_prefix
= "lock ";
5351 used_prefixes
|= PREFIX_LOCK
;
5357 if (prefixes
& PREFIX_ADDR
)
5360 if (dp
->op
[2].bytemode
!= loop_jcxz_mode
|| intel_syntax
)
5362 if ((sizeflag
& AFLAG
) || address_mode
== mode_64bit
)
5363 addr_prefix
= "addr32 ";
5365 addr_prefix
= "addr16 ";
5366 used_prefixes
|= PREFIX_ADDR
;
5371 if ((prefixes
& PREFIX_DATA
))
5374 if (dp
->op
[2].bytemode
== cond_jump_mode
5375 && dp
->op
[0].bytemode
== v_mode
5378 if (sizeflag
& DFLAG
)
5379 data_prefix
= "data32 ";
5381 data_prefix
= "data16 ";
5382 used_prefixes
|= PREFIX_DATA
;
5388 FETCH_DATA (info
, codep
+ 1);
5389 modrm
.mod
= (*codep
>> 6) & 3;
5390 modrm
.reg
= (*codep
>> 3) & 7;
5391 modrm
.rm
= *codep
& 7;
5394 if (dp
->name
== NULL
&& dp
->op
[0].bytemode
== FLOATCODE
)
5400 dp
= get_valid_dis386 (dp
, info
);
5401 if (dp
!= NULL
&& putop (dp
->name
, sizeflag
) == 0)
5403 for (i
= 0; i
< MAX_OPERANDS
; ++i
)
5406 op_ad
= MAX_OPERANDS
- 1 - i
;
5408 (*dp
->op
[i
].rtn
) (dp
->op
[i
].bytemode
, sizeflag
);
5413 /* See if any prefixes were not used. If so, print the first one
5414 separately. If we don't do this, we'll wind up printing an
5415 instruction stream which does not precisely correspond to the
5416 bytes we are disassembling. */
5417 if ((prefixes
& ~used_prefixes
) != 0)
5421 name
= prefix_name (priv
.the_buffer
[0], priv
.orig_sizeflag
);
5423 name
= INTERNAL_DISASSEMBLER_ERROR
;
5424 (*info
->fprintf_func
) (info
->stream
, "%s", name
);
5427 if (rex
& ~rex_used
)
5430 name
= prefix_name (rex
| 0x40, priv
.orig_sizeflag
);
5432 name
= INTERNAL_DISASSEMBLER_ERROR
;
5433 (*info
->fprintf_func
) (info
->stream
, "%s ", name
);
5437 prefix_obufp
= prefix_obuf
;
5439 prefix_obufp
= stpcpy (prefix_obufp
, lock_prefix
);
5441 prefix_obufp
= stpcpy (prefix_obufp
, repz_prefix
);
5443 prefix_obufp
= stpcpy (prefix_obufp
, repnz_prefix
);
5445 prefix_obufp
= stpcpy (prefix_obufp
, addr_prefix
);
5447 prefix_obufp
= stpcpy (prefix_obufp
, data_prefix
);
5449 if (prefix_obuf
[0] != 0)
5450 (*info
->fprintf_func
) (info
->stream
, "%s", prefix_obuf
);
5452 obufp
= obuf
+ strlen (obuf
);
5453 for (i
= strlen (obuf
) + strlen (prefix_obuf
); i
< 6; i
++)
5456 (*info
->fprintf_func
) (info
->stream
, "%s", obuf
);
5458 /* The enter and bound instructions are printed with operands in the same
5459 order as the intel book; everything else is printed in reverse order. */
5460 if (intel_syntax
|| two_source_ops
)
5464 for (i
= 0; i
< MAX_OPERANDS
; ++i
)
5465 op_txt
[i
] = op_out
[i
];
5467 for (i
= 0; i
< (MAX_OPERANDS
>> 1); ++i
)
5469 op_ad
= op_index
[i
];
5470 op_index
[i
] = op_index
[MAX_OPERANDS
- 1 - i
];
5471 op_index
[MAX_OPERANDS
- 1 - i
] = op_ad
;
5472 riprel
= op_riprel
[i
];
5473 op_riprel
[i
] = op_riprel
[MAX_OPERANDS
- 1 - i
];
5474 op_riprel
[MAX_OPERANDS
- 1 - i
] = riprel
;
5479 for (i
= 0; i
< MAX_OPERANDS
; ++i
)
5480 op_txt
[MAX_OPERANDS
- 1 - i
] = op_out
[i
];
5484 for (i
= 0; i
< MAX_OPERANDS
; ++i
)
5488 (*info
->fprintf_func
) (info
->stream
, ",");
5489 if (op_index
[i
] != -1 && !op_riprel
[i
])
5490 (*info
->print_address_func
) ((bfd_vma
) op_address
[op_index
[i
]], info
);
5492 (*info
->fprintf_func
) (info
->stream
, "%s", op_txt
[i
]);
5496 for (i
= 0; i
< MAX_OPERANDS
; i
++)
5497 if (op_index
[i
] != -1 && op_riprel
[i
])
5499 (*info
->fprintf_func
) (info
->stream
, " # ");
5500 (*info
->print_address_func
) ((bfd_vma
) (start_pc
+ codep
- start_codep
5501 + op_address
[op_index
[i
]]), info
);
5504 return codep
- priv
.the_buffer
;
5507 static const char *float_mem
[] = {
5582 static const unsigned char float_mem_mode
[] = {
5657 #define ST { OP_ST, 0 }
5658 #define STi { OP_STi, 0 }
5660 #define FGRPd9_2 NULL, { { NULL, 0 } }
5661 #define FGRPd9_4 NULL, { { NULL, 1 } }
5662 #define FGRPd9_5 NULL, { { NULL, 2 } }
5663 #define FGRPd9_6 NULL, { { NULL, 3 } }
5664 #define FGRPd9_7 NULL, { { NULL, 4 } }
5665 #define FGRPda_5 NULL, { { NULL, 5 } }
5666 #define FGRPdb_4 NULL, { { NULL, 6 } }
5667 #define FGRPde_3 NULL, { { NULL, 7 } }
5668 #define FGRPdf_4 NULL, { { NULL, 8 } }
5670 static const struct dis386 float_reg
[][8] = {
5673 { "fadd", { ST
, STi
} },
5674 { "fmul", { ST
, STi
} },
5675 { "fcom", { STi
} },
5676 { "fcomp", { STi
} },
5677 { "fsub", { ST
, STi
} },
5678 { "fsubr", { ST
, STi
} },
5679 { "fdiv", { ST
, STi
} },
5680 { "fdivr", { ST
, STi
} },
5685 { "fxch", { STi
} },
5687 { "(bad)", { XX
} },
5695 { "fcmovb", { ST
, STi
} },
5696 { "fcmove", { ST
, STi
} },
5697 { "fcmovbe",{ ST
, STi
} },
5698 { "fcmovu", { ST
, STi
} },
5699 { "(bad)", { XX
} },
5701 { "(bad)", { XX
} },
5702 { "(bad)", { XX
} },
5706 { "fcmovnb",{ ST
, STi
} },
5707 { "fcmovne",{ ST
, STi
} },
5708 { "fcmovnbe",{ ST
, STi
} },
5709 { "fcmovnu",{ ST
, STi
} },
5711 { "fucomi", { ST
, STi
} },
5712 { "fcomi", { ST
, STi
} },
5713 { "(bad)", { XX
} },
5717 { "fadd", { STi
, ST
} },
5718 { "fmul", { STi
, ST
} },
5719 { "(bad)", { XX
} },
5720 { "(bad)", { XX
} },
5722 { "fsub", { STi
, ST
} },
5723 { "fsubr", { STi
, ST
} },
5724 { "fdiv", { STi
, ST
} },
5725 { "fdivr", { STi
, ST
} },
5727 { "fsubr", { STi
, ST
} },
5728 { "fsub", { STi
, ST
} },
5729 { "fdivr", { STi
, ST
} },
5730 { "fdiv", { STi
, ST
} },
5735 { "ffree", { STi
} },
5736 { "(bad)", { XX
} },
5738 { "fstp", { STi
} },
5739 { "fucom", { STi
} },
5740 { "fucomp", { STi
} },
5741 { "(bad)", { XX
} },
5742 { "(bad)", { XX
} },
5746 { "faddp", { STi
, ST
} },
5747 { "fmulp", { STi
, ST
} },
5748 { "(bad)", { XX
} },
5751 { "fsubp", { STi
, ST
} },
5752 { "fsubrp", { STi
, ST
} },
5753 { "fdivp", { STi
, ST
} },
5754 { "fdivrp", { STi
, ST
} },
5756 { "fsubrp", { STi
, ST
} },
5757 { "fsubp", { STi
, ST
} },
5758 { "fdivrp", { STi
, ST
} },
5759 { "fdivp", { STi
, ST
} },
5764 { "ffreep", { STi
} },
5765 { "(bad)", { XX
} },
5766 { "(bad)", { XX
} },
5767 { "(bad)", { XX
} },
5769 { "fucomip", { ST
, STi
} },
5770 { "fcomip", { ST
, STi
} },
5771 { "(bad)", { XX
} },
5775 static char *fgrps
[][8] = {
5778 "fnop","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
5783 "fchs","fabs","(bad)","(bad)","ftst","fxam","(bad)","(bad)",
5788 "fld1","fldl2t","fldl2e","fldpi","fldlg2","fldln2","fldz","(bad)",
5793 "f2xm1","fyl2x","fptan","fpatan","fxtract","fprem1","fdecstp","fincstp",
5798 "fprem","fyl2xp1","fsqrt","fsincos","frndint","fscale","fsin","fcos",
5803 "(bad)","fucompp","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
5808 "feni(287 only)","fdisi(287 only)","fNclex","fNinit",
5809 "fNsetpm(287 only)","(bad)","(bad)","(bad)",
5814 "(bad)","fcompp","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
5819 "fNstsw","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)","(bad)",
5824 OP_Skip_MODRM (int bytemode ATTRIBUTE_UNUSED
,
5825 int sizeflag ATTRIBUTE_UNUSED
)
5827 /* Skip mod/rm byte. */
5833 dofloat (int sizeflag
)
5835 const struct dis386
*dp
;
5836 unsigned char floatop
;
5838 floatop
= codep
[-1];
5842 int fp_indx
= (floatop
- 0xd8) * 8 + modrm
.reg
;
5844 putop (float_mem
[fp_indx
], sizeflag
);
5847 OP_E (float_mem_mode
[fp_indx
], sizeflag
);
5850 /* Skip mod/rm byte. */
5854 dp
= &float_reg
[floatop
- 0xd8][modrm
.reg
];
5855 if (dp
->name
== NULL
)
5857 putop (fgrps
[dp
->op
[0].bytemode
][modrm
.rm
], sizeflag
);
5859 /* Instruction fnstsw is only one with strange arg. */
5860 if (floatop
== 0xdf && codep
[-1] == 0xe0)
5861 strcpy (op_out
[0], names16
[0]);
5865 putop (dp
->name
, sizeflag
);
5870 (*dp
->op
[0].rtn
) (dp
->op
[0].bytemode
, sizeflag
);
5875 (*dp
->op
[1].rtn
) (dp
->op
[1].bytemode
, sizeflag
);
5880 OP_ST (int bytemode ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
5882 oappend ("%st" + intel_syntax
);
5886 OP_STi (int bytemode ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
5888 sprintf (scratchbuf
, "%%st(%d)", modrm
.rm
);
5889 oappend (scratchbuf
+ intel_syntax
);
5892 /* Capital letters in template are macros. */
5894 putop (const char *template, int sizeflag
)
5899 for (p
= template; *p
; p
++)
5911 if (*p
== '}' || *p
== '\0')
5930 if (modrm
.mod
!= 3 || (sizeflag
& SUFFIX_ALWAYS
))
5936 if (sizeflag
& SUFFIX_ALWAYS
)
5940 if (intel_syntax
&& !alt
)
5942 if ((prefixes
& PREFIX_DATA
) || (sizeflag
& SUFFIX_ALWAYS
))
5944 if (sizeflag
& DFLAG
)
5945 *obufp
++ = intel_syntax
? 'd' : 'l';
5947 *obufp
++ = intel_syntax
? 'w' : 's';
5948 used_prefixes
|= (prefixes
& PREFIX_DATA
);
5952 if (intel_syntax
|| !(sizeflag
& SUFFIX_ALWAYS
))
5959 else if (sizeflag
& DFLAG
)
5960 *obufp
++ = intel_syntax
? 'd' : 'l';
5963 used_prefixes
|= (prefixes
& PREFIX_DATA
);
5968 case 'E': /* For jcxz/jecxz */
5969 if (address_mode
== mode_64bit
)
5971 if (sizeflag
& AFLAG
)
5977 if (sizeflag
& AFLAG
)
5979 used_prefixes
|= (prefixes
& PREFIX_ADDR
);
5984 if ((prefixes
& PREFIX_ADDR
) || (sizeflag
& SUFFIX_ALWAYS
))
5986 if (sizeflag
& AFLAG
)
5987 *obufp
++ = address_mode
== mode_64bit
? 'q' : 'l';
5989 *obufp
++ = address_mode
== mode_64bit
? 'l' : 'w';
5990 used_prefixes
|= (prefixes
& PREFIX_ADDR
);
5994 if (intel_syntax
|| (obufp
[-1] != 's' && !(sizeflag
& SUFFIX_ALWAYS
)))
5996 if ((rex
& REX_W
) || (sizeflag
& DFLAG
))
6001 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6006 if ((prefixes
& (PREFIX_CS
| PREFIX_DS
)) == PREFIX_CS
6007 || (prefixes
& (PREFIX_CS
| PREFIX_DS
)) == PREFIX_DS
)
6009 used_prefixes
|= prefixes
& (PREFIX_CS
| PREFIX_DS
);
6012 if (prefixes
& PREFIX_DS
)
6033 if (address_mode
== mode_64bit
&& (sizeflag
& SUFFIX_ALWAYS
))
6042 if (sizeflag
& SUFFIX_ALWAYS
)
6046 if ((prefixes
& PREFIX_FWAIT
) == 0)
6049 used_prefixes
|= PREFIX_FWAIT
;
6055 else if (intel_syntax
&& (sizeflag
& DFLAG
))
6060 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6065 if (address_mode
== mode_64bit
&& (sizeflag
& DFLAG
))
6074 if ((prefixes
& PREFIX_DATA
)
6076 || (sizeflag
& SUFFIX_ALWAYS
))
6083 if (sizeflag
& DFLAG
)
6088 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6094 if (address_mode
== mode_64bit
&& (sizeflag
& DFLAG
))
6096 if (modrm
.mod
!= 3 || (sizeflag
& SUFFIX_ALWAYS
))
6102 if (intel_syntax
&& !alt
)
6105 if (modrm
.mod
!= 3 || (sizeflag
& SUFFIX_ALWAYS
))
6111 if (sizeflag
& DFLAG
)
6112 *obufp
++ = intel_syntax
? 'd' : 'l';
6116 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6123 else if (sizeflag
& DFLAG
)
6132 if (intel_syntax
&& !p
[1]
6133 && ((rex
& REX_W
) || (sizeflag
& DFLAG
)))
6136 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6141 if (address_mode
== mode_64bit
&& (sizeflag
& DFLAG
))
6143 if (sizeflag
& SUFFIX_ALWAYS
)
6151 if (sizeflag
& SUFFIX_ALWAYS
)
6157 if (sizeflag
& DFLAG
)
6161 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6166 if (prefixes
& PREFIX_DATA
)
6170 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6181 /* implicit operand size 'l' for i386 or 'q' for x86-64 */
6183 /* operand size flag for cwtl, cbtw */
6192 else if (sizeflag
& DFLAG
)
6197 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6207 oappend (const char *s
)
6210 obufp
+= strlen (s
);
6216 if (prefixes
& PREFIX_CS
)
6218 used_prefixes
|= PREFIX_CS
;
6219 oappend ("%cs:" + intel_syntax
);
6221 if (prefixes
& PREFIX_DS
)
6223 used_prefixes
|= PREFIX_DS
;
6224 oappend ("%ds:" + intel_syntax
);
6226 if (prefixes
& PREFIX_SS
)
6228 used_prefixes
|= PREFIX_SS
;
6229 oappend ("%ss:" + intel_syntax
);
6231 if (prefixes
& PREFIX_ES
)
6233 used_prefixes
|= PREFIX_ES
;
6234 oappend ("%es:" + intel_syntax
);
6236 if (prefixes
& PREFIX_FS
)
6238 used_prefixes
|= PREFIX_FS
;
6239 oappend ("%fs:" + intel_syntax
);
6241 if (prefixes
& PREFIX_GS
)
6243 used_prefixes
|= PREFIX_GS
;
6244 oappend ("%gs:" + intel_syntax
);
6249 OP_indirE (int bytemode
, int sizeflag
)
6253 OP_E (bytemode
, sizeflag
);
6257 print_operand_value (char *buf
, int hex
, bfd_vma disp
)
6259 if (address_mode
== mode_64bit
)
6267 sprintf_vma (tmp
, disp
);
6268 for (i
= 0; tmp
[i
] == '0' && tmp
[i
+ 1]; i
++);
6269 strcpy (buf
+ 2, tmp
+ i
);
6273 bfd_signed_vma v
= disp
;
6280 /* Check for possible overflow on 0x8000000000000000. */
6283 strcpy (buf
, "9223372036854775808");
6297 tmp
[28 - i
] = (v
% 10) + '0';
6301 strcpy (buf
, tmp
+ 29 - i
);
6307 sprintf (buf
, "0x%x", (unsigned int) disp
);
6309 sprintf (buf
, "%d", (int) disp
);
6313 /* Put DISP in BUF as signed hex number. */
6316 print_displacement (char *buf
, bfd_vma disp
)
6318 bfd_signed_vma val
= disp
;
6327 /* Check for possible overflow. */
6330 switch (address_mode
)
6333 strcpy (buf
+ j
, "0x8000000000000000");
6336 strcpy (buf
+ j
, "0x80000000");
6339 strcpy (buf
+ j
, "0x8000");
6349 sprintf_vma (tmp
, val
);
6350 for (i
= 0; tmp
[i
] == '0'; i
++)
6354 strcpy (buf
+ j
, tmp
+ i
);
6358 intel_operand_size (int bytemode
, int sizeflag
)
6364 oappend ("BYTE PTR ");
6368 oappend ("WORD PTR ");
6371 if (address_mode
== mode_64bit
&& (sizeflag
& DFLAG
))
6373 oappend ("QWORD PTR ");
6374 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6382 oappend ("QWORD PTR ");
6383 else if ((sizeflag
& DFLAG
) || bytemode
== dq_mode
)
6384 oappend ("DWORD PTR ");
6386 oappend ("WORD PTR ");
6387 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6390 if ((rex
& REX_W
) || (sizeflag
& DFLAG
))
6392 oappend ("WORD PTR ");
6394 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6398 oappend ("DWORD PTR ");
6401 oappend ("QWORD PTR ");
6404 if (address_mode
== mode_64bit
)
6405 oappend ("QWORD PTR ");
6407 oappend ("DWORD PTR ");
6410 if (sizeflag
& DFLAG
)
6411 oappend ("FWORD PTR ");
6413 oappend ("DWORD PTR ");
6414 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6417 oappend ("TBYTE PTR ");
6420 oappend ("XMMWORD PTR ");
6423 oappend ("OWORD PTR ");
6431 OP_E_extended (int bytemode
, int sizeflag
, int has_drex
)
6440 /* Skip mod/rm byte. */
6451 oappend (names8rex
[modrm
.rm
+ add
]);
6453 oappend (names8
[modrm
.rm
+ add
]);
6456 oappend (names16
[modrm
.rm
+ add
]);
6459 oappend (names32
[modrm
.rm
+ add
]);
6462 oappend (names64
[modrm
.rm
+ add
]);
6465 if (address_mode
== mode_64bit
)
6466 oappend (names64
[modrm
.rm
+ add
]);
6468 oappend (names32
[modrm
.rm
+ add
]);
6471 if (address_mode
== mode_64bit
&& (sizeflag
& DFLAG
))
6473 oappend (names64
[modrm
.rm
+ add
]);
6474 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6486 oappend (names64
[modrm
.rm
+ add
]);
6487 else if ((sizeflag
& DFLAG
) || bytemode
!= v_mode
)
6488 oappend (names32
[modrm
.rm
+ add
]);
6490 oappend (names16
[modrm
.rm
+ add
]);
6491 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6496 oappend (INTERNAL_DISASSEMBLER_ERROR
);
6504 intel_operand_size (bytemode
, sizeflag
);
6507 if ((sizeflag
& AFLAG
) || address_mode
== mode_64bit
)
6509 /* 32/64 bit address mode */
6527 FETCH_DATA (the_info
, codep
+ 1);
6528 index
= (*codep
>> 3) & 7;
6529 scale
= (*codep
>> 6) & 3;
6534 haveindex
= index
!= 4;
6539 /* If we have a DREX byte, skip it now
6540 (it has already been handled) */
6543 FETCH_DATA (the_info
, codep
+ 1);
6550 if ((base
& 7) == 5)
6553 if (address_mode
== mode_64bit
&& !havesib
)
6559 FETCH_DATA (the_info
, codep
+ 1);
6561 if ((disp
& 0x80) != 0)
6569 /* In 32bit mode, we need index register to tell [offset] from
6570 [eiz*1 + offset]. */
6571 needindex
= (havesib
6574 && address_mode
== mode_32bit
);
6575 havedisp
= (havebase
6577 || (havesib
&& (haveindex
|| scale
!= 0)));
6580 if (modrm
.mod
!= 0 || (base
& 7) == 5)
6582 if (havedisp
|| riprel
)
6583 print_displacement (scratchbuf
, disp
);
6585 print_operand_value (scratchbuf
, 1, disp
);
6586 oappend (scratchbuf
);
6590 oappend (sizeflag
& AFLAG
? "(%rip)" : "(%eip)");
6594 if (havebase
|| haveindex
|| riprel
)
6595 used_prefixes
|= PREFIX_ADDR
;
6597 if (havedisp
|| (intel_syntax
&& riprel
))
6599 *obufp
++ = open_char
;
6600 if (intel_syntax
&& riprel
)
6603 oappend (sizeflag
& AFLAG
? "rip" : "eip");
6607 oappend (address_mode
== mode_64bit
&& (sizeflag
& AFLAG
)
6608 ? names64
[base
] : names32
[base
]);
6611 /* ESP/RSP won't allow index. If base isn't ESP/RSP,
6612 print index to tell base + index from base. */
6616 || (havebase
&& base
!= ESP_REG_NUM
))
6618 if (!intel_syntax
|| havebase
)
6620 *obufp
++ = separator_char
;
6624 oappend (address_mode
== mode_64bit
6625 && (sizeflag
& AFLAG
)
6626 ? names64
[index
] : names32
[index
]);
6628 oappend (address_mode
== mode_64bit
6629 && (sizeflag
& AFLAG
)
6630 ? index64
: index32
);
6632 *obufp
++ = scale_char
;
6634 sprintf (scratchbuf
, "%d", 1 << scale
);
6635 oappend (scratchbuf
);
6639 && (disp
|| modrm
.mod
!= 0 || (base
& 7) == 5))
6641 if (!havedisp
|| (bfd_signed_vma
) disp
>= 0)
6646 else if (modrm
.mod
!= 1)
6650 disp
= - (bfd_signed_vma
) disp
;
6654 print_displacement (scratchbuf
, disp
);
6656 print_operand_value (scratchbuf
, 1, disp
);
6657 oappend (scratchbuf
);
6660 *obufp
++ = close_char
;
6663 else if (intel_syntax
)
6665 if (modrm
.mod
!= 0 || (base
& 7) == 5)
6667 if (prefixes
& (PREFIX_CS
| PREFIX_SS
| PREFIX_DS
6668 | PREFIX_ES
| PREFIX_FS
| PREFIX_GS
))
6672 oappend (names_seg
[ds_reg
- es_reg
]);
6675 print_operand_value (scratchbuf
, 1, disp
);
6676 oappend (scratchbuf
);
6681 { /* 16 bit address mode */
6688 if ((disp
& 0x8000) != 0)
6693 FETCH_DATA (the_info
, codep
+ 1);
6695 if ((disp
& 0x80) != 0)
6700 if ((disp
& 0x8000) != 0)
6706 if (modrm
.mod
!= 0 || modrm
.rm
== 6)
6708 print_displacement (scratchbuf
, disp
);
6709 oappend (scratchbuf
);
6712 if (modrm
.mod
!= 0 || modrm
.rm
!= 6)
6714 *obufp
++ = open_char
;
6716 oappend (index16
[modrm
.rm
]);
6718 && (disp
|| modrm
.mod
!= 0 || modrm
.rm
== 6))
6720 if ((bfd_signed_vma
) disp
>= 0)
6725 else if (modrm
.mod
!= 1)
6729 disp
= - (bfd_signed_vma
) disp
;
6732 print_displacement (scratchbuf
, disp
);
6733 oappend (scratchbuf
);
6736 *obufp
++ = close_char
;
6739 else if (intel_syntax
)
6741 if (prefixes
& (PREFIX_CS
| PREFIX_SS
| PREFIX_DS
6742 | PREFIX_ES
| PREFIX_FS
| PREFIX_GS
))
6746 oappend (names_seg
[ds_reg
- es_reg
]);
6749 print_operand_value (scratchbuf
, 1, disp
& 0xffff);
6750 oappend (scratchbuf
);
6756 OP_E (int bytemode
, int sizeflag
)
6758 OP_E_extended (bytemode
, sizeflag
, 0);
6763 OP_G (int bytemode
, int sizeflag
)
6774 oappend (names8rex
[modrm
.reg
+ add
]);
6776 oappend (names8
[modrm
.reg
+ add
]);
6779 oappend (names16
[modrm
.reg
+ add
]);
6782 oappend (names32
[modrm
.reg
+ add
]);
6785 oappend (names64
[modrm
.reg
+ add
]);
6794 oappend (names64
[modrm
.reg
+ add
]);
6795 else if ((sizeflag
& DFLAG
) || bytemode
!= v_mode
)
6796 oappend (names32
[modrm
.reg
+ add
]);
6798 oappend (names16
[modrm
.reg
+ add
]);
6799 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6802 if (address_mode
== mode_64bit
)
6803 oappend (names64
[modrm
.reg
+ add
]);
6805 oappend (names32
[modrm
.reg
+ add
]);
6808 oappend (INTERNAL_DISASSEMBLER_ERROR
);
6821 FETCH_DATA (the_info
, codep
+ 8);
6822 a
= *codep
++ & 0xff;
6823 a
|= (*codep
++ & 0xff) << 8;
6824 a
|= (*codep
++ & 0xff) << 16;
6825 a
|= (*codep
++ & 0xff) << 24;
6826 b
= *codep
++ & 0xff;
6827 b
|= (*codep
++ & 0xff) << 8;
6828 b
|= (*codep
++ & 0xff) << 16;
6829 b
|= (*codep
++ & 0xff) << 24;
6830 x
= a
+ ((bfd_vma
) b
<< 32);
6838 static bfd_signed_vma
6841 bfd_signed_vma x
= 0;
6843 FETCH_DATA (the_info
, codep
+ 4);
6844 x
= *codep
++ & (bfd_signed_vma
) 0xff;
6845 x
|= (*codep
++ & (bfd_signed_vma
) 0xff) << 8;
6846 x
|= (*codep
++ & (bfd_signed_vma
) 0xff) << 16;
6847 x
|= (*codep
++ & (bfd_signed_vma
) 0xff) << 24;
6851 static bfd_signed_vma
6854 bfd_signed_vma x
= 0;
6856 FETCH_DATA (the_info
, codep
+ 4);
6857 x
= *codep
++ & (bfd_signed_vma
) 0xff;
6858 x
|= (*codep
++ & (bfd_signed_vma
) 0xff) << 8;
6859 x
|= (*codep
++ & (bfd_signed_vma
) 0xff) << 16;
6860 x
|= (*codep
++ & (bfd_signed_vma
) 0xff) << 24;
6862 x
= (x
^ ((bfd_signed_vma
) 1 << 31)) - ((bfd_signed_vma
) 1 << 31);
6872 FETCH_DATA (the_info
, codep
+ 2);
6873 x
= *codep
++ & 0xff;
6874 x
|= (*codep
++ & 0xff) << 8;
6879 set_op (bfd_vma op
, int riprel
)
6881 op_index
[op_ad
] = op_ad
;
6882 if (address_mode
== mode_64bit
)
6884 op_address
[op_ad
] = op
;
6885 op_riprel
[op_ad
] = riprel
;
6889 /* Mask to get a 32-bit address. */
6890 op_address
[op_ad
] = op
& 0xffffffff;
6891 op_riprel
[op_ad
] = riprel
& 0xffffffff;
6896 OP_REG (int code
, int sizeflag
)
6906 case ax_reg
: case cx_reg
: case dx_reg
: case bx_reg
:
6907 case sp_reg
: case bp_reg
: case si_reg
: case di_reg
:
6908 s
= names16
[code
- ax_reg
+ add
];
6910 case es_reg
: case ss_reg
: case cs_reg
:
6911 case ds_reg
: case fs_reg
: case gs_reg
:
6912 s
= names_seg
[code
- es_reg
+ add
];
6914 case al_reg
: case ah_reg
: case cl_reg
: case ch_reg
:
6915 case dl_reg
: case dh_reg
: case bl_reg
: case bh_reg
:
6918 s
= names8rex
[code
- al_reg
+ add
];
6920 s
= names8
[code
- al_reg
];
6922 case rAX_reg
: case rCX_reg
: case rDX_reg
: case rBX_reg
:
6923 case rSP_reg
: case rBP_reg
: case rSI_reg
: case rDI_reg
:
6924 if (address_mode
== mode_64bit
&& (sizeflag
& DFLAG
))
6926 s
= names64
[code
- rAX_reg
+ add
];
6929 code
+= eAX_reg
- rAX_reg
;
6931 case eAX_reg
: case eCX_reg
: case eDX_reg
: case eBX_reg
:
6932 case eSP_reg
: case eBP_reg
: case eSI_reg
: case eDI_reg
:
6935 s
= names64
[code
- eAX_reg
+ add
];
6936 else if (sizeflag
& DFLAG
)
6937 s
= names32
[code
- eAX_reg
+ add
];
6939 s
= names16
[code
- eAX_reg
+ add
];
6940 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6943 s
= INTERNAL_DISASSEMBLER_ERROR
;
6950 OP_IMREG (int code
, int sizeflag
)
6962 case ax_reg
: case cx_reg
: case dx_reg
: case bx_reg
:
6963 case sp_reg
: case bp_reg
: case si_reg
: case di_reg
:
6964 s
= names16
[code
- ax_reg
];
6966 case es_reg
: case ss_reg
: case cs_reg
:
6967 case ds_reg
: case fs_reg
: case gs_reg
:
6968 s
= names_seg
[code
- es_reg
];
6970 case al_reg
: case ah_reg
: case cl_reg
: case ch_reg
:
6971 case dl_reg
: case dh_reg
: case bl_reg
: case bh_reg
:
6974 s
= names8rex
[code
- al_reg
];
6976 s
= names8
[code
- al_reg
];
6978 case eAX_reg
: case eCX_reg
: case eDX_reg
: case eBX_reg
:
6979 case eSP_reg
: case eBP_reg
: case eSI_reg
: case eDI_reg
:
6982 s
= names64
[code
- eAX_reg
];
6983 else if (sizeflag
& DFLAG
)
6984 s
= names32
[code
- eAX_reg
];
6986 s
= names16
[code
- eAX_reg
];
6987 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6990 if ((rex
& REX_W
) || (sizeflag
& DFLAG
))
6995 used_prefixes
|= (prefixes
& PREFIX_DATA
);
6998 s
= INTERNAL_DISASSEMBLER_ERROR
;
7005 OP_I (int bytemode
, int sizeflag
)
7008 bfd_signed_vma mask
= -1;
7013 FETCH_DATA (the_info
, codep
+ 1);
7018 if (address_mode
== mode_64bit
)
7028 else if (sizeflag
& DFLAG
)
7038 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7049 oappend (INTERNAL_DISASSEMBLER_ERROR
);
7054 scratchbuf
[0] = '$';
7055 print_operand_value (scratchbuf
+ 1, 1, op
);
7056 oappend (scratchbuf
+ intel_syntax
);
7057 scratchbuf
[0] = '\0';
7061 OP_I64 (int bytemode
, int sizeflag
)
7064 bfd_signed_vma mask
= -1;
7066 if (address_mode
!= mode_64bit
)
7068 OP_I (bytemode
, sizeflag
);
7075 FETCH_DATA (the_info
, codep
+ 1);
7083 else if (sizeflag
& DFLAG
)
7093 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7100 oappend (INTERNAL_DISASSEMBLER_ERROR
);
7105 scratchbuf
[0] = '$';
7106 print_operand_value (scratchbuf
+ 1, 1, op
);
7107 oappend (scratchbuf
+ intel_syntax
);
7108 scratchbuf
[0] = '\0';
7112 OP_sI (int bytemode
, int sizeflag
)
7115 bfd_signed_vma mask
= -1;
7120 FETCH_DATA (the_info
, codep
+ 1);
7122 if ((op
& 0x80) != 0)
7130 else if (sizeflag
& DFLAG
)
7139 if ((op
& 0x8000) != 0)
7142 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7147 if ((op
& 0x8000) != 0)
7151 oappend (INTERNAL_DISASSEMBLER_ERROR
);
7155 scratchbuf
[0] = '$';
7156 print_operand_value (scratchbuf
+ 1, 1, op
);
7157 oappend (scratchbuf
+ intel_syntax
);
7161 OP_J (int bytemode
, int sizeflag
)
7165 bfd_vma segment
= 0;
7170 FETCH_DATA (the_info
, codep
+ 1);
7172 if ((disp
& 0x80) != 0)
7176 if ((sizeflag
& DFLAG
) || (rex
& REX_W
))
7181 if ((disp
& 0x8000) != 0)
7183 /* In 16bit mode, address is wrapped around at 64k within
7184 the same segment. Otherwise, a data16 prefix on a jump
7185 instruction means that the pc is masked to 16 bits after
7186 the displacement is added! */
7188 if ((prefixes
& PREFIX_DATA
) == 0)
7189 segment
= ((start_pc
+ codep
- start_codep
)
7190 & ~((bfd_vma
) 0xffff));
7192 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7195 oappend (INTERNAL_DISASSEMBLER_ERROR
);
7198 disp
= ((start_pc
+ codep
- start_codep
+ disp
) & mask
) | segment
;
7200 print_operand_value (scratchbuf
, 1, disp
);
7201 oappend (scratchbuf
);
7205 OP_SEG (int bytemode
, int sizeflag
)
7207 if (bytemode
== w_mode
)
7208 oappend (names_seg
[modrm
.reg
]);
7210 OP_E (modrm
.mod
== 3 ? bytemode
: w_mode
, sizeflag
);
7214 OP_DIR (int dummy ATTRIBUTE_UNUSED
, int sizeflag
)
7218 if (sizeflag
& DFLAG
)
7228 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7230 sprintf (scratchbuf
, "0x%x:0x%x", seg
, offset
);
7232 sprintf (scratchbuf
, "$0x%x,$0x%x", seg
, offset
);
7233 oappend (scratchbuf
);
7237 OP_OFF (int bytemode
, int sizeflag
)
7241 if (intel_syntax
&& (sizeflag
& SUFFIX_ALWAYS
))
7242 intel_operand_size (bytemode
, sizeflag
);
7245 if ((sizeflag
& AFLAG
) || address_mode
== mode_64bit
)
7252 if (!(prefixes
& (PREFIX_CS
| PREFIX_SS
| PREFIX_DS
7253 | PREFIX_ES
| PREFIX_FS
| PREFIX_GS
)))
7255 oappend (names_seg
[ds_reg
- es_reg
]);
7259 print_operand_value (scratchbuf
, 1, off
);
7260 oappend (scratchbuf
);
7264 OP_OFF64 (int bytemode
, int sizeflag
)
7268 if (address_mode
!= mode_64bit
7269 || (prefixes
& PREFIX_ADDR
))
7271 OP_OFF (bytemode
, sizeflag
);
7275 if (intel_syntax
&& (sizeflag
& SUFFIX_ALWAYS
))
7276 intel_operand_size (bytemode
, sizeflag
);
7283 if (!(prefixes
& (PREFIX_CS
| PREFIX_SS
| PREFIX_DS
7284 | PREFIX_ES
| PREFIX_FS
| PREFIX_GS
)))
7286 oappend (names_seg
[ds_reg
- es_reg
]);
7290 print_operand_value (scratchbuf
, 1, off
);
7291 oappend (scratchbuf
);
7295 ptr_reg (int code
, int sizeflag
)
7299 *obufp
++ = open_char
;
7300 used_prefixes
|= (prefixes
& PREFIX_ADDR
);
7301 if (address_mode
== mode_64bit
)
7303 if (!(sizeflag
& AFLAG
))
7304 s
= names32
[code
- eAX_reg
];
7306 s
= names64
[code
- eAX_reg
];
7308 else if (sizeflag
& AFLAG
)
7309 s
= names32
[code
- eAX_reg
];
7311 s
= names16
[code
- eAX_reg
];
7313 *obufp
++ = close_char
;
7318 OP_ESreg (int code
, int sizeflag
)
7324 case 0x6d: /* insw/insl */
7325 intel_operand_size (z_mode
, sizeflag
);
7327 case 0xa5: /* movsw/movsl/movsq */
7328 case 0xa7: /* cmpsw/cmpsl/cmpsq */
7329 case 0xab: /* stosw/stosl */
7330 case 0xaf: /* scasw/scasl */
7331 intel_operand_size (v_mode
, sizeflag
);
7334 intel_operand_size (b_mode
, sizeflag
);
7337 oappend ("%es:" + intel_syntax
);
7338 ptr_reg (code
, sizeflag
);
7342 OP_DSreg (int code
, int sizeflag
)
7348 case 0x6f: /* outsw/outsl */
7349 intel_operand_size (z_mode
, sizeflag
);
7351 case 0xa5: /* movsw/movsl/movsq */
7352 case 0xa7: /* cmpsw/cmpsl/cmpsq */
7353 case 0xad: /* lodsw/lodsl/lodsq */
7354 intel_operand_size (v_mode
, sizeflag
);
7357 intel_operand_size (b_mode
, sizeflag
);
7367 prefixes
|= PREFIX_DS
;
7369 ptr_reg (code
, sizeflag
);
7373 OP_C (int dummy ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7381 else if (address_mode
!= mode_64bit
&& (prefixes
& PREFIX_LOCK
))
7384 used_prefixes
|= PREFIX_LOCK
;
7387 sprintf (scratchbuf
, "%%cr%d", modrm
.reg
+ add
);
7388 oappend (scratchbuf
+ intel_syntax
);
7392 OP_D (int dummy ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7399 sprintf (scratchbuf
, "db%d", modrm
.reg
+ add
);
7401 sprintf (scratchbuf
, "%%db%d", modrm
.reg
+ add
);
7402 oappend (scratchbuf
);
7406 OP_T (int dummy ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7408 sprintf (scratchbuf
, "%%tr%d", modrm
.reg
);
7409 oappend (scratchbuf
+ intel_syntax
);
7413 OP_R (int bytemode
, int sizeflag
)
7416 OP_E (bytemode
, sizeflag
);
7422 OP_MMX (int bytemode ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7424 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7425 if (prefixes
& PREFIX_DATA
)
7431 sprintf (scratchbuf
, "%%xmm%d", modrm
.reg
+ add
);
7434 sprintf (scratchbuf
, "%%mm%d", modrm
.reg
);
7435 oappend (scratchbuf
+ intel_syntax
);
7439 OP_XMM (int bytemode ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7445 sprintf (scratchbuf
, "%%xmm%d", modrm
.reg
+ add
);
7446 oappend (scratchbuf
+ intel_syntax
);
7450 OP_EM (int bytemode
, int sizeflag
)
7454 if (intel_syntax
&& bytemode
== v_mode
)
7456 bytemode
= (prefixes
& PREFIX_DATA
) ? x_mode
: q_mode
;
7457 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7459 OP_E (bytemode
, sizeflag
);
7463 /* Skip mod/rm byte. */
7466 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7467 if (prefixes
& PREFIX_DATA
)
7474 sprintf (scratchbuf
, "%%xmm%d", modrm
.rm
+ add
);
7477 sprintf (scratchbuf
, "%%mm%d", modrm
.rm
);
7478 oappend (scratchbuf
+ intel_syntax
);
7481 /* cvt* are the only instructions in sse2 which have
7482 both SSE and MMX operands and also have 0x66 prefix
7483 in their opcode. 0x66 was originally used to differentiate
7484 between SSE and MMX instruction(operands). So we have to handle the
7485 cvt* separately using OP_EMC and OP_MXC */
7487 OP_EMC (int bytemode
, int sizeflag
)
7491 if (intel_syntax
&& bytemode
== v_mode
)
7493 bytemode
= (prefixes
& PREFIX_DATA
) ? x_mode
: q_mode
;
7494 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7496 OP_E (bytemode
, sizeflag
);
7500 /* Skip mod/rm byte. */
7503 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7504 sprintf (scratchbuf
, "%%mm%d", modrm
.rm
);
7505 oappend (scratchbuf
+ intel_syntax
);
7509 OP_MXC (int bytemode ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7511 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7512 sprintf (scratchbuf
, "%%mm%d", modrm
.reg
);
7513 oappend (scratchbuf
+ intel_syntax
);
7517 OP_EX (int bytemode
, int sizeflag
)
7522 OP_E (bytemode
, sizeflag
);
7529 /* Skip mod/rm byte. */
7532 sprintf (scratchbuf
, "%%xmm%d", modrm
.rm
+ add
);
7533 oappend (scratchbuf
+ intel_syntax
);
7537 OP_MS (int bytemode
, int sizeflag
)
7540 OP_EM (bytemode
, sizeflag
);
7546 OP_XS (int bytemode
, int sizeflag
)
7549 OP_EX (bytemode
, sizeflag
);
7555 OP_M (int bytemode
, int sizeflag
)
7558 /* bad bound,lea,lds,les,lfs,lgs,lss,cmpxchg8b,vmptrst modrm */
7561 OP_E (bytemode
, sizeflag
);
7565 OP_0f07 (int bytemode
, int sizeflag
)
7567 if (modrm
.mod
!= 3 || modrm
.rm
!= 0)
7570 OP_E (bytemode
, sizeflag
);
7573 /* NOP is an alias of "xchg %ax,%ax" in 16bit mode, "xchg %eax,%eax" in
7574 32bit mode and "xchg %rax,%rax" in 64bit mode. */
7577 NOP_Fixup1 (int bytemode
, int sizeflag
)
7579 if ((prefixes
& PREFIX_DATA
) != 0
7582 && address_mode
== mode_64bit
))
7583 OP_REG (bytemode
, sizeflag
);
7585 strcpy (obuf
, "nop");
7589 NOP_Fixup2 (int bytemode
, int sizeflag
)
7591 if ((prefixes
& PREFIX_DATA
) != 0
7594 && address_mode
== mode_64bit
))
7595 OP_IMREG (bytemode
, sizeflag
);
7598 static const char *const Suffix3DNow
[] = {
7599 /* 00 */ NULL
, NULL
, NULL
, NULL
,
7600 /* 04 */ NULL
, NULL
, NULL
, NULL
,
7601 /* 08 */ NULL
, NULL
, NULL
, NULL
,
7602 /* 0C */ "pi2fw", "pi2fd", NULL
, NULL
,
7603 /* 10 */ NULL
, NULL
, NULL
, NULL
,
7604 /* 14 */ NULL
, NULL
, NULL
, NULL
,
7605 /* 18 */ NULL
, NULL
, NULL
, NULL
,
7606 /* 1C */ "pf2iw", "pf2id", NULL
, NULL
,
7607 /* 20 */ NULL
, NULL
, NULL
, NULL
,
7608 /* 24 */ NULL
, NULL
, NULL
, NULL
,
7609 /* 28 */ NULL
, NULL
, NULL
, NULL
,
7610 /* 2C */ NULL
, NULL
, NULL
, NULL
,
7611 /* 30 */ NULL
, NULL
, NULL
, NULL
,
7612 /* 34 */ NULL
, NULL
, NULL
, NULL
,
7613 /* 38 */ NULL
, NULL
, NULL
, NULL
,
7614 /* 3C */ NULL
, NULL
, NULL
, NULL
,
7615 /* 40 */ NULL
, NULL
, NULL
, NULL
,
7616 /* 44 */ NULL
, NULL
, NULL
, NULL
,
7617 /* 48 */ NULL
, NULL
, NULL
, NULL
,
7618 /* 4C */ NULL
, NULL
, NULL
, NULL
,
7619 /* 50 */ NULL
, NULL
, NULL
, NULL
,
7620 /* 54 */ NULL
, NULL
, NULL
, NULL
,
7621 /* 58 */ NULL
, NULL
, NULL
, NULL
,
7622 /* 5C */ NULL
, NULL
, NULL
, NULL
,
7623 /* 60 */ NULL
, NULL
, NULL
, NULL
,
7624 /* 64 */ NULL
, NULL
, NULL
, NULL
,
7625 /* 68 */ NULL
, NULL
, NULL
, NULL
,
7626 /* 6C */ NULL
, NULL
, NULL
, NULL
,
7627 /* 70 */ NULL
, NULL
, NULL
, NULL
,
7628 /* 74 */ NULL
, NULL
, NULL
, NULL
,
7629 /* 78 */ NULL
, NULL
, NULL
, NULL
,
7630 /* 7C */ NULL
, NULL
, NULL
, NULL
,
7631 /* 80 */ NULL
, NULL
, NULL
, NULL
,
7632 /* 84 */ NULL
, NULL
, NULL
, NULL
,
7633 /* 88 */ NULL
, NULL
, "pfnacc", NULL
,
7634 /* 8C */ NULL
, NULL
, "pfpnacc", NULL
,
7635 /* 90 */ "pfcmpge", NULL
, NULL
, NULL
,
7636 /* 94 */ "pfmin", NULL
, "pfrcp", "pfrsqrt",
7637 /* 98 */ NULL
, NULL
, "pfsub", NULL
,
7638 /* 9C */ NULL
, NULL
, "pfadd", NULL
,
7639 /* A0 */ "pfcmpgt", NULL
, NULL
, NULL
,
7640 /* A4 */ "pfmax", NULL
, "pfrcpit1", "pfrsqit1",
7641 /* A8 */ NULL
, NULL
, "pfsubr", NULL
,
7642 /* AC */ NULL
, NULL
, "pfacc", NULL
,
7643 /* B0 */ "pfcmpeq", NULL
, NULL
, NULL
,
7644 /* B4 */ "pfmul", NULL
, "pfrcpit2", "pmulhrw",
7645 /* B8 */ NULL
, NULL
, NULL
, "pswapd",
7646 /* BC */ NULL
, NULL
, NULL
, "pavgusb",
7647 /* C0 */ NULL
, NULL
, NULL
, NULL
,
7648 /* C4 */ NULL
, NULL
, NULL
, NULL
,
7649 /* C8 */ NULL
, NULL
, NULL
, NULL
,
7650 /* CC */ NULL
, NULL
, NULL
, NULL
,
7651 /* D0 */ NULL
, NULL
, NULL
, NULL
,
7652 /* D4 */ NULL
, NULL
, NULL
, NULL
,
7653 /* D8 */ NULL
, NULL
, NULL
, NULL
,
7654 /* DC */ NULL
, NULL
, NULL
, NULL
,
7655 /* E0 */ NULL
, NULL
, NULL
, NULL
,
7656 /* E4 */ NULL
, NULL
, NULL
, NULL
,
7657 /* E8 */ NULL
, NULL
, NULL
, NULL
,
7658 /* EC */ NULL
, NULL
, NULL
, NULL
,
7659 /* F0 */ NULL
, NULL
, NULL
, NULL
,
7660 /* F4 */ NULL
, NULL
, NULL
, NULL
,
7661 /* F8 */ NULL
, NULL
, NULL
, NULL
,
7662 /* FC */ NULL
, NULL
, NULL
, NULL
,
7666 OP_3DNowSuffix (int bytemode ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7668 const char *mnemonic
;
7670 FETCH_DATA (the_info
, codep
+ 1);
7671 /* AMD 3DNow! instructions are specified by an opcode suffix in the
7672 place where an 8-bit immediate would normally go. ie. the last
7673 byte of the instruction. */
7674 obufp
= obuf
+ strlen (obuf
);
7675 mnemonic
= Suffix3DNow
[*codep
++ & 0xff];
7680 /* Since a variable sized modrm/sib chunk is between the start
7681 of the opcode (0x0f0f) and the opcode suffix, we need to do
7682 all the modrm processing first, and don't know until now that
7683 we have a bad opcode. This necessitates some cleaning up. */
7684 op_out
[0][0] = '\0';
7685 op_out
[1][0] = '\0';
7690 static const char *simd_cmp_op
[] = {
7702 OP_SIMD_Suffix (int bytemode ATTRIBUTE_UNUSED
, int sizeflag ATTRIBUTE_UNUSED
)
7704 unsigned int cmp_type
;
7706 FETCH_DATA (the_info
, codep
+ 1);
7707 obufp
= obuf
+ strlen (obuf
);
7708 cmp_type
= *codep
++ & 0xff;
7711 char suffix1
= 'p', suffix2
= 's';
7712 used_prefixes
|= (prefixes
& PREFIX_REPZ
);
7713 if (prefixes
& PREFIX_REPZ
)
7717 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7718 if (prefixes
& PREFIX_DATA
)
7722 used_prefixes
|= (prefixes
& PREFIX_REPNZ
);
7723 if (prefixes
& PREFIX_REPNZ
)
7724 suffix1
= 's', suffix2
= 'd';
7727 sprintf (scratchbuf
, "cmp%s%c%c",
7728 simd_cmp_op
[cmp_type
], suffix1
, suffix2
);
7729 used_prefixes
|= (prefixes
& PREFIX_REPZ
);
7730 oappend (scratchbuf
);
7734 /* We have a bad extension byte. Clean up. */
7735 op_out
[0][0] = '\0';
7736 op_out
[1][0] = '\0';
7742 OP_Mwait (int bytemode ATTRIBUTE_UNUSED
,
7743 int sizeflag ATTRIBUTE_UNUSED
)
7745 /* mwait %eax,%ecx */
7748 const char **names
= (address_mode
== mode_64bit
7749 ? names64
: names32
);
7750 strcpy (op_out
[0], names
[0]);
7751 strcpy (op_out
[1], names
[1]);
7754 /* Skip mod/rm byte. */
7760 OP_Monitor (int bytemode ATTRIBUTE_UNUSED
,
7761 int sizeflag ATTRIBUTE_UNUSED
)
7763 /* monitor %eax,%ecx,%edx" */
7766 const char **op1_names
;
7767 const char **names
= (address_mode
== mode_64bit
7768 ? names64
: names32
);
7770 if (!(prefixes
& PREFIX_ADDR
))
7771 op1_names
= (address_mode
== mode_16bit
7775 /* Remove "addr16/addr32". */
7777 op1_names
= (address_mode
!= mode_32bit
7778 ? names32
: names16
);
7779 used_prefixes
|= PREFIX_ADDR
;
7781 strcpy (op_out
[0], op1_names
[0]);
7782 strcpy (op_out
[1], names
[1]);
7783 strcpy (op_out
[2], names
[2]);
7786 /* Skip mod/rm byte. */
7794 /* Throw away prefixes and 1st. opcode byte. */
7795 codep
= insn_codep
+ 1;
7800 REP_Fixup (int bytemode
, int sizeflag
)
7802 /* The 0xf3 prefix should be displayed as "rep" for ins, outs, movs,
7804 if (prefixes
& PREFIX_REPZ
)
7805 repz_prefix
= "rep ";
7812 OP_IMREG (bytemode
, sizeflag
);
7815 OP_ESreg (bytemode
, sizeflag
);
7818 OP_DSreg (bytemode
, sizeflag
);
7827 CMPXCHG8B_Fixup (int bytemode
, int sizeflag
)
7832 /* Change cmpxchg8b to cmpxchg16b. */
7833 char *p
= obuf
+ strlen (obuf
) - 2;
7837 OP_M (bytemode
, sizeflag
);
7841 XMM_Fixup (int reg
, int sizeflag ATTRIBUTE_UNUSED
)
7843 sprintf (scratchbuf
, "%%xmm%d", reg
);
7844 oappend (scratchbuf
+ intel_syntax
);
7848 CRC32_Fixup (int bytemode
, int sizeflag
)
7850 /* Add proper suffix to "crc32". */
7851 char *p
= obuf
+ strlen (obuf
);
7868 else if (sizeflag
& DFLAG
)
7872 used_prefixes
|= (prefixes
& PREFIX_DATA
);
7875 oappend (INTERNAL_DISASSEMBLER_ERROR
);
7884 /* Skip mod/rm byte. */
7889 add
= (rex
& REX_B
) ? 8 : 0;
7890 if (bytemode
== b_mode
)
7894 oappend (names8rex
[modrm
.rm
+ add
]);
7896 oappend (names8
[modrm
.rm
+ add
]);
7902 oappend (names64
[modrm
.rm
+ add
]);
7903 else if ((prefixes
& PREFIX_DATA
))
7904 oappend (names16
[modrm
.rm
+ add
]);
7906 oappend (names32
[modrm
.rm
+ add
]);
7910 OP_E (bytemode
, sizeflag
);
7913 /* Print a DREX argument as either a register or memory operation. */
7915 print_drex_arg (unsigned int reg
, int bytemode
, int sizeflag
)
7917 if (reg
== DREX_REG_UNKNOWN
)
7920 else if (reg
!= DREX_REG_MEMORY
)
7922 sprintf (scratchbuf
, "%%xmm%d", reg
);
7923 oappend (scratchbuf
+ intel_syntax
);
7927 OP_E_extended (bytemode
, sizeflag
, 1);
7930 /* SSE5 instructions that have 4 arguments are encoded as:
7931 0f 24 <sub-opcode> <modrm> <optional-sib> <drex> <offset>.
7933 The <sub-opcode> byte has 1 bit (0x4) that is combined with 1 bit in
7934 the DREX field (0x8) to determine how the arguments are laid out.
7935 The destination register must be the same register as one of the
7936 inputs, and it is encoded in the DREX byte. No REX prefix is used
7937 for these instructions, since the DREX field contains the 3 extension
7938 bits provided by the REX prefix.
7940 The bytemode argument adds 2 extra bits for passing extra information:
7941 DREX_OC1 -- Set the OC1 bit to indicate dest == 1st arg
7942 DREX_NO_OC0 -- OC0 in DREX is invalid
7943 (but pretend it is set). */
7946 OP_DREX4 (int flag_bytemode
, int sizeflag
)
7948 unsigned int drex_byte
;
7949 unsigned int regs
[4];
7950 unsigned int modrm_regmem
;
7951 unsigned int modrm_reg
;
7952 unsigned int drex_reg
;
7955 int rex_used_save
= rex_used
;
7957 int oc1
= (flag_bytemode
& DREX_OC1
) ? 2 : 0;
7961 bytemode
= flag_bytemode
& ~ DREX_MASK
;
7963 for (i
= 0; i
< 4; i
++)
7964 regs
[i
] = DREX_REG_UNKNOWN
;
7966 /* Determine if we have a SIB byte in addition to MODRM before the
7968 if (((sizeflag
& AFLAG
) || address_mode
== mode_64bit
)
7973 /* Get the DREX byte. */
7974 FETCH_DATA (the_info
, codep
+ 2 + has_sib
);
7975 drex_byte
= codep
[has_sib
+1];
7976 drex_reg
= DREX_XMM (drex_byte
);
7977 modrm_reg
= modrm
.reg
+ ((drex_byte
& REX_R
) ? 8 : 0);
7979 /* Is OC0 legal? If not, hardwire oc0 == 1. */
7980 if (flag_bytemode
& DREX_NO_OC0
)
7983 if (DREX_OC0 (drex_byte
))
7987 oc0
= DREX_OC0 (drex_byte
);
7991 /* regmem == register */
7992 modrm_regmem
= modrm
.rm
+ ((drex_byte
& REX_B
) ? 8 : 0);
7994 /* skip modrm/drex since we don't call OP_E_extended */
7999 /* regmem == memory, fill in appropriate REX bits */
8000 modrm_regmem
= DREX_REG_MEMORY
;
8001 rex
= drex_byte
& (REX_B
| REX_X
| REX_R
);
8007 /* Based on the OC1/OC0 bits, lay out the arguments in the correct
8016 regs
[0] = modrm_regmem
;
8017 regs
[1] = modrm_reg
;
8023 regs
[0] = modrm_reg
;
8024 regs
[1] = modrm_regmem
;
8031 regs
[1] = modrm_regmem
;
8032 regs
[2] = modrm_reg
;
8038 regs
[1] = modrm_reg
;
8039 regs
[2] = modrm_regmem
;
8044 /* Print out the arguments. */
8045 for (i
= 0; i
< 4; i
++)
8047 int j
= (intel_syntax
) ? 3 - i
: i
;
8054 print_drex_arg (regs
[j
], bytemode
, sizeflag
);
8058 rex_used
= rex_used_save
;
8061 /* SSE5 instructions that have 3 arguments, and are encoded as:
8062 0f 24 <sub-opcode> <modrm> <optional-sib> <drex> <offset> (or)
8063 0f 25 <sub-opcode> <modrm> <optional-sib> <drex> <offset> <cmp-byte>
8065 The DREX field has 1 bit (0x8) to determine how the arguments are
8066 laid out. The destination register is encoded in the DREX byte.
8067 No REX prefix is used for these instructions, since the DREX field
8068 contains the 3 extension bits provided by the REX prefix. */
8071 OP_DREX3 (int flag_bytemode
, int sizeflag
)
8073 unsigned int drex_byte
;
8074 unsigned int regs
[3];
8075 unsigned int modrm_regmem
;
8076 unsigned int modrm_reg
;
8077 unsigned int drex_reg
;
8080 int rex_used_save
= rex_used
;
8085 bytemode
= flag_bytemode
& ~ DREX_MASK
;
8087 for (i
= 0; i
< 3; i
++)
8088 regs
[i
] = DREX_REG_UNKNOWN
;
8090 /* Determine if we have a SIB byte in addition to MODRM before the
8092 if (((sizeflag
& AFLAG
) || address_mode
== mode_64bit
)
8097 /* Get the DREX byte. */
8098 FETCH_DATA (the_info
, codep
+ 2 + has_sib
);
8099 drex_byte
= codep
[has_sib
+1];
8100 drex_reg
= DREX_XMM (drex_byte
);
8101 modrm_reg
= modrm
.reg
+ ((drex_byte
& REX_R
) ? 8 : 0);
8103 /* Is OC0 legal? If not, hardwire oc0 == 0 */
8104 oc0
= DREX_OC0 (drex_byte
);
8105 if ((flag_bytemode
& DREX_NO_OC0
) && oc0
)
8110 /* regmem == register */
8111 modrm_regmem
= modrm
.rm
+ ((drex_byte
& REX_B
) ? 8 : 0);
8113 /* skip modrm/drex since we don't call OP_E_extended. */
8118 /* regmem == memory, fill in appropriate REX bits. */
8119 modrm_regmem
= DREX_REG_MEMORY
;
8120 rex
= drex_byte
& (REX_B
| REX_X
| REX_R
);
8126 /* Based on the OC1/OC0 bits, lay out the arguments in the correct
8135 regs
[0] = modrm_regmem
;
8136 regs
[1] = modrm_reg
;
8141 regs
[0] = modrm_reg
;
8142 regs
[1] = modrm_regmem
;
8147 /* Print out the arguments. */
8148 for (i
= 0; i
< 3; i
++)
8150 int j
= (intel_syntax
) ? 2 - i
: i
;
8157 print_drex_arg (regs
[j
], bytemode
, sizeflag
);
8161 rex_used
= rex_used_save
;
8164 /* Emit a floating point comparison for comp<xx> instructions. */
8167 OP_DREX_FCMP (int bytemode ATTRIBUTE_UNUSED
,
8168 int sizeflag ATTRIBUTE_UNUSED
)
8172 static const char *const cmp_test
[] = {
8191 FETCH_DATA (the_info
, codep
+ 1);
8192 byte
= *codep
& 0xff;
8194 if (byte
>= ARRAY_SIZE (cmp_test
)
8199 /* The instruction isn't one we know about, so just append the
8200 extension byte as a numeric value. */
8206 sprintf (scratchbuf
, "com%s%s", cmp_test
[byte
], obuf
+3);
8207 strcpy (obuf
, scratchbuf
);
8212 /* Emit an integer point comparison for pcom<xx> instructions,
8213 rewriting the instruction to have the test inside of it. */
8216 OP_DREX_ICMP (int bytemode ATTRIBUTE_UNUSED
,
8217 int sizeflag ATTRIBUTE_UNUSED
)
8221 static const char *const cmp_test
[] = {
8232 FETCH_DATA (the_info
, codep
+ 1);
8233 byte
= *codep
& 0xff;
8235 if (byte
>= ARRAY_SIZE (cmp_test
)
8241 /* The instruction isn't one we know about, so just print the
8242 comparison test byte as a numeric value. */
8248 sprintf (scratchbuf
, "pcom%s%s", cmp_test
[byte
], obuf
+4);
8249 strcpy (obuf
, scratchbuf
);