Coverage Report

Created: 2025-06-24 06:45

/src/binutils-gdb/opcodes/arm-dis.c
Line
Count
Source (jump to first uncovered line)
1
/* Instruction printing code for the ARM
2
   Copyright (C) 1994-2025 Free Software Foundation, Inc.
3
   Contributed by Richard Earnshaw (rwe@pegasus.esprit.ec.org)
4
   Modification by James G. Smith (jsmith@cygnus.co.uk)
5
6
   This file is part of libopcodes.
7
8
   This library is free software; you can redistribute it and/or modify
9
   it under the terms of the GNU General Public License as published by
10
   the Free Software Foundation; either version 3 of the License, or
11
   (at your option) any later version.
12
13
   It is distributed in the hope that it will be useful, but WITHOUT
14
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
15
   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
16
   License for more details.
17
18
   You should have received a copy of the GNU General Public License
19
   along with this program; if not, write to the Free Software
20
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
21
   MA 02110-1301, USA.  */
22
23
#include "sysdep.h"
24
#include <assert.h>
25
26
#include "disassemble.h"
27
#include "opcode/arm.h"
28
#include "opintl.h"
29
#include "safe-ctype.h"
30
#include "libiberty.h"
31
#include "floatformat.h"
32
33
/* FIXME: This shouldn't be done here.  */
34
#include "coff/internal.h"
35
#include "libcoff.h"
36
#include "bfd.h"
37
#include "elf-bfd.h"
38
#include "elf/internal.h"
39
#include "elf/arm.h"
40
#include "mach-o.h"
41
42
/* Cached mapping symbol state.  */
43
enum map_type
44
{
45
  MAP_ARM,
46
  MAP_THUMB,
47
  MAP_DATA
48
};
49
50
struct arm_private_data
51
{
52
  /* The features to use when disassembling optional instructions.  */
53
  arm_feature_set features;
54
55
  /* Track the last type (although this doesn't seem to be useful) */
56
  enum map_type last_type;
57
58
  /* Tracking symbol table information */
59
  int last_mapping_sym;
60
61
  /* The end range of the current range being disassembled.  */
62
  bfd_vma last_stop_offset;
63
  bfd_vma last_mapping_addr;
64
};
65
66
enum mve_instructions
67
{
68
  MVE_VPST,
69
  MVE_VPT_FP_T1,
70
  MVE_VPT_FP_T2,
71
  MVE_VPT_VEC_T1,
72
  MVE_VPT_VEC_T2,
73
  MVE_VPT_VEC_T3,
74
  MVE_VPT_VEC_T4,
75
  MVE_VPT_VEC_T5,
76
  MVE_VPT_VEC_T6,
77
  MVE_VCMP_FP_T1,
78
  MVE_VCMP_FP_T2,
79
  MVE_VCMP_VEC_T1,
80
  MVE_VCMP_VEC_T2,
81
  MVE_VCMP_VEC_T3,
82
  MVE_VCMP_VEC_T4,
83
  MVE_VCMP_VEC_T5,
84
  MVE_VCMP_VEC_T6,
85
  MVE_VDUP,
86
  MVE_VEOR,
87
  MVE_VFMAS_FP_SCALAR,
88
  MVE_VFMA_FP_SCALAR,
89
  MVE_VFMA_FP,
90
  MVE_VFMS_FP,
91
  MVE_VHADD_T1,
92
  MVE_VHADD_T2,
93
  MVE_VHSUB_T1,
94
  MVE_VHSUB_T2,
95
  MVE_VRHADD,
96
  MVE_VLD2,
97
  MVE_VLD4,
98
  MVE_VST2,
99
  MVE_VST4,
100
  MVE_VLDRB_T1,
101
  MVE_VLDRH_T2,
102
  MVE_VLDRB_T5,
103
  MVE_VLDRH_T6,
104
  MVE_VLDRW_T7,
105
  MVE_VSTRB_T1,
106
  MVE_VSTRH_T2,
107
  MVE_VSTRB_T5,
108
  MVE_VSTRH_T6,
109
  MVE_VSTRW_T7,
110
  MVE_VLDRB_GATHER_T1,
111
  MVE_VLDRH_GATHER_T2,
112
  MVE_VLDRW_GATHER_T3,
113
  MVE_VLDRD_GATHER_T4,
114
  MVE_VLDRW_GATHER_T5,
115
  MVE_VLDRD_GATHER_T6,
116
  MVE_VSTRB_SCATTER_T1,
117
  MVE_VSTRH_SCATTER_T2,
118
  MVE_VSTRW_SCATTER_T3,
119
  MVE_VSTRD_SCATTER_T4,
120
  MVE_VSTRW_SCATTER_T5,
121
  MVE_VSTRD_SCATTER_T6,
122
  MVE_VCVT_FP_FIX_VEC,
123
  MVE_VCVT_BETWEEN_FP_INT,
124
  MVE_VCVT_FP_HALF_FP,
125
  MVE_VCVT_FROM_FP_TO_INT,
126
  MVE_VRINT_FP,
127
  MVE_VMOV_HFP_TO_GP,
128
  MVE_VMOV_GP_TO_VEC_LANE,
129
  MVE_VMOV_IMM_TO_VEC,
130
  MVE_VMOV_VEC_TO_VEC,
131
  MVE_VMOV2_VEC_LANE_TO_GP,
132
  MVE_VMOV2_GP_TO_VEC_LANE,
133
  MVE_VMOV_VEC_LANE_TO_GP,
134
  MVE_VMVN_IMM,
135
  MVE_VMVN_REG,
136
  MVE_VORR_IMM,
137
  MVE_VORR_REG,
138
  MVE_VORN,
139
  MVE_VBIC_IMM,
140
  MVE_VBIC_REG,
141
  MVE_VMOVX,
142
  MVE_VMOVL,
143
  MVE_VMOVN,
144
  MVE_VMULL_INT,
145
  MVE_VMULL_POLY,
146
  MVE_VQDMULL_T1,
147
  MVE_VQDMULL_T2,
148
  MVE_VQMOVN,
149
  MVE_VQMOVUN,
150
  MVE_VADDV,
151
  MVE_VMLADAV_T1,
152
  MVE_VMLADAV_T2,
153
  MVE_VMLALDAV,
154
  MVE_VMLAS,
155
  MVE_VADDLV,
156
  MVE_VMLSDAV_T1,
157
  MVE_VMLSDAV_T2,
158
  MVE_VMLSLDAV,
159
  MVE_VRMLALDAVH,
160
  MVE_VRMLSLDAVH,
161
  MVE_VQDMLADH,
162
  MVE_VQRDMLADH,
163
  MVE_VQDMLAH,
164
  MVE_VQRDMLAH,
165
  MVE_VQDMLASH,
166
  MVE_VQRDMLASH,
167
  MVE_VQDMLSDH,
168
  MVE_VQRDMLSDH,
169
  MVE_VQDMULH_T1,
170
  MVE_VQRDMULH_T2,
171
  MVE_VQDMULH_T3,
172
  MVE_VQRDMULH_T4,
173
  MVE_VDDUP,
174
  MVE_VDWDUP,
175
  MVE_VIWDUP,
176
  MVE_VIDUP,
177
  MVE_VCADD_FP,
178
  MVE_VCADD_VEC,
179
  MVE_VHCADD,
180
  MVE_VCMLA_FP,
181
  MVE_VCMUL_FP,
182
  MVE_VQRSHL_T1,
183
  MVE_VQRSHL_T2,
184
  MVE_VQRSHRN,
185
  MVE_VQRSHRUN,
186
  MVE_VQSHL_T1,
187
  MVE_VQSHL_T2,
188
  MVE_VQSHLU_T3,
189
  MVE_VQSHL_T4,
190
  MVE_VQSHRN,
191
  MVE_VQSHRUN,
192
  MVE_VRSHL_T1,
193
  MVE_VRSHL_T2,
194
  MVE_VRSHR,
195
  MVE_VRSHRN,
196
  MVE_VSHL_T1,
197
  MVE_VSHL_T2,
198
  MVE_VSHL_T3,
199
  MVE_VSHLC,
200
  MVE_VSHLL_T1,
201
  MVE_VSHLL_T2,
202
  MVE_VSHR,
203
  MVE_VSHRN,
204
  MVE_VSLI,
205
  MVE_VSRI,
206
  MVE_VADC,
207
  MVE_VABAV,
208
  MVE_VABD_FP,
209
  MVE_VABD_VEC,
210
  MVE_VABS_FP,
211
  MVE_VABS_VEC,
212
  MVE_VADD_FP_T1,
213
  MVE_VADD_FP_T2,
214
  MVE_VADD_VEC_T1,
215
  MVE_VADD_VEC_T2,
216
  MVE_VSBC,
217
  MVE_VSUB_FP_T1,
218
  MVE_VSUB_FP_T2,
219
  MVE_VSUB_VEC_T1,
220
  MVE_VSUB_VEC_T2,
221
  MVE_VAND,
222
  MVE_VBRSR,
223
  MVE_VCLS,
224
  MVE_VCLZ,
225
  MVE_VCTP,
226
  MVE_VMAX,
227
  MVE_VMAXA,
228
  MVE_VMAXNM_FP,
229
  MVE_VMAXNMA_FP,
230
  MVE_VMAXNMV_FP,
231
  MVE_VMAXNMAV_FP,
232
  MVE_VMAXV,
233
  MVE_VMAXAV,
234
  MVE_VMIN,
235
  MVE_VMINA,
236
  MVE_VMINNM_FP,
237
  MVE_VMINNMA_FP,
238
  MVE_VMINNMV_FP,
239
  MVE_VMINNMAV_FP,
240
  MVE_VMINV,
241
  MVE_VMINAV,
242
  MVE_VMLA,
243
  MVE_VMUL_FP_T1,
244
  MVE_VMUL_FP_T2,
245
  MVE_VMUL_VEC_T1,
246
  MVE_VMUL_VEC_T2,
247
  MVE_VMULH,
248
  MVE_VRMULH,
249
  MVE_VNEG_FP,
250
  MVE_VNEG_VEC,
251
  MVE_VPNOT,
252
  MVE_VPSEL,
253
  MVE_VQABS,
254
  MVE_VQADD_T1,
255
  MVE_VQADD_T2,
256
  MVE_VQSUB_T1,
257
  MVE_VQSUB_T2,
258
  MVE_VQNEG,
259
  MVE_VREV16,
260
  MVE_VREV32,
261
  MVE_VREV64,
262
  MVE_LSLL,
263
  MVE_LSLLI,
264
  MVE_LSRL,
265
  MVE_ASRL,
266
  MVE_ASRLI,
267
  MVE_SQRSHRL,
268
  MVE_SQRSHR,
269
  MVE_UQRSHL,
270
  MVE_UQRSHLL,
271
  MVE_UQSHL,
272
  MVE_UQSHLL,
273
  MVE_URSHRL,
274
  MVE_URSHR,
275
  MVE_SRSHRL,
276
  MVE_SRSHR,
277
  MVE_SQSHLL,
278
  MVE_SQSHL,
279
  MVE_CINC,
280
  MVE_CINV,
281
  MVE_CNEG,
282
  MVE_CSINC,
283
  MVE_CSINV,
284
  MVE_CSET,
285
  MVE_CSETM,
286
  MVE_CSNEG,
287
  MVE_CSEL,
288
  MVE_NONE
289
};
290
291
enum mve_unpredictable
292
{
293
  UNPRED_IT_BLOCK,    /* Unpredictable because mve insn in it block.
294
         */
295
  UNPRED_FCA_0_FCB_1,   /* Unpredictable because fcA = 0 and
296
           fcB = 1 (vpt).  */
297
  UNPRED_R13,     /* Unpredictable because r13 (sp) or
298
           r15 (sp) used.  */
299
  UNPRED_R15,     /* Unpredictable because r15 (pc) is used.  */
300
  UNPRED_Q_GT_4,    /* Unpredictable because
301
           vec reg start > 4 (vld4/st4).  */
302
  UNPRED_Q_GT_6,    /* Unpredictable because
303
           vec reg start > 6 (vld2/st2).  */
304
  UNPRED_R13_AND_WB,    /* Unpredictable becase gp reg = r13
305
           and WB bit = 1.  */
306
  UNPRED_Q_REGS_EQUAL,    /* Unpredictable because vector registers are
307
           equal.  */
308
  UNPRED_OS,      /* Unpredictable because offset scaled == 1.  */
309
  UNPRED_GP_REGS_EQUAL,   /* Unpredictable because gp registers are the
310
           same.  */
311
  UNPRED_Q_REGS_EQ_AND_SIZE_1,  /* Unpredictable because q regs equal and
312
           size = 1.  */
313
  UNPRED_Q_REGS_EQ_AND_SIZE_2,  /* Unpredictable because q regs equal and
314
           size = 2.  */
315
  UNPRED_NONE     /* No unpredictable behavior.  */
316
};
317
318
enum mve_undefined
319
{
320
  UNDEF_SIZE,     /* undefined size.  */
321
  UNDEF_SIZE_0,     /* undefined because size == 0.  */
322
  UNDEF_SIZE_2,     /* undefined because size == 2.  */
323
  UNDEF_SIZE_3,     /* undefined because size == 3.  */
324
  UNDEF_SIZE_LE_1,    /* undefined because size <= 1.  */
325
  UNDEF_SIZE_NOT_0,   /* undefined because size != 0.  */
326
  UNDEF_SIZE_NOT_2,   /* undefined because size != 2.  */
327
  UNDEF_SIZE_NOT_3,   /* undefined because size != 3.  */
328
  UNDEF_NOT_UNS_SIZE_0,   /* undefined because U == 0 and
329
           size == 0.  */
330
  UNDEF_NOT_UNS_SIZE_1,   /* undefined because U == 0 and
331
           size == 1.  */
332
  UNDEF_NOT_UNSIGNED,   /* undefined because U == 0.  */
333
  UNDEF_VCVT_IMM6,    /* imm6 < 32.  */
334
  UNDEF_VCVT_FSI_IMM6,    /* fsi = 0 and 32 >= imm6 <= 47.  */
335
  UNDEF_BAD_OP1_OP2,    /* undefined with op2 = 2 and
336
           op1 == (0 or 1).  */
337
  UNDEF_BAD_U_OP1_OP2,    /* undefined with U = 1 and
338
           op2 == 0 and op1 == (0 or 1).  */
339
  UNDEF_OP_0_BAD_CMODE,   /* undefined because op == 0 and cmode
340
           in {0xx1, x0x1}.  */
341
  UNDEF_XCHG_UNS,   /* undefined because X == 1 and U == 1.  */
342
  UNDEF_NONE      /* no undefined behavior.  */
343
};
344
345
struct opcode32
346
{
347
  arm_feature_set arch;   /* Architecture defining this insn.  */
348
  unsigned long value;    /* If arch is 0 then value is a sentinel.  */
349
  unsigned long mask;   /* Recognise insn if (op & mask) == value.  */
350
  const char *  assembler;  /* How to disassemble this insn.  */
351
};
352
353
struct cdeopcode32
354
{
355
  arm_feature_set arch;   /* Architecture defining this insn.  */
356
  uint8_t coproc_shift;   /* coproc is this far into op.  */
357
  uint16_t coproc_mask;   /* Length of coproc field in op.  */
358
  unsigned long value;    /* If arch is 0 then value is a sentinel.  */
359
  unsigned long mask;   /* Recognise insn if (op & mask) == value.  */
360
  const char *  assembler;  /* How to disassemble this insn.  */
361
};
362
363
/* MVE opcodes.  */
364
365
struct mopcode32
366
{
367
  arm_feature_set arch;   /* Architecture defining this insn.  */
368
  enum mve_instructions mve_op;  /* Specific mve instruction for faster
369
            decoding.  */
370
  unsigned long value;    /* If arch is 0 then value is a sentinel.  */
371
  unsigned long mask;   /* Recognise insn if (op & mask) == value.  */
372
  const char *  assembler;  /* How to disassemble this insn.  */
373
};
374
375
enum isa {
376
  ANY,
377
  T32,
378
  ARM
379
};
380
381
382
/* Shared (between Arm and Thumb mode) opcode.  */
383
struct sopcode32
384
{
385
  enum isa isa;     /* Execution mode instruction availability.  */
386
  arm_feature_set arch;   /* Architecture defining this insn.  */
387
  unsigned long value;    /* If arch is 0 then value is a sentinel.  */
388
  unsigned long mask;   /* Recognise insn if (op & mask) == value.  */
389
  const char *  assembler;  /* How to disassemble this insn.  */
390
};
391
392
struct opcode16
393
{
394
  arm_feature_set arch;   /* Architecture defining this insn.  */
395
  unsigned short value, mask; /* Recognise insn if (op & mask) == value.  */
396
  const char *assembler;  /* How to disassemble this insn.  */
397
};
398
399
/* print_insn_coprocessor recognizes the following format control codes:
400
401
   %%     %
402
403
   %c     print condition code (always bits 28-31 in ARM mode)
404
   %b     print condition code allowing cp_num == 9
405
   %q     print shifter argument
406
   %u     print condition code (unconditional in ARM mode,
407
                          UNPREDICTABLE if not AL in Thumb)
408
   %A     print address for ldc/stc instruction
409
   %B     print vstm/vldm register list
410
   %C     print vscclrm register list
411
   %J     print register for VLDR instruction
412
   %K     print address for VLDR instruction
413
414
   %<bitfield>c   print as a condition code (for vsel)
415
   %<bitfield>r   print as an ARM register
416
   %<bitfield>R   as %<>r but r15 is UNPREDICTABLE
417
   %<bitfield>ru        as %<>r but each u register must be unique.
418
   %<bitfield>d   print the bitfield in decimal
419
   %<bitfield>k   print immediate for VFPv3 conversion instruction
420
   %<bitfield>x   print the bitfield in hex
421
   %<bitfield>X   print the bitfield as 1 hex digit without leading "0x"
422
   %<bitfield>w         print as an iWMMXt width field - [bhwd]ss/us
423
   %<bitfield>g         print as an iWMMXt 64-bit register
424
   %<bitfield>G         print as an iWMMXt general purpose or control register
425
   %<bitfield>D   print as a NEON D register
426
   %<bitfield>Q   print as a NEON Q register
427
   %<bitfield>V   print as a NEON D or Q register
428
   %<bitfield>E   print a quarter-float immediate value
429
430
   %y<code>   print a single precision VFP reg.
431
        Codes: 0=>Sm, 1=>Sd, 2=>Sn, 3=>multi-list, 4=>Sm pair
432
   %z<code>   print a double precision VFP reg
433
        Codes: 0=>Dm, 1=>Dd, 2=>Dn, 3=>multi-list
434
435
   %<bitfield>'c  print specified char iff bitfield is all ones
436
   %<bitfield>`c  print specified char iff bitfield is all zeroes
437
   %<bitfield>?ab...    select from array of values in big endian order
438
439
   %L     print as an iWMMXt N/M width field.
440
   %Z     print the Immediate of a WSHUFH instruction.
441
   %l     like 'A' except use byte offsets for 'B' & 'H'
442
      versions.
443
   %i     print 5-bit immediate in bits 8,3..0
444
      (print "32" when 0)
445
   %r     print register offset address for wldt/wstr instruction.  */
446
447
enum opcode_sentinel_enum
448
{
449
  SENTINEL_IWMMXT_START = 1,
450
  SENTINEL_IWMMXT_END,
451
  SENTINEL_GENERIC_START
452
} opcode_sentinels;
453
454
#define UNDEFINED_INSTRUCTION      "\t\t@ <UNDEFINED> instruction: %0-31x"
455
1.52k
#define UNKNOWN_INSTRUCTION_32BIT  "\t\t@ <UNDEFINED> instruction: %08x"
456
0
#define UNKNOWN_INSTRUCTION_16BIT  "\t\t@ <UNDEFINED> instruction: %04x"
457
209k
#define UNPREDICTABLE_INSTRUCTION  "\t@ <UNPREDICTABLE>"
458
459
/* Common coprocessor opcodes shared between Arm and Thumb-2.  */
460
461
/* print_insn_cde recognizes the following format control codes:
462
463
   %%     %
464
465
   %a     print 'a' iff bit 28 is 1
466
   %p     print bits 8-10 as coprocessor
467
   %<bitfield>d   print as decimal
468
   %<bitfield>r   print as an ARM register
469
   %<bitfield>n   print as an ARM register but r15 is APSR_nzcv
470
   %<bitfield>T   print as an ARM register + 1
471
   %<bitfield>R   as %r but r13 is UNPREDICTABLE
472
   %<bitfield>S   as %r but rX where X > 10 is UNPREDICTABLE
473
   %j     print immediate taken from bits (16..21,7,0..5)
474
   %k     print immediate taken from bits (20..21,7,0..5).
475
   %l     print immediate taken from bits (20..22,7,4..5).  */
476
477
/* At the moment there is only one valid position for the coprocessor number,
478
   and hence that's encoded in the macro below.  */
479
#define CDE_OPCODE(ARCH, VALUE, MASK, ASM) \
480
  { ARCH, 8, 7, VALUE, MASK, ASM }
481
static const struct cdeopcode32 cde_opcodes[] =
482
{
483
  /* Custom Datapath Extension instructions.  */
484
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
485
        0xee000000, 0xefc00840,
486
        "cx1%a\t%p, %12-15n, %{I:#%0-5,7,16-21d%}"),
487
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
488
        0xee000040, 0xefc00840,
489
        "cx1d%a\t%p, %12-15S, %12-15T, %{I:#%0-5,7,16-21d%}"),
490
491
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
492
        0xee400000, 0xefc00840,
493
        "cx2%a\t%p, %12-15n, %16-19n, %{I:#%0-5,7,20-21d%}"),
494
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
495
        0xee400040, 0xefc00840,
496
        "cx2d%a\t%p, %12-15S, %12-15T, %16-19n, %{I:#%0-5,7,20-21d%}"),
497
498
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
499
        0xee800000, 0xef800840,
500
        "cx3%a\t%p, %0-3n, %16-19n, %12-15n, %{I:#%4-5,7,20-22d%}"),
501
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
502
        0xee800040, 0xef800840,
503
       "cx3d%a\t%p, %0-3S, %0-3T, %16-19n, %12-15n, %{I:#%4-5,7,20-22d%}"),
504
505
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
506
        0xec200000, 0xeeb00840,
507
        "vcx1%a\t%p, %12-15,22V, %{I:#%0-5,7,16-19d%}"),
508
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
509
        0xec200040, 0xeeb00840,
510
        "vcx1%a\t%p, %12-15,22V, %{I:#%0-5,7,16-19,24d%}"),
511
512
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
513
        0xec300000, 0xeeb00840,
514
        "vcx2%a\t%p, %12-15,22V, %0-3,5V, %{I:#%4,7,16-19d%}"),
515
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
516
        0xec300040, 0xeeb00840,
517
        "vcx2%a\t%p, %12-15,22V, %0-3,5V, %{I:#%4,7,16-19,24d%}"),
518
519
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
520
        0xec800000, 0xee800840,
521
        "vcx3%a\t%p, %12-15,22V, %16-19,7V, %0-3,5V, %{I:#%4,20-21d%}"),
522
  CDE_OPCODE (ARM_FEATURE_CORE_HIGH (ARM_EXT2_CDE),
523
        0xec800040, 0xee800840,
524
        "vcx3%a\t%p, %12-15,22V, %16-19,7V, %0-3,5V, %{I:#%4,20-21,24d%}"),
525
526
  CDE_OPCODE (ARM_FEATURE_CORE_LOW (0), 0, 0, 0)
527
528
};
529
530
static const struct sopcode32 coprocessor_opcodes[] =
531
{
532
  /* XScale instructions.  */
533
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
534
    0x0e200010, 0x0fff0ff0,
535
    "mia%c\t%{R:acc0%}, %0-3r, %12-15r"},
536
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
537
    0x0e280010, 0x0fff0ff0,
538
    "miaph%c\t%{R:acc0%}, %0-3r, %12-15r"},
539
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
540
    0x0e2c0010, 0x0ffc0ff0, "mia%17'T%17`B%16'T%16`B%c\t%{R:acc0%}, %0-3r, %12-15r"},
541
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
542
    0x0c400000, 0x0ff00fff, "mar%c\t%{R:acc0%}, %12-15r, %16-19r"},
543
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
544
    0x0c500000, 0x0ff00fff, "mra%c\t%12-15r, %16-19r, %{R:acc0%}"},
545
546
  /* Intel Wireless MMX technology instructions.  */
547
  {ANY, ARM_FEATURE_CORE_LOW (0), SENTINEL_IWMMXT_START, 0, "" },
548
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_IWMMXT),
549
    0x0e130130, 0x0f3f0fff, "tandc%22-23w%c\t%12-15r"},
550
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
551
    0x0e400010, 0x0ff00f3f, "tbcst%6-7w%c\t%16-19g, %12-15r"},
552
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
553
    0x0e130170, 0x0f3f0ff8, "textrc%22-23w%c\t%12-15r, %{I:#%0-2d%}"},
554
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
555
    0x0e100070, 0x0f300ff0, "textrm%3?su%22-23w%c\t%12-15r, %16-19g, %{I:#%0-2d%}"},
556
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
557
    0x0e600010, 0x0ff00f38, "tinsr%6-7w%c\t%16-19g, %12-15r, %{I:#%0-2d%}"},
558
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
559
    0x0e000110, 0x0ff00fff, "tmcr%c\t%16-19G, %12-15r"},
560
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
561
    0x0c400000, 0x0ff00ff0, "tmcrr%c\t%0-3g, %12-15r, %16-19r"},
562
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
563
    0x0e2c0010, 0x0ffc0e10, "tmia%17?tb%16?tb%c\t%5-8g, %0-3r, %12-15r"},
564
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
565
    0x0e200010, 0x0fff0e10, "tmia%c\t%5-8g, %0-3r, %12-15r"},
566
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
567
    0x0e280010, 0x0fff0e10, "tmiaph%c\t%5-8g, %0-3r, %12-15r"},
568
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
569
    0x0e100030, 0x0f300fff, "tmovmsk%22-23w%c\t%12-15r, %16-19g"},
570
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
571
    0x0e100110, 0x0ff00ff0, "tmrc%c\t%12-15r, %16-19G"},
572
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
573
    0x0c500000, 0x0ff00ff0, "tmrrc%c\t%12-15r, %16-19r, %0-3g"},
574
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
575
    0x0e130150, 0x0f3f0fff, "torc%22-23w%c\t%12-15r"},
576
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
577
    0x0e120190, 0x0f3f0fff, "torvsc%22-23w%c\t%12-15r"},
578
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
579
    0x0e2001c0, 0x0f300fff, "wabs%22-23w%c\t%12-15g, %16-19g"},
580
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
581
    0x0e0001c0, 0x0f300fff, "wacc%22-23w%c\t%12-15g, %16-19g"},
582
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
583
    0x0e000180, 0x0f000ff0, "wadd%20-23w%c\t%12-15g, %16-19g, %0-3g"},
584
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
585
    0x0e2001a0, 0x0fb00ff0, "waddbhus%22?ml%c\t%12-15g, %16-19g, %0-3g"},
586
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
587
    0x0ea001a0, 0x0ff00ff0, "waddsubhx%c\t%12-15g, %16-19g, %0-3g"},
588
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
589
    0x0e000020, 0x0f800ff0, "waligni%c\t%12-15g, %16-19g, %0-3g, %{I:#%20-22d%}"},
590
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
591
    0x0e800020, 0x0fc00ff0, "walignr%20-21d%c\t%12-15g, %16-19g, %0-3g"},
592
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
593
    0x0e200000, 0x0fe00ff0, "wand%20'n%c\t%12-15g, %16-19g, %0-3g"},
594
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
595
    0x0e800000, 0x0fa00ff0, "wavg2%22?hb%20'r%c\t%12-15g, %16-19g, %0-3g"},
596
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
597
    0x0e400000, 0x0fe00ff0, "wavg4%20'r%c\t%12-15g, %16-19g, %0-3g"},
598
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
599
    0x0e000060, 0x0f300ff0, "wcmpeq%22-23w%c\t%12-15g, %16-19g, %0-3g"},
600
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
601
    0x0e100060, 0x0f100ff0, "wcmpgt%21?su%22-23w%c\t%12-15g, %16-19g, %0-3g"},
602
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
603
    0xfc500100, 0xfe500f00, "wldrd\t%12-15g, %r"},
604
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
605
    0xfc100100, 0xfe500f00, "wldrw\t%12-15G, %A"},
606
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
607
    0x0c100000, 0x0e100e00, "wldr%L%c\t%12-15g, %l"},
608
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
609
    0x0e400100, 0x0fc00ff0, "wmac%21?su%20'z%c\t%12-15g, %16-19g, %0-3g"},
610
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
611
    0x0e800100, 0x0fc00ff0, "wmadd%21?su%20'x%c\t%12-15g, %16-19g, %0-3g"},
612
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
613
    0x0ec00100, 0x0fd00ff0, "wmadd%21?sun%c\t%12-15g, %16-19g, %0-3g"},
614
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
615
    0x0e000160, 0x0f100ff0, "wmax%21?su%22-23w%c\t%12-15g, %16-19g, %0-3g"},
616
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
617
    0x0e000080, 0x0f100fe0, "wmerge%c\t%12-15g, %16-19g, %0-3g, %{I:#%21-23d%}"},
618
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
619
    0x0e0000a0, 0x0f800ff0, "wmia%21?tb%20?tb%22'n%c\t%12-15g, %16-19g, %0-3g"},
620
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
621
    0x0e800120, 0x0f800ff0,
622
    "wmiaw%21?tb%20?tb%22'n%c\t%12-15g, %16-19g, %0-3g"},
623
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
624
    0x0e100160, 0x0f100ff0, "wmin%21?su%22-23w%c\t%12-15g, %16-19g, %0-3g"},
625
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
626
    0x0e000100, 0x0fc00ff0, "wmul%21?su%20?ml%23'r%c\t%12-15g, %16-19g, %0-3g"},
627
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
628
    0x0ed00100, 0x0fd00ff0, "wmul%21?sumr%c\t%12-15g, %16-19g, %0-3g"},
629
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
630
    0x0ee000c0, 0x0fe00ff0, "wmulwsm%20`r%c\t%12-15g, %16-19g, %0-3g"},
631
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
632
    0x0ec000c0, 0x0fe00ff0, "wmulwum%20`r%c\t%12-15g, %16-19g, %0-3g"},
633
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
634
    0x0eb000c0, 0x0ff00ff0, "wmulwl%c\t%12-15g, %16-19g, %0-3g"},
635
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
636
    0x0e8000a0, 0x0f800ff0,
637
    "wqmia%21?tb%20?tb%22'n%c\t%12-15g, %16-19g, %0-3g"},
638
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
639
    0x0e100080, 0x0fd00ff0, "wqmulm%21'r%c\t%12-15g, %16-19g, %0-3g"},
640
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
641
    0x0ec000e0, 0x0fd00ff0, "wqmulwm%21'r%c\t%12-15g, %16-19g, %0-3g"},
642
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
643
    0x0e000000, 0x0ff00ff0, "wor%c\t%12-15g, %16-19g, %0-3g"},
644
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
645
    0x0e000080, 0x0f000ff0, "wpack%20-23w%c\t%12-15g, %16-19g, %0-3g"},
646
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
647
    0xfe300040, 0xff300ef0, "wror%22-23w\t%12-15g, %16-19g, %{I:#%i%}"},
648
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
649
    0x0e300040, 0x0f300ff0, "wror%22-23w%c\t%12-15g, %16-19g, %0-3g"},
650
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
651
    0x0e300140, 0x0f300ff0, "wror%22-23wg%c\t%12-15g, %16-19g, %0-3G"},
652
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
653
    0x0e000120, 0x0fa00ff0, "wsad%22?hb%20'z%c\t%12-15g, %16-19g, %0-3g"},
654
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
655
    0x0e0001e0, 0x0f000ff0, "wshufh%c\t%12-15g, %16-19g, %{I:#%Z%}"},
656
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
657
    0xfe100040, 0xff300ef0, "wsll%22-23w\t%12-15g, %16-19g, %{I:#%i%}"},
658
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
659
    0x0e100040, 0x0f300ff0, "wsll%22-23w%8'g%c\t%12-15g, %16-19g, %0-3g"},
660
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
661
    0x0e100148, 0x0f300ffc, "wsll%22-23w%8'g%c\t%12-15g, %16-19g, %0-3G"},
662
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
663
    0xfe000040, 0xff300ef0, "wsra%22-23w\t%12-15g, %16-19g, %{I:#%i%}"},
664
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
665
    0x0e000040, 0x0f300ff0, "wsra%22-23w%8'g%c\t%12-15g, %16-19g, %0-3g"},
666
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
667
    0x0e000148, 0x0f300ffc, "wsra%22-23w%8'g%c\t%12-15g, %16-19g, %0-3G"},
668
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
669
    0xfe200040, 0xff300ef0, "wsrl%22-23w\t%12-15g, %16-19g, %{I:#%i%}"},
670
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
671
    0x0e200040, 0x0f300ff0, "wsrl%22-23w%8'g%c\t%12-15g, %16-19g, %0-3g"},
672
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
673
    0x0e200148, 0x0f300ffc, "wsrl%22-23w%8'g%c\t%12-15g, %16-19g, %0-3G"},
674
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
675
    0xfc400100, 0xfe500f00, "wstrd\t%12-15g, %r"},
676
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
677
    0xfc000100, 0xfe500f00, "wstrw\t%12-15G, %A"},
678
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
679
    0x0c000000, 0x0e100e00, "wstr%L%c\t%12-15g, %l"},
680
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
681
    0x0e0001a0, 0x0f000ff0, "wsub%20-23w%c\t%12-15g, %16-19g, %0-3g"},
682
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
683
    0x0ed001c0, 0x0ff00ff0, "wsubaddhx%c\t%12-15g, %16-19g, %0-3g"},
684
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
685
    0x0e1001c0, 0x0f300ff0, "wabsdiff%22-23w%c\t%12-15g, %16-19g, %0-3g"},
686
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
687
    0x0e0000c0, 0x0fd00fff, "wunpckeh%21?sub%c\t%12-15g, %16-19g"},
688
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
689
    0x0e4000c0, 0x0fd00fff, "wunpckeh%21?suh%c\t%12-15g, %16-19g"},
690
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
691
    0x0e8000c0, 0x0fd00fff, "wunpckeh%21?suw%c\t%12-15g, %16-19g"},
692
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
693
    0x0e0000e0, 0x0f100fff, "wunpckel%21?su%22-23w%c\t%12-15g, %16-19g"},
694
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
695
    0x0e1000c0, 0x0f300ff0, "wunpckih%22-23w%c\t%12-15g, %16-19g, %0-3g"},
696
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
697
    0x0e1000e0, 0x0f300ff0, "wunpckil%22-23w%c\t%12-15g, %16-19g, %0-3g"},
698
  {ANY, ARM_FEATURE_COPROC (ARM_CEXT_XSCALE),
699
    0x0e100000, 0x0ff00ff0, "wxor%c\t%12-15g, %16-19g, %0-3g"},
700
  {ANY, ARM_FEATURE_CORE_LOW (0),
701
    SENTINEL_IWMMXT_END, 0, "" },
702
703
  /* Armv8.1-M Mainline instructions.  */
704
  {T32, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
705
    0xec9f0b00, 0xffbf0f01, "vscclrm%c\t%C"},
706
  {T32, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
707
    0xec9f0a00, 0xffbf0f00, "vscclrm%c\t%C"},
708
709
  /* ARMv8-M Mainline Security Extensions instructions.  */
710
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M_MAIN),
711
    0xec300a00, 0xfff0ffff, "vlldm\t%16-19r"},
712
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M_MAIN),
713
    0xec200a00, 0xfff0ffff, "vlstm\t%16-19r"},
714
715
  /* Register load/store.  */
716
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
717
    0x0d2d0b00, 0x0fbf0f01, "vpush%c\t%B"},
718
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
719
    0x0d200b00, 0x0fb00f01, "vstmdb%c\t%16-19r!, %B"},
720
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
721
    0x0d300b00, 0x0fb00f01, "vldmdb%c\t%16-19r!, %B"},
722
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
723
    0x0c800b00, 0x0f900f01, "vstmia%c\t%16-19r%21'!, %B"},
724
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
725
    0x0cbd0b00, 0x0fbf0f01, "vpop%c\t%B"},
726
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
727
    0x0c900b00, 0x0f900f01, "vldmia%c\t%16-19r%21'!, %B"},
728
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
729
    0x0d000b00, 0x0f300f00, "vstr%c\t%12-15,22D, %A"},
730
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD | FPU_NEON_EXT_V1),
731
    0x0d100b00, 0x0f300f00, "vldr%c\t%12-15,22D, %A"},
732
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
733
    0x0d2d0a00, 0x0fbf0f00, "vpush%c\t%y3"},
734
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
735
    0x0d200a00, 0x0fb00f00, "vstmdb%c\t%16-19r!, %y3"},
736
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
737
    0x0d300a00, 0x0fb00f00, "vldmdb%c\t%16-19r!, %y3"},
738
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
739
    0x0c800a00, 0x0f900f00, "vstmia%c\t%16-19r%21'!, %y3"},
740
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
741
    0x0cbd0a00, 0x0fbf0f00, "vpop%c\t%y3"},
742
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
743
    0x0c900a00, 0x0f900f00, "vldmia%c\t%16-19r%21'!, %y3"},
744
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
745
    0x0d000a00, 0x0f300f00, "vstr%c\t%y1, %A"},
746
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
747
    0x0d100a00, 0x0f300f00, "vldr%c\t%y1, %A"},
748
  {ANY, ARM_FEATURE_COPROC (ARM_EXT2_V8_1M_MAIN),
749
    0xec100f80, 0xfe101f80, "vldr%c\t%J, %K"},
750
  {ANY, ARM_FEATURE_COPROC (ARM_EXT2_V8_1M_MAIN),
751
    0xec000f80, 0xfe101f80, "vstr%c\t%J, %K"},
752
753
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
754
    0x0d200b01, 0x0fb00f01, "fstmdbx%c\t%16-19r!, %z3\t@ Deprecated"},
755
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
756
    0x0d300b01, 0x0fb00f01, "fldmdbx%c\t%16-19r!, %z3\t@ Deprecated"},
757
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
758
    0x0c800b01, 0x0f900f01, "fstmiax%c\t%16-19r%21'!, %z3\t@ Deprecated"},
759
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
760
    0x0c900b01, 0x0f900f01, "fldmiax%c\t%16-19r%21'!, %z3\t@ Deprecated"},
761
762
  /* Data transfer between ARM and NEON registers.  */
763
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
764
    0x0c400b10, 0x0ff00fd0, "vmov%c\t%0-3,5D, %12-15r, %16-19r"},
765
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
766
    0x0c500b10, 0x0ff00fd0, "vmov%c\t%12-15r, %16-19r, %0-3,5D"},
767
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
768
    0x0e000b10, 0x0fd00f70, "vmov%c.32\t%{R:%16-19,7D[%21d]%}, %12-15r"},
769
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
770
    0x0e100b10, 0x0f500f70, "vmov%c.32\t%12-15r, %{R:%16-19,7D[%21d]%}"},
771
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
772
    0x0e000b30, 0x0fd00f30, "vmov%c.16\t%{R:%16-19,7D[%6,21d]%}, %12-15r"},
773
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
774
    0x0e100b30, 0x0f500f30, "vmov%c.%23?us16\t%12-15r, %{R:%16-19,7D[%6,21d]%}"},
775
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
776
    0x0e400b10, 0x0fd00f10, "vmov%c.8\t%{R:%16-19,7D[%5,6,21d]%}, %12-15r"},
777
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
778
    0x0e500b10, 0x0f500f10, "vmov%c.%23?us8\t%12-15r, %{R:%16-19,7D[%5,6,21d]%}"},
779
  /* Half-precision conversion instructions.  */
780
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
781
    0x0eb20b40, 0x0fbf0f50, "vcvt%7?tb%c.f64.f16\t%z1, %y0"},
782
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
783
    0x0eb30b40, 0x0fbf0f50, "vcvt%7?tb%c.f16.f64\t%y1, %z0"},
784
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FP16),
785
    0x0eb20a40, 0x0fbf0f50, "vcvt%7?tb%c.f32.f16\t%y1, %y0"},
786
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FP16),
787
    0x0eb30a40, 0x0fbf0f50, "vcvt%7?tb%c.f16.f32\t%y1, %y0"},
788
789
  /* Floating point coprocessor (VFP) instructions.  */
790
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
791
    0x0ee00a10, 0x0fff0fff, "vmsr%c\t%{R:fpsid%}, %12-15r"},
792
  {ANY, ARM_FEATURE (0, ARM_EXT2_V8_1M_MAIN, FPU_VFP_EXT_V1xD),
793
    0x0ee10a10, 0x0fff0fff, "vmsr%c\t%{R:fpscr%}, %12-15r"},
794
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
795
    0x0ee20a10, 0x0fff0fff, "vmsr%c\t%{R:fpscr_nzcvqc%}, %12-15r"},
796
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
797
    0x0ee60a10, 0x0fff0fff, "vmsr%c\t%{R:mvfr1%}, %12-15r"},
798
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
799
    0x0ee70a10, 0x0fff0fff, "vmsr%c\t%{R:mvfr0%}, %12-15r"},
800
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
801
    0x0ee50a10, 0x0fff0fff, "vmsr%c\t%{R:mvfr2%}, %12-15r"},
802
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
803
    0x0ee80a10, 0x0fff0fff, "vmsr%c\t%{R:fpexc%}, %12-15r"},
804
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
805
    0x0ee90a10, 0x0fff0fff, "vmsr%c\t%{R:fpinst%}, %12-15r\t@ Impl def"},
806
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
807
    0x0eea0a10, 0x0fff0fff, "vmsr%c\t%{R:fpinst2%}, %12-15r\t@ Impl def"},
808
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
809
    0x0eec0a10, 0x0fff0fff, "vmsr%c\t%{R:vpr%}, %12-15r"},
810
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
811
    0x0eed0a10, 0x0fff0fff, "vmsr%c\t%{R:p0%}, %12-15r"},
812
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
813
    0x0eee0a10, 0x0fff0fff, "vmsr%c\t%{R:fpcxt_ns%}, %12-15r"},
814
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
815
    0x0eef0a10, 0x0fff0fff, "vmsr%c\t%{R:fpcxt_s%}, %12-15r"},
816
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
817
    0x0ef00a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpsid%}"},
818
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
819
    0x0ef1fa10, 0x0fffffff, "vmrs%c\t%{R:APSR_nzcv%}, %{R:fpscr%}"},
820
  {ANY, ARM_FEATURE (0, ARM_EXT2_V8_1M_MAIN, FPU_VFP_EXT_V1xD),
821
    0x0ef10a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpscr%}"},
822
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
823
    0x0ef20a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpscr_nzcvqc%}"},
824
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
825
    0x0ef50a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:mvfr2%}"},
826
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
827
    0x0ef60a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:mvfr1%}"},
828
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
829
    0x0ef70a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:mvfr0%}"},
830
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
831
    0x0ef80a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpexc%}"},
832
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
833
    0x0ef90a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpinst%}\t@ Impl def"},
834
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
835
    0x0efa0a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpinst2%}\t@ Impl def"},
836
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
837
    0x0efc0a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:vpr%}"},
838
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
839
    0x0efd0a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:p0%}"},
840
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
841
    0x0efe0a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpcxt_ns%}"},
842
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
843
    0x0eff0a10, 0x0fff0fff, "vmrs%c\t%12-15r, %{R:fpcxt_s%}"},
844
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
845
    0x0e000b10, 0x0fd00fff, "vmov%c.32\t%z2[%{I:%21d%}], %12-15r"},
846
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
847
    0x0e100b10, 0x0fd00fff, "vmov%c.32\t%12-15r, %z2[%{I:%21d%}]"},
848
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
849
    0x0ee00a10, 0x0ff00fff, "vmsr%c\t<impl def %16-19x>, %12-15r"},
850
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
851
    0x0ef00a10, 0x0ff00fff, "vmrs%c\t%12-15r, <impl def %16-19x>"},
852
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
853
    0x0e000a10, 0x0ff00f7f, "vmov%c\t%y2, %12-15r"},
854
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
855
    0x0e100a10, 0x0ff00f7f, "vmov%c\t%12-15r, %y2"},
856
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
857
    0x0eb50a40, 0x0fbf0f70, "vcmp%7'e%c.f32\t%y1, %{I:#0.0%}"},
858
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
859
    0x0eb50b40, 0x0fbf0f70, "vcmp%7'e%c.f64\t%z1, %{I:#0.0%}"},
860
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
861
    0x0eb00a40, 0x0fbf0fd0, "vmov%c.f32\t%y1, %y0"},
862
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
863
    0x0eb00ac0, 0x0fbf0fd0, "vabs%c.f32\t%y1, %y0"},
864
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
865
    0x0eb00b40, 0x0fbf0fd0, "vmov%c.f64\t%z1, %z0"},
866
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
867
    0x0eb00bc0, 0x0fbf0fd0, "vabs%c.f64\t%z1, %z0"},
868
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
869
    0x0eb10a40, 0x0fbf0fd0, "vneg%c.f32\t%y1, %y0"},
870
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
871
    0x0eb10ac0, 0x0fbf0fd0, "vsqrt%c.f32\t%y1, %y0"},
872
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
873
    0x0eb10b40, 0x0fbf0fd0, "vneg%c.f64\t%z1, %z0"},
874
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
875
    0x0eb10bc0, 0x0fbf0fd0, "vsqrt%c.f64\t%z1, %z0"},
876
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
877
    0x0eb70ac0, 0x0fbf0fd0, "vcvt%c.f64.f32\t%z1, %y0"},
878
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
879
    0x0eb70bc0, 0x0fbf0fd0, "vcvt%c.f32.f64\t%y1, %z0"},
880
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
881
    0x0eb80a40, 0x0fbf0f50, "vcvt%c.f32.%7?su32\t%y1, %y0"},
882
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
883
    0x0eb80b40, 0x0fbf0f50, "vcvt%c.f64.%7?su32\t%z1, %y0"},
884
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
885
    0x0eb40a40, 0x0fbf0f50, "vcmp%7'e%c.f32\t%y1, %y0"},
886
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
887
    0x0eb40b40, 0x0fbf0f50, "vcmp%7'e%c.f64\t%z1, %z0"},
888
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V3xD),
889
    0x0eba0a40, 0x0fbe0f50, "vcvt%c.f32.%16?us%7?31%7?26\t%y1, %y1, %{I:#%5,0-3k%}"},
890
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V3),
891
    0x0eba0b40, 0x0fbe0f50, "vcvt%c.f64.%16?us%7?31%7?26\t%z1, %z1, %{I:#%5,0-3k%}"},
892
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
893
    0x0ebc0a40, 0x0fbe0f50, "vcvt%7`r%c.%16?su32.f32\t%y1, %y0"},
894
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
895
    0x0ebc0b40, 0x0fbe0f50, "vcvt%7`r%c.%16?su32.f64\t%y1, %z0"},
896
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V3xD),
897
    0x0ebe0a40, 0x0fbe0f50, "vcvt%c.%16?us%7?31%7?26.f32\t%y1, %y1, %{I:#%5,0-3k%}"},
898
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V3),
899
    0x0ebe0b40, 0x0fbe0f50, "vcvt%c.%16?us%7?31%7?26.f64\t%z1, %z1, %{I:#%5,0-3k%}"},
900
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
901
    0x0c500b10, 0x0fb00ff0, "vmov%c\t%12-15r, %16-19r, %z0"},
902
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V3xD),
903
    0x0eb00a00, 0x0fb00ff0, "vmov%c.f32\t%y1, %{I:#%0-3,16-19E%}"},
904
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V3),
905
    0x0eb00b00, 0x0fb00ff0, "vmov%c.f64\t%z1, %{I:#%0-3,16-19E%}"},
906
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V2),
907
    0x0c400a10, 0x0ff00fd0, "vmov%c\t%y4, %12-15r, %16-19r"},
908
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V2),
909
    0x0c400b10, 0x0ff00fd0, "vmov%c\t%z0, %12-15r, %16-19r"},
910
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V2),
911
    0x0c500a10, 0x0ff00fd0, "vmov%c\t%12-15r, %16-19r, %y4"},
912
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
913
    0x0e000a00, 0x0fb00f50, "vmla%c.f32\t%y1, %y2, %y0"},
914
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
915
    0x0e000a40, 0x0fb00f50, "vmls%c.f32\t%y1, %y2, %y0"},
916
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
917
    0x0e000b00, 0x0fb00f50, "vmla%c.f64\t%z1, %z2, %z0"},
918
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
919
    0x0e000b40, 0x0fb00f50, "vmls%c.f64\t%z1, %z2, %z0"},
920
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
921
    0x0e100a00, 0x0fb00f50, "vnmls%c.f32\t%y1, %y2, %y0"},
922
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
923
    0x0e100a40, 0x0fb00f50, "vnmla%c.f32\t%y1, %y2, %y0"},
924
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
925
    0x0e100b00, 0x0fb00f50, "vnmls%c.f64\t%z1, %z2, %z0"},
926
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
927
    0x0e100b40, 0x0fb00f50, "vnmla%c.f64\t%z1, %z2, %z0"},
928
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
929
    0x0e200a00, 0x0fb00f50, "vmul%c.f32\t%y1, %y2, %y0"},
930
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
931
    0x0e200a40, 0x0fb00f50, "vnmul%c.f32\t%y1, %y2, %y0"},
932
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
933
    0x0e200b00, 0x0fb00f50, "vmul%c.f64\t%z1, %z2, %z0"},
934
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
935
    0x0e200b40, 0x0fb00f50, "vnmul%c.f64\t%z1, %z2, %z0"},
936
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
937
    0x0e300a00, 0x0fb00f50, "vadd%c.f32\t%y1, %y2, %y0"},
938
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
939
    0x0e300a40, 0x0fb00f50, "vsub%c.f32\t%y1, %y2, %y0"},
940
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
941
    0x0e300b00, 0x0fb00f50, "vadd%c.f64\t%z1, %z2, %z0"},
942
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
943
    0x0e300b40, 0x0fb00f50, "vsub%c.f64\t%z1, %z2, %z0"},
944
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1xD),
945
    0x0e800a00, 0x0fb00f50, "vdiv%c.f32\t%y1, %y2, %y0"},
946
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_V1),
947
    0x0e800b00, 0x0fb00f50, "vdiv%c.f64\t%z1, %z2, %z0"},
948
949
  /* VFP Fused multiply add instructions.  */
950
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
951
    0x0ea00a00, 0x0fb00f50, "vfma%c.f32\t%y1, %y2, %y0"},
952
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
953
    0x0ea00b00, 0x0fb00f50, "vfma%c.f64\t%z1, %z2, %z0"},
954
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
955
    0x0ea00a40, 0x0fb00f50, "vfms%c.f32\t%y1, %y2, %y0"},
956
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
957
    0x0ea00b40, 0x0fb00f50, "vfms%c.f64\t%z1, %z2, %z0"},
958
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
959
    0x0e900a40, 0x0fb00f50, "vfnma%c.f32\t%y1, %y2, %y0"},
960
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
961
    0x0e900b40, 0x0fb00f50, "vfnma%c.f64\t%z1, %z2, %z0"},
962
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
963
    0x0e900a00, 0x0fb00f50, "vfnms%c.f32\t%y1, %y2, %y0"},
964
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_FMA),
965
    0x0e900b00, 0x0fb00f50, "vfnms%c.f64\t%z1, %z2, %z0"},
966
967
  /* FP v5.  */
968
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
969
    0xfe000a00, 0xff800f50, "vsel%20-21c%u.f32\t%y1, %y2, %y0"},
970
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
971
    0xfe000b00, 0xff800f50, "vsel%20-21c%u.f64\t%z1, %z2, %z0"},
972
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
973
    0xfe800a00, 0xffb00f50, "vmaxnm%u.f32\t%y1, %y2, %y0"},
974
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
975
    0xfe800b00, 0xffb00f50, "vmaxnm%u.f64\t%z1, %z2, %z0"},
976
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
977
    0xfe800a40, 0xffb00f50, "vminnm%u.f32\t%y1, %y2, %y0"},
978
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
979
    0xfe800b40, 0xffb00f50, "vminnm%u.f64\t%z1, %z2, %z0"},
980
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
981
    0xfebc0a40, 0xffbc0f50, "vcvt%16-17?mpna%u.%7?su32.f32\t%y1, %y0"},
982
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
983
    0xfebc0b40, 0xffbc0f50, "vcvt%16-17?mpna%u.%7?su32.f64\t%y1, %z0"},
984
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
985
    0x0eb60a40, 0x0fbe0f50, "vrint%7,16??xzr%c.f32\t%y1, %y0"},
986
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
987
    0x0eb60b40, 0x0fbe0f50, "vrint%7,16??xzr%c.f64\t%z1, %z0"},
988
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
989
    0xfeb80a40, 0xffbc0fd0, "vrint%16-17?mpna%u.f32\t%y1, %y0"},
990
  {ANY, ARM_FEATURE_COPROC (FPU_VFP_EXT_ARMV8),
991
    0xfeb80b40, 0xffbc0fd0, "vrint%16-17?mpna%u.f64\t%z1, %z0"},
992
993
  {ANY, ARM_FEATURE_CORE_LOW (0), SENTINEL_GENERIC_START, 0, "" },
994
  /* ARMv8.3 AdvSIMD instructions in the space of coprocessor 8.  */
995
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
996
    0xfc800800, 0xfeb00f10, "vcadd%c.f16\t%12-15,22V, %16-19,7V, %0-3,5V, %{I:#%24?29%24'70%}"},
997
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
998
    0xfc900800, 0xfeb00f10, "vcadd%c.f32\t%12-15,22V, %16-19,7V, %0-3,5V, %{I:#%24?29%24'70%}"},
999
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1000
    0xfc200800, 0xff300f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %0-3,5V, %{I:#%23'90%}"},
1001
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1002
    0xfd200800, 0xff300f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %0-3,5V, %{I:#%23?21%23?780%}"},
1003
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1004
    0xfc300800, 0xff300f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %0-3,5V, %{I:#%23'90%}"},
1005
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1006
    0xfd300800, 0xff300f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %0-3,5V, %{I:#%23?21%23?780%}"},
1007
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1008
    0xfe000800, 0xffa00f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %{R:%0-3D[%5?10]%}, %{I:#%20'90%}"},
1009
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1010
    0xfe200800, 0xffa00f10, "vcmla%c.f16\t%12-15,22V, %16-19,7V, %{R:%0-3D[%5?10]%}, %{I:#%20?21%20?780%}"},
1011
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1012
    0xfe800800, 0xffa00f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %{R:%0-3,5D[0]%}, %{I:#%20'90%}"},
1013
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1014
    0xfea00800, 0xffa00f10, "vcmla%c.f32\t%12-15,22V, %16-19,7V, %{R:%0-3,5D[0]%}, %{I:#%20?21%20?780%}"},
1015
1016
  /* BFloat16 instructions.  */
1017
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_BF16),
1018
    0x0eb30940, 0x0fbf0f50, "vcvt%7?tb%b.bf16.f32\t%y1, %y0"},
1019
1020
  /* Dot Product instructions in the space of coprocessor 13.  */
1021
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD),
1022
    0xfc200d00, 0xffb00f00, "v%4?usdot.%4?us8\t%12-15,22V, %16-19,7V, %0-3,5V"},
1023
  {ANY, ARM_FEATURE_COPROC (FPU_NEON_EXT_DOTPROD),
1024
    0xfe200d00, 0xff200f00, "v%4?usdot.%4?us8\t%12-15,22V, %16-19,7V, %{R:%0-3D[%5?10]%}"},
1025
1026
  /* ARMv8.2 FMAC Long instructions in the space of coprocessor 8.  */
1027
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1028
    0xfc200810, 0xffb00f50, "vfmal.f16\t%12-15,22D, %{R:s%7,16-19d%}, %{R:s%5,0-3d%}"},
1029
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1030
    0xfca00810, 0xffb00f50, "vfmsl.f16\t%12-15,22D, %{R:s%7,16-19d%}, %{R:s%5,0-3d%}"},
1031
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1032
    0xfc200850, 0xffb00f50, "vfmal.f16\t%12-15,22Q, %{R:d%16-19,7d%}, %{R:d%0-3,5d%}"},
1033
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1034
    0xfca00850, 0xffb00f50, "vfmsl.f16\t%12-15,22Q, %{R:d%16-19,7d%}, %{R:d%0-3,5d%}"},
1035
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1036
    0xfe000810, 0xffb00f50, "vfmal.f16\t%12-15,22D, %{R:s%7,16-19d%}, %{R:s%5,0-2d[%3d]%}"},
1037
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1038
    0xfe100810, 0xffb00f50, "vfmsl.f16\t%12-15,22D, %{R:s%7,16-19d%}, %{R:s%5,0-2d[%3d]%}"},
1039
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1040
    0xfe000850, 0xffb00f50, "vfmal.f16\t%12-15,22Q, %{R:d%16-19,7d%}, %{R:d%0-2d[%3,5d]%}"},
1041
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST | ARM_EXT2_V8_2A),
1042
    0xfe100850, 0xffb00f50, "vfmsl.f16\t%12-15,22Q, %{R:d%16-19,7d%}, %{R:d%0-2d[%3,5d]%}"},
1043
1044
  /* ARMv8.2 half-precision Floating point coprocessor 9 (VFP) instructions.
1045
     cp_num: bit <11:8> == 0b1001.
1046
     cond: bit <31:28> == 0b1110, otherwise, it's UNPREDICTABLE.  */
1047
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1048
    0x0eb009c0, 0x0fbf0fd0, "vabs%c.f16\t%y1, %y0"},
1049
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1050
    0x0e300900, 0x0fb00f50, "vadd%c.f16\t%y1, %y2, %y0"},
1051
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1052
    0x0eb40940, 0x0fbf0f50, "vcmp%7'e%c.f16\t%y1, %y0"},
1053
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1054
    0x0eb50940, 0x0fbf0f70, "vcmp%7'e%c.f16\t%y1, %{I:#0.0%}"},
1055
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1056
    0x0eba09c0, 0x0fbe0fd0, "vcvt%c.f16.%16?us%7?31%7?26\t%y1, %y1, %{I:#%5,0-3k%}"},
1057
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1058
    0x0ebe09c0, 0x0fbe0fd0, "vcvt%c.%16?us%7?31%7?26.f16\t%y1, %y1, %{I:#%5,0-3k%}"},
1059
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1060
    0x0ebc0940, 0x0fbe0f50, "vcvt%7`r%c.%16?su32.f16\t%y1, %y0"},
1061
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1062
    0x0eb80940, 0x0fbf0f50, "vcvt%c.f16.%7?su32\t%y1, %y0"},
1063
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1064
    0xfebc0940, 0xffbc0f50, "vcvt%16-17?mpna%u.%7?su32.f16\t%y1, %y0"},
1065
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1066
    0x0e800900, 0x0fb00f50, "vdiv%c.f16\t%y1, %y2, %y0"},
1067
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1068
    0x0ea00900, 0x0fb00f50, "vfma%c.f16\t%y1, %y2, %y0"},
1069
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1070
    0x0ea00940, 0x0fb00f50, "vfms%c.f16\t%y1, %y2, %y0"},
1071
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1072
    0x0e900940, 0x0fb00f50, "vfnma%c.f16\t%y1, %y2, %y0"},
1073
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1074
    0x0e900900, 0x0fb00f50, "vfnms%c.f16\t%y1, %y2, %y0"},
1075
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1076
    0xfeb00ac0, 0xffbf0fd0, "vins.f16\t%y1, %y0"},
1077
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1078
    0xfeb00a40, 0xffbf0fd0, "vmovx%c.f16\t%y1, %y0"},
1079
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1080
    0x0d100900, 0x0f300f00, "vldr%c.16\t%y1, %A"},
1081
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1082
    0x0d000900, 0x0f300f00, "vstr%c.16\t%y1, %A"},
1083
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1084
    0xfe800900, 0xffb00f50, "vmaxnm%c.f16\t%y1, %y2, %y0"},
1085
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1086
    0xfe800940, 0xffb00f50, "vminnm%c.f16\t%y1, %y2, %y0"},
1087
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1088
    0x0e000900, 0x0fb00f50, "vmla%c.f16\t%y1, %y2, %y0"},
1089
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1090
    0x0e000940, 0x0fb00f50, "vmls%c.f16\t%y1, %y2, %y0"},
1091
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1092
    0x0e100910, 0x0ff00f7f, "vmov%c.f16\t%12-15r, %y2"},
1093
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1094
    0x0e000910, 0x0ff00f7f, "vmov%c.f16\t%y2, %12-15r"},
1095
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1096
    0xeb00900, 0x0fb00ff0, "vmov%c.f16\t%y1, %{I:#%0-3,16-19E%}"},
1097
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1098
    0x0e200900, 0x0fb00f50, "vmul%c.f16\t%y1, %y2, %y0"},
1099
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1100
    0x0eb10940, 0x0fbf0fd0, "vneg%c.f16\t%y1, %y0"},
1101
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1102
    0x0e100940, 0x0fb00f50, "vnmla%c.f16\t%y1, %y2, %y0"},
1103
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1104
    0x0e100900, 0x0fb00f50, "vnmls%c.f16\t%y1, %y2, %y0"},
1105
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1106
    0x0e200940, 0x0fb00f50, "vnmul%c.f16\t%y1, %y2, %y0"},
1107
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1108
    0x0eb60940, 0x0fbe0f50, "vrint%7,16??xzr%c.f16\t%y1, %y0"},
1109
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1110
    0xfeb80940, 0xffbc0fd0, "vrint%16-17?mpna%u.f16\t%y1, %y0"},
1111
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1112
    0xfe000900, 0xff800f50, "vsel%20-21c%u.f16\t%y1, %y2, %y0"},
1113
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1114
    0x0eb109c0, 0x0fbf0fd0, "vsqrt%c.f16\t%y1, %y0"},
1115
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1116
    0x0e300940, 0x0fb00f50, "vsub%c.f16\t%y1, %y2, %y0"},
1117
1118
  /* ARMv8.3 javascript conversion instruction.  */
1119
  {ANY, ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_3A),
1120
    0x0eb90bc0, 0x0fbf0fd0, "vjcvt%c.s32.f64\t%y1, %z0"},
1121
1122
  {ANY, ARM_FEATURE_CORE_LOW (0), 0, 0, 0}
1123
};
1124
1125
/* Generic coprocessor instructions.  These are only matched if a more specific
1126
   SIMD or co-processor instruction does not match first.  */
1127
1128
static const struct sopcode32 generic_coprocessor_opcodes[] =
1129
{
1130
  /* Generic coprocessor instructions.  */
1131
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V5E),
1132
    0x0c400000, 0x0ff00000, "mcrr%c\t%{I:%8-11d%}, %{I:%4-7d%}, %12-15R, %16-19r, %{R:cr%0-3d%}"},
1133
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V5E),
1134
    0x0c500000, 0x0ff00000,
1135
    "mrrc%c\t%{I:%8-11d%}, %{I:%4-7d%}, %12-15Ru, %16-19Ru, %{R:cr%0-3d%}"},
1136
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
1137
    0x0e000000, 0x0f000010,
1138
    "cdp%c\t%{I:%8-11d%}, %{I:%20-23d%}, %{R:cr%12-15d%}, %{R:cr%16-19d%}, %{R:cr%0-3d%}, {%{I:%5-7d%}}"},
1139
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
1140
    0x0e10f010, 0x0f10f010,
1141
    "mrc%c\t%{I:%8-11d%}, %{I:%21-23d%}, %{R:APSR_nzcv%}, %{R:cr%16-19d%}, %{R:cr%0-3d%}, {%{I:%5-7d%}}"},
1142
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
1143
    0x0e100010, 0x0f100010,
1144
    "mrc%c\t%{I:%8-11d%}, %{I:%21-23d%}, %12-15r, %{R:cr%16-19d%}, %{R:cr%0-3d%}, {%{I:%5-7d%}}"},
1145
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
1146
    0x0e000010, 0x0f100010,
1147
    "mcr%c\t%{I:%8-11d%}, %{I:%21-23d%}, %12-15R, %{R:cr%16-19d%}, %{R:cr%0-3d%}, {%{I:%5-7d%}}"},
1148
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
1149
    0x0c000000, 0x0e100000, "stc%22'l%c\t%{I:%8-11d%}, %{R:cr%12-15d%}, %A"},
1150
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
1151
    0x0c100000, 0x0e100000, "ldc%22'l%c\t%{I:%8-11d%}, %{R:cr%12-15d%}, %A"},
1152
1153
  /* V6 coprocessor instructions.  */
1154
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
1155
    0xfc500000, 0xfff00000,
1156
    "mrrc2%c\t%{I:%8-11d%}, %{I:%4-7d%}, %12-15Ru, %16-19Ru, %{R:cr%0-3d%}"},
1157
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
1158
    0xfc400000, 0xfff00000,
1159
    "mcrr2%c\t%{I:%8-11d%}, %{I:%4-7d%}, %12-15R, %16-19R, %{R:cr%0-3d%}"},
1160
1161
  /* V5 coprocessor instructions.  */
1162
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
1163
    0xfc100000, 0xfe100000, "ldc2%22'l%c\t%{I:%8-11d%}, %{R:cr%12-15d%}, %A"},
1164
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
1165
    0xfc000000, 0xfe100000, "stc2%22'l%c\t%{I:%8-11d%}, %{R:cr%12-15d%}, %A"},
1166
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
1167
    0xfe000000, 0xff000010,
1168
    "cdp2%c\t%{I:%8-11d%}, %{I:%20-23d%}, %{R:cr%12-15d%}, %{R:cr%16-19d%}, %{R:cr%0-3d%}, {%{I:%5-7d%}}"},
1169
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
1170
    0xfe000010, 0xff100010,
1171
    "mcr2%c\t%{I:%8-11d%}, %{I:%21-23d%}, %12-15R, %{R:cr%16-19d%}, %{R:cr%0-3d%}, {%{I:%5-7d%}}"},
1172
  {ANY, ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
1173
    0xfe100010, 0xff100010,
1174
    "mrc2%c\t%{I:%8-11d%}, %{I:%21-23d%}, %12-15r, %{R:cr%16-19d%}, %{R:cr%0-3d%}, {%{I:%5-7d%}}"},
1175
1176
  {ANY, ARM_FEATURE_CORE_LOW (0), 0, 0, 0}
1177
};
1178
1179
/* Neon opcode table:  This does not encode the top byte -- that is
1180
   checked by the print_insn_neon routine, as it depends on whether we are
1181
   doing thumb32 or arm32 disassembly.  */
1182
1183
/* print_insn_neon recognizes the following format control codes:
1184
1185
   %%     %
1186
1187
   %c     print condition code
1188
   %u     print condition code (unconditional in ARM mode,
1189
                          UNPREDICTABLE if not AL in Thumb)
1190
   %A     print v{st,ld}[1234] operands
1191
   %B     print v{st,ld}[1234] any one operands
1192
   %C     print v{st,ld}[1234] single->all operands
1193
   %D     print scalar
1194
   %E     print vmov, vmvn, vorr, vbic encoded constant
1195
   %F     print vtbl,vtbx register list
1196
1197
   %<bitfield>r   print as an ARM register
1198
   %<bitfield>d   print the bitfield in decimal
1199
   %<bitfield>e         print the 2^N - bitfield in decimal
1200
   %<bitfield>D   print as a NEON D register
1201
   %<bitfield>Q   print as a NEON Q register
1202
   %<bitfield>R   print as a NEON D or Q register
1203
   %<bitfield>Sn  print byte scaled width limited by n
1204
   %<bitfield>Tn  print short scaled width limited by n
1205
   %<bitfield>Un  print long scaled width limited by n
1206
1207
   %<bitfield>'c  print specified char iff bitfield is all ones
1208
   %<bitfield>`c  print specified char iff bitfield is all zeroes
1209
   %<bitfield>?ab...    select from array of values in big endian order.  */
1210
1211
static const struct opcode32 neon_opcodes[] =
1212
{
1213
  /* Extract.  */
1214
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1215
    0xf2b00840, 0xffb00850,
1216
    "vext%c.8\t%12-15,22R, %16-19,7R, %0-3,5R, %{I:#%8-11d%}"},
1217
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1218
    0xf2b00000, 0xffb00810,
1219
    "vext%c.8\t%12-15,22R, %16-19,7R, %0-3,5R, %{I:#%8-11d%}"},
1220
1221
  /* Data transfer between ARM and NEON registers.  */
1222
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1223
    0x0e800b10, 0x0ff00f70, "vdup%c.32\t%16-19,7D, %12-15r"},
1224
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1225
    0x0e800b30, 0x0ff00f70, "vdup%c.16\t%16-19,7D, %12-15r"},
1226
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1227
    0x0ea00b10, 0x0ff00f70, "vdup%c.32\t%16-19,7Q, %12-15r"},
1228
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1229
    0x0ea00b30, 0x0ff00f70, "vdup%c.16\t%16-19,7Q, %12-15r"},
1230
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1231
    0x0ec00b10, 0x0ff00f70, "vdup%c.8\t%16-19,7D, %12-15r"},
1232
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1233
    0x0ee00b10, 0x0ff00f70, "vdup%c.8\t%16-19,7Q, %12-15r"},
1234
1235
  /* Move data element to all lanes.  */
1236
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1237
    0xf3b40c00, 0xffb70f90, "vdup%c.32\t%12-15,22R, %{R:%0-3,5D[%19d]%}"},
1238
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1239
    0xf3b20c00, 0xffb30f90, "vdup%c.16\t%12-15,22R, %{R:%0-3,5D[%18-19d]%}"},
1240
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1241
    0xf3b10c00, 0xffb10f90, "vdup%c.8\t%12-15,22R, %{R:%0-3,5D[%17-19d]%}"},
1242
1243
  /* Table lookup.  */
1244
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1245
    0xf3b00800, 0xffb00c50, "vtbl%c.8\t%12-15,22D, %F, %0-3,5D"},
1246
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1247
    0xf3b00840, 0xffb00c50, "vtbx%c.8\t%12-15,22D, %F, %0-3,5D"},
1248
1249
  /* Half-precision conversions.  */
1250
  {ARM_FEATURE_COPROC (FPU_VFP_EXT_FP16),
1251
    0xf3b60600, 0xffbf0fd0, "vcvt%c.f16.f32\t%12-15,22D, %0-3,5Q"},
1252
  {ARM_FEATURE_COPROC (FPU_VFP_EXT_FP16),
1253
    0xf3b60700, 0xffbf0fd0, "vcvt%c.f32.f16\t%12-15,22Q, %0-3,5D"},
1254
1255
  /* NEON fused multiply add instructions.  */
1256
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_FMA),
1257
    0xf2000c10, 0xffb00f10, "vfma%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1258
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1259
    0xf2100c10, 0xffb00f10, "vfma%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1260
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_FMA),
1261
    0xf2200c10, 0xffb00f10, "vfms%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1262
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1263
    0xf2300c10, 0xffb00f10, "vfms%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1264
1265
  /* BFloat16 instructions.  */
1266
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_BF16),
1267
    0xfc000d00, 0xffb00f10, "vdot.bf16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1268
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_BF16),
1269
    0xfe000d00, 0xffb00f10, "vdot.bf16\t%12-15,22R, %16-19,7R, %{R:d%0-3d[%5d]%}"},
1270
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_BF16),
1271
    0xfc000c40, 0xffb00f50, "vmmla.bf16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1272
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_BF16),
1273
    0xf3b60640, 0xffbf0fd0, "vcvt%c.bf16.f32\t%12-15,22D, %0-3,5Q"},
1274
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_BF16),
1275
    0xfc300810, 0xffb00f10, "vfma%6?tb.bf16\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1276
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_BF16),
1277
    0xfe300810, 0xffb00f10, "vfma%6?tb.bf16\t%12-15,22Q, %16-19,7Q, %{R:%0-2D[%3,5d]%}"},
1278
1279
  /* Matrix Multiply instructions.  */
1280
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_I8MM),
1281
    0xfc200c40, 0xffb00f50, "vsmmla.s8\t%12-15,22R, %16-19,7R, %0-3,5R"},
1282
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_I8MM),
1283
    0xfc200c50, 0xffb00f50, "vummla.u8\t%12-15,22R, %16-19,7R, %0-3,5R"},
1284
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_I8MM),
1285
    0xfca00c40, 0xffb00f50, "vusmmla.s8\t%12-15,22R, %16-19,7R, %0-3,5R"},
1286
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_I8MM),
1287
    0xfca00d00, 0xffb00f10, "vusdot.s8\t%12-15,22R, %16-19,7R, %0-3,5R"},
1288
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_I8MM),
1289
    0xfe800d00, 0xffb00f10, "vusdot.s8\t%12-15,22R, %16-19,7R, %{R:d%0-3d[%5d]%}"},
1290
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_I8MM),
1291
    0xfe800d10, 0xffb00f10, "vsudot.u8\t%12-15,22R, %16-19,7R, %{R:d%0-3d[%5d]%}"},
1292
1293
  /* Two registers, miscellaneous.  */
1294
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_ARMV8),
1295
    0xf3ba0400, 0xffbf0c10, "vrint%7-9?p?m?zaxn%u.f32\t%12-15,22R, %0-3,5R"},
1296
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1297
    0xf3b60400, 0xffbf0c10, "vrint%7-9?p?m?zaxn%u.f16\t%12-15,22R, %0-3,5R"},
1298
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_ARMV8),
1299
    0xf3bb0000, 0xffbf0c10, "vcvt%8-9?mpna%u.%7?us32.f32\t%12-15,22R, %0-3,5R"},
1300
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1301
    0xf3b70000, 0xffbf0c10, "vcvt%8-9?mpna%u.%7?us16.f16\t%12-15,22R, %0-3,5R"},
1302
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1303
    0xf3b00300, 0xffbf0fd0, "aese%u.8\t%12-15,22Q, %0-3,5Q"},
1304
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1305
    0xf3b00340, 0xffbf0fd0, "aesd%u.8\t%12-15,22Q, %0-3,5Q"},
1306
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1307
    0xf3b00380, 0xffbf0fd0, "aesmc%u.8\t%12-15,22Q, %0-3,5Q"},
1308
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1309
    0xf3b003c0, 0xffbf0fd0, "aesimc%u.8\t%12-15,22Q, %0-3,5Q"},
1310
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1311
    0xf3b902c0, 0xffbf0fd0, "sha1h%u.32\t%12-15,22Q, %0-3,5Q"},
1312
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1313
    0xf3ba0380, 0xffbf0fd0, "sha1su1%u.32\t%12-15,22Q, %0-3,5Q"},
1314
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1315
    0xf3ba03c0, 0xffbf0fd0, "sha256su0%u.32\t%12-15,22Q, %0-3,5Q"},
1316
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1317
    0xf2880a10, 0xfebf0fd0, "vmovl%c.%24?us8\t%12-15,22Q, %0-3,5D"},
1318
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1319
    0xf2900a10, 0xfebf0fd0, "vmovl%c.%24?us16\t%12-15,22Q, %0-3,5D"},
1320
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1321
    0xf2a00a10, 0xfebf0fd0, "vmovl%c.%24?us32\t%12-15,22Q, %0-3,5D"},
1322
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1323
    0xf3b00500, 0xffbf0f90, "vcnt%c.8\t%12-15,22R, %0-3,5R"},
1324
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1325
    0xf3b00580, 0xffbf0f90, "vmvn%c\t%12-15,22R, %0-3,5R"},
1326
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1327
    0xf3b20000, 0xffbf0f90, "vswp%c\t%12-15,22R, %0-3,5R"},
1328
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1329
    0xf3b20200, 0xffb30fd0, "vmovn%c.i%18-19T2\t%12-15,22D, %0-3,5Q"},
1330
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1331
    0xf3b20240, 0xffb30fd0, "vqmovun%c.s%18-19T2\t%12-15,22D, %0-3,5Q"},
1332
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1333
    0xf3b20280, 0xffb30fd0, "vqmovn%c.s%18-19T2\t%12-15,22D, %0-3,5Q"},
1334
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1335
    0xf3b202c0, 0xffb30fd0, "vqmovn%c.u%18-19T2\t%12-15,22D, %0-3,5Q"},
1336
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1337
    0xf3b20300, 0xffb30fd0,
1338
    "vshll%c.i%18-19S2\t%12-15,22Q, %0-3,5D, %{I:#%18-19S2%}"},
1339
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1340
    0xf3bb0400, 0xffbf0e90, "vrecpe%c.%8?fu%18-19S2\t%12-15,22R, %0-3,5R"},
1341
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1342
    0xf3b70400, 0xffbf0e90, "vrecpe%c.%8?fu16\t%12-15,22R, %0-3,5R"},
1343
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1344
    0xf3bb0480, 0xffbf0e90, "vrsqrte%c.%8?fu%18-19S2\t%12-15,22R, %0-3,5R"},
1345
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1346
    0xf3b70480, 0xffbf0e90, "vrsqrte%c.%8?fu16\t%12-15,22R, %0-3,5R"},
1347
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1348
    0xf3b00000, 0xffb30f90, "vrev64%c.%18-19S2\t%12-15,22R, %0-3,5R"},
1349
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1350
    0xf3b00080, 0xffb30f90, "vrev32%c.%18-19S2\t%12-15,22R, %0-3,5R"},
1351
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1352
    0xf3b00100, 0xffb30f90, "vrev16%c.%18-19S2\t%12-15,22R, %0-3,5R"},
1353
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1354
    0xf3b00400, 0xffb30f90, "vcls%c.s%18-19S2\t%12-15,22R, %0-3,5R"},
1355
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1356
    0xf3b00480, 0xffb30f90, "vclz%c.i%18-19S2\t%12-15,22R, %0-3,5R"},
1357
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1358
    0xf3b00700, 0xffb30f90, "vqabs%c.s%18-19S2\t%12-15,22R, %0-3,5R"},
1359
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1360
    0xf3b00780, 0xffb30f90, "vqneg%c.s%18-19S2\t%12-15,22R, %0-3,5R"},
1361
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1362
    0xf3b20080, 0xffb30f90, "vtrn%c.%18-19S2\t%12-15,22R, %0-3,5R"},
1363
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1364
    0xf3b20100, 0xffb30f90, "vuzp%c.%18-19S2\t%12-15,22R, %0-3,5R"},
1365
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1366
    0xf3b20180, 0xffb30f90, "vzip%c.%18-19S2\t%12-15,22R, %0-3,5R"},
1367
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1368
    0xf3b10000, 0xffb30b90, "vcgt%c.%10?fs%18-19S2\t%12-15,22R, %0-3,5R, %{I:#0%}"},
1369
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1370
    0xf3b10080, 0xffb30b90, "vcge%c.%10?fs%18-19S2\t%12-15,22R, %0-3,5R, %{I:#0%}"},
1371
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1372
    0xf3b10100, 0xffb30b90, "vceq%c.%10?fi%18-19S2\t%12-15,22R, %0-3,5R, %{I:#0%}"},
1373
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1374
    0xf3b10180, 0xffb30b90, "vcle%c.%10?fs%18-19S2\t%12-15,22R, %0-3,5R, %{I:#0%}"},
1375
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1376
    0xf3b10200, 0xffb30b90, "vclt%c.%10?fs%18-19S2\t%12-15,22R, %0-3,5R, %{I:#0%}"},
1377
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1378
    0xf3b10300, 0xffb30b90, "vabs%c.%10?fs%18-19S2\t%12-15,22R, %0-3,5R"},
1379
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1380
    0xf3b10380, 0xffb30b90, "vneg%c.%10?fs%18-19S2\t%12-15,22R, %0-3,5R"},
1381
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1382
    0xf3b00200, 0xffb30f10, "vpaddl%c.%7?us%18-19S2\t%12-15,22R, %0-3,5R"},
1383
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1384
    0xf3b00600, 0xffb30f10, "vpadal%c.%7?us%18-19S2\t%12-15,22R, %0-3,5R"},
1385
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1386
    0xf3bb0600, 0xffbf0e10,
1387
    "vcvt%c.%7-8?usff%18-19Sa.%7-8?ffus%18-19Sa\t%12-15,22R, %0-3,5R"},
1388
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1389
    0xf3b70600, 0xffbf0e10,
1390
    "vcvt%c.%7-8?usff16.%7-8?ffus16\t%12-15,22R, %0-3,5R"},
1391
1392
  /* Three registers of the same length.  */
1393
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1394
    0xf2000c40, 0xffb00f50, "sha1c%u.32\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1395
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1396
    0xf2100c40, 0xffb00f50, "sha1p%u.32\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1397
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1398
    0xf2200c40, 0xffb00f50, "sha1m%u.32\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1399
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1400
    0xf2300c40, 0xffb00f50, "sha1su0%u.32\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1401
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1402
    0xf3000c40, 0xffb00f50, "sha256h%u.32\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1403
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1404
    0xf3100c40, 0xffb00f50, "sha256h2%u.32\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1405
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1406
    0xf3200c40, 0xffb00f50, "sha256su1%u.32\t%12-15,22Q, %16-19,7Q, %0-3,5Q"},
1407
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_ARMV8),
1408
    0xf3000f10, 0xffb00f10, "vmaxnm%u.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1409
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1410
    0xf3100f10, 0xffb00f10, "vmaxnm%u.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1411
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_ARMV8),
1412
    0xf3200f10, 0xffb00f10, "vminnm%u.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1413
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1414
    0xf3300f10, 0xffb00f10, "vminnm%u.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1415
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1416
    0xf2000110, 0xffb00f10, "vand%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1417
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1418
    0xf2100110, 0xffb00f10, "vbic%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1419
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1420
    0xf2200110, 0xffb00f10, "vorr%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1421
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1422
    0xf2300110, 0xffb00f10, "vorn%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1423
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1424
    0xf3000110, 0xffb00f10, "veor%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1425
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1426
    0xf3100110, 0xffb00f10, "vbsl%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1427
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1428
    0xf3200110, 0xffb00f10, "vbit%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1429
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1430
    0xf3300110, 0xffb00f10, "vbif%c\t%12-15,22R, %16-19,7R, %0-3,5R"},
1431
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1432
    0xf2000d00, 0xffb00f10, "vadd%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1433
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1434
    0xf2100d00, 0xffb00f10, "vadd%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1435
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1436
    0xf2000d10, 0xffb00f10, "vmla%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1437
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1438
    0xf2100d10, 0xffb00f10, "vmla%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1439
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1440
    0xf2000e00, 0xffb00f10, "vceq%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1441
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1442
    0xf2100e00, 0xffb00f10, "vceq%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1443
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1444
    0xf2000f00, 0xffb00f10, "vmax%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1445
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1446
    0xf2100f00, 0xffb00f10, "vmax%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1447
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1448
    0xf2000f10, 0xffb00f10, "vrecps%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1449
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1450
    0xf2100f10, 0xffb00f10, "vrecps%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1451
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1452
    0xf2200d00, 0xffb00f10, "vsub%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1453
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1454
    0xf2300d00, 0xffb00f10, "vsub%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1455
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1456
    0xf2200d10, 0xffb00f10, "vmls%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1457
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1458
    0xf2300d10, 0xffb00f10, "vmls%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1459
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1460
    0xf2200f00, 0xffb00f10, "vmin%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1461
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1462
    0xf2300f00, 0xffb00f10, "vmin%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1463
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1464
    0xf2200f10, 0xffb00f10, "vrsqrts%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1465
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1466
    0xf2300f10, 0xffb00f10, "vrsqrts%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1467
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1468
    0xf3000d00, 0xffb00f10, "vpadd%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1469
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1470
    0xf3100d00, 0xffb00f10, "vpadd%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1471
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1472
    0xf3000d10, 0xffb00f10, "vmul%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1473
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1474
    0xf3100d10, 0xffb00f10, "vmul%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1475
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1476
    0xf3000e00, 0xffb00f10, "vcge%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1477
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1478
    0xf3100e00, 0xffb00f10, "vcge%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1479
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1480
    0xf3000e10, 0xffb00f10, "vacge%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1481
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1482
    0xf3100e10, 0xffb00f10, "vacge%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1483
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1484
    0xf3000f00, 0xffb00f10, "vpmax%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1485
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1486
    0xf3100f00, 0xffb00f10, "vpmax%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1487
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1488
    0xf3200d00, 0xffb00f10, "vabd%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1489
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1490
    0xf3300d00, 0xffb00f10, "vabd%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1491
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1492
    0xf3200e00, 0xffb00f10, "vcgt%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1493
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1494
    0xf3300e00, 0xffb00f10, "vcgt%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1495
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1496
    0xf3200e10, 0xffb00f10, "vacgt%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1497
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1498
    0xf3300e10, 0xffb00f10, "vacgt%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1499
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1500
    0xf3200f00, 0xffb00f10, "vpmin%c.f32\t%12-15,22R, %16-19,7R, %0-3,5R"},
1501
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1502
    0xf3300f00, 0xffb00f10, "vpmin%c.f16\t%12-15,22R, %16-19,7R, %0-3,5R"},
1503
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1504
    0xf2000800, 0xff800f10, "vadd%c.i%20-21S3\t%12-15,22R, %16-19,7R, %0-3,5R"},
1505
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1506
    0xf2000810, 0xff800f10, "vtst%c.%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1507
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1508
    0xf2000900, 0xff800f10, "vmla%c.i%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1509
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1510
    0xf2000b00, 0xff800f10,
1511
    "vqdmulh%c.s%20-21S6\t%12-15,22R, %16-19,7R, %0-3,5R"},
1512
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1513
    0xf2000b10, 0xff800f10,
1514
    "vpadd%c.i%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1515
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1516
    0xf3000800, 0xff800f10, "vsub%c.i%20-21S3\t%12-15,22R, %16-19,7R, %0-3,5R"},
1517
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1518
    0xf3000810, 0xff800f10, "vceq%c.i%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1519
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1520
    0xf3000900, 0xff800f10, "vmls%c.i%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1521
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1522
    0xf3000b00, 0xff800f10,
1523
    "vqrdmulh%c.s%20-21S6\t%12-15,22R, %16-19,7R, %0-3,5R"},
1524
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1525
    0xf2000000, 0xfe800f10,
1526
    "vhadd%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1527
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1528
    0xf2000010, 0xfe800f10,
1529
    "vqadd%c.%24?us%20-21S3\t%12-15,22R, %16-19,7R, %0-3,5R"},
1530
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1531
    0xf2000100, 0xfe800f10,
1532
    "vrhadd%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1533
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1534
    0xf2000200, 0xfe800f10,
1535
    "vhsub%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1536
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1537
    0xf2000210, 0xfe800f10,
1538
    "vqsub%c.%24?us%20-21S3\t%12-15,22R, %16-19,7R, %0-3,5R"},
1539
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1540
    0xf2000300, 0xfe800f10,
1541
    "vcgt%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1542
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1543
    0xf2000310, 0xfe800f10,
1544
    "vcge%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1545
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1546
    0xf2000400, 0xfe800f10,
1547
    "vshl%c.%24?us%20-21S3\t%12-15,22R, %0-3,5R, %16-19,7R"},
1548
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1549
    0xf2000410, 0xfe800f10,
1550
    "vqshl%c.%24?us%20-21S3\t%12-15,22R, %0-3,5R, %16-19,7R"},
1551
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1552
    0xf2000500, 0xfe800f10,
1553
    "vrshl%c.%24?us%20-21S3\t%12-15,22R, %0-3,5R, %16-19,7R"},
1554
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1555
    0xf2000510, 0xfe800f10,
1556
    "vqrshl%c.%24?us%20-21S3\t%12-15,22R, %0-3,5R, %16-19,7R"},
1557
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1558
    0xf2000600, 0xfe800f10,
1559
    "vmax%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1560
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1561
    0xf2000610, 0xfe800f10,
1562
    "vmin%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1563
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1564
    0xf2000700, 0xfe800f10,
1565
    "vabd%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1566
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1567
    0xf2000710, 0xfe800f10,
1568
    "vaba%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1569
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1570
    0xf2000910, 0xfe800f10,
1571
    "vmul%c.%24?pi%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1572
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1573
    0xf2000a00, 0xfe800f10,
1574
    "vpmax%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1575
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1576
    0xf2000a10, 0xfe800f10,
1577
    "vpmin%c.%24?us%20-21S2\t%12-15,22R, %16-19,7R, %0-3,5R"},
1578
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_RDMA),
1579
    0xf3000b10, 0xff800f10,
1580
    "vqrdmlah%c.s%20-21S6\t%12-15,22R, %16-19,7R, %0-3,5R"},
1581
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_RDMA),
1582
    0xf3000c10, 0xff800f10,
1583
    "vqrdmlsh%c.s%20-21S6\t%12-15,22R, %16-19,7R, %0-3,5R"},
1584
1585
  /* One register and an immediate value.  */
1586
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1587
    0xf2800e10, 0xfeb80fb0, "vmov%c.i8\t%12-15,22R, %E"},
1588
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1589
    0xf2800e30, 0xfeb80fb0, "vmov%c.i64\t%12-15,22R, %E"},
1590
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1591
    0xf2800f10, 0xfeb80fb0, "vmov%c.f32\t%12-15,22R, %E"},
1592
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1593
    0xf2800810, 0xfeb80db0, "vmov%c.i16\t%12-15,22R, %E"},
1594
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1595
    0xf2800830, 0xfeb80db0, "vmvn%c.i16\t%12-15,22R, %E"},
1596
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1597
    0xf2800910, 0xfeb80db0, "vorr%c.i16\t%12-15,22R, %E"},
1598
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1599
    0xf2800930, 0xfeb80db0, "vbic%c.i16\t%12-15,22R, %E"},
1600
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1601
    0xf2800c10, 0xfeb80eb0, "vmov%c.i32\t%12-15,22R, %E"},
1602
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1603
    0xf2800c30, 0xfeb80eb0, "vmvn%c.i32\t%12-15,22R, %E"},
1604
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1605
    0xf2800110, 0xfeb809b0, "vorr%c.i32\t%12-15,22R, %E"},
1606
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1607
    0xf2800130, 0xfeb809b0, "vbic%c.i32\t%12-15,22R, %E"},
1608
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1609
    0xf2800010, 0xfeb808b0, "vmov%c.i32\t%12-15,22R, %E"},
1610
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1611
    0xf2800030, 0xfeb808b0, "vmvn%c.i32\t%12-15,22R, %E"},
1612
1613
  /* Two registers and a shift amount.  */
1614
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1615
    0xf2880810, 0xffb80fd0, "vshrn%c.i16\t%12-15,22D, %0-3,5Q, %{I:#%16-18e%}"},
1616
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1617
    0xf2880850, 0xffb80fd0, "vrshrn%c.i16\t%12-15,22D, %0-3,5Q, %{I:#%16-18e%}"},
1618
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1619
    0xf2880810, 0xfeb80fd0, "vqshrun%c.s16\t%12-15,22D, %0-3,5Q, %{I:#%16-18e%}"},
1620
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1621
    0xf2880850, 0xfeb80fd0, "vqrshrun%c.s16\t%12-15,22D, %0-3,5Q, %{I:#%16-18e%}"},
1622
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1623
    0xf2880910, 0xfeb80fd0, "vqshrn%c.%24?us16\t%12-15,22D, %0-3,5Q, %{I:#%16-18e%}"},
1624
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1625
    0xf2880950, 0xfeb80fd0,
1626
    "vqrshrn%c.%24?us16\t%12-15,22D, %0-3,5Q, %{I:#%16-18e%}"},
1627
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1628
    0xf2880a10, 0xfeb80fd0, "vshll%c.%24?us8\t%12-15,22Q, %0-3,5D, %{I:#%16-18d%}"},
1629
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1630
    0xf2900810, 0xffb00fd0, "vshrn%c.i32\t%12-15,22D, %0-3,5Q, %{I:#%16-19e%}"},
1631
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1632
    0xf2900850, 0xffb00fd0, "vrshrn%c.i32\t%12-15,22D, %0-3,5Q, %{I:#%16-19e%}"},
1633
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1634
    0xf2880510, 0xffb80f90, "vshl%c.%24?us8\t%12-15,22R, %0-3,5R, %{I:#%16-18d%}"},
1635
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1636
    0xf3880410, 0xffb80f90, "vsri%c.8\t%12-15,22R, %0-3,5R, %{I:#%16-18e%}"},
1637
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1638
    0xf3880510, 0xffb80f90, "vsli%c.8\t%12-15,22R, %0-3,5R, %{I:#%16-18d%}"},
1639
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1640
    0xf3880610, 0xffb80f90, "vqshlu%c.s8\t%12-15,22R, %0-3,5R, %{I:#%16-18d%}"},
1641
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1642
    0xf2900810, 0xfeb00fd0, "vqshrun%c.s32\t%12-15,22D, %0-3,5Q, %{I:#%16-19e%}"},
1643
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1644
    0xf2900850, 0xfeb00fd0, "vqrshrun%c.s32\t%12-15,22D, %0-3,5Q, %{I:#%16-19e%}"},
1645
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1646
    0xf2900910, 0xfeb00fd0, "vqshrn%c.%24?us32\t%12-15,22D, %0-3,5Q, %{I:#%16-19e%}"},
1647
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1648
    0xf2900950, 0xfeb00fd0,
1649
    "vqrshrn%c.%24?us32\t%12-15,22D, %0-3,5Q, %{I:#%16-19e%}"},
1650
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1651
    0xf2900a10, 0xfeb00fd0, "vshll%c.%24?us16\t%12-15,22Q, %0-3,5D, %{I:#%16-19d%}"},
1652
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1653
    0xf2880010, 0xfeb80f90, "vshr%c.%24?us8\t%12-15,22R, %0-3,5R, %{I:#%16-18e%}"},
1654
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1655
    0xf2880110, 0xfeb80f90, "vsra%c.%24?us8\t%12-15,22R, %0-3,5R, %{I:#%16-18e%}"},
1656
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1657
    0xf2880210, 0xfeb80f90, "vrshr%c.%24?us8\t%12-15,22R, %0-3,5R, %{I:#%16-18e%}"},
1658
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1659
    0xf2880310, 0xfeb80f90, "vrsra%c.%24?us8\t%12-15,22R, %0-3,5R, %{I:#%16-18e%}"},
1660
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1661
    0xf2880710, 0xfeb80f90, "vqshl%c.%24?us8\t%12-15,22R, %0-3,5R, %{I:#%16-18d%}"},
1662
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1663
    0xf2a00810, 0xffa00fd0, "vshrn%c.i64\t%12-15,22D, %0-3,5Q, %{I:#%16-20e%}"},
1664
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1665
    0xf2a00850, 0xffa00fd0, "vrshrn%c.i64\t%12-15,22D, %0-3,5Q, %{I:#%16-20e%}"},
1666
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1667
    0xf2900510, 0xffb00f90, "vshl%c.%24?us16\t%12-15,22R, %0-3,5R, %{I:#%16-19d%}"},
1668
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1669
    0xf3900410, 0xffb00f90, "vsri%c.16\t%12-15,22R, %0-3,5R, %{I:#%16-19e%}"},
1670
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1671
    0xf3900510, 0xffb00f90, "vsli%c.16\t%12-15,22R, %0-3,5R, %{I:#%16-19d%}"},
1672
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1673
    0xf3900610, 0xffb00f90, "vqshlu%c.s16\t%12-15,22R, %0-3,5R, %{I:#%16-19d%}"},
1674
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1675
    0xf2a00a10, 0xfea00fd0, "vshll%c.%24?us32\t%12-15,22Q, %0-3,5D, %{I:#%16-20d%}"},
1676
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1677
    0xf2900010, 0xfeb00f90, "vshr%c.%24?us16\t%12-15,22R, %0-3,5R, %{I:#%16-19e%}"},
1678
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1679
    0xf2900110, 0xfeb00f90, "vsra%c.%24?us16\t%12-15,22R, %0-3,5R, %{I:#%16-19e%}"},
1680
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1681
    0xf2900210, 0xfeb00f90, "vrshr%c.%24?us16\t%12-15,22R, %0-3,5R, %{I:#%16-19e%}"},
1682
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1683
    0xf2900310, 0xfeb00f90, "vrsra%c.%24?us16\t%12-15,22R, %0-3,5R, %{I:#%16-19e%}"},
1684
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1685
    0xf2900710, 0xfeb00f90, "vqshl%c.%24?us16\t%12-15,22R, %0-3,5R, %{I:#%16-19d%}"},
1686
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1687
    0xf2a00810, 0xfea00fd0, "vqshrun%c.s64\t%12-15,22D, %0-3,5Q, %{I:#%16-20e%}"},
1688
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1689
    0xf2a00850, 0xfea00fd0, "vqrshrun%c.s64\t%12-15,22D, %0-3,5Q, %{I:#%16-20e%}"},
1690
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1691
    0xf2a00910, 0xfea00fd0, "vqshrn%c.%24?us64\t%12-15,22D, %0-3,5Q, %{I:#%16-20e%}"},
1692
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1693
    0xf2a00950, 0xfea00fd0,
1694
    "vqrshrn%c.%24?us64\t%12-15,22D, %0-3,5Q, %{I:#%16-20e%}"},
1695
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1696
    0xf2a00510, 0xffa00f90, "vshl%c.%24?us32\t%12-15,22R, %0-3,5R, %{I:#%16-20d%}"},
1697
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1698
    0xf3a00410, 0xffa00f90, "vsri%c.32\t%12-15,22R, %0-3,5R, %{I:#%16-20e%}"},
1699
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1700
    0xf3a00510, 0xffa00f90, "vsli%c.32\t%12-15,22R, %0-3,5R, %{I:#%16-20d%}"},
1701
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1702
    0xf3a00610, 0xffa00f90, "vqshlu%c.s32\t%12-15,22R, %0-3,5R, %{I:#%16-20d%}"},
1703
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1704
    0xf2a00010, 0xfea00f90, "vshr%c.%24?us32\t%12-15,22R, %0-3,5R, %{I:#%16-20e%}"},
1705
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1706
    0xf2a00110, 0xfea00f90, "vsra%c.%24?us32\t%12-15,22R, %0-3,5R, %{I:#%16-20e%}"},
1707
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1708
    0xf2a00210, 0xfea00f90, "vrshr%c.%24?us32\t%12-15,22R, %0-3,5R, %{I:#%16-20e%}"},
1709
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1710
    0xf2a00310, 0xfea00f90, "vrsra%c.%24?us32\t%12-15,22R, %0-3,5R, %{I:#%16-20e%}"},
1711
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1712
    0xf2a00710, 0xfea00f90, "vqshl%c.%24?us32\t%12-15,22R, %0-3,5R, %{I:#%16-20d%}"},
1713
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1714
    0xf2800590, 0xff800f90, "vshl%c.%24?us64\t%12-15,22R, %0-3,5R, %{I:#%16-21d%}"},
1715
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1716
    0xf3800490, 0xff800f90, "vsri%c.64\t%12-15,22R, %0-3,5R, %{I:#%16-21e%}"},
1717
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1718
    0xf3800590, 0xff800f90, "vsli%c.64\t%12-15,22R, %0-3,5R, %{I:#%16-21d%}"},
1719
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1720
    0xf3800690, 0xff800f90, "vqshlu%c.s64\t%12-15,22R, %0-3,5R, %{I:#%16-21d%}"},
1721
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1722
    0xf2800090, 0xfe800f90, "vshr%c.%24?us64\t%12-15,22R, %0-3,5R, %{I:#%16-21e%}"},
1723
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1724
    0xf2800190, 0xfe800f90, "vsra%c.%24?us64\t%12-15,22R, %0-3,5R, %{I:#%16-21e%}"},
1725
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1726
    0xf2800290, 0xfe800f90, "vrshr%c.%24?us64\t%12-15,22R, %0-3,5R, %{I:#%16-21e%}"},
1727
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1728
    0xf2800390, 0xfe800f90, "vrsra%c.%24?us64\t%12-15,22R, %0-3,5R, %{I:#%16-21e%}"},
1729
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1730
    0xf2800790, 0xfe800f90, "vqshl%c.%24?us64\t%12-15,22R, %0-3,5R, %{I:#%16-21d%}"},
1731
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1732
    0xf2a00e10, 0xfea00e90,
1733
    "vcvt%c.%24,8?usff32.%24,8?ffus32\t%12-15,22R, %0-3,5R, %{I:#%16-20e%}"},
1734
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST),
1735
    0xf2a00c10, 0xfea00e90,
1736
    "vcvt%c.%24,8?usff16.%24,8?ffus16\t%12-15,22R, %0-3,5R, %{I:#%16-20e%}"},
1737
1738
  /* Three registers of different lengths.  */
1739
  {ARM_FEATURE_COPROC (FPU_CRYPTO_EXT_ARMV8),
1740
    0xf2a00e00, 0xfeb00f50, "vmull%c.p64\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1741
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1742
    0xf2800e00, 0xfea00f50, "vmull%c.p%20S0\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1743
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1744
    0xf2800400, 0xff800f50,
1745
    "vaddhn%c.i%20-21T2\t%12-15,22D, %16-19,7Q, %0-3,5Q"},
1746
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1747
    0xf2800600, 0xff800f50,
1748
    "vsubhn%c.i%20-21T2\t%12-15,22D, %16-19,7Q, %0-3,5Q"},
1749
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1750
    0xf2800900, 0xff800f50,
1751
    "vqdmlal%c.s%20-21S6\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1752
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1753
    0xf2800b00, 0xff800f50,
1754
    "vqdmlsl%c.s%20-21S6\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1755
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1756
    0xf2800d00, 0xff800f50,
1757
    "vqdmull%c.s%20-21S6\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1758
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1759
    0xf3800400, 0xff800f50,
1760
    "vraddhn%c.i%20-21T2\t%12-15,22D, %16-19,7Q, %0-3,5Q"},
1761
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1762
    0xf3800600, 0xff800f50,
1763
    "vrsubhn%c.i%20-21T2\t%12-15,22D, %16-19,7Q, %0-3,5Q"},
1764
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1765
    0xf2800000, 0xfe800f50,
1766
    "vaddl%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1767
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1768
    0xf2800100, 0xfe800f50,
1769
    "vaddw%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7Q, %0-3,5D"},
1770
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1771
    0xf2800200, 0xfe800f50,
1772
    "vsubl%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1773
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1774
    0xf2800300, 0xfe800f50,
1775
    "vsubw%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7Q, %0-3,5D"},
1776
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1777
    0xf2800500, 0xfe800f50,
1778
    "vabal%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1779
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1780
    0xf2800700, 0xfe800f50,
1781
    "vabdl%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1782
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1783
    0xf2800800, 0xfe800f50,
1784
    "vmlal%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1785
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1786
    0xf2800a00, 0xfe800f50,
1787
    "vmlsl%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1788
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1789
    0xf2800c00, 0xfe800f50,
1790
    "vmull%c.%24?us%20-21S2\t%12-15,22Q, %16-19,7D, %0-3,5D"},
1791
1792
  /* Two registers and a scalar.  */
1793
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1794
    0xf2800040, 0xff800f50, "vmla%c.i%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1795
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1796
    0xf2800140, 0xff900f50, "vmla%c.f%20-21Sa\t%12-15,22D, %16-19,7D, %D"},
1797
  {ARM_FEATURE_COPROC (ARM_EXT2_FP16_INST),
1798
    0xf2900140, 0xffb00f50, "vmla%c.f16\t%12-15,22D, %16-19,7D, %D"},
1799
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1800
    0xf2800340, 0xff800f50, "vqdmlal%c.s%20-21S6\t%12-15,22Q, %16-19,7D, %D"},
1801
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1802
    0xf2800440, 0xff800f50, "vmls%c.i%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1803
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1804
    0xf2800540, 0xff900f50, "vmls%c.f%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1805
  {ARM_FEATURE_COPROC (ARM_EXT2_FP16_INST),
1806
    0xf2900540, 0xffb00f50, "vmls%c.f16\t%12-15,22D, %16-19,7D, %D"},
1807
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1808
    0xf2800740, 0xff800f50, "vqdmlsl%c.s%20-21S6\t%12-15,22Q, %16-19,7D, %D"},
1809
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1810
    0xf2800840, 0xff800f50, "vmul%c.i%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1811
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1812
    0xf2800940, 0xff900f50, "vmul%c.f%20-21Sa\t%12-15,22D, %16-19,7D, %D"},
1813
  {ARM_FEATURE_COPROC (ARM_EXT2_FP16_INST),
1814
    0xf2900940, 0xffb00f50, "vmul%c.f16\t%12-15,22D, %16-19,7D, %D"},
1815
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1816
    0xf2800b40, 0xff800f50, "vqdmull%c.s%20-21S6\t%12-15,22Q, %16-19,7D, %D"},
1817
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1818
    0xf2800c40, 0xff800f50, "vqdmulh%c.s%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1819
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1820
    0xf2800d40, 0xff800f50, "vqrdmulh%c.s%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1821
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1822
    0xf3800040, 0xff800f50, "vmla%c.i%20-21S6\t%12-15,22Q, %16-19,7Q, %D"},
1823
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1824
    0xf3800140, 0xff900f50, "vmla%c.f%20-21Sa\t%12-15,22Q, %16-19,7Q, %D"},
1825
  {ARM_FEATURE_COPROC (ARM_EXT2_FP16_INST),
1826
    0xf3900140, 0xffb00f50, "vmla%c.f16\t%12-15,22Q, %16-19,7Q, %D"},
1827
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1828
    0xf3800440, 0xff800f50, "vmls%c.i%20-21S6\t%12-15,22Q, %16-19,7Q, %D"},
1829
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1830
    0xf3800540, 0xff900f50, "vmls%c.f%20-21Sa\t%12-15,22Q, %16-19,7Q, %D"},
1831
  {ARM_FEATURE_COPROC (ARM_EXT2_FP16_INST),
1832
    0xf3900540, 0xffb00f50, "vmls%c.f16\t%12-15,22Q, %16-19,7Q, %D"},
1833
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1834
    0xf3800840, 0xff800f50, "vmul%c.i%20-21S6\t%12-15,22Q, %16-19,7Q, %D"},
1835
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1836
    0xf3800940, 0xff900f50, "vmul%c.f%20-21Sa\t%12-15,22Q, %16-19,7Q, %D"},
1837
  {ARM_FEATURE_COPROC (ARM_EXT2_FP16_INST),
1838
    0xf3900940, 0xffb00f50, "vmul%c.f16\t%12-15,22Q, %16-19,7Q, %D"},
1839
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1840
    0xf3800c40, 0xff800f50, "vqdmulh%c.s%20-21S6\t%12-15,22Q, %16-19,7Q, %D"},
1841
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1842
    0xf3800d40, 0xff800f50, "vqrdmulh%c.s%20-21S6\t%12-15,22Q, %16-19,7Q, %D"},
1843
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1844
    0xf2800240, 0xfe800f50,
1845
    "vmlal%c.%24?us%20-21S6\t%12-15,22Q, %16-19,7D, %D"},
1846
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1847
    0xf2800640, 0xfe800f50,
1848
    "vmlsl%c.%24?us%20-21S6\t%12-15,22Q, %16-19,7D, %D"},
1849
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1850
    0xf2800a40, 0xfe800f50,
1851
    "vmull%c.%24?us%20-21S6\t%12-15,22Q, %16-19,7D, %D"},
1852
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_RDMA),
1853
    0xf2800e40, 0xff800f50,
1854
   "vqrdmlah%c.s%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1855
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_RDMA),
1856
    0xf2800f40, 0xff800f50,
1857
   "vqrdmlsh%c.s%20-21S6\t%12-15,22D, %16-19,7D, %D"},
1858
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_RDMA),
1859
    0xf3800e40, 0xff800f50,
1860
   "vqrdmlah%c.s%20-21S6\t%12-15,22Q, %16-19,7Q, %D"},
1861
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_RDMA),
1862
    0xf3800f40, 0xff800f50,
1863
   "vqrdmlsh%c.s%20-21S6\t%12-15,22Q, %16-19,7Q, %D"
1864
  },
1865
1866
  /* Element and structure load/store.  */
1867
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1868
    0xf4a00fc0, 0xffb00fc0, "vld4%c.32\t%C"},
1869
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1870
    0xf4a00c00, 0xffb00f00, "vld1%c.%6-7S2\t%C"},
1871
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1872
    0xf4a00d00, 0xffb00f00, "vld2%c.%6-7S2\t%C"},
1873
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1874
    0xf4a00e00, 0xffb00f00, "vld3%c.%6-7S2\t%C"},
1875
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1876
    0xf4a00f00, 0xffb00f00, "vld4%c.%6-7S2\t%C"},
1877
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1878
    0xf4000200, 0xff900f00, "v%21?ls%21?dt1%c.%6-7S3\t%A"},
1879
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1880
    0xf4000300, 0xff900f00, "v%21?ls%21?dt2%c.%6-7S2\t%A"},
1881
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1882
    0xf4000400, 0xff900f00, "v%21?ls%21?dt3%c.%6-7S2\t%A"},
1883
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1884
    0xf4000500, 0xff900f00, "v%21?ls%21?dt3%c.%6-7S2\t%A"},
1885
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1886
    0xf4000600, 0xff900f00, "v%21?ls%21?dt1%c.%6-7S3\t%A"},
1887
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1888
    0xf4000700, 0xff900f00, "v%21?ls%21?dt1%c.%6-7S3\t%A"},
1889
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1890
    0xf4000800, 0xff900f00, "v%21?ls%21?dt2%c.%6-7S2\t%A"},
1891
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1892
    0xf4000900, 0xff900f00, "v%21?ls%21?dt2%c.%6-7S2\t%A"},
1893
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1894
    0xf4000a00, 0xff900f00, "v%21?ls%21?dt1%c.%6-7S3\t%A"},
1895
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1896
    0xf4000000, 0xff900e00, "v%21?ls%21?dt4%c.%6-7S2\t%A"},
1897
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1898
    0xf4800000, 0xff900300, "v%21?ls%21?dt1%c.%10-11S2\t%B"},
1899
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1900
    0xf4800100, 0xff900300, "v%21?ls%21?dt2%c.%10-11S2\t%B"},
1901
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1902
    0xf4800200, 0xff900300, "v%21?ls%21?dt3%c.%10-11S2\t%B"},
1903
  {ARM_FEATURE_COPROC (FPU_NEON_EXT_V1),
1904
    0xf4800300, 0xff900300, "v%21?ls%21?dt4%c.%10-11S2\t%B"},
1905
1906
  {ARM_FEATURE_CORE_LOW (0), 0 ,0, 0}
1907
};
1908
1909
/* mve opcode table.  */
1910
1911
/* print_insn_mve recognizes the following format control codes:
1912
1913
   %%     %
1914
1915
   %a     print '+' or '-' or imm offset in vldr[bhwd] and
1916
      vstr[bhwd]
1917
   %c     print condition code
1918
   %d     print addr mode of MVE vldr[bhw] and vstr[bhw]
1919
   %u     print 'U' (unsigned) or 'S' for various mve instructions
1920
   %i     print MVE predicate(s) for vpt and vpst
1921
   %j     print a 5-bit immediate from hw2[14:12,7:6]
1922
   %k     print 48 if the 7th position bit is set else print 64.
1923
   %m     print rounding mode for vcvt and vrint
1924
   %n     print vector comparison code for predicated instruction
1925
   %s     print size for various vcvt instructions
1926
   %v     print vector predicate for instruction in predicated
1927
      block
1928
   %o     print offset scaled for vldr[hwd] and vstr[hwd]
1929
   %w     print writeback mode for MVE v{st,ld}[24]
1930
   %B     print v{st,ld}[24] any one operands
1931
   %E     print vmov, vmvn, vorr, vbic encoded constant
1932
   %N     print generic index for vmov
1933
   %T     print bottom ('b') or top ('t') of source register
1934
   %X     print exchange field in vmla* instructions
1935
1936
   %<bitfield>r   print as an ARM register
1937
   %<bitfield>d   print the bitfield in decimal
1938
   %<bitfield>A   print accumulate or not
1939
   %<bitfield>c   print bitfield as a condition code
1940
   %<bitfield>C   print bitfield as an inverted condition code
1941
   %<bitfield>Q   print as a MVE Q register
1942
   %<bitfield>F   print as a MVE S register
1943
   %<bitfield>Z   as %<>r but r15 is ZR instead of PC and r13 is
1944
      UNPREDICTABLE
1945
1946
   %<bitfield>S   as %<>r but r15 or r13 is UNPREDICTABLE
1947
   %<bitfield>s   print size for vector predicate & non VMOV instructions
1948
   %<bitfield>I   print carry flag or not
1949
   %<bitfield>i   print immediate for vstr/vldr reg +/- imm
1950
   %<bitfield>h   print high half of 64-bit destination reg
1951
   %<bitfield>k   print immediate for vector conversion instruction
1952
   %<bitfield>l   print low half of 64-bit destination reg
1953
   %<bitfield>o   print rotate value for vcmul
1954
   %<bitfield>u   print immediate value for vddup/vdwdup
1955
   %<bitfield>x   print the bitfield in hex.
1956
  */
1957
1958
static const struct mopcode32 mve_opcodes[] =
1959
{
1960
  /* MVE.  */
1961
1962
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
1963
   MVE_VPST,
1964
   0xfe310f4d, 0xffbf1fff,
1965
   "vpst%i"
1966
  },
1967
1968
  /* Floating point VPT T1.  */
1969
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
1970
   MVE_VPT_FP_T1,
1971
   0xee310f00, 0xefb10f50,
1972
   "vpt%i.f%28s\t%n, %17-19Q, %1-3,5Q"},
1973
  /* Floating point VPT T2.  */
1974
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
1975
   MVE_VPT_FP_T2,
1976
   0xee310f40, 0xefb10f50,
1977
   "vpt%i.f%28s\t%n, %17-19Q, %0-3Z"},
1978
1979
  /* Vector VPT T1.  */
1980
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
1981
   MVE_VPT_VEC_T1,
1982
   0xfe010f00, 0xff811f51,
1983
   "vpt%i.i%20-21s\t%n, %17-19Q, %1-3,5Q"},
1984
  /* Vector VPT T2.  */
1985
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
1986
   MVE_VPT_VEC_T2,
1987
   0xfe010f01, 0xff811f51,
1988
   "vpt%i.u%20-21s\t%n, %17-19Q, %1-3,5Q"},
1989
  /* Vector VPT T3.  */
1990
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
1991
   MVE_VPT_VEC_T3,
1992
   0xfe011f00, 0xff811f50,
1993
   "vpt%i.s%20-21s\t%n, %17-19Q, %1-3,5Q"},
1994
  /* Vector VPT T4.  */
1995
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
1996
   MVE_VPT_VEC_T4,
1997
   0xfe010f40, 0xff811f70,
1998
   "vpt%i.i%20-21s\t%n, %17-19Q, %0-3Z"},
1999
  /* Vector VPT T5.  */
2000
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2001
   MVE_VPT_VEC_T5,
2002
   0xfe010f60, 0xff811f70,
2003
   "vpt%i.u%20-21s\t%n, %17-19Q, %0-3Z"},
2004
  /* Vector VPT T6.  */
2005
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2006
   MVE_VPT_VEC_T6,
2007
   0xfe011f40, 0xff811f50,
2008
   "vpt%i.s%20-21s\t%n, %17-19Q, %0-3Z"},
2009
2010
  /* Vector VBIC immediate.  */
2011
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2012
   MVE_VBIC_IMM,
2013
   0xef800070, 0xefb81070,
2014
   "vbic%v.i%8-11s\t%13-15,22Q, %E"},
2015
2016
  /* Vector VBIC register.  */
2017
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2018
   MVE_VBIC_REG,
2019
   0xef100150, 0xffb11f51,
2020
   "vbic%v\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2021
2022
  /* Vector VABAV.  */
2023
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2024
   MVE_VABAV,
2025
   0xee800f01, 0xefc10f51,
2026
   "vabav%v.%u%20-21s\t%12-15r, %17-19,7Q, %1-3,5Q"},
2027
2028
  /* Vector VABD floating point.  */
2029
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2030
   MVE_VABD_FP,
2031
   0xff200d40, 0xffa11f51,
2032
   "vabd%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2033
2034
  /* Vector VABD.  */
2035
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2036
   MVE_VABD_VEC,
2037
   0xef000740, 0xef811f51,
2038
   "vabd%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2039
2040
  /* Vector VABS floating point.  */
2041
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2042
   MVE_VABS_FP,
2043
   0xFFB10740, 0xFFB31FD1,
2044
   "vabs%v.f%18-19s\t%13-15,22Q, %1-3,5Q"},
2045
  /* Vector VABS.  */
2046
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2047
   MVE_VABS_VEC,
2048
   0xffb10340, 0xffb31fd1,
2049
   "vabs%v.s%18-19s\t%13-15,22Q, %1-3,5Q"},
2050
2051
  /* Vector VADD floating point T1.  */
2052
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2053
   MVE_VADD_FP_T1,
2054
   0xef000d40, 0xffa11f51,
2055
   "vadd%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2056
  /* Vector VADD floating point T2.  */
2057
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2058
   MVE_VADD_FP_T2,
2059
   0xee300f40, 0xefb11f70,
2060
   "vadd%v.f%28s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2061
  /* Vector VADD T1.  */
2062
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2063
   MVE_VADD_VEC_T1,
2064
   0xef000840, 0xff811f51,
2065
   "vadd%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2066
  /* Vector VADD T2.  */
2067
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2068
   MVE_VADD_VEC_T2,
2069
   0xee010f40, 0xff811f70,
2070
   "vadd%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2071
2072
  /* Vector VADDLV.  */
2073
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2074
   MVE_VADDLV,
2075
   0xee890f00, 0xef8f1fd1,
2076
   "vaddlv%5A%v.%u32\t%13-15l, %20-22h, %1-3Q"},
2077
2078
  /* Vector VADDV.  */
2079
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2080
   MVE_VADDV,
2081
   0xeef10f00, 0xeff31fd1,
2082
   "vaddv%5A%v.%u%18-19s\t%13-15l, %1-3Q"},
2083
2084
  /* Vector VADC.  */
2085
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2086
   MVE_VADC,
2087
   0xee300f00, 0xffb10f51,
2088
   "vadc%12I%v.i32\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2089
2090
  /* Vector VAND.  */
2091
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2092
   MVE_VAND,
2093
   0xef000150, 0xffb11f51,
2094
   "vand%v\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2095
2096
  /* Vector VBRSR register.  */
2097
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2098
   MVE_VBRSR,
2099
   0xfe011e60, 0xff811f70,
2100
   "vbrsr%v.%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2101
2102
  /* Vector VCADD floating point.  */
2103
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2104
   MVE_VCADD_FP,
2105
   0xfc800840, 0xfea11f51,
2106
   "vcadd%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q, %{I:#%24o%}"},
2107
2108
  /* Vector VCADD.  */
2109
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2110
   MVE_VCADD_VEC,
2111
   0xfe000f00, 0xff810f51,
2112
   "vcadd%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q, %{I:#%12o%}"},
2113
2114
  /* Vector VCLS.  */
2115
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2116
   MVE_VCLS,
2117
   0xffb00440, 0xffb31fd1,
2118
   "vcls%v.s%18-19s\t%13-15,22Q, %1-3,5Q"},
2119
2120
  /* Vector VCLZ.  */
2121
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2122
   MVE_VCLZ,
2123
   0xffb004c0, 0xffb31fd1,
2124
   "vclz%v.i%18-19s\t%13-15,22Q, %1-3,5Q"},
2125
2126
  /* Vector VCMLA.  */
2127
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2128
   MVE_VCMLA_FP,
2129
   0xfc200840, 0xfe211f51,
2130
   "vcmla%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q, %{I:#%23-24o%}"},
2131
2132
  /* Vector VCMP floating point T1.  */
2133
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2134
   MVE_VCMP_FP_T1,
2135
   0xee310f00, 0xeff1ef50,
2136
   "vcmp%v.f%28s\t%n, %17-19Q, %1-3,5Q"},
2137
2138
  /* Vector VCMP floating point T2.  */
2139
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2140
   MVE_VCMP_FP_T2,
2141
   0xee310f40, 0xeff1ef50,
2142
   "vcmp%v.f%28s\t%n, %17-19Q, %0-3Z"},
2143
2144
  /* Vector VCMP T1.  */
2145
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2146
   MVE_VCMP_VEC_T1,
2147
   0xfe010f00, 0xffc1ff51,
2148
   "vcmp%v.i%20-21s\t%n, %17-19Q, %1-3,5Q"},
2149
  /* Vector VCMP T2.  */
2150
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2151
   MVE_VCMP_VEC_T2,
2152
   0xfe010f01, 0xffc1ff51,
2153
   "vcmp%v.u%20-21s\t%n, %17-19Q, %1-3,5Q"},
2154
  /* Vector VCMP T3.  */
2155
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2156
   MVE_VCMP_VEC_T3,
2157
   0xfe011f00, 0xffc1ff50,
2158
   "vcmp%v.s%20-21s\t%n, %17-19Q, %1-3,5Q"},
2159
  /* Vector VCMP T4.  */
2160
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2161
   MVE_VCMP_VEC_T4,
2162
   0xfe010f40, 0xffc1ff70,
2163
   "vcmp%v.i%20-21s\t%n, %17-19Q, %0-3Z"},
2164
  /* Vector VCMP T5.  */
2165
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2166
   MVE_VCMP_VEC_T5,
2167
   0xfe010f60, 0xffc1ff70,
2168
   "vcmp%v.u%20-21s\t%n, %17-19Q, %0-3Z"},
2169
  /* Vector VCMP T6.  */
2170
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2171
   MVE_VCMP_VEC_T6,
2172
   0xfe011f40, 0xffc1ff50,
2173
   "vcmp%v.s%20-21s\t%n, %17-19Q, %0-3Z"},
2174
2175
  /* Vector VDUP.  */
2176
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2177
   MVE_VDUP,
2178
   0xeea00b10, 0xffb10f5f,
2179
   "vdup%v.%5,22s\t%17-19,7Q, %12-15r"},
2180
2181
  /* Vector VEOR.  */
2182
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2183
   MVE_VEOR,
2184
   0xff000150, 0xffd11f51,
2185
   "veor%v\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2186
2187
  /* Vector VFMA, vector * scalar.  */
2188
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2189
   MVE_VFMA_FP_SCALAR,
2190
   0xee310e40, 0xefb11f70,
2191
   "vfma%v.f%28s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2192
2193
  /* Vector VFMA floating point.  */
2194
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2195
   MVE_VFMA_FP,
2196
   0xef000c50, 0xffa11f51,
2197
   "vfma%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2198
2199
  /* Vector VFMS floating point.  */
2200
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2201
   MVE_VFMS_FP,
2202
   0xef200c50, 0xffa11f51,
2203
   "vfms%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2204
2205
  /* Vector VFMAS, vector * scalar.  */
2206
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2207
   MVE_VFMAS_FP_SCALAR,
2208
   0xee311e40, 0xefb11f70,
2209
   "vfmas%v.f%28s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2210
2211
  /* Vector VHADD T1.  */
2212
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2213
   MVE_VHADD_T1,
2214
   0xef000040, 0xef811f51,
2215
   "vhadd%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2216
2217
  /* Vector VHADD T2.  */
2218
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2219
   MVE_VHADD_T2,
2220
   0xee000f40, 0xef811f70,
2221
   "vhadd%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2222
2223
  /* Vector VHSUB T1.  */
2224
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2225
   MVE_VHSUB_T1,
2226
   0xef000240, 0xef811f51,
2227
   "vhsub%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2228
2229
  /* Vector VHSUB T2.  */
2230
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2231
   MVE_VHSUB_T2,
2232
   0xee001f40, 0xef811f70,
2233
   "vhsub%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2234
2235
  /* Vector VCMUL.  */
2236
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2237
   MVE_VCMUL_FP,
2238
   0xee300e00, 0xefb10f50,
2239
   "vcmul%v.f%28s\t%13-15,22Q, %17-19,7Q, %1-3,5Q, %{I:#%0,12o%}"},
2240
2241
   /* Vector VCTP.  */
2242
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2243
   MVE_VCTP,
2244
   0xf000e801, 0xffc0ffff,
2245
   "vctp%v.%20-21s\t%16-19r"},
2246
2247
  /* Vector VDUP.  */
2248
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2249
   MVE_VDUP,
2250
   0xeea00b10, 0xffb10f5f,
2251
   "vdup%v.%5,22s\t%17-19,7Q, %12-15r"},
2252
2253
  /* Vector VRHADD.  */
2254
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2255
   MVE_VRHADD,
2256
   0xef000140, 0xef811f51,
2257
   "vrhadd%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2258
2259
  /* Vector VCVT.  */
2260
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2261
   MVE_VCVT_FP_FIX_VEC,
2262
   0xef800c50, 0xef801cd1,
2263
   "vcvt%v.%s\t%13-15,22Q, %1-3,5Q, %{I:#%16-21k%}"},
2264
2265
  /* Vector VCVT.  */
2266
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2267
   MVE_VCVT_BETWEEN_FP_INT,
2268
   0xffb30640, 0xffb31e51,
2269
   "vcvt%v.%s\t%13-15,22Q, %1-3,5Q"},
2270
2271
  /* Vector VCVT between single and half-precision float, bottom half.  */
2272
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2273
   MVE_VCVT_FP_HALF_FP,
2274
   0xee3f0e01, 0xefbf1fd1,
2275
   "vcvtb%v.%s\t%13-15,22Q, %1-3,5Q"},
2276
2277
  /* Vector VCVT between single and half-precision float, top half.  */
2278
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2279
   MVE_VCVT_FP_HALF_FP,
2280
   0xee3f1e01, 0xefbf1fd1,
2281
   "vcvtt%v.%s\t%13-15,22Q, %1-3,5Q"},
2282
2283
  /* Vector VCVT.  */
2284
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2285
   MVE_VCVT_FROM_FP_TO_INT,
2286
   0xffb30040, 0xffb31c51,
2287
   "vcvt%m%v.%s\t%13-15,22Q, %1-3,5Q"},
2288
2289
  /* Vector VDDUP.  */
2290
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2291
   MVE_VDDUP,
2292
   0xee011f6e, 0xff811f7e,
2293
   "vddup%v.u%20-21s\t%13-15,22Q, %17-19l, %{I:#%0,7u%}"},
2294
2295
  /* Vector VDWDUP.  */
2296
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2297
   MVE_VDWDUP,
2298
   0xee011f60, 0xff811f70,
2299
   "vdwdup%v.u%20-21s\t%13-15,22Q, %17-19l, %1-3h, %{I:#%0,7u%}"},
2300
2301
  /* Vector VHCADD.  */
2302
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2303
   MVE_VHCADD,
2304
   0xee000f00, 0xff810f51,
2305
   "vhcadd%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q, %{I:#%12o%}"},
2306
2307
  /* Vector VIWDUP.  */
2308
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2309
   MVE_VIWDUP,
2310
   0xee010f60, 0xff811f70,
2311
   "viwdup%v.u%20-21s\t%13-15,22Q, %17-19l, %1-3h, %{I:#%0,7u%}"},
2312
2313
  /* Vector VIDUP.  */
2314
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2315
   MVE_VIDUP,
2316
   0xee010f6e, 0xff811f7e,
2317
   "vidup%v.u%20-21s\t%13-15,22Q, %17-19l, %{I:#%0,7u%}"},
2318
2319
  /* Vector VLD2.  */
2320
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2321
   MVE_VLD2,
2322
   0xfc901e00, 0xff901e5f,
2323
   "vld2%5d.%7-8s\t%B, [%16-19r]%w"},
2324
2325
  /* Vector VLD4.  */
2326
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2327
   MVE_VLD4,
2328
   0xfc901e01, 0xff901e1f,
2329
   "vld4%5-6d.%7-8s\t%B, [%16-19r]%w"},
2330
2331
  /* Vector VLDRB gather load.  */
2332
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2333
   MVE_VLDRB_GATHER_T1,
2334
   0xec900e00, 0xefb01e50,
2335
   "vldrb%v.%u%7-8s\t%13-15,22Q, [%16-19r, %1-3,5Q]"},
2336
2337
  /* Vector VLDRH gather load.  */
2338
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2339
   MVE_VLDRH_GATHER_T2,
2340
   0xec900e10, 0xefb01e50,
2341
   "vldrh%v.%u%7-8s\t%13-15,22Q, [%16-19r, %1-3,5Q%o]"},
2342
2343
  /* Vector VLDRW gather load.  */
2344
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2345
   MVE_VLDRW_GATHER_T3,
2346
   0xfc900f40, 0xffb01fd0,
2347
   "vldrw%v.u32\t%13-15,22Q, [%16-19r, %1-3,5Q%o]"},
2348
2349
  /* Vector VLDRD gather load.  */
2350
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2351
   MVE_VLDRD_GATHER_T4,
2352
   0xec900fd0, 0xefb01fd0,
2353
   "vldrd%v.u64\t%13-15,22Q, [%16-19r, %1-3,5Q%o]"},
2354
2355
  /* Vector VLDRW gather load.  */
2356
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2357
   MVE_VLDRW_GATHER_T5,
2358
   0xfd101e00, 0xff111f00,
2359
   "vldrw%v.u32\t%13-15,22Q, [%17-19,7Q, %{I:#%a%0-6i%}]%w"},
2360
2361
  /* Vector VLDRD gather load, variant T6.  */
2362
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2363
   MVE_VLDRD_GATHER_T6,
2364
   0xfd101f00, 0xff111f00,
2365
   "vldrd%v.u64\t%13-15,22Q, [%17-19,7Q, %{I:#%a%0-6i%}]%w"},
2366
2367
  /* Vector VLDRB.  */
2368
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2369
   MVE_VLDRB_T1,
2370
   0xec100e00, 0xee581e00,
2371
   "vldrb%v.%u%7-8s\t%13-15Q, %d"},
2372
2373
  /* Vector VLDRH.  */
2374
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2375
   MVE_VLDRH_T2,
2376
   0xec180e00, 0xee581e00,
2377
   "vldrh%v.%u%7-8s\t%13-15Q, %d"},
2378
2379
  /* Vector VLDRB unsigned, variant T5.  */
2380
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2381
   MVE_VLDRB_T5,
2382
   0xec101e00, 0xfe101f80,
2383
   "vldrb%v.u8\t%13-15,22Q, %d"},
2384
2385
  /* Vector VLDRH unsigned, variant T6.  */
2386
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2387
   MVE_VLDRH_T6,
2388
   0xec101e80, 0xfe101f80,
2389
   "vldrh%v.u16\t%13-15,22Q, %d"},
2390
2391
  /* Vector VLDRW unsigned, variant T7.  */
2392
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2393
   MVE_VLDRW_T7,
2394
   0xec101f00, 0xfe101f80,
2395
   "vldrw%v.u32\t%13-15,22Q, %d"},
2396
2397
  /* Vector VMAX.  */
2398
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2399
   MVE_VMAX,
2400
   0xef000640, 0xef811f51,
2401
   "vmax%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2402
2403
  /* Vector VMAXA.  */
2404
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2405
   MVE_VMAXA,
2406
   0xee330e81, 0xffb31fd1,
2407
   "vmaxa%v.s%18-19s\t%13-15,22Q, %1-3,5Q"},
2408
2409
  /* Vector VMAXNM floating point.  */
2410
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2411
   MVE_VMAXNM_FP,
2412
   0xff000f50, 0xffa11f51,
2413
   "vmaxnm%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2414
2415
  /* Vector VMAXNMA floating point.  */
2416
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2417
   MVE_VMAXNMA_FP,
2418
   0xee3f0e81, 0xefbf1fd1,
2419
   "vmaxnma%v.f%28s\t%13-15,22Q, %1-3,5Q"},
2420
2421
  /* Vector VMAXNMV floating point.  */
2422
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2423
   MVE_VMAXNMV_FP,
2424
   0xeeee0f00, 0xefff0fd1,
2425
   "vmaxnmv%v.f%28s\t%12-15r, %1-3,5Q"},
2426
2427
  /* Vector VMAXNMAV floating point.  */
2428
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2429
   MVE_VMAXNMAV_FP,
2430
   0xeeec0f00, 0xefff0fd1,
2431
   "vmaxnmav%v.f%28s\t%12-15r, %1-3,5Q"},
2432
2433
  /* Vector VMAXV.  */
2434
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2435
   MVE_VMAXV,
2436
   0xeee20f00, 0xeff30fd1,
2437
   "vmaxv%v.%u%18-19s\t%12-15r, %1-3,5Q"},
2438
2439
  /* Vector VMAXAV.  */
2440
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2441
   MVE_VMAXAV,
2442
   0xeee00f00, 0xfff30fd1,
2443
   "vmaxav%v.s%18-19s\t%12-15r, %1-3,5Q"},
2444
2445
  /* Vector VMIN.  */
2446
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2447
   MVE_VMIN,
2448
   0xef000650, 0xef811f51,
2449
   "vmin%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2450
2451
  /* Vector VMINA.  */
2452
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2453
   MVE_VMINA,
2454
   0xee331e81, 0xffb31fd1,
2455
   "vmina%v.s%18-19s\t%13-15,22Q, %1-3,5Q"},
2456
2457
  /* Vector VMINNM floating point.  */
2458
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2459
   MVE_VMINNM_FP,
2460
   0xff200f50, 0xffa11f51,
2461
   "vminnm%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2462
2463
  /* Vector VMINNMA floating point.  */
2464
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2465
   MVE_VMINNMA_FP,
2466
   0xee3f1e81, 0xefbf1fd1,
2467
   "vminnma%v.f%28s\t%13-15,22Q, %1-3,5Q"},
2468
2469
  /* Vector VMINNMV floating point.  */
2470
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2471
   MVE_VMINNMV_FP,
2472
   0xeeee0f80, 0xefff0fd1,
2473
   "vminnmv%v.f%28s\t%12-15r, %1-3,5Q"},
2474
2475
  /* Vector VMINNMAV floating point.  */
2476
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2477
   MVE_VMINNMAV_FP,
2478
   0xeeec0f80, 0xefff0fd1,
2479
   "vminnmav%v.f%28s\t%12-15r, %1-3,5Q"},
2480
2481
  /* Vector VMINV.  */
2482
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2483
   MVE_VMINV,
2484
   0xeee20f80, 0xeff30fd1,
2485
   "vminv%v.%u%18-19s\t%12-15r, %1-3,5Q"},
2486
2487
  /* Vector VMINAV.  */
2488
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2489
   MVE_VMINAV,
2490
   0xeee00f80, 0xfff30fd1,
2491
   "vminav%v.s%18-19s\t%12-15r, %1-3,5Q"},
2492
2493
  /* Vector VMLA.  */
2494
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2495
   MVE_VMLA,
2496
   0xee010e40, 0xef811f70,
2497
   "vmla%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2498
2499
  /* Vector VMLALDAV.  Note must appear before VMLADAV due to instruction
2500
     opcode aliasing.  */
2501
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2502
   MVE_VMLALDAV,
2503
   0xee801e00, 0xef801f51,
2504
   "vmlaldav%5Ax%v.%u%16s\t%13-15l, %20-22h, %17-19,7Q, %1-3Q"},
2505
2506
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2507
   MVE_VMLALDAV,
2508
   0xee800e00, 0xef801f51,
2509
   "vmlalv%5A%v.%u%16s\t%13-15l, %20-22h, %17-19,7Q, %1-3Q"},
2510
2511
  /* Vector VMLAV T1 variant, same as VMLADAV but with X == 0.  */
2512
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2513
   MVE_VMLADAV_T1,
2514
   0xeef00e00, 0xeff01f51,
2515
   "vmlav%5A%v.%u%16s\t%13-15l, %17-19,7Q, %1-3Q"},
2516
2517
  /* Vector VMLAV T2 variant, same as VMLADAV but with X == 0.  */
2518
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2519
   MVE_VMLADAV_T2,
2520
   0xeef00f00, 0xeff11f51,
2521
   "vmlav%5A%v.%u8\t%13-15l, %17-19,7Q, %1-3Q"},
2522
2523
  /* Vector VMLADAV T1 variant.  */
2524
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2525
   MVE_VMLADAV_T1,
2526
   0xeef01e00, 0xeff01f51,
2527
   "vmladav%5Ax%v.%u%16s\t%13-15l, %17-19,7Q, %1-3Q"},
2528
2529
  /* Vector VMLADAV T2 variant.  */
2530
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2531
   MVE_VMLADAV_T2,
2532
   0xeef01f00, 0xeff11f51,
2533
   "vmladav%5Ax%v.%u8\t%13-15l, %17-19,7Q, %1-3Q"},
2534
2535
  /* Vector VMLAS.  */
2536
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2537
   MVE_VMLAS,
2538
   0xee011e40, 0xef811f70,
2539
   "vmlas%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2540
2541
  /* Vector VRMLSLDAVH.  Note must appear before VMLSDAV due to instruction
2542
     opcode aliasing.  */
2543
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2544
   MVE_VRMLSLDAVH,
2545
   0xfe800e01, 0xff810f51,
2546
   "vrmlsldavh%5A%X%v.s32\t%13-15l, %20-22h, %17-19,7Q, %1-3Q"},
2547
2548
  /* Vector VMLSLDAV.  Note must appear before VMLSDAV due to instruction
2549
     opcdoe aliasing.  */
2550
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2551
   MVE_VMLSLDAV,
2552
   0xee800e01, 0xff800f51,
2553
   "vmlsldav%5A%X%v.%u%16s\t%13-15l, %20-22h, %17-19,7Q, %1-3Q"},
2554
2555
  /* Vector VMLSDAV T1 Variant.  */
2556
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2557
   MVE_VMLSDAV_T1,
2558
   0xeef00e01, 0xfff00f51,
2559
   "vmlsdav%5A%X%v.s%16s\t%13-15l, %17-19,7Q, %1-3Q"},
2560
2561
  /* Vector VMLSDAV T2 Variant.  */
2562
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2563
   MVE_VMLSDAV_T2,
2564
   0xfef00e01, 0xfff10f51,
2565
   "vmlsdav%5A%X%v.s8\t%13-15l, %17-19,7Q, %1-3Q"},
2566
2567
  /* Vector VMOV between gpr and half precision register, op == 0.  */
2568
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2569
   MVE_VMOV_HFP_TO_GP,
2570
   0xee000910, 0xfff00f7f,
2571
   "vmov.f16\t%7,16-19F, %12-15r"},
2572
2573
  /* Vector VMOV between gpr and half precision register, op == 1.  */
2574
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2575
   MVE_VMOV_HFP_TO_GP,
2576
   0xee100910, 0xfff00f7f,
2577
   "vmov.f16\t%12-15r, %7,16-19F"},
2578
2579
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2580
   MVE_VMOV_GP_TO_VEC_LANE,
2581
   0xee000b10, 0xff900f1f,
2582
   "vmov%c.%5-6,21-22s\t%{R:%17-19,7Q[%N]%}, %12-15r"},
2583
2584
  /* Vector VORR immediate to vector.
2585
     NOTE: MVE_VORR_IMM must appear in the table
2586
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2587
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2588
   MVE_VORR_IMM,
2589
   0xef800050, 0xefb810f0,
2590
   "vorr%v.i%8-11s\t%13-15,22Q, %E"},
2591
2592
  /* Vector VQSHL T2 Variant.
2593
     NOTE: MVE_VQSHL_T2 must appear in the table before
2594
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2595
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2596
   MVE_VQSHL_T2,
2597
   0xef800750, 0xef801fd1,
2598
   "vqshl%v.%u%19-21s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2599
2600
  /* Vector VQSHLU T3 Variant
2601
     NOTE: MVE_VQSHL_T2 must appear in the table before
2602
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2603
2604
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2605
   MVE_VQSHLU_T3,
2606
   0xff800650, 0xff801fd1,
2607
   "vqshlu%v.s%19-21s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2608
2609
  /* Vector VRSHR
2610
     NOTE: MVE_VRSHR must appear in the table before
2611
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2612
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2613
   MVE_VRSHR,
2614
   0xef800250, 0xef801fd1,
2615
   "vrshr%v.%u%19-21s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2616
2617
  /* Vector VSHL.
2618
     NOTE: MVE_VSHL must appear in the table before
2619
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2620
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2621
   MVE_VSHL_T1,
2622
   0xef800550, 0xff801fd1,
2623
   "vshl%v.i%19-21s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2624
2625
  /* Vector VSHR
2626
     NOTE: MVE_VSHR must appear in the table before
2627
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2628
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2629
   MVE_VSHR,
2630
   0xef800050, 0xef801fd1,
2631
   "vshr%v.%u%19-21s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2632
2633
  /* Vector VSLI
2634
     NOTE: MVE_VSLI must appear in the table before
2635
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2636
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2637
   MVE_VSLI,
2638
   0xff800550, 0xff801fd1,
2639
   "vsli%v.%19-21s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2640
2641
  /* Vector VSRI
2642
     NOTE: MVE_VSRI must appear in the table before
2643
     before MVE_VMOV_IMM_TO_VEC due to opcode aliasing.  */
2644
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2645
   MVE_VSRI,
2646
   0xff800450, 0xff801fd1,
2647
   "vsri%v.%19-21s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2648
2649
  /* Vector VMOV immediate to vector,
2650
     undefinded for cmode == 1111 */
2651
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2652
   MVE_VMVN_IMM, 0xef800f70, 0xefb81ff0, UNDEFINED_INSTRUCTION},
2653
2654
  /* Vector VMOV immediate to vector,
2655
     cmode == 1101 */
2656
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2657
   MVE_VMOV_IMM_TO_VEC, 0xef800d50, 0xefb81fd0,
2658
   "vmov%v.%5,8-11s\t%13-15,22Q, %E"},
2659
2660
  /* Vector VMOV immediate to vector.  */
2661
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2662
   MVE_VMOV_IMM_TO_VEC,
2663
   0xef800050, 0xefb810d0,
2664
   "vmov%v.%5,8-11s\t%13-15,22Q, %E"},
2665
2666
  /* Vector VMOV two 32-bit lanes to two gprs, idx = 0.  */
2667
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2668
   MVE_VMOV2_VEC_LANE_TO_GP,
2669
   0xec000f00, 0xffb01ff0,
2670
   "vmov%c\t%0-3r, %16-19r, %{R:%13-15,22Q[2]%}, %{R:%13-15,22Q[0]%}"},
2671
2672
  /* Vector VMOV two 32-bit lanes to two gprs, idx = 1.  */
2673
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2674
   MVE_VMOV2_VEC_LANE_TO_GP,
2675
   0xec000f10, 0xffb01ff0,
2676
   "vmov%c\t%0-3r, %16-19r, %{R:%13-15,22Q[3]%}, %{R:%13-15,22Q[1]%}"},
2677
2678
  /* Vector VMOV Two gprs to two 32-bit lanes, idx = 0.  */
2679
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2680
   MVE_VMOV2_GP_TO_VEC_LANE,
2681
   0xec100f00, 0xffb01ff0,
2682
   "vmov%c\t%{R:%13-15,22Q[2]%}, %{R:%13-15,22Q[0]%}, %0-3r, %16-19r"},
2683
2684
  /* Vector VMOV Two gprs to two 32-bit lanes, idx = 1.  */
2685
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2686
   MVE_VMOV2_GP_TO_VEC_LANE,
2687
   0xec100f10, 0xffb01ff0,
2688
   "vmov%c\t%{R:%13-15,22Q[3]%}, %{R:%13-15,22Q[1]%}, %0-3r, %16-19r"},
2689
2690
  /* Vector VMOV Vector lane to gpr.  */
2691
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2692
   MVE_VMOV_VEC_LANE_TO_GP,
2693
   0xee100b10, 0xff100f1f,
2694
   "vmov%c.%u%5-6,21-22s\t%12-15r, %{R:%17-19,7Q[%N]%}"},
2695
2696
  /* Vector VSHLL T1 Variant.  Note: VSHLL T1 must appear before MVE_VMOVL due
2697
     to instruction opcode aliasing.  */
2698
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2699
   MVE_VSHLL_T1,
2700
   0xeea00f40, 0xefa00fd1,
2701
   "vshll%T%v.%u%19-20s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2702
2703
  /* Vector VMOVL long.  */
2704
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2705
   MVE_VMOVL,
2706
   0xeea00f40, 0xefa70fd1,
2707
   "vmovl%T%v.%u%19-20s\t%13-15,22Q, %1-3,5Q"},
2708
2709
  /* Vector VMOV and narrow.  */
2710
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2711
   MVE_VMOVN,
2712
   0xfe310e81, 0xffb30fd1,
2713
   "vmovn%T%v.i%18-19s\t%13-15,22Q, %1-3,5Q"},
2714
2715
  /* Floating point move extract.  */
2716
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2717
   MVE_VMOVX,
2718
   0xfeb00a40, 0xffbf0fd0,
2719
   "vmovx.f16\t%22,12-15F, %5,0-3F"},
2720
2721
  /* Vector VMUL floating-point T1 variant.  */
2722
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2723
   MVE_VMUL_FP_T1,
2724
   0xff000d50, 0xffa11f51,
2725
   "vmul%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2726
2727
  /* Vector VMUL floating-point T2 variant.  */
2728
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2729
   MVE_VMUL_FP_T2,
2730
   0xee310e60, 0xefb11f70,
2731
   "vmul%v.f%28s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2732
2733
  /* Vector VMUL T1 variant.  */
2734
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2735
   MVE_VMUL_VEC_T1,
2736
   0xef000950, 0xff811f51,
2737
   "vmul%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2738
2739
  /* Vector VMUL T2 variant.  */
2740
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2741
   MVE_VMUL_VEC_T2,
2742
   0xee011e60, 0xff811f70,
2743
   "vmul%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2744
2745
  /* Vector VMULH.  */
2746
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2747
   MVE_VMULH,
2748
   0xee010e01, 0xef811f51,
2749
   "vmulh%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2750
2751
  /* Vector VRMULH.  */
2752
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2753
   MVE_VRMULH,
2754
   0xee011e01, 0xef811f51,
2755
   "vrmulh%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2756
2757
  /* Vector VMULL integer.  */
2758
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2759
   MVE_VMULL_INT,
2760
   0xee010e00, 0xef810f51,
2761
   "vmull%T%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2762
2763
  /* Vector VMULL polynomial.  */
2764
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2765
   MVE_VMULL_POLY,
2766
   0xee310e00, 0xefb10f51,
2767
   "vmull%T%v.%28s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2768
2769
  /* Vector VMVN immediate to vector.  */
2770
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2771
   MVE_VMVN_IMM,
2772
   0xef800070, 0xefb810f0,
2773
   "vmvn%v.i%8-11s\t%13-15,22Q, %E"},
2774
2775
  /* Vector VMVN register.  */
2776
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2777
   MVE_VMVN_REG,
2778
   0xffb005c0, 0xffbf1fd1,
2779
   "vmvn%v\t%13-15,22Q, %1-3,5Q"},
2780
2781
  /* Vector VNEG floating point.  */
2782
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
2783
   MVE_VNEG_FP,
2784
   0xffb107c0, 0xffb31fd1,
2785
   "vneg%v.f%18-19s\t%13-15,22Q, %1-3,5Q"},
2786
2787
  /* Vector VNEG.  */
2788
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2789
   MVE_VNEG_VEC,
2790
   0xffb103c0, 0xffb31fd1,
2791
   "vneg%v.s%18-19s\t%13-15,22Q, %1-3,5Q"},
2792
2793
  /* Vector VORN, vector bitwise or not.  */
2794
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2795
   MVE_VORN,
2796
   0xef300150, 0xffb11f51,
2797
   "vorn%v\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2798
2799
  /* Vector VORR register.  */
2800
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2801
   MVE_VORR_REG,
2802
   0xef200150, 0xffb11f51,
2803
   "vorr%v\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2804
2805
  /* Vector VMOV, vector to vector move. While decoding MVE_VORR_REG if
2806
     "Qm==Qn", VORR should replaced by its alias VMOV. For that to happen
2807
     MVE_VMOV_VEC_TO_VEC need to placed after MVE_VORR_REG in this mve_opcodes
2808
     array.  */
2809
2810
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2811
   MVE_VMOV_VEC_TO_VEC,
2812
   0xef200150, 0xffb11f51,
2813
   "vmov%v\t%13-15,22Q, %17-19,7Q"},
2814
2815
  /* Vector VQDMULL T1 variant.  */
2816
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2817
   MVE_VQDMULL_T1,
2818
   0xee300f01, 0xefb10f51,
2819
   "vqdmull%T%v.s%28s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2820
2821
  /* Vector VPNOT.  */
2822
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2823
   MVE_VPNOT,
2824
   0xfe310f4d, 0xffffffff,
2825
   "vpnot%v"},
2826
2827
  /* Vector VPSEL.  */
2828
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2829
   MVE_VPSEL,
2830
   0xfe310f01, 0xffb11f51,
2831
   "vpsel%v\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2832
2833
  /* Vector VQABS.  */
2834
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2835
   MVE_VQABS,
2836
   0xffb00740, 0xffb31fd1,
2837
   "vqabs%v.s%18-19s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2838
2839
  /* Vector VQADD T1 variant.  */
2840
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2841
   MVE_VQADD_T1,
2842
   0xef000050, 0xef811f51,
2843
   "vqadd%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2844
2845
  /* Vector VQADD T2 variant.  */
2846
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2847
   MVE_VQADD_T2,
2848
   0xee000f60, 0xef811f70,
2849
   "vqadd%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2850
2851
  /* Vector VQDMULL T2 variant.  */
2852
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2853
   MVE_VQDMULL_T2,
2854
   0xee300f60, 0xefb10f70,
2855
   "vqdmull%T%v.s%28s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2856
2857
  /* Vector VQMOVN.  */
2858
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2859
   MVE_VQMOVN,
2860
   0xee330e01, 0xefb30fd1,
2861
   "vqmovn%T%v.%u%18-19s\t%13-15,22Q, %1-3,5Q"},
2862
2863
  /* Vector VQMOVUN.  */
2864
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2865
   MVE_VQMOVUN,
2866
   0xee310e81, 0xffb30fd1,
2867
   "vqmovun%T%v.s%18-19s\t%13-15,22Q, %1-3,5Q"},
2868
2869
  /* Vector VQDMLADH.  */
2870
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2871
   MVE_VQDMLADH,
2872
   0xee000e00, 0xff810f51,
2873
   "vqdmladh%X%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2874
2875
  /* Vector VQRDMLADH.  */
2876
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2877
   MVE_VQRDMLADH,
2878
   0xee000e01, 0xff810f51,
2879
   "vqrdmladh%X%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2880
2881
  /* Vector VQDMLAH.  */
2882
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2883
   MVE_VQDMLAH,
2884
   0xee000e60, 0xff811f70,
2885
   "vqdmlah%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2886
2887
  /* Vector VQRDMLAH.  */
2888
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2889
   MVE_VQRDMLAH,
2890
   0xee000e40, 0xff811f70,
2891
   "vqrdmlah%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2892
2893
  /* Vector VQDMLASH.  */
2894
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2895
   MVE_VQDMLASH,
2896
   0xee001e60, 0xff811f70,
2897
   "vqdmlash%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2898
2899
  /* Vector VQRDMLASH.  */
2900
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2901
   MVE_VQRDMLASH,
2902
   0xee001e40, 0xff811f70,
2903
   "vqrdmlash%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2904
2905
  /* Vector VQDMLSDH.  */
2906
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2907
   MVE_VQDMLSDH,
2908
   0xfe000e00, 0xff810f51,
2909
   "vqdmlsdh%X%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2910
2911
  /* Vector VQRDMLSDH.  */
2912
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2913
   MVE_VQRDMLSDH,
2914
   0xfe000e01, 0xff810f51,
2915
   "vqrdmlsdh%X%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2916
2917
  /* Vector VQDMULH T1 variant.  */
2918
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2919
   MVE_VQDMULH_T1,
2920
   0xef000b40, 0xff811f51,
2921
   "vqdmulh%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2922
2923
  /* Vector VQRDMULH T2 variant.  */
2924
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2925
   MVE_VQRDMULH_T2,
2926
   0xff000b40, 0xff811f51,
2927
   "vqrdmulh%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
2928
2929
  /* Vector VQDMULH T3 variant.  */
2930
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2931
   MVE_VQDMULH_T3,
2932
   0xee010e60, 0xff811f70,
2933
   "vqdmulh%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2934
2935
  /* Vector VQRDMULH T4 variant.  */
2936
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2937
   MVE_VQRDMULH_T4,
2938
   0xfe010e60, 0xff811f70,
2939
   "vqrdmulh%v.s%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
2940
2941
  /* Vector VQNEG.  */
2942
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2943
   MVE_VQNEG,
2944
   0xffb007c0, 0xffb31fd1,
2945
   "vqneg%v.s%18-19s\t%13-15,22Q, %1-3,5Q"},
2946
2947
  /* Vector VQRSHL T1 variant.  */
2948
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2949
   MVE_VQRSHL_T1,
2950
   0xef000550, 0xef811f51,
2951
   "vqrshl%v.%u%20-21s\t%13-15,22Q, %1-3,5Q, %17-19,7Q"},
2952
2953
  /* Vector VQRSHL T2 variant.  */
2954
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2955
   MVE_VQRSHL_T2,
2956
   0xee331ee0, 0xefb31ff0,
2957
   "vqrshl%v.%u%18-19s\t%13-15,22Q, %0-3r"},
2958
2959
  /* Vector VQRSHRN.  */
2960
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2961
   MVE_VQRSHRN,
2962
   0xee800f41, 0xefa00fd1,
2963
   "vqrshrn%T%v.%u%19-20s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2964
2965
  /* Vector VQRSHRUN.  */
2966
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2967
   MVE_VQRSHRUN,
2968
   0xfe800fc0, 0xffa00fd1,
2969
   "vqrshrun%T%v.s%19-20s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2970
2971
  /* Vector VQSHL T1 Variant.  */
2972
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2973
   MVE_VQSHL_T1,
2974
   0xee311ee0, 0xefb31ff0,
2975
   "vqshl%v.%u%18-19s\t%13-15,22Q, %0-3r"},
2976
2977
  /* Vector VQSHL T4 Variant.  */
2978
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2979
   MVE_VQSHL_T4,
2980
   0xef000450, 0xef811f51,
2981
   "vqshl%v.%u%20-21s\t%13-15,22Q, %1-3,5Q, %17-19,7Q"},
2982
2983
  /* Vector VQSHRN.  */
2984
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2985
   MVE_VQSHRN,
2986
   0xee800f40, 0xefa00fd1,
2987
   "vqshrn%T%v.%u%19-20s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2988
2989
  /* Vector VQSHRUN.  */
2990
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2991
   MVE_VQSHRUN,
2992
   0xee800fc0, 0xffa00fd1,
2993
   "vqshrun%T%v.s%19-20s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
2994
2995
  /* Vector VQSUB T1 Variant.  */
2996
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
2997
   MVE_VQSUB_T1,
2998
   0xef000250, 0xef811f51,
2999
   "vqsub%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
3000
3001
  /* Vector VQSUB T2 Variant.  */
3002
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3003
   MVE_VQSUB_T2,
3004
   0xee001f60, 0xef811f70,
3005
   "vqsub%v.%u%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
3006
3007
  /* Vector VREV16.  */
3008
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3009
   MVE_VREV16,
3010
   0xffb00140, 0xffb31fd1,
3011
   "vrev16%v.8\t%13-15,22Q, %1-3,5Q"},
3012
3013
  /* Vector VREV32.  */
3014
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3015
   MVE_VREV32,
3016
   0xffb000c0, 0xffb31fd1,
3017
   "vrev32%v.%18-19s\t%13-15,22Q, %1-3,5Q"},
3018
3019
  /* Vector VREV64.  */
3020
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3021
   MVE_VREV64,
3022
   0xffb00040, 0xffb31fd1,
3023
   "vrev64%v.%18-19s\t%13-15,22Q, %1-3,5Q"},
3024
3025
  /* Vector VRINT floating point.  */
3026
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
3027
   MVE_VRINT_FP,
3028
   0xffb20440, 0xffb31c51,
3029
   "vrint%m%v.f%18-19s\t%13-15,22Q, %1-3,5Q"},
3030
3031
  /* Vector VRMLALDAVH.  */
3032
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3033
   MVE_VRMLALDAVH,
3034
   0xee800f00, 0xef811f51,
3035
   "vrmlalvh%5A%v.%u32\t%13-15l, %20-22h, %17-19,7Q, %1-3Q"},
3036
3037
  /* Vector VRMLALDAVH.  */
3038
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3039
   MVE_VRMLALDAVH,
3040
   0xee801f00, 0xef811f51,
3041
   "vrmlaldavh%5Ax%v.%u32\t%13-15l, %20-22h, %17-19,7Q, %1-3Q"},
3042
3043
  /* Vector VRSHL T1 Variant.  */
3044
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3045
   MVE_VRSHL_T1,
3046
   0xef000540, 0xef811f51,
3047
   "vrshl%v.%u%20-21s\t%13-15,22Q, %1-3,5Q, %17-19,7Q"},
3048
3049
  /* Vector VRSHL T2 Variant.  */
3050
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3051
   MVE_VRSHL_T2,
3052
   0xee331e60, 0xefb31ff0,
3053
   "vrshl%v.%u%18-19s\t%13-15,22Q, %0-3r"},
3054
3055
  /* Vector VRSHRN.  */
3056
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3057
   MVE_VRSHRN,
3058
   0xfe800fc1, 0xffa00fd1,
3059
   "vrshrn%T%v.i%19-20s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
3060
3061
  /* Vector VSBC.  */
3062
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3063
   MVE_VSBC,
3064
   0xfe300f00, 0xffb10f51,
3065
   "vsbc%12I%v.i32\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
3066
3067
  /* Vector VSHL T2 Variant.  */
3068
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3069
   MVE_VSHL_T2,
3070
   0xee311e60, 0xefb31ff0,
3071
   "vshl%v.%u%18-19s\t%13-15,22Q, %0-3r"},
3072
3073
  /* Vector VSHL T3 Variant.  */
3074
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3075
   MVE_VSHL_T3,
3076
   0xef000440, 0xef811f51,
3077
   "vshl%v.%u%20-21s\t%13-15,22Q, %1-3,5Q, %17-19,7Q"},
3078
3079
  /* Vector VSHLC.  */
3080
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3081
   MVE_VSHLC,
3082
   0xeea00fc0, 0xffa01ff0,
3083
   "vshlc%v\t%13-15,22Q, %0-3r, %{I:#%16-20d%}"},
3084
3085
  /* Vector VSHLL T2 Variant.  */
3086
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3087
   MVE_VSHLL_T2,
3088
   0xee310e01, 0xefb30fd1,
3089
   "vshll%T%v.%u%18-19s\t%13-15,22Q, %1-3,5Q, %{I:#%18-19d%}"},
3090
3091
  /* Vector VSHRN.  */
3092
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3093
   MVE_VSHRN,
3094
   0xee800fc1, 0xffa00fd1,
3095
   "vshrn%T%v.i%19-20s\t%13-15,22Q, %1-3,5Q, %{I:#%16-18d%}"},
3096
3097
  /* Vector VST2 no writeback.  */
3098
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3099
   MVE_VST2,
3100
   0xfc801e00, 0xffb01e5f,
3101
   "vst2%5d.%7-8s\t%B, [%16-19r]"},
3102
3103
  /* Vector VST2 writeback.  */
3104
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3105
   MVE_VST2,
3106
   0xfca01e00, 0xffb01e5f,
3107
   "vst2%5d.%7-8s\t%B, [%16-19r]!"},
3108
3109
  /* Vector VST4 no writeback.  */
3110
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3111
   MVE_VST4,
3112
   0xfc801e01, 0xffb01e1f,
3113
   "vst4%5-6d.%7-8s\t%B, [%16-19r]"},
3114
3115
  /* Vector VST4 writeback.  */
3116
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3117
   MVE_VST4,
3118
   0xfca01e01, 0xffb01e1f,
3119
   "vst4%5-6d.%7-8s\t%B, [%16-19r]!"},
3120
3121
  /* Vector VSTRB scatter store, T1 variant.  */
3122
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3123
   MVE_VSTRB_SCATTER_T1,
3124
   0xec800e00, 0xffb01e50,
3125
   "vstrb%v.%7-8s\t%13-15,22Q, [%16-19r, %1-3,5Q]"},
3126
3127
  /* Vector VSTRH scatter store, T2 variant.  */
3128
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3129
   MVE_VSTRH_SCATTER_T2,
3130
   0xec800e10, 0xffb01e50,
3131
   "vstrh%v.%7-8s\t%13-15,22Q, [%16-19r, %1-3,5Q%o]"},
3132
3133
  /* Vector VSTRW scatter store, T3 variant.  */
3134
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3135
   MVE_VSTRW_SCATTER_T3,
3136
   0xec800e40, 0xffb01e50,
3137
   "vstrw%v.%7-8s\t%13-15,22Q, [%16-19r, %1-3,5Q%o]"},
3138
3139
  /* Vector VSTRD scatter store, T4 variant.  */
3140
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3141
   MVE_VSTRD_SCATTER_T4,
3142
   0xec800fd0, 0xffb01fd0,
3143
   "vstrd%v.64\t%13-15,22Q, [%16-19r, %1-3,5Q%o]"},
3144
3145
  /* Vector VSTRW scatter store, T5 variant.  */
3146
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3147
   MVE_VSTRW_SCATTER_T5,
3148
   0xfd001e00, 0xff111f00,
3149
   "vstrw%v.32\t%13-15,22Q, [%17-19,7Q, %{I:#%a%0-6i%}]%w"},
3150
3151
  /* Vector VSTRD scatter store, T6 variant.  */
3152
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3153
   MVE_VSTRD_SCATTER_T6,
3154
   0xfd001f00, 0xff111f00,
3155
   "vstrd%v.64\t%13-15,22Q, [%17-19,7Q, %{I:#%a%0-6i%}]%w"},
3156
3157
  /* Vector VSTRB.  */
3158
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3159
   MVE_VSTRB_T1,
3160
   0xec000e00, 0xfe581e00,
3161
   "vstrb%v.%7-8s\t%13-15Q, %d"},
3162
3163
  /* Vector VSTRH.  */
3164
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3165
   MVE_VSTRH_T2,
3166
   0xec080e00, 0xfe581e00,
3167
   "vstrh%v.%7-8s\t%13-15Q, %d"},
3168
3169
  /* Vector VSTRB variant T5.  */
3170
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3171
   MVE_VSTRB_T5,
3172
   0xec001e00, 0xfe101f80,
3173
   "vstrb%v.8\t%13-15,22Q, %d"},
3174
3175
  /* Vector VSTRH variant T6.  */
3176
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3177
   MVE_VSTRH_T6,
3178
   0xec001e80, 0xfe101f80,
3179
   "vstrh%v.16\t%13-15,22Q, %d"},
3180
3181
  /* Vector VSTRW variant T7.  */
3182
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3183
   MVE_VSTRW_T7,
3184
   0xec001f00, 0xfe101f80,
3185
   "vstrw%v.32\t%13-15,22Q, %d"},
3186
3187
  /* Vector VSUB floating point T1 variant.  */
3188
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
3189
   MVE_VSUB_FP_T1,
3190
   0xef200d40, 0xffa11f51,
3191
   "vsub%v.f%20s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
3192
3193
  /* Vector VSUB floating point T2 variant.  */
3194
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE_FP),
3195
   MVE_VSUB_FP_T2,
3196
   0xee301f40, 0xefb11f70,
3197
   "vsub%v.f%28s\t%13-15,22Q, %17-19,7Q, %0-3r"},
3198
3199
  /* Vector VSUB T1 variant.  */
3200
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3201
   MVE_VSUB_VEC_T1,
3202
   0xff000840, 0xff811f51,
3203
   "vsub%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %1-3,5Q"},
3204
3205
  /* Vector VSUB T2 variant.  */
3206
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3207
   MVE_VSUB_VEC_T2,
3208
   0xee011f40, 0xff811f70,
3209
   "vsub%v.i%20-21s\t%13-15,22Q, %17-19,7Q, %0-3r"},
3210
3211
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3212
   MVE_ASRLI,
3213
   0xea50012f, 0xfff1813f,
3214
   "asrl%c\t%17-19l, %9-11h, %j"},
3215
3216
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3217
   MVE_ASRL,
3218
   0xea50012d, 0xfff101ff,
3219
   "asrl%c\t%17-19l, %9-11h, %12-15S"},
3220
3221
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3222
   MVE_LSLLI,
3223
   0xea50010f, 0xfff1813f,
3224
   "lsll%c\t%17-19l, %9-11h, %j"},
3225
3226
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3227
   MVE_LSLL,
3228
   0xea50010d, 0xfff101ff,
3229
   "lsll%c\t%17-19l, %9-11h, %12-15S"},
3230
3231
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3232
   MVE_LSRL,
3233
   0xea50011f, 0xfff1813f,
3234
   "lsrl%c\t%17-19l, %9-11h, %j"},
3235
3236
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3237
   MVE_SQRSHRL,
3238
   0xea51012d, 0xfff1017f,
3239
   "sqrshrl%c\t%17-19l, %9-11h, %k, %12-15S"},
3240
3241
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3242
   MVE_SQRSHR,
3243
   0xea500f2d, 0xfff00fff,
3244
   "sqrshr%c\t%16-19S, %12-15S"},
3245
3246
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3247
   MVE_SQSHLL,
3248
   0xea51013f, 0xfff1813f,
3249
   "sqshll%c\t%17-19l, %9-11h, %j"},
3250
3251
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3252
   MVE_SQSHL,
3253
   0xea500f3f, 0xfff08f3f,
3254
   "sqshl%c\t%16-19S, %j"},
3255
3256
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3257
   MVE_SRSHRL,
3258
   0xea51012f, 0xfff1813f,
3259
   "srshrl%c\t%17-19l, %9-11h, %j"},
3260
3261
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3262
   MVE_SRSHR,
3263
   0xea500f2f, 0xfff08f3f,
3264
   "srshr%c\t%16-19S, %j"},
3265
3266
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3267
   MVE_UQRSHLL,
3268
   0xea51010d, 0xfff1017f,
3269
   "uqrshll%c\t%17-19l, %9-11h, %k, %12-15S"},
3270
3271
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3272
   MVE_UQRSHL,
3273
   0xea500f0d, 0xfff00fff,
3274
   "uqrshl%c\t%16-19S, %12-15S"},
3275
3276
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3277
   MVE_UQSHLL,
3278
    0xea51010f, 0xfff1813f,
3279
   "uqshll%c\t%17-19l, %9-11h, %j"},
3280
3281
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3282
   MVE_UQSHL,
3283
   0xea500f0f, 0xfff08f3f,
3284
   "uqshl%c\t%16-19S, %j"},
3285
3286
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3287
   MVE_URSHRL,
3288
    0xea51011f, 0xfff1813f,
3289
   "urshrl%c\t%17-19l, %9-11h, %j"},
3290
3291
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE),
3292
   MVE_URSHR,
3293
   0xea500f1f, 0xfff08f3f,
3294
   "urshr%c\t%16-19S, %j"},
3295
3296
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3297
   MVE_CSINC,
3298
   0xea509000, 0xfff0f000,
3299
   "csinc\t%8-11S, %16-19Z, %0-3Z, %4-7c"},
3300
3301
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3302
   MVE_CSINV,
3303
   0xea50a000, 0xfff0f000,
3304
   "csinv\t%8-11S, %16-19Z, %0-3Z, %4-7c"},
3305
3306
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3307
   MVE_CSET,
3308
   0xea5f900f, 0xfffff00f,
3309
   "cset\t%8-11S, %4-7C"},
3310
3311
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3312
   MVE_CSETM,
3313
   0xea5fa00f, 0xfffff00f,
3314
   "csetm\t%8-11S, %4-7C"},
3315
3316
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3317
   MVE_CSEL,
3318
   0xea508000, 0xfff0f000,
3319
   "csel\t%8-11S, %16-19Z, %0-3Z, %4-7c"},
3320
3321
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3322
   MVE_CSNEG,
3323
   0xea50b000, 0xfff0f000,
3324
   "csneg\t%8-11S, %16-19Z, %0-3Z, %4-7c"},
3325
3326
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3327
   MVE_CINC,
3328
   0xea509000, 0xfff0f000,
3329
   "cinc\t%8-11S, %16-19Z, %4-7C"},
3330
3331
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3332
   MVE_CINV,
3333
   0xea50a000, 0xfff0f000,
3334
   "cinv\t%8-11S, %16-19Z, %4-7C"},
3335
3336
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
3337
   MVE_CNEG,
3338
   0xea50b000, 0xfff0f000,
3339
   "cneg\t%8-11S, %16-19Z, %4-7C"},
3340
3341
  {ARM_FEATURE_CORE_LOW (0),
3342
   MVE_NONE,
3343
   0x00000000, 0x00000000, 0}
3344
};
3345
3346
/* Opcode tables: ARM, 16-bit Thumb, 32-bit Thumb.  All three are partially
3347
   ordered: they must be searched linearly from the top to obtain a correct
3348
   match.  */
3349
3350
/* print_insn_arm recognizes the following format control codes:
3351
3352
   %%     %
3353
3354
   %a     print address for ldr/str instruction
3355
   %s                   print address for ldr/str halfword/signextend instruction
3356
   %S                   like %s but allow UNPREDICTABLE addressing
3357
   %b     print branch destination
3358
   %c     print condition code (always bits 28-31)
3359
   %m     print register mask for ldm/stm instruction
3360
   %o     print operand2 (immediate or register + shift)
3361
   %p     print 'p' iff bits 12-15 are 15
3362
   %O     print 'OBSOLETE' iff bits 12-15 are 15
3363
   %t     print 't' iff bit 21 set and bit 24 clear
3364
   %B     print arm BLX(1) destination
3365
   %C     print the PSR sub type.
3366
   %U     print barrier type.
3367
   %P     print address for pli instruction.
3368
   %T     print 'from Armv4T onwards'
3369
3370
   %<bitfield>r   print as an ARM register
3371
   %<bitfield>T   print as an ARM register + 1
3372
   %<bitfield>R   as %r but r15 is UNPREDICTABLE
3373
   %<bitfield>{r|R}u    as %{r|R} but if matches the other %u field then is UNPREDICTABLE
3374
   %<bitfield>{r|R}U    as %{r|R} but if matches the other %U field then is UNPREDICTABLE
3375
   %<bitfield>d   print the bitfield in decimal
3376
   %<bitfield>W         print the bitfield plus one in decimal
3377
   %<bitfield>x   print the bitfield in hex
3378
   %<bitfield>X   print the bitfield as 1 hex digit without leading "0x"
3379
3380
   %<bitfield>'c  print specified char iff bitfield is all ones
3381
   %<bitfield>`c  print specified char iff bitfield is all zeroes
3382
   %<bitfield>?ab...    select from array of values in big endian order
3383
3384
   %e                   print arm SMI operand (bits 0..7,8..19).
3385
   %E     print the LSB and WIDTH fields of a BFI or BFC instruction.
3386
   %V                   print the 16-bit immediate field of a MOVT or MOVW instruction.
3387
   %R     print the SPSR/CPSR or banked register of an MRS.  */
3388
3389
static const struct opcode32 arm_opcodes[] =
3390
{
3391
  /* ARM instructions.  */
3392
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3393
    0xe1a00000, 0xffffffff, "nop\t\t\t@ (mov r0, r0)"},
3394
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3395
    0xe7f000f0, 0xfff000f0, "udf\t%{I:#%e%}"},
3396
3397
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4),
3398
    0x012FFF10, 0x0ffffff0, "bx%c\t%0-3r%T"},
3399
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
3400
    0x00000090, 0x0fe000f0, "mul%20's%c\t%16-19R, %0-3R, %8-11R"},
3401
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V2),
3402
    0x00200090, 0x0fe000f0, "mla%20's%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3403
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V2S),
3404
    0x01000090, 0x0fb00ff0, "swp%22'b%c\t%12-15RU, %0-3Ru, [%16-19RuU]"},
3405
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V3M),
3406
    0x00800090, 0x0fa000f0,
3407
    "%22?sumull%20's%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3408
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V3M),
3409
    0x00a00090, 0x0fa000f0,
3410
    "%22?sumlal%20's%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3411
3412
  /* V8.2 RAS extension instructions.  */
3413
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_RAS),
3414
    0xe320f010, 0xffffffff, "esb"},
3415
3416
  /* V8-R instructions.  */
3417
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8R),
3418
    0xf57ff04c, 0xffffffff, "dfb"},
3419
3420
  /* V8 instructions.  */
3421
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
3422
    0x0320f005, 0x0fffffff, "sevl"},
3423
  /* Defined in V8 but is in NOP space so available to all arch.  */
3424
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3425
    0xe1000070, 0xfff000f0, "hlt\t%{I:0x%16-19X%12-15X%8-11X%0-3X%}"},
3426
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_ATOMICS),
3427
    0x01800e90, 0x0ff00ff0, "stlex%c\t%12-15r, %0-3r, [%16-19R]"},
3428
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3429
    0x01900e9f, 0x0ff00fff, "ldaex%c\t%12-15r, [%16-19R]"},
3430
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
3431
    0x01a00e90, 0x0ff00ff0, "stlexd%c\t%12-15r, %0-3r, %0-3T, [%16-19R]"},
3432
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
3433
    0x01b00e9f, 0x0ff00fff, "ldaexd%c\t%12-15r, %12-15T, [%16-19R]"},
3434
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3435
    0x01c00e90, 0x0ff00ff0, "stlexb%c\t%12-15r, %0-3r, [%16-19R]"},
3436
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3437
    0x01d00e9f, 0x0ff00fff, "ldaexb%c\t%12-15r, [%16-19R]"},
3438
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3439
    0x01e00e90, 0x0ff00ff0, "stlexh%c\t%12-15r, %0-3r, [%16-19R]"},
3440
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3441
    0x01f00e9f, 0x0ff00fff, "ldaexh%c\t%12-15r, [%16-19R]"},
3442
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3443
    0x0180fc90, 0x0ff0fff0, "stl%c\t%0-3r, [%16-19R]"},
3444
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3445
    0x01900c9f, 0x0ff00fff, "lda%c\t%12-15r, [%16-19R]"},
3446
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3447
    0x01c0fc90, 0x0ff0fff0, "stlb%c\t%0-3r, [%16-19R]"},
3448
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3449
    0x01d00c9f, 0x0ff00fff, "ldab%c\t%12-15r, [%16-19R]"},
3450
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3451
    0x01e0fc90, 0x0ff0fff0, "stlh%c\t%0-3r, [%16-19R]"},
3452
  {ARM_FEATURE_CORE_LOW (ARM_EXT2_ATOMICS),
3453
    0x01f00c9f, 0x0ff00fff, "ldah%c\t%12-15r, [%16-19R]"},
3454
  /* CRC32 instructions.  */
3455
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
3456
    0xe1000040, 0xfff00ff0, "crc32b\t%12-15R, %16-19R, %0-3R"},
3457
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
3458
    0xe1200040, 0xfff00ff0, "crc32h\t%12-15R, %16-19R, %0-3R"},
3459
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
3460
    0xe1400040, 0xfff00ff0, "crc32w\t%12-15R, %16-19R, %0-3R"},
3461
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
3462
    0xe1000240, 0xfff00ff0, "crc32cb\t%12-15R, %16-19R, %0-3R"},
3463
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
3464
    0xe1200240, 0xfff00ff0, "crc32ch\t%12-15R, %16-19R, %0-3R"},
3465
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
3466
    0xe1400240, 0xfff00ff0, "crc32cw\t%12-15R, %16-19R, %0-3R"},
3467
3468
  /* Privileged Access Never extension instructions.  */
3469
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_PAN),
3470
    0xf1100000, 0xfffffdff, "setpan\t%{I:#%9-9d%}"},
3471
3472
  /* Virtualization Extension instructions.  */
3473
  {ARM_FEATURE_CORE_LOW (ARM_EXT_VIRT), 0x0160006e, 0x0fffffff, "eret%c"},
3474
  {ARM_FEATURE_CORE_LOW (ARM_EXT_VIRT), 0x01400070, 0x0ff000f0, "hvc%c\t%e"},
3475
3476
  /* Integer Divide Extension instructions.  */
3477
  {ARM_FEATURE_CORE_LOW (ARM_EXT_ADIV),
3478
    0x0710f010, 0x0ff0f0f0, "sdiv%c\t%16-19r, %0-3r, %8-11r"},
3479
  {ARM_FEATURE_CORE_LOW (ARM_EXT_ADIV),
3480
    0x0730f010, 0x0ff0f0f0, "udiv%c\t%16-19r, %0-3r, %8-11r"},
3481
3482
  /* MP Extension instructions.  */
3483
  {ARM_FEATURE_CORE_LOW (ARM_EXT_MP), 0xf410f000, 0xfc70f000, "pldw\t%a"},
3484
3485
  /* Speculation Barriers.  */
3486
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V3), 0xe320f014, 0xffffffff, "csdb"},
3487
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V3), 0xf57ff040, 0xffffffff, "ssbb"},
3488
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V3), 0xf57ff044, 0xffffffff, "pssbb"},
3489
3490
  /* V7 instructions.  */
3491
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf450f000, 0xfd70f000, "pli\t%P"},
3492
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0x0320f0f0, 0x0ffffff0, "dbg%c\t%{I:#%0-3d%}"},
3493
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8), 0xf57ff051, 0xfffffff3, "dmb\t%U"},
3494
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8), 0xf57ff041, 0xfffffff3, "dsb\t%U"},
3495
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf57ff050, 0xfffffff0, "dmb\t%U"},
3496
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf57ff040, 0xfffffff0, "dsb\t%U"},
3497
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf57ff060, 0xfffffff0, "isb\t%U"},
3498
   {ARM_FEATURE_CORE_LOW (ARM_EXT_V7),
3499
    0x0320f000, 0x0fffffff, "nop%c\t{%{I:%0-7d%}}"},
3500
3501
  /* ARM V6T2 instructions.  */
3502
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3503
    0x07c0001f, 0x0fe0007f, "bfc%c\t%12-15R, %E"},
3504
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3505
    0x07c00010, 0x0fe00070, "bfi%c\t%12-15R, %0-3r, %E"},
3506
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3507
    0x00600090, 0x0ff000f0, "mls%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3508
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3509
    0x002000b0, 0x0f3000f0, "strht%c\t%12-15R, %S"},
3510
3511
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3512
    0x00300090, 0x0f3000f0, UNDEFINED_INSTRUCTION },
3513
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3514
    0x00300090, 0x0f300090, "ldr%6's%5?hbt%c\t%12-15R, %S"},
3515
3516
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
3517
    0x03000000, 0x0ff00000, "movw%c\t%12-15R, %V"},
3518
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
3519
    0x03400000, 0x0ff00000, "movt%c\t%12-15R, %V"},
3520
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3521
    0x06ff0f30, 0x0fff0ff0, "rbit%c\t%12-15R, %0-3R"},
3522
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
3523
    0x07a00050, 0x0fa00070, "%22?usbfx%c\t%12-15r, %0-3r, %{I:#%7-11d%}, %{I:#%16-20W%}"},
3524
3525
  /* ARM Security extension instructions.  */
3526
  {ARM_FEATURE_CORE_LOW (ARM_EXT_SEC),
3527
    0x01600070, 0x0ff000f0, "smc%c\t%e"},
3528
3529
  /* ARM V6K instructions.  */
3530
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3531
    0xf57ff01f, 0xffffffff, "clrex"},
3532
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3533
    0x01d00f9f, 0x0ff00fff, "ldrexb%c\t%12-15R, [%16-19R]"},
3534
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3535
    0x01b00f9f, 0x0ff00fff, "ldrexd%c\t%12-15r, [%16-19R]"},
3536
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3537
    0x01f00f9f, 0x0ff00fff, "ldrexh%c\t%12-15R, [%16-19R]"},
3538
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3539
    0x01c00f90, 0x0ff00ff0, "strexb%c\t%12-15R, %0-3R, [%16-19R]"},
3540
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3541
    0x01a00f90, 0x0ff00ff0, "strexd%c\t%12-15R, %0-3r, [%16-19R]"},
3542
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3543
    0x01e00f90, 0x0ff00ff0, "strexh%c\t%12-15R, %0-3R, [%16-19R]"},
3544
3545
  /* ARMv8.5-A instructions.  */
3546
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_SB), 0xf57ff070, 0xffffffff, "sb"},
3547
3548
  /* ARM V6K NOP hints.  */
3549
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3550
    0x0320f001, 0x0fffffff, "yield%c"},
3551
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3552
    0x0320f002, 0x0fffffff, "wfe%c"},
3553
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3554
    0x0320f003, 0x0fffffff, "wfi%c"},
3555
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3556
    0x0320f004, 0x0fffffff, "sev%c"},
3557
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K),
3558
    0x0320f000, 0x0fffff00, "nop%c\t{%{I:%0-7d%}}"},
3559
3560
  /* ARM V6 instructions.  */
3561
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3562
    0xf1080000, 0xfffffe3f, "cpsie\t%{B:%8'a%7'i%6'f%}"},
3563
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3564
    0xf10a0000, 0xfffffe20, "cpsie\t%{B:%8'a%7'i%6'f%}, %{I:#%0-4d%}"},
3565
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3566
    0xf10C0000, 0xfffffe3f, "cpsid\t%{B:%8'a%7'i%6'f%}"},
3567
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3568
    0xf10e0000, 0xfffffe20, "cpsid\t%{B:%8'a%7'i%6'f%}, %{I:#%0-4d%}"},
3569
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3570
    0xf1000000, 0xfff1fe20, "cps\t%{I:#%0-4d%}"},
3571
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3572
    0x06800010, 0x0ff00ff0, "pkhbt%c\t%12-15R, %16-19R, %0-3R"},
3573
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3574
    0x06800010, 0x0ff00070, "pkhbt%c\t%12-15R, %16-19R, %0-3R, %{B:lsl%} %{I:#%7-11d%}"},
3575
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3576
    0x06800050, 0x0ff00ff0, "pkhtb%c\t%12-15R, %16-19R, %0-3R, %{B:asr%} %{I:#32%}"},
3577
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3578
    0x06800050, 0x0ff00070, "pkhtb%c\t%12-15R, %16-19R, %0-3R, %{B:asr%} %{I:#%7-11d%}"},
3579
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3580
    0x01900f9f, 0x0ff00fff, "ldrex%c\t%{R:r%12-15d%}, [%16-19R]"},
3581
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3582
    0x06200f10, 0x0ff00ff0, "qadd16%c\t%12-15R, %16-19R, %0-3R"},
3583
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3584
    0x06200f90, 0x0ff00ff0, "qadd8%c\t%12-15R, %16-19R, %0-3R"},
3585
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3586
    0x06200f30, 0x0ff00ff0, "qasx%c\t%12-15R, %16-19R, %0-3R"},
3587
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3588
    0x06200f70, 0x0ff00ff0, "qsub16%c\t%12-15R, %16-19R, %0-3R"},
3589
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3590
    0x06200ff0, 0x0ff00ff0, "qsub8%c\t%12-15R, %16-19R, %0-3R"},
3591
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3592
    0x06200f50, 0x0ff00ff0, "qsax%c\t%12-15R, %16-19R, %0-3R"},
3593
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3594
    0x06100f10, 0x0ff00ff0, "sadd16%c\t%12-15R, %16-19R, %0-3R"},
3595
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3596
    0x06100f90, 0x0ff00ff0, "sadd8%c\t%12-15R, %16-19R, %0-3R"},
3597
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3598
    0x06100f30, 0x0ff00ff0, "sasx%c\t%12-15R, %16-19R, %0-3R"},
3599
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3600
    0x06300f10, 0x0ff00ff0, "shadd16%c\t%12-15R, %16-19R, %0-3R"},
3601
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3602
    0x06300f90, 0x0ff00ff0, "shadd8%c\t%12-15R, %16-19R, %0-3R"},
3603
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3604
    0x06300f30, 0x0ff00ff0, "shasx%c\t%12-15R, %16-19R, %0-3R"},
3605
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3606
    0x06300f70, 0x0ff00ff0, "shsub16%c\t%12-15R, %16-19R, %0-3R"},
3607
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3608
    0x06300ff0, 0x0ff00ff0, "shsub8%c\t%12-15R, %16-19R, %0-3R"},
3609
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3610
    0x06300f50, 0x0ff00ff0, "shsax%c\t%12-15R, %16-19R, %0-3R"},
3611
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3612
    0x06100f70, 0x0ff00ff0, "ssub16%c\t%12-15R, %16-19R, %0-3R"},
3613
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3614
    0x06100ff0, 0x0ff00ff0, "ssub8%c\t%12-15R, %16-19R, %0-3R"},
3615
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3616
    0x06100f50, 0x0ff00ff0, "ssax%c\t%12-15R, %16-19R, %0-3R"},
3617
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3618
    0x06500f10, 0x0ff00ff0, "uadd16%c\t%12-15R, %16-19R, %0-3R"},
3619
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3620
    0x06500f90, 0x0ff00ff0, "uadd8%c\t%12-15R, %16-19R, %0-3R"},
3621
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3622
    0x06500f30, 0x0ff00ff0, "uasx%c\t%12-15R, %16-19R, %0-3R"},
3623
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3624
    0x06700f10, 0x0ff00ff0, "uhadd16%c\t%12-15R, %16-19R, %0-3R"},
3625
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3626
    0x06700f90, 0x0ff00ff0, "uhadd8%c\t%12-15R, %16-19R, %0-3R"},
3627
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3628
    0x06700f30, 0x0ff00ff0, "uhasx%c\t%12-15R, %16-19R, %0-3R"},
3629
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3630
    0x06700f70, 0x0ff00ff0, "uhsub16%c\t%12-15R, %16-19R, %0-3R"},
3631
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3632
    0x06700ff0, 0x0ff00ff0, "uhsub8%c\t%12-15R, %16-19R, %0-3R"},
3633
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3634
    0x06700f50, 0x0ff00ff0, "uhsax%c\t%12-15R, %16-19R, %0-3R"},
3635
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3636
    0x06600f10, 0x0ff00ff0, "uqadd16%c\t%12-15R, %16-19R, %0-3R"},
3637
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3638
    0x06600f90, 0x0ff00ff0, "uqadd8%c\t%12-15R, %16-19R, %0-3R"},
3639
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3640
    0x06600f30, 0x0ff00ff0, "uqasx%c\t%12-15R, %16-19R, %0-3R"},
3641
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3642
    0x06600f70, 0x0ff00ff0, "uqsub16%c\t%12-15R, %16-19R, %0-3R"},
3643
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3644
    0x06600ff0, 0x0ff00ff0, "uqsub8%c\t%12-15R, %16-19R, %0-3R"},
3645
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3646
    0x06600f50, 0x0ff00ff0, "uqsax%c\t%12-15R, %16-19R, %0-3R"},
3647
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3648
    0x06500f70, 0x0ff00ff0, "usub16%c\t%12-15R, %16-19R, %0-3R"},
3649
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3650
    0x06500ff0, 0x0ff00ff0, "usub8%c\t%12-15R, %16-19R, %0-3R"},
3651
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3652
    0x06500f50, 0x0ff00ff0, "usax%c\t%12-15R, %16-19R, %0-3R"},
3653
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3654
    0x06bf0f30, 0x0fff0ff0, "rev%c\t%12-15R, %0-3R"},
3655
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3656
    0x06bf0fb0, 0x0fff0ff0, "rev16%c\t%12-15R, %0-3R"},
3657
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3658
    0x06ff0fb0, 0x0fff0ff0, "revsh%c\t%12-15R, %0-3R"},
3659
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3660
    0xf8100a00, 0xfe50ffff, "rfe%23?id%24?ba\t%16-19r%21'!"},
3661
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3662
    0x06bf0070, 0x0fff0ff0, "sxth%c\t%12-15R, %0-3R"},
3663
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3664
    0x06bf0470, 0x0fff0ff0, "sxth%c\t%12-15R, %0-3R, %{B:ror%} %{I:#8%}"},
3665
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3666
    0x06bf0870, 0x0fff0ff0, "sxth%c\t%12-15R, %0-3R, %{B:ror%} %{I:#16%}"},
3667
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3668
    0x06bf0c70, 0x0fff0ff0, "sxth%c\t%12-15R, %0-3R, %{B:ror%} %{I:#24%}"},
3669
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3670
    0x068f0070, 0x0fff0ff0, "sxtb16%c\t%12-15R, %0-3R"},
3671
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3672
    0x068f0470, 0x0fff0ff0, "sxtb16%c\t%12-15R, %0-3R, %{B:ror%} %{I:#8%}"},
3673
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3674
    0x068f0870, 0x0fff0ff0, "sxtb16%c\t%12-15R, %0-3R, %{B:ror%} %{I:#16%}"},
3675
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3676
    0x068f0c70, 0x0fff0ff0, "sxtb16%c\t%12-15R, %0-3R, %{B:ror%} %{I:#24%}"},
3677
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3678
    0x06af0070, 0x0fff0ff0, "sxtb%c\t%12-15R, %0-3R"},
3679
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3680
    0x06af0470, 0x0fff0ff0, "sxtb%c\t%12-15R, %0-3R, %{B:ror%} %{I:#8%}"},
3681
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3682
    0x06af0870, 0x0fff0ff0, "sxtb%c\t%12-15R, %0-3R, %{B:ror%} %{I:#16%}"},
3683
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3684
    0x06af0c70, 0x0fff0ff0, "sxtb%c\t%12-15R, %0-3R, %{B:ror%} %{I:#24%}"},
3685
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3686
    0x06ff0070, 0x0fff0ff0, "uxth%c\t%12-15R, %0-3R"},
3687
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3688
    0x06ff0470, 0x0fff0ff0, "uxth%c\t%12-15R, %0-3R, %{B:ror%} %{I:#8%}"},
3689
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3690
    0x06ff0870, 0x0fff0ff0, "uxth%c\t%12-15R, %0-3R, %{B:ror%} %{I:#16%}"},
3691
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3692
    0x06ff0c70, 0x0fff0ff0, "uxth%c\t%12-15R, %0-3R, %{B:ror%} %{I:#24%}"},
3693
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3694
    0x06cf0070, 0x0fff0ff0, "uxtb16%c\t%12-15R, %0-3R"},
3695
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3696
    0x06cf0470, 0x0fff0ff0, "uxtb16%c\t%12-15R, %0-3R, %{B:ror%} %{I:#8%}"},
3697
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3698
    0x06cf0870, 0x0fff0ff0, "uxtb16%c\t%12-15R, %0-3R, %{B:ror%} %{I:#16%}"},
3699
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3700
    0x06cf0c70, 0x0fff0ff0, "uxtb16%c\t%12-15R, %0-3R, %{B:ror%} %{I:#24%}"},
3701
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3702
    0x06ef0070, 0x0fff0ff0, "uxtb%c\t%12-15R, %0-3R"},
3703
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3704
    0x06ef0470, 0x0fff0ff0, "uxtb%c\t%12-15R, %0-3R, %{B:ror%} %{I:#8%}"},
3705
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3706
    0x06ef0870, 0x0fff0ff0, "uxtb%c\t%12-15R, %0-3R, %{B:ror%} %{I:#16%}"},
3707
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3708
    0x06ef0c70, 0x0fff0ff0, "uxtb%c\t%12-15R, %0-3R, %{B:ror%} %{I:#24%}"},
3709
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3710
    0x06b00070, 0x0ff00ff0, "sxtah%c\t%12-15R, %16-19r, %0-3R"},
3711
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3712
    0x06b00470, 0x0ff00ff0, "sxtah%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#8%}"},
3713
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3714
    0x06b00870, 0x0ff00ff0, "sxtah%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#16%}"},
3715
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3716
    0x06b00c70, 0x0ff00ff0, "sxtah%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#24%}"},
3717
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3718
    0x06800070, 0x0ff00ff0, "sxtab16%c\t%12-15R, %16-19r, %0-3R"},
3719
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3720
    0x06800470, 0x0ff00ff0, "sxtab16%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#8%}"},
3721
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3722
    0x06800870, 0x0ff00ff0, "sxtab16%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#16%}"},
3723
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3724
    0x06800c70, 0x0ff00ff0, "sxtab16%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#24%}"},
3725
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3726
    0x06a00070, 0x0ff00ff0, "sxtab%c\t%12-15R, %16-19r, %0-3R"},
3727
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3728
    0x06a00470, 0x0ff00ff0, "sxtab%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#8%}"},
3729
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3730
    0x06a00870, 0x0ff00ff0, "sxtab%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#16%}"},
3731
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3732
    0x06a00c70, 0x0ff00ff0, "sxtab%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#24%}"},
3733
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3734
    0x06f00070, 0x0ff00ff0, "uxtah%c\t%12-15R, %16-19r, %0-3R"},
3735
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3736
    0x06f00470, 0x0ff00ff0, "uxtah%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#8%}"},
3737
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3738
    0x06f00870, 0x0ff00ff0, "uxtah%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#16%}"},
3739
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3740
    0x06f00c70, 0x0ff00ff0, "uxtah%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#24%}"},
3741
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3742
    0x06c00070, 0x0ff00ff0, "uxtab16%c\t%12-15R, %16-19r, %0-3R"},
3743
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3744
    0x06c00470, 0x0ff00ff0, "uxtab16%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#8%}"},
3745
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3746
    0x06c00870, 0x0ff00ff0, "uxtab16%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#16%}"},
3747
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3748
    0x06c00c70, 0x0ff00ff0, "uxtab16%c\t%12-15R, %16-19r, %0-3R, ROR %{I:#24%}"},
3749
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3750
    0x06e00070, 0x0ff00ff0, "uxtab%c\t%12-15R, %16-19r, %0-3R"},
3751
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3752
    0x06e00470, 0x0ff00ff0, "uxtab%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#8%}"},
3753
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3754
    0x06e00870, 0x0ff00ff0, "uxtab%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#16%}"},
3755
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3756
    0x06e00c70, 0x0ff00ff0, "uxtab%c\t%12-15R, %16-19r, %0-3R, %{B:ror%} %{I:#24%}"},
3757
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3758
    0x06800fb0, 0x0ff00ff0, "sel%c\t%12-15R, %16-19R, %0-3R"},
3759
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3760
    0xf1010000, 0xfffffc00, "setend\t%{B:%9?ble%}"},
3761
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3762
    0x0700f010, 0x0ff0f0d0, "smuad%5'x%c\t%16-19R, %0-3R, %8-11R"},
3763
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3764
    0x0700f050, 0x0ff0f0d0, "smusd%5'x%c\t%16-19R, %0-3R, %8-11R"},
3765
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3766
    0x07000010, 0x0ff000d0, "smlad%5'x%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3767
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3768
    0x07400010, 0x0ff000d0, "smlald%5'x%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3769
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3770
    0x07000050, 0x0ff000d0, "smlsd%5'x%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3771
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3772
    0x07400050, 0x0ff000d0, "smlsld%5'x%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3773
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3774
    0x0750f010, 0x0ff0f0d0, "smmul%5'r%c\t%16-19R, %0-3R, %8-11R"},
3775
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3776
    0x07500010, 0x0ff000d0, "smmla%5'r%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3777
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3778
    0x075000d0, 0x0ff000d0, "smmls%5'r%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3779
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3780
    0xf84d0500, 0xfe5fffe0, "srs%23?id%24?ba\t%16-19r%21'!, %{I:#%0-4d%}"},
3781
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3782
    0x06a00010, 0x0fe00ff0, "ssat%c\t%12-15R, %{I:#%16-20W%}, %0-3R"},
3783
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3784
    0x06a00010, 0x0fe00070, "ssat%c\t%12-15R, %{I:#%16-20W%}, %0-3R, %{B:lsl%} %{I:#%7-11d%}"},
3785
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3786
    0x06a00050, 0x0fe00070, "ssat%c\t%12-15R, %{I:#%16-20W%}, %0-3R, %{B:asr%} %{I:#%7-11d%}"},
3787
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3788
    0x06a00f30, 0x0ff00ff0, "ssat16%c\t%12-15r, %{I:#%16-19W%}, %0-3r"},
3789
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3790
    0x01800f90, 0x0ff00ff0, "strex%c\t%12-15R, %0-3R, [%16-19R]"},
3791
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3792
    0x00400090, 0x0ff000f0, "umaal%c\t%12-15R, %16-19R, %0-3R, %8-11R"},
3793
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3794
    0x0780f010, 0x0ff0f0f0, "usad8%c\t%16-19R, %0-3R, %8-11R"},
3795
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3796
    0x07800010, 0x0ff000f0, "usada8%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3797
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3798
    0x06e00010, 0x0fe00ff0, "usat%c\t%12-15R, %{I:#%16-20d%}, %0-3R"},
3799
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3800
    0x06e00010, 0x0fe00070, "usat%c\t%12-15R, %{I:#%16-20d%}, %0-3R, %{B:lsl%} %{I:#%7-11d%}"},
3801
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3802
    0x06e00050, 0x0fe00070, "usat%c\t%12-15R, %{I:#%16-20d%}, %0-3R, %{B:asr%} %{I:#%7-11d%}"},
3803
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6),
3804
    0x06e00f30, 0x0ff00ff0, "usat16%c\t%12-15R, %{I:#%16-19d%}, %0-3R"},
3805
3806
  /* V5J instruction.  */
3807
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5J),
3808
    0x012fff20, 0x0ffffff0, "bxj%c\t%0-3R"},
3809
3810
  /* V5 Instructions.  */
3811
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
3812
    0xe1200070, 0xfff000f0,
3813
    "bkpt\t%{I:0x%16-19X%12-15X%8-11X%0-3X%}"},
3814
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
3815
    0xfa000000, 0xfe000000, "blx\t%B"},
3816
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
3817
    0x012fff30, 0x0ffffff0, "blx%c\t%0-3R"},
3818
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5),
3819
    0x016f0f10, 0x0fff0ff0, "clz%c\t%12-15R, %0-3R"},
3820
3821
  /* V5E "El Segundo" Instructions.  */
3822
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5E),
3823
    0x000000d0, 0x0e1000f0, "ldrd%c\t%12-15r, %s"},
3824
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5E),
3825
    0x000000f0, 0x0e1000f0, "strd%c\t%12-15r, %s"},
3826
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5E),
3827
    0xf450f000, 0xfc70f000, "pld\t%a"},
3828
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3829
    0x01000080, 0x0ff000f0, "smlabb%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3830
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3831
    0x010000a0, 0x0ff000f0, "smlatb%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3832
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3833
    0x010000c0, 0x0ff000f0, "smlabt%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3834
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3835
    0x010000e0, 0x0ff000f0, "smlatt%c\t%16-19r, %0-3r, %8-11R, %12-15R"},
3836
3837
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3838
    0x01200080, 0x0ff000f0, "smlawb%c\t%16-19R, %0-3R, %8-11R, %12-15R"},
3839
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3840
    0x012000c0, 0x0ff000f0, "smlawt%c\t%16-19R, %0-3r, %8-11R, %12-15R"},
3841
3842
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3843
    0x01400080, 0x0ff000f0, "smlalbb%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3844
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3845
    0x014000a0, 0x0ff000f0, "smlaltb%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3846
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3847
    0x014000c0, 0x0ff000f0, "smlalbt%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3848
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3849
    0x014000e0, 0x0ff000f0, "smlaltt%c\t%12-15Ru, %16-19Ru, %0-3R, %8-11R"},
3850
3851
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3852
    0x01600080, 0x0ff0f0f0, "smulbb%c\t%16-19R, %0-3R, %8-11R"},
3853
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3854
    0x016000a0, 0x0ff0f0f0, "smultb%c\t%16-19R, %0-3R, %8-11R"},
3855
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3856
    0x016000c0, 0x0ff0f0f0, "smulbt%c\t%16-19R, %0-3R, %8-11R"},
3857
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3858
    0x016000e0, 0x0ff0f0f0, "smultt%c\t%16-19R, %0-3R, %8-11R"},
3859
3860
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3861
    0x012000a0, 0x0ff0f0f0, "smulwb%c\t%16-19R, %0-3R, %8-11R"},
3862
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3863
    0x012000e0, 0x0ff0f0f0, "smulwt%c\t%16-19R, %0-3R, %8-11R"},
3864
3865
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3866
    0x01000050, 0x0ff00ff0,  "qadd%c\t%12-15R, %0-3R, %16-19R"},
3867
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3868
    0x01400050, 0x0ff00ff0, "qdadd%c\t%12-15R, %0-3R, %16-19R"},
3869
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3870
    0x01200050, 0x0ff00ff0,  "qsub%c\t%12-15R, %0-3R, %16-19R"},
3871
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5ExP),
3872
    0x01600050, 0x0ff00ff0, "qdsub%c\t%12-15R, %0-3R, %16-19R"},
3873
3874
  /* ARM Instructions.  */
3875
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3876
    0x052d0004, 0x0fff0fff, "push%c\t{%12-15r}\t\t@ (str%c %12-15r, %a)"},
3877
3878
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3879
    0x04400000, 0x0e500000, "strb%t%c\t%12-15R, %a"},
3880
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3881
    0x04000000, 0x0e500000, "str%t%c\t%12-15r, %a"},
3882
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3883
    0x06400000, 0x0e500ff0, "strb%t%c\t%12-15R, %a"},
3884
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3885
    0x06000000, 0x0e500ff0, "str%t%c\t%12-15r, %a"},
3886
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3887
    0x04400000, 0x0c500010, "strb%t%c\t%12-15R, %a"},
3888
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3889
    0x04000000, 0x0c500010, "str%t%c\t%12-15r, %a"},
3890
3891
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3892
    0x04400000, 0x0e500000, "strb%c\t%12-15R, %a"},
3893
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3894
    0x06400000, 0x0e500010, "strb%c\t%12-15R, %a"},
3895
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3896
    0x004000b0, 0x0e5000f0, "strh%c\t%12-15R, %s"},
3897
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3898
    0x000000b0, 0x0e500ff0, "strh%c\t%12-15R, %s"},
3899
3900
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3901
    0x00500090, 0x0e5000f0, UNDEFINED_INSTRUCTION},
3902
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3903
    0x00500090, 0x0e500090, "ldr%6's%5?hb%c\t%12-15R, %s"},
3904
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3905
    0x00100090, 0x0e500ff0, UNDEFINED_INSTRUCTION},
3906
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3907
    0x00100090, 0x0e500f90, "ldr%6's%5?hb%c\t%12-15R, %s"},
3908
3909
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3910
    0x02000000, 0x0fe00000, "and%20's%c\t%12-15r, %16-19r, %o"},
3911
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3912
    0x00000000, 0x0fe00010, "and%20's%c\t%12-15r, %16-19r, %o"},
3913
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3914
    0x00000010, 0x0fe00090, "and%20's%c\t%12-15R, %16-19R, %o"},
3915
3916
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3917
    0x02200000, 0x0fe00000, "eor%20's%c\t%12-15r, %16-19r, %o"},
3918
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3919
    0x00200000, 0x0fe00010, "eor%20's%c\t%12-15r, %16-19r, %o"},
3920
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3921
    0x00200010, 0x0fe00090, "eor%20's%c\t%12-15R, %16-19R, %o"},
3922
3923
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3924
    0x02400000, 0x0fe00000, "sub%20's%c\t%12-15r, %16-19r, %o"},
3925
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3926
    0x00400000, 0x0fe00010, "sub%20's%c\t%12-15r, %16-19r, %o"},
3927
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3928
    0x00400010, 0x0fe00090, "sub%20's%c\t%12-15R, %16-19R, %o"},
3929
3930
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3931
    0x02600000, 0x0fe00000, "rsb%20's%c\t%12-15r, %16-19r, %o"},
3932
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3933
    0x00600000, 0x0fe00010, "rsb%20's%c\t%12-15r, %16-19r, %o"},
3934
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3935
    0x00600010, 0x0fe00090, "rsb%20's%c\t%12-15R, %16-19R, %o"},
3936
3937
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3938
    0x02800000, 0x0fe00000, "add%20's%c\t%12-15r, %16-19r, %o"},
3939
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3940
    0x00800000, 0x0fe00010, "add%20's%c\t%12-15r, %16-19r, %o"},
3941
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3942
    0x00800010, 0x0fe00090, "add%20's%c\t%12-15R, %16-19R, %o"},
3943
3944
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3945
    0x02a00000, 0x0fe00000, "adc%20's%c\t%12-15r, %16-19r, %o"},
3946
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3947
    0x00a00000, 0x0fe00010, "adc%20's%c\t%12-15r, %16-19r, %o"},
3948
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3949
    0x00a00010, 0x0fe00090, "adc%20's%c\t%12-15R, %16-19R, %o"},
3950
3951
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3952
    0x02c00000, 0x0fe00000, "sbc%20's%c\t%12-15r, %16-19r, %o"},
3953
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3954
    0x00c00000, 0x0fe00010, "sbc%20's%c\t%12-15r, %16-19r, %o"},
3955
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3956
    0x00c00010, 0x0fe00090, "sbc%20's%c\t%12-15R, %16-19R, %o"},
3957
3958
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3959
    0x02e00000, 0x0fe00000, "rsc%20's%c\t%12-15r, %16-19r, %o"},
3960
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3961
    0x00e00000, 0x0fe00010, "rsc%20's%c\t%12-15r, %16-19r, %o"},
3962
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3963
    0x00e00010, 0x0fe00090, "rsc%20's%c\t%12-15R, %16-19R, %o"},
3964
3965
  {ARM_FEATURE_CORE_LOW (ARM_EXT_VIRT),
3966
    0x0120f200, 0x0fb0f200, "msr%c\t%C, %0-3r"},
3967
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V3),
3968
    0x0120f000, 0x0db0f000, "msr%c\t%C, %o"},
3969
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V3),
3970
    0x01000000, 0x0fb00cff, "mrs%c\t%12-15R, %R"},
3971
3972
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3973
    0x03000000, 0x0fe00000, "tst%p%c\t%16-19r, %o%O"},
3974
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3975
    0x01000000, 0x0fe00010, "tst%p%c\t%16-19r, %o%O"},
3976
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3977
    0x01000010, 0x0fe00090, "tst%p%c\t%16-19R, %o%O"},
3978
3979
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3980
    0x03300000, 0x0ff00000, "teq%p%c\t%16-19r, %o%O"},
3981
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3982
    0x01300000, 0x0ff00010, "teq%p%c\t%16-19r, %o%O"},
3983
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3984
    0x01300010, 0x0ff00010, "teq%p%c\t%16-19R, %o%O"},
3985
3986
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3987
    0x03400000, 0x0fe00000, "cmp%p%c\t%16-19r, %o%O"},
3988
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3989
    0x01400000, 0x0fe00010, "cmp%p%c\t%16-19r, %o%O"},
3990
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3991
    0x01400010, 0x0fe00090, "cmp%p%c\t%16-19R, %o%O"},
3992
3993
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3994
    0x03600000, 0x0fe00000, "cmn%p%c\t%16-19r, %o%O"},
3995
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3996
    0x01600000, 0x0fe00010, "cmn%p%c\t%16-19r, %o%O"},
3997
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
3998
    0x01600010, 0x0fe00090, "cmn%p%c\t%16-19R, %o%O"},
3999
4000
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4001
    0x03800000, 0x0fe00000, "orr%20's%c\t%12-15r, %16-19r, %o"},
4002
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4003
    0x01800000, 0x0fe00010, "orr%20's%c\t%12-15r, %16-19r, %o"},
4004
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4005
    0x01800010, 0x0fe00090, "orr%20's%c\t%12-15R, %16-19R, %o"},
4006
4007
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4008
    0x03a00000, 0x0fef0000, "mov%20's%c\t%12-15r, %o"},
4009
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4010
    0x01a00000, 0x0def0ff0, "mov%20's%c\t%12-15r, %0-3r"},
4011
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4012
    0x01a00000, 0x0def0060, "lsl%20's%c\t%12-15R, %q"},
4013
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4014
    0x01a00020, 0x0def0060, "lsr%20's%c\t%12-15R, %q"},
4015
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4016
    0x01a00040, 0x0def0060, "asr%20's%c\t%12-15R, %q"},
4017
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4018
    0x01a00060, 0x0def0ff0, "rrx%20's%c\t%12-15r, %0-3r"},
4019
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4020
    0x01a00060, 0x0def0060, "ror%20's%c\t%12-15R, %q"},
4021
4022
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4023
    0x03c00000, 0x0fe00000, "bic%20's%c\t%12-15r, %16-19r, %o"},
4024
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4025
    0x01c00000, 0x0fe00010, "bic%20's%c\t%12-15r, %16-19r, %o"},
4026
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4027
    0x01c00010, 0x0fe00090, "bic%20's%c\t%12-15R, %16-19R, %o"},
4028
4029
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4030
    0x03e00000, 0x0fe00000, "mvn%20's%c\t%12-15r, %o"},
4031
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4032
    0x01e00000, 0x0fe00010, "mvn%20's%c\t%12-15r, %o"},
4033
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4034
    0x01e00010, 0x0fe00090, "mvn%20's%c\t%12-15R, %o"},
4035
4036
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4037
    0x06000010, 0x0e000010, UNDEFINED_INSTRUCTION},
4038
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4039
    0x049d0004, 0x0fff0fff, "pop%c\t{%12-15r}\t\t@ (ldr%c %12-15r, %a)"},
4040
4041
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4042
    0x04500000, 0x0c500000, "ldrb%t%c\t%12-15R, %a"},
4043
4044
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4045
    0x04300000, 0x0d700000, "ldrt%c\t%12-15R, %a"},
4046
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4047
    0x04100000, 0x0c500000, "ldr%c\t%12-15r, %a"},
4048
4049
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4050
    0x092d0001, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4051
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4052
    0x092d0002, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4053
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4054
    0x092d0004, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4055
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4056
    0x092d0008, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4057
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4058
    0x092d0010, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4059
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4060
    0x092d0020, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4061
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4062
    0x092d0040, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4063
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4064
    0x092d0080, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4065
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4066
    0x092d0100, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4067
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4068
    0x092d0200, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4069
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4070
    0x092d0400, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4071
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4072
    0x092d0800, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4073
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4074
    0x092d1000, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4075
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4076
    0x092d2000, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4077
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4078
    0x092d4000, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4079
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4080
    0x092d8000, 0x0fffffff, "stmfd%c\t%16-19R!, %m"},
4081
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4082
    0x092d0000, 0x0fff0000, "push%c\t%m"},
4083
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4084
    0x08800000, 0x0ff00000, "stm%c\t%16-19R%21'!, %m%22'^"},
4085
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4086
    0x08000000, 0x0e100000, "stm%23?id%24?ba%c\t%16-19R%21'!, %m%22'^"},
4087
4088
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4089
    0x08bd0001, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4090
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4091
    0x08bd0002, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4092
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4093
    0x08bd0004, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4094
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4095
    0x08bd0008, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4096
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4097
    0x08bd0010, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4098
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4099
    0x08bd0020, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4100
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4101
    0x08bd0040, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4102
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4103
    0x08bd0080, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4104
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4105
    0x08bd0100, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4106
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4107
    0x08bd0200, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4108
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4109
    0x08bd0400, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4110
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4111
    0x08bd0800, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4112
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4113
    0x08bd1000, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4114
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4115
    0x08bd2000, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4116
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4117
    0x08bd4000, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4118
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4119
    0x08bd8000, 0x0fffffff, "ldmfd%c\t%16-19R!, %m"},
4120
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4121
    0x08bd0000, 0x0fff0000, "pop%c\t%m"},
4122
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4123
    0x08900000, 0x0f900000, "ldm%c\t%16-19R%21'!, %m%22'^"},
4124
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4125
    0x08100000, 0x0e100000, "ldm%23?id%24?ba%c\t%16-19R%21'!, %m%22'^"},
4126
4127
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4128
    0x0a000000, 0x0e000000, "b%24'l%c\t%b"},
4129
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4130
    0x0f000000, 0x0f000000, "svc%c\t%0-23x"},
4131
4132
  /* The rest.  */
4133
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7),
4134
    0x03200000, 0x0fff00ff, "nop%c\t{%{I:%0-7d%}}" UNPREDICTABLE_INSTRUCTION},
4135
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4136
    0x00000000, 0x00000000, UNDEFINED_INSTRUCTION},
4137
  {ARM_FEATURE_CORE_LOW (0),
4138
    0x00000000, 0x00000000, 0}
4139
};
4140
4141
/* print_insn_thumb16 recognizes the following format control codes:
4142
4143
   %S                   print Thumb register (bits 3..5 as high number if bit 6 set)
4144
   %D                   print Thumb register (bits 0..2 as high number if bit 7 set)
4145
   %<bitfield>I         print bitfield as a signed decimal
4146
          (top bit of range being the sign bit)
4147
   %N                   print Thumb register mask (with LR)
4148
   %O                   print Thumb register mask (with PC)
4149
   %M                   print Thumb register mask
4150
   %b     print CZB's 6-bit unsigned branch destination
4151
   %s     print Thumb right-shift immediate (6..10; 0 == 32).
4152
   %c     print the condition code
4153
   %C     print the condition code, or "s" if not conditional
4154
   %x     print warning if conditional an not at end of IT block"
4155
   %X     print "\t@ unpredictable <IT:code>" if conditional
4156
   %I     print IT instruction suffix and operands
4157
   %W     print Thumb Writeback indicator for LDMIA
4158
   %<bitfield>r   print bitfield as an ARM register
4159
   %<bitfield>d   print bitfield as a decimal
4160
   %<bitfield>H         print (bitfield * 2) as a decimal
4161
   %<bitfield>W         print (bitfield * 4) as a decimal
4162
   %<bitfield>a         print (bitfield * 4) as a pc-rel offset + decoded symbol
4163
   %<bitfield>B         print Thumb branch destination (signed displacement)
4164
   %<bitfield>c         print bitfield as a condition code
4165
   %<bitnum>'c    print specified char iff bit is one
4166
   %<bitnum>?ab   print a if bit is one else print b.  */
4167
4168
static const struct opcode16 thumb_opcodes[] =
4169
{
4170
  /* Thumb instructions.  */
4171
4172
  /* ARMv8-M Security Extensions instructions.  */
4173
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M), 0x4784, 0xff87, "blxns\t%3-6r"},
4174
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M), 0x4704, 0xff87, "bxns\t%3-6r"},
4175
4176
  /* ARM V8 instructions.  */
4177
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),  0xbf50, 0xffff, "sevl%c"},
4178
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),  0xba80, 0xffc0, "hlt\t%0-5x"},
4179
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_PAN),  0xb610, 0xfff7, "setpan\t%{I:#%3-3d%}"},
4180
4181
  /* ARM V6K no-argument instructions.  */
4182
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K), 0xbf00, 0xffff, "nop%c"},
4183
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K), 0xbf10, 0xffff, "yield%c"},
4184
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K), 0xbf20, 0xffff, "wfe%c"},
4185
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K), 0xbf30, 0xffff, "wfi%c"},
4186
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K), 0xbf40, 0xffff, "sev%c"},
4187
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6K), 0xbf00, 0xff0f, "nop%c\t{%4-7d}"},
4188
4189
  /* ARM V6T2 instructions.  */
4190
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4191
    0xb900, 0xfd00, "cbnz\t%0-2r, %b%X"},
4192
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4193
    0xb100, 0xfd00, "cbz\t%0-2r, %b%X"},
4194
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xbf00, 0xff00, "it%I%X"},
4195
4196
  /* ARM V6.  */
4197
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xb660, 0xfff8, "cpsie\t%{B:%2'a%1'i%0'f%}%X"},
4198
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xb670, 0xfff8, "cpsid\t%{B:%2'a%1'i%0'f%}%X"},
4199
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0x4600, 0xffc0, "mov%c\t%0-2r, %3-5r"},
4200
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xba00, 0xffc0, "rev%c\t%0-2r, %3-5r"},
4201
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xba40, 0xffc0, "rev16%c\t%0-2r, %3-5r"},
4202
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xbac0, 0xffc0, "revsh%c\t%0-2r, %3-5r"},
4203
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xb650, 0xfff7, "setend\t%{B:%3?ble%}%X"},
4204
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xb200, 0xffc0, "sxth%c\t%0-2r, %3-5r"},
4205
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xb240, 0xffc0, "sxtb%c\t%0-2r, %3-5r"},
4206
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xb280, 0xffc0, "uxth%c\t%0-2r, %3-5r"},
4207
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6), 0xb2c0, 0xffc0, "uxtb%c\t%0-2r, %3-5r"},
4208
4209
  /* ARM V5 ISA extends Thumb.  */
4210
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5T),
4211
    0xbe00, 0xff00, "bkpt\t%0-7x"}, /* Is always unconditional.  */
4212
  /* This is BLX(2).  BLX(1) is a 32-bit instruction.  */
4213
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V5T),
4214
    0x4780, 0xff87, "blx%c\t%3-6r%x"},  /* note: 4 bit register number.  */
4215
  /* ARM V4T ISA (Thumb v1).  */
4216
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4217
    0x46C0, 0xFFFF, "nop%c\t\t\t@ (mov r8, r8)"},
4218
  /* Format 4.  */
4219
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4000, 0xFFC0, "and%C\t%0-2r, %3-5r"},
4220
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4040, 0xFFC0, "eor%C\t%0-2r, %3-5r"},
4221
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4080, 0xFFC0, "lsl%C\t%0-2r, %3-5r"},
4222
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x40C0, 0xFFC0, "lsr%C\t%0-2r, %3-5r"},
4223
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4100, 0xFFC0, "asr%C\t%0-2r, %3-5r"},
4224
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4140, 0xFFC0, "adc%C\t%0-2r, %3-5r"},
4225
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4180, 0xFFC0, "sbc%C\t%0-2r, %3-5r"},
4226
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x41C0, 0xFFC0, "ror%C\t%0-2r, %3-5r"},
4227
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4200, 0xFFC0, "tst%c\t%0-2r, %3-5r"},
4228
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4240, 0xFFC0, "neg%C\t%0-2r, %3-5r"},
4229
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4280, 0xFFC0, "cmp%c\t%0-2r, %3-5r"},
4230
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x42C0, 0xFFC0, "cmn%c\t%0-2r, %3-5r"},
4231
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4300, 0xFFC0, "orr%C\t%0-2r, %3-5r"},
4232
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4340, 0xFFC0, "mul%C\t%0-2r, %3-5r"},
4233
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4380, 0xFFC0, "bic%C\t%0-2r, %3-5r"},
4234
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x43C0, 0xFFC0, "mvn%C\t%0-2r, %3-5r"},
4235
  /* format 13 */
4236
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xB000, 0xFF80, "add%c\t%{R:sp%}, %{I:#%0-6W%}"},
4237
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xB080, 0xFF80, "sub%c\t%{R:sp%}, %{I:#%0-6W%}"},
4238
  /* format 5 */
4239
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4700, 0xFF80, "bx%c\t%S%x"},
4240
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4400, 0xFF00, "add%c\t%D, %S"},
4241
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4500, 0xFF00, "cmp%c\t%D, %S"},
4242
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x4600, 0xFF00, "mov%c\t%D, %S"},
4243
  /* format 14 */
4244
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xB400, 0xFE00, "push%c\t%N"},
4245
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xBC00, 0xFE00, "pop%c\t%O"},
4246
  /* format 2 */
4247
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4248
    0x1800, 0xFE00, "add%C\t%0-2r, %3-5r, %6-8r"},
4249
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4250
    0x1A00, 0xFE00, "sub%C\t%0-2r, %3-5r, %6-8r"},
4251
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4252
    0x1C00, 0xFE00, "add%C\t%0-2r, %3-5r, %{I:#%6-8d%}"},
4253
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4254
    0x1E00, 0xFE00, "sub%C\t%0-2r, %3-5r, %{I:#%6-8d%}"},
4255
  /* format 8 */
4256
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4257
    0x5200, 0xFE00, "strh%c\t%0-2r, [%3-5r, %6-8r]"},
4258
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4259
    0x5A00, 0xFE00, "ldrh%c\t%0-2r, [%3-5r, %6-8r]"},
4260
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4261
    0x5600, 0xF600, "ldrs%11?hb%c\t%0-2r, [%3-5r, %6-8r]"},
4262
  /* format 7 */
4263
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4264
    0x5000, 0xFA00, "str%10'b%c\t%0-2r, [%3-5r, %6-8r]"},
4265
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4266
    0x5800, 0xFA00, "ldr%10'b%c\t%0-2r, [%3-5r, %6-8r]"},
4267
  /* format 1 */
4268
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x0000, 0xFFC0, "mov%C\t%0-2r, %3-5r"},
4269
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4270
    0x0000, 0xF800, "lsl%C\t%0-2r, %3-5r, %{I:#%6-10d%}"},
4271
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x0800, 0xF800, "lsr%C\t%0-2r, %3-5r, %s"},
4272
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x1000, 0xF800, "asr%C\t%0-2r, %3-5r, %s"},
4273
  /* format 3 */
4274
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x2000, 0xF800, "mov%C\t%8-10r, %{I:#%0-7d%}"},
4275
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x2800, 0xF800, "cmp%c\t%8-10r, %{I:#%0-7d%}"},
4276
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x3000, 0xF800, "add%C\t%8-10r, %{I:#%0-7d%}"},
4277
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0x3800, 0xF800, "sub%C\t%8-10r, %{I:#%0-7d%}"},
4278
  /* format 6 */
4279
  /* TODO: Disassemble PC relative "LDR rD,=<symbolic>" */
4280
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4281
    0x4800, 0xF800,
4282
    "ldr%c\t%8-10r, [%{R:pc%}, %{I:#%0-7W%}]\t@ (%0-7a)"},
4283
  /* format 9 */
4284
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4285
    0x6000, 0xF800, "str%c\t%0-2r, [%3-5r, %{I:#%6-10W%}]"},
4286
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4287
    0x6800, 0xF800, "ldr%c\t%0-2r, [%3-5r, %{I:#%6-10W%}]"},
4288
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4289
    0x7000, 0xF800, "strb%c\t%0-2r, [%3-5r, %{I:#%6-10d%}]"},
4290
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4291
    0x7800, 0xF800, "ldrb%c\t%0-2r, [%3-5r, %{I:#%6-10d%}]"},
4292
  /* format 10 */
4293
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4294
    0x8000, 0xF800, "strh%c\t%0-2r, [%3-5r, %{I:#%6-10H%}]"},
4295
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4296
    0x8800, 0xF800, "ldrh%c\t%0-2r, [%3-5r, %{I:#%6-10H%}]"},
4297
  /* format 11 */
4298
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4299
    0x9000, 0xF800, "str%c\t%8-10r, [%{R:sp%}, %{I:#%0-7W%}]"},
4300
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4301
    0x9800, 0xF800, "ldr%c\t%8-10r, [%{R:sp%}, %{I:#%0-7W%}]"},
4302
  /* format 12 */
4303
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4304
    0xA000, 0xF800, "add%c\t%8-10r, %{R:pc%}, %{I:#%0-7W%}\t@ (adr %8-10r, %0-7a)"},
4305
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4306
    0xA800, 0xF800, "add%c\t%8-10r, %{R:sp%}, %{I:#%0-7W%}"},
4307
  /* format 15 */
4308
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xC000, 0xF800, "stmia%c\t%8-10r!, %M"},
4309
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xC800, 0xF800, "ldmia%c\t%8-10r%W, %M"},
4310
  /* format 17 */
4311
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xDF00, 0xFF00, "svc%c\t%0-7d"},
4312
  /* format 16 */
4313
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xDE00, 0xFF00, "udf%c\t%{I:#%0-7d%}"},
4314
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xDE00, 0xFE00, UNDEFINED_INSTRUCTION},
4315
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xD000, 0xF000, "b%8-11c.n\t%0-7B%X"},
4316
  /* format 18 */
4317
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T), 0xE000, 0xF800, "b%c.n\t%0-10B%x"},
4318
4319
  /* The E800 .. FFFF range is unconditionally redirected to the
4320
     32-bit table, because even in pre-V6T2 ISAs, BL and BLX(1) pairs
4321
     are processed via that table.  Thus, we can never encounter a
4322
     bare "second half of BL/BLX(1)" instruction here.  */
4323
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),  0x0000, 0x0000, UNDEFINED_INSTRUCTION},
4324
  {ARM_FEATURE_CORE_LOW (0), 0, 0, 0}
4325
};
4326
4327
/* Thumb32 opcodes use the same table structure as the ARM opcodes.
4328
   We adopt the convention that hw1 is the high 16 bits of .value and
4329
   .mask, hw2 the low 16 bits.
4330
4331
   print_insn_thumb32 recognizes the following format control codes:
4332
4333
       %%   %
4334
4335
       %I   print a 12-bit immediate from hw1[10],hw2[14:12,7:0]
4336
       %M   print a modified 12-bit immediate (same location)
4337
       %J   print a 16-bit immediate from hw1[3:0,10],hw2[14:12,7:0]
4338
       %K   print a 16-bit immediate from hw2[3:0],hw1[3:0],hw2[11:4]
4339
       %H   print a 16-bit immediate from hw2[3:0],hw1[11:0]
4340
       %S   print a possibly-shifted Rm
4341
4342
       %L   print address for a ldrd/strd instruction
4343
       %a   print the address of a plain load/store
4344
       %w   print the width and signedness of a core load/store
4345
       %m   print register mask for ldm/stm
4346
       %n   print register mask for clrm
4347
4348
       %E   print the lsb and width fields of a bfc/bfi instruction
4349
       %F   print the lsb and width fields of a sbfx/ubfx instruction
4350
       %G   print a fallback offset for Branch Future instructions
4351
       %W   print an offset for BF instruction
4352
       %Y   print an offset for BFL instruction
4353
       %Z   print an offset for BFCSEL instruction
4354
       %Q   print an offset for Low Overhead Loop instructions
4355
       %P   print an offset for Low Overhead Loop end instructions
4356
       %b   print a conditional branch offset
4357
       %B   print an unconditional branch offset
4358
       %s   print the shift field of an SSAT instruction
4359
       %R   print the rotation field of an SXT instruction
4360
       %U   print barrier type.
4361
       %P   print address for pli instruction.
4362
       %c   print the condition code
4363
       %x   print warning if conditional an not at end of IT block"
4364
       %X   print "\t@ unpredictable <IT:code>" if conditional
4365
4366
       %<bitfield>d print bitfield in decimal
4367
       %<bitfield>D     print bitfield plus one in decimal
4368
       %<bitfield>W print bitfield*4 in decimal
4369
       %<bitfield>r print bitfield as an ARM register
4370
       %<bitfield>R as %<>r but r15 is UNPREDICTABLE
4371
       %<bitfield>S as %<>r but r13 and r15 is UNPREDICTABLE
4372
       %<bitfield>c print bitfield as a condition code
4373
4374
       %<bitfield>'c  print specified char iff bitfield is all ones
4375
       %<bitfield>`c  print specified char iff bitfield is all zeroes
4376
       %<bitfield>?ab... select from array of values in big endian order
4377
4378
   With one exception at the bottom (done because BL and BLX(1) need
4379
   to come dead last), this table was machine-sorted first in
4380
   decreasing order of number of bits set in the mask, then in
4381
   increasing numeric order of mask, then in increasing numeric order
4382
   of opcode.  This order is not the clearest for a human reader, but
4383
   is guaranteed never to catch a special-case bit pattern with a more
4384
   general mask, which is important, because this instruction encoding
4385
   makes heavy use of special-case bit patterns.  */
4386
static const struct opcode32 thumb32_opcodes[] =
4387
{
4388
  /* Arm v8.1-M Mainline Pointer Authentication and Branch Target
4389
     Identification Extension.  */
4390
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4391
   0xf3af802d, 0xffffffff, "aut\t%{R:r12%}, %{R:lr%}, %{R:sp%}"},
4392
  {ARM_FEATURE_CORE_HIGH_HIGH (ARM_EXT3_PACBTI),
4393
   0xfb500f00, 0xfff00ff0, "autg%c\t%12-15r, %16-19r, %0-3r"},
4394
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4395
   0xf3af800f, 0xffffffff, "bti"},
4396
  {ARM_FEATURE_CORE_HIGH_HIGH (ARM_EXT3_PACBTI),
4397
   0xfb500f10, 0xfff00ff0, "bxaut%c\t%12-15r, %16-19r, %0-3r"},
4398
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4399
   0xf3af801d, 0xffffffff, "pac\t%{R:r12%}, %{R:lr%}, %{R:sp%}"},
4400
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4401
   0xf3af800d, 0xffffffff, "pacbti\t%{R:r12%}, %{R:lr%}, %{R:sp%}"},
4402
  {ARM_FEATURE_CORE_HIGH_HIGH (ARM_EXT3_PACBTI),
4403
   0xfb60f000, 0xfff0f0f0, "pacg%c\t%8-11r, %16-19r, %0-3r"},
4404
4405
  /* Armv8.1-M Mainline and Armv8.1-M Mainline Security Extensions
4406
     instructions.  */
4407
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4408
    0xf00fe001, 0xffffffff, "lctp%c"},
4409
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4410
    0xf02fc001, 0xfffff001, "le\t%P"},
4411
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4412
    0xf00fc001, 0xfffff001, "le\t%{R:lr%}, %P"},
4413
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4414
    0xf01fc001, 0xfffff001, "letp\t%{R:lr%}, %P"},
4415
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4416
    0xf040c001, 0xfff0f001, "wls\t%{R:lr%}, %16-19S, %Q"},
4417
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4418
    0xf000c001, 0xffc0f001, "wlstp.%20-21s\t%{R:lr%}, %16-19S, %Q"},
4419
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4420
    0xf040e001, 0xfff0ffff, "dls\t%{R:lr%}, %16-19S"},
4421
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4422
    0xf000e001, 0xffc0ffff, "dlstp.%20-21s\t%{R:lr%}, %16-19S"},
4423
4424
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4425
    0xf040e001, 0xf860f001, "bf%c\t%G, %W"},
4426
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4427
    0xf060e001, 0xf8f0f001, "bfx%c\t%G, %16-19S"},
4428
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4429
    0xf000c001, 0xf800f001, "bfl%c\t%G, %Y"},
4430
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4431
    0xf070e001, 0xf8f0f001, "bflx%c\t%G, %16-19S"},
4432
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4433
    0xf000e001, 0xf840f001, "bfcsel\t%G, %Z, %{B:%18-21c%}"},
4434
4435
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN),
4436
    0xe89f0000, 0xffff2000, "clrm%c\t%n"},
4437
4438
  /* ARMv8-M and ARMv8-M Security Extensions instructions.  */
4439
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M), 0xe97fe97f, 0xffffffff, "sg"},
4440
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M),
4441
    0xe840f000, 0xfff0f0ff, "tt\t%8-11r, %16-19r"},
4442
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M),
4443
    0xe840f040, 0xfff0f0ff, "ttt\t%8-11r, %16-19r"},
4444
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M),
4445
    0xe840f080, 0xfff0f0ff, "tta\t%8-11r, %16-19r"},
4446
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8M),
4447
    0xe840f0c0, 0xfff0f0ff, "ttat\t%8-11r, %16-19r"},
4448
4449
  /* ARM V8.2 RAS extension instructions.  */
4450
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_RAS),
4451
    0xf3af8010, 0xffffffff, "esb"},
4452
4453
  /* V8 instructions.  */
4454
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4455
    0xf3af8005, 0xffffffff, "sevl%c.w"},
4456
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4457
    0xf78f8000, 0xfffffffc, "dcps%0-1d"},
4458
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4459
    0xe8c00f8f, 0xfff00fff, "stlb%c\t%12-15r, [%16-19R]"},
4460
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4461
    0xe8c00f9f, 0xfff00fff, "stlh%c\t%12-15r, [%16-19R]"},
4462
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4463
    0xe8c00faf, 0xfff00fff, "stl%c\t%12-15r, [%16-19R]"},
4464
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4465
    0xe8c00fc0, 0xfff00ff0, "stlexb%c\t%0-3r, %12-15r, [%16-19R]"},
4466
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4467
    0xe8c00fd0, 0xfff00ff0, "stlexh%c\t%0-3r, %12-15r, [%16-19R]"},
4468
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4469
    0xe8c00fe0, 0xfff00ff0, "stlex%c\t%0-3r, %12-15r, [%16-19R]"},
4470
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4471
    0xe8c000f0, 0xfff000f0, "stlexd%c\t%0-3r, %12-15r, %8-11r, [%16-19R]"},
4472
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4473
    0xe8d00f8f, 0xfff00fff, "ldab%c\t%12-15r, [%16-19R]"},
4474
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4475
    0xe8d00f9f, 0xfff00fff, "ldah%c\t%12-15r, [%16-19R]"},
4476
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4477
    0xe8d00faf, 0xfff00fff, "lda%c\t%12-15r, [%16-19R]"},
4478
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4479
    0xe8d00fcf, 0xfff00fff, "ldaexb%c\t%12-15r, [%16-19R]"},
4480
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4481
    0xe8d00fdf, 0xfff00fff, "ldaexh%c\t%12-15r, [%16-19R]"},
4482
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4483
    0xe8d00fef, 0xfff00fff, "ldaex%c\t%12-15r, [%16-19R]"},
4484
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8),
4485
    0xe8d000ff, 0xfff000ff, "ldaexd%c\t%12-15r, %8-11r, [%16-19R]"},
4486
4487
  /* V8-R instructions.  */
4488
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8R),
4489
    0xf3bf8f4c, 0xffffffff, "dfb%c"},
4490
4491
  /* CRC32 instructions.  */
4492
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
4493
    0xfac0f080, 0xfff0f0f0, "crc32b\t%8-11R, %16-19R, %0-3R"},
4494
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
4495
    0xfac0f090, 0xfff0f0f0, "crc32h\t%9-11R, %16-19R, %0-3R"},
4496
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
4497
    0xfac0f0a0, 0xfff0f0f0, "crc32w\t%8-11R, %16-19R, %0-3R"},
4498
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
4499
    0xfad0f080, 0xfff0f0f0, "crc32cb\t%8-11R, %16-19R, %0-3R"},
4500
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
4501
    0xfad0f090, 0xfff0f0f0, "crc32ch\t%8-11R, %16-19R, %0-3R"},
4502
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_CRC),
4503
    0xfad0f0a0, 0xfff0f0f0, "crc32cw\t%8-11R, %16-19R, %0-3R"},
4504
4505
  /* Speculation Barriers.  */
4506
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3af8014, 0xffffffff, "csdb"},
4507
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3bf8f40, 0xffffffff, "ssbb"},
4508
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3bf8f44, 0xffffffff, "pssbb"},
4509
4510
  /* V7 instructions.  */
4511
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf910f000, 0xff70f000, "pli%c\t%a"},
4512
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf3af80f0, 0xfffffff0, "dbg%c\t%{I:#%0-3d%}"},
4513
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8), 0xf3bf8f51, 0xfffffff3, "dmb%c\t%U"},
4514
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V8), 0xf3bf8f41, 0xfffffff3, "dsb%c\t%U"},
4515
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf3bf8f50, 0xfffffff0, "dmb%c\t%U"},
4516
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf3bf8f40, 0xfffffff0, "dsb%c\t%U"},
4517
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V7), 0xf3bf8f60, 0xfffffff0, "isb%c\t%U"},
4518
  {ARM_FEATURE_CORE_LOW (ARM_EXT_DIV),
4519
    0xfb90f0f0, 0xfff0f0f0, "sdiv%c\t%8-11r, %16-19r, %0-3r"},
4520
  {ARM_FEATURE_CORE_LOW (ARM_EXT_DIV),
4521
    0xfbb0f0f0, 0xfff0f0f0, "udiv%c\t%8-11r, %16-19r, %0-3r"},
4522
4523
  /* Virtualization Extension instructions.  */
4524
  {ARM_FEATURE_CORE_LOW (ARM_EXT_VIRT), 0xf7e08000, 0xfff0f000, "hvc%c\t%V"},
4525
  /* We skip ERET as that is SUBS pc, lr, #0.  */
4526
4527
  /* MP Extension instructions.  */
4528
  {ARM_FEATURE_CORE_LOW (ARM_EXT_MP),   0xf830f000, 0xff70f000, "pldw%c\t%a"},
4529
4530
  /* Security extension instructions.  */
4531
  {ARM_FEATURE_CORE_LOW (ARM_EXT_SEC),  0xf7f08000, 0xfff0f000, "smc%c\t%K"},
4532
4533
  /* ARMv8.5-A instructions.  */
4534
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_SB), 0xf3bf8f70, 0xffffffff, "sb"},
4535
4536
  /* Instructions defined in the basic V6T2 set.  */
4537
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3af8000, 0xffffffff, "nop%c.w"},
4538
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3af8001, 0xffffffff, "yield%c.w"},
4539
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3af8002, 0xffffffff, "wfe%c.w"},
4540
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3af8003, 0xffffffff, "wfi%c.w"},
4541
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf3af8004, 0xffffffff, "sev%c.w"},
4542
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4543
    0xf3af8000, 0xffffff00, "nop%c.w\t{%{I:%0-7d%}}"},
4544
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2), 0xf7f0a000, 0xfff0f000, "udf%c.w\t%H"},
4545
4546
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4547
    0xf3bf8f2f, 0xffffffff, "clrex%c"},
4548
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4549
    0xf3af8400, 0xffffff1f, "cpsie.w\t%{B:%7'a%6'i%5'f%}%X"},
4550
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4551
    0xf3af8600, 0xffffff1f, "cpsid.w\t%{B:%7'a%6'i%5'f%}%X"},
4552
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4553
    0xf3c08f00, 0xfff0ffff, "bxj%c\t%16-19r%x"},
4554
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4555
    0xe810c000, 0xffd0ffff, "rfedb%c\t%16-19r%21'!"},
4556
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4557
    0xe990c000, 0xffd0ffff, "rfeia%c\t%16-19r%21'!"},
4558
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4559
    0xf3e08000, 0xffe0f000, "mrs%c\t%8-11r, %D"},
4560
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4561
    0xf3af8100, 0xffffffe0, "cps\t%{I:#%0-4d%}%X"},
4562
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4563
    0xe8d0f000, 0xfff0fff0, "tbb%c\t[%16-19r, %0-3r]%x"},
4564
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4565
    0xe8d0f010, 0xfff0fff0, "tbh%c\t[%16-19r, %0-3r, %{B:lsl%} %{I:#1%}]%x"},
4566
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4567
    0xf3af8500, 0xffffff00, "cpsie\t%{B:%7'a%6'i%5'f%}, %{I:#%0-4d%}%X"},
4568
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4569
    0xf3af8700, 0xffffff00, "cpsid\t%{B:%7'a%6'i%5'f%}, %{I:#%0-4d%}%X"},
4570
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4571
    0xf3de8f00, 0xffffff00, "subs%c\t%{R:pc%}, %{R:lr%}, %{I:#%0-7d%}"},
4572
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4573
    0xf3808000, 0xffe0f000, "msr%c\t%C, %16-19r"},
4574
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4575
    0xe8500f00, 0xfff00fff, "ldrex%c\t%12-15r, [%16-19r]"},
4576
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4577
    0xe8d00f4f, 0xfff00fef, "ldrex%4?hb%c\t%12-15r, [%16-19r]"},
4578
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4579
    0xe800c000, 0xffd0ffe0, "srsdb%c\t%16-19r%21'!, %{I:#%0-4d%}"},
4580
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4581
    0xe980c000, 0xffd0ffe0, "srsia%c\t%16-19r%21'!, %{I:#%0-4d%}"},
4582
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4583
    0xfa0ff080, 0xfffff0c0, "sxth%c.w\t%8-11r, %0-3r%R"},
4584
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4585
    0xfa1ff080, 0xfffff0c0, "uxth%c.w\t%8-11r, %0-3r%R"},
4586
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4587
    0xfa2ff080, 0xfffff0c0, "sxtb16%c\t%8-11r, %0-3r%R"},
4588
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4589
    0xfa3ff080, 0xfffff0c0, "uxtb16%c\t%8-11r, %0-3r%R"},
4590
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4591
    0xfa4ff080, 0xfffff0c0, "sxtb%c.w\t%8-11r, %0-3r%R"},
4592
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4593
    0xfa5ff080, 0xfffff0c0, "uxtb%c.w\t%8-11r, %0-3r%R"},
4594
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4595
    0xe8400000, 0xfff000ff, "strex%c\t%8-11r, %12-15r, [%16-19r]"},
4596
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4597
    0xe8d0007f, 0xfff000ff, "ldrexd%c\t%12-15r, %8-11r, [%16-19r]"},
4598
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4599
    0xfa80f000, 0xfff0f0f0, "sadd8%c\t%8-11r, %16-19r, %0-3r"},
4600
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4601
    0xfa80f010, 0xfff0f0f0, "qadd8%c\t%8-11r, %16-19r, %0-3r"},
4602
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4603
    0xfa80f020, 0xfff0f0f0, "shadd8%c\t%8-11r, %16-19r, %0-3r"},
4604
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4605
    0xfa80f040, 0xfff0f0f0, "uadd8%c\t%8-11r, %16-19r, %0-3r"},
4606
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4607
    0xfa80f050, 0xfff0f0f0, "uqadd8%c\t%8-11r, %16-19r, %0-3r"},
4608
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4609
    0xfa80f060, 0xfff0f0f0, "uhadd8%c\t%8-11r, %16-19r, %0-3r"},
4610
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4611
    0xfa80f080, 0xfff0f0f0, "qadd%c\t%8-11r, %0-3r, %16-19r"},
4612
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4613
    0xfa80f090, 0xfff0f0f0, "qdadd%c\t%8-11r, %0-3r, %16-19r"},
4614
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4615
    0xfa80f0a0, 0xfff0f0f0, "qsub%c\t%8-11r, %0-3r, %16-19r"},
4616
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4617
    0xfa80f0b0, 0xfff0f0f0, "qdsub%c\t%8-11r, %0-3r, %16-19r"},
4618
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4619
    0xfa90f000, 0xfff0f0f0, "sadd16%c\t%8-11r, %16-19r, %0-3r"},
4620
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4621
    0xfa90f010, 0xfff0f0f0, "qadd16%c\t%8-11r, %16-19r, %0-3r"},
4622
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4623
    0xfa90f020, 0xfff0f0f0, "shadd16%c\t%8-11r, %16-19r, %0-3r"},
4624
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4625
    0xfa90f040, 0xfff0f0f0, "uadd16%c\t%8-11r, %16-19r, %0-3r"},
4626
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4627
    0xfa90f050, 0xfff0f0f0, "uqadd16%c\t%8-11r, %16-19r, %0-3r"},
4628
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4629
    0xfa90f060, 0xfff0f0f0, "uhadd16%c\t%8-11r, %16-19r, %0-3r"},
4630
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4631
    0xfa90f080, 0xfff0f0f0, "rev%c.w\t%8-11r, %16-19r"},
4632
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4633
    0xfa90f090, 0xfff0f0f0, "rev16%c.w\t%8-11r, %16-19r"},
4634
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4635
    0xfa90f0a0, 0xfff0f0f0, "rbit%c\t%8-11r, %16-19r"},
4636
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4637
    0xfa90f0b0, 0xfff0f0f0, "revsh%c.w\t%8-11r, %16-19r"},
4638
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4639
    0xfaa0f000, 0xfff0f0f0, "sasx%c\t%8-11r, %16-19r, %0-3r"},
4640
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4641
    0xfaa0f010, 0xfff0f0f0, "qasx%c\t%8-11r, %16-19r, %0-3r"},
4642
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4643
    0xfaa0f020, 0xfff0f0f0, "shasx%c\t%8-11r, %16-19r, %0-3r"},
4644
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4645
    0xfaa0f040, 0xfff0f0f0, "uasx%c\t%8-11r, %16-19r, %0-3r"},
4646
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4647
    0xfaa0f050, 0xfff0f0f0, "uqasx%c\t%8-11r, %16-19r, %0-3r"},
4648
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4649
    0xfaa0f060, 0xfff0f0f0, "uhasx%c\t%8-11r, %16-19r, %0-3r"},
4650
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4651
    0xfaa0f080, 0xfff0f0f0, "sel%c\t%8-11r, %16-19r, %0-3r"},
4652
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4653
    0xfab0f080, 0xfff0f0f0, "clz%c\t%8-11r, %16-19r"},
4654
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4655
    0xfac0f000, 0xfff0f0f0, "ssub8%c\t%8-11r, %16-19r, %0-3r"},
4656
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4657
    0xfac0f010, 0xfff0f0f0, "qsub8%c\t%8-11r, %16-19r, %0-3r"},
4658
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4659
    0xfac0f020, 0xfff0f0f0, "shsub8%c\t%8-11r, %16-19r, %0-3r"},
4660
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4661
    0xfac0f040, 0xfff0f0f0, "usub8%c\t%8-11r, %16-19r, %0-3r"},
4662
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4663
    0xfac0f050, 0xfff0f0f0, "uqsub8%c\t%8-11r, %16-19r, %0-3r"},
4664
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4665
    0xfac0f060, 0xfff0f0f0, "uhsub8%c\t%8-11r, %16-19r, %0-3r"},
4666
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4667
    0xfad0f000, 0xfff0f0f0, "ssub16%c\t%8-11r, %16-19r, %0-3r"},
4668
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4669
    0xfad0f010, 0xfff0f0f0, "qsub16%c\t%8-11r, %16-19r, %0-3r"},
4670
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4671
    0xfad0f020, 0xfff0f0f0, "shsub16%c\t%8-11r, %16-19r, %0-3r"},
4672
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4673
    0xfad0f040, 0xfff0f0f0, "usub16%c\t%8-11r, %16-19r, %0-3r"},
4674
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4675
    0xfad0f050, 0xfff0f0f0, "uqsub16%c\t%8-11r, %16-19r, %0-3r"},
4676
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4677
    0xfad0f060, 0xfff0f0f0, "uhsub16%c\t%8-11r, %16-19r, %0-3r"},
4678
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4679
    0xfae0f000, 0xfff0f0f0, "ssax%c\t%8-11r, %16-19r, %0-3r"},
4680
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4681
    0xfae0f010, 0xfff0f0f0, "qsax%c\t%8-11r, %16-19r, %0-3r"},
4682
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4683
    0xfae0f020, 0xfff0f0f0, "shsax%c\t%8-11r, %16-19r, %0-3r"},
4684
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4685
    0xfae0f040, 0xfff0f0f0, "usax%c\t%8-11r, %16-19r, %0-3r"},
4686
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4687
    0xfae0f050, 0xfff0f0f0, "uqsax%c\t%8-11r, %16-19r, %0-3r"},
4688
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4689
    0xfae0f060, 0xfff0f0f0, "uhsax%c\t%8-11r, %16-19r, %0-3r"},
4690
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4691
    0xfb00f000, 0xfff0f0f0, "mul%c.w\t%8-11r, %16-19r, %0-3r"},
4692
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4693
    0xfb70f000, 0xfff0f0f0, "usad8%c\t%8-11r, %16-19r, %0-3r"},
4694
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4695
    0xfa00f000, 0xffe0f0f0, "lsl%20's%c.w\t%8-11R, %16-19R, %0-3R"},
4696
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4697
    0xfa20f000, 0xffe0f0f0, "lsr%20's%c.w\t%8-11R, %16-19R, %0-3R"},
4698
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4699
    0xfa40f000, 0xffe0f0f0, "asr%20's%c.w\t%8-11R, %16-19R, %0-3R"},
4700
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4701
    0xfa60f000, 0xffe0f0f0, "ror%20's%c.w\t%8-11r, %16-19r, %0-3r"},
4702
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4703
    0xe8c00f40, 0xfff00fe0, "strex%4?hb%c\t%0-3r, %12-15r, [%16-19r]"},
4704
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4705
    0xf3200000, 0xfff0f0e0, "ssat16%c\t%8-11r, %{I:#%0-4D%}, %16-19r"},
4706
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4707
    0xf3a00000, 0xfff0f0e0, "usat16%c\t%8-11r, %{I:#%0-4d%}, %16-19r"},
4708
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4709
    0xfb20f000, 0xfff0f0e0, "smuad%4'x%c\t%8-11r, %16-19r, %0-3r"},
4710
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4711
    0xfb30f000, 0xfff0f0e0, "smulw%4?tb%c\t%8-11r, %16-19r, %0-3r"},
4712
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4713
    0xfb40f000, 0xfff0f0e0, "smusd%4'x%c\t%8-11r, %16-19r, %0-3r"},
4714
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4715
    0xfb50f000, 0xfff0f0e0, "smmul%4'r%c\t%8-11r, %16-19r, %0-3r"},
4716
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4717
    0xfa00f080, 0xfff0f0c0, "sxtah%c\t%8-11r, %16-19r, %0-3r%R"},
4718
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4719
    0xfa10f080, 0xfff0f0c0, "uxtah%c\t%8-11r, %16-19r, %0-3r%R"},
4720
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4721
    0xfa20f080, 0xfff0f0c0, "sxtab16%c\t%8-11r, %16-19r, %0-3r%R"},
4722
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4723
    0xfa30f080, 0xfff0f0c0, "uxtab16%c\t%8-11r, %16-19r, %0-3r%R"},
4724
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4725
    0xfa40f080, 0xfff0f0c0, "sxtab%c\t%8-11r, %16-19r, %0-3r%R"},
4726
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4727
    0xfa50f080, 0xfff0f0c0, "uxtab%c\t%8-11r, %16-19r, %0-3r%R"},
4728
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4729
    0xfb10f000, 0xfff0f0c0, "smul%5?tb%4?tb%c\t%8-11r, %16-19r, %0-3r"},
4730
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4731
    0xf36f0000, 0xffff8020, "bfc%c\t%8-11r, %E"},
4732
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4733
    0xea100f00, 0xfff08f00, "tst%c.w\t%16-19r, %S"},
4734
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4735
    0xea900f00, 0xfff08f00, "teq%c\t%16-19r, %S"},
4736
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4737
    0xeb100f00, 0xfff08f00, "cmn%c.w\t%16-19r, %S"},
4738
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4739
    0xebb00f00, 0xfff08f00, "cmp%c.w\t%16-19r, %S"},
4740
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4741
    0xf0100f00, 0xfbf08f00, "tst%c.w\t%16-19r, %M"},
4742
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4743
    0xf0900f00, 0xfbf08f00, "teq%c\t%16-19r, %M"},
4744
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4745
    0xf1100f00, 0xfbf08f00, "cmn%c.w\t%16-19r, %M"},
4746
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4747
    0xf1b00f00, 0xfbf08f00, "cmp%c.w\t%16-19r, %M"},
4748
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4749
    0xea4f0000, 0xffef8000, "mov%20's%c.w\t%8-11r, %S"},
4750
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4751
    0xea6f0000, 0xffef8000, "mvn%20's%c.w\t%8-11r, %S"},
4752
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4753
    0xe8c00070, 0xfff000f0, "strexd%c\t%0-3r, %12-15r, %8-11r, [%16-19r]"},
4754
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4755
    0xfb000000, 0xfff000f0, "mla%c\t%8-11r, %16-19r, %0-3r, %12-15r"},
4756
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4757
    0xfb000010, 0xfff000f0, "mls%c\t%8-11r, %16-19r, %0-3r, %12-15r"},
4758
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4759
    0xfb700000, 0xfff000f0, "usada8%c\t%8-11R, %16-19R, %0-3R, %12-15R"},
4760
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4761
    0xfb800000, 0xfff000f0, "smull%c\t%12-15R, %8-11R, %16-19R, %0-3R"},
4762
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4763
    0xfba00000, 0xfff000f0, "umull%c\t%12-15R, %8-11R, %16-19R, %0-3R"},
4764
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4765
    0xfbc00000, 0xfff000f0, "smlal%c\t%12-15R, %8-11R, %16-19R, %0-3R"},
4766
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4767
    0xfbe00000, 0xfff000f0, "umlal%c\t%12-15R, %8-11R, %16-19R, %0-3R"},
4768
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4769
    0xfbe00060, 0xfff000f0, "umaal%c\t%12-15R, %8-11R, %16-19R, %0-3R"},
4770
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4771
    0xe8500f00, 0xfff00f00, "ldrex%c\t%12-15r, [%16-19r, %{I:#%0-7W%}]"},
4772
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4773
    0xf04f0000, 0xfbef8000, "mov%20's%c.w\t%8-11r, %M"},
4774
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4775
    0xf06f0000, 0xfbef8000, "mvn%20's%c.w\t%8-11r, %M"},
4776
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4777
    0xf810f000, 0xff70f000, "pld%c\t%a"},
4778
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4779
    0xfb200000, 0xfff000e0, "smlad%4'x%c\t%8-11R, %16-19R, %0-3R, %12-15R"},
4780
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4781
    0xfb300000, 0xfff000e0, "smlaw%4?tb%c\t%8-11R, %16-19R, %0-3R, %12-15R"},
4782
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4783
    0xfb400000, 0xfff000e0, "smlsd%4'x%c\t%8-11R, %16-19R, %0-3R, %12-15R"},
4784
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4785
    0xfb500000, 0xfff000e0, "smmla%4'r%c\t%8-11R, %16-19R, %0-3R, %12-15R"},
4786
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4787
    0xfb600000, 0xfff000e0, "smmls%4'r%c\t%8-11R, %16-19R, %0-3R, %12-15R"},
4788
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4789
    0xfbc000c0, 0xfff000e0, "smlald%4'x%c\t%12-15R, %8-11R, %16-19R, %0-3R"},
4790
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4791
    0xfbd000c0, 0xfff000e0, "smlsld%4'x%c\t%12-15R, %8-11R, %16-19R, %0-3R"},
4792
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4793
    0xeac00000, 0xfff08030, "pkhbt%c\t%8-11r, %16-19r, %S"},
4794
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4795
    0xeac00020, 0xfff08030, "pkhtb%c\t%8-11r, %16-19r, %S"},
4796
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4797
    0xf3400000, 0xfff08020, "sbfx%c\t%8-11r, %16-19r, %F"},
4798
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4799
    0xf3c00000, 0xfff08020, "ubfx%c\t%8-11r, %16-19r, %F"},
4800
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4801
    0xf8000e00, 0xff900f00, "str%wt%c\t%12-15r, %a"},
4802
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4803
    0xfb100000, 0xfff000c0,
4804
    "smla%5?tb%4?tb%c\t%8-11r, %16-19r, %0-3r, %12-15r"},
4805
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4806
    0xfbc00080, 0xfff000c0,
4807
    "smlal%5?tb%4?tb%c\t%12-15r, %8-11r, %16-19r, %0-3r"},
4808
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4809
    0xf3600000, 0xfff08020, "bfi%c\t%8-11r, %16-19r, %E"},
4810
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4811
    0xf8100e00, 0xfe900f00, "ldr%wt%c\t%12-15r, %a"},
4812
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4813
    0xf3000000, 0xffd08020, "ssat%c\t%8-11r, %{I:#%0-4D%}, %16-19r%s"},
4814
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4815
    0xf3800000, 0xffd08020, "usat%c\t%8-11r, %{I:#%0-4d%}, %16-19r%s"},
4816
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4817
    0xf2000000, 0xfbf08000, "addw%c\t%8-11r, %16-19r, %I"},
4818
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4819
    0xf2400000, 0xfbf08000, "movw%c\t%8-11r, %J"},
4820
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4821
    0xf2a00000, 0xfbf08000, "subw%c\t%8-11r, %16-19r, %I"},
4822
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4823
    0xf2c00000, 0xfbf08000, "movt%c\t%8-11r, %J"},
4824
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4825
    0xea000000, 0xffe08000, "and%20's%c.w\t%8-11r, %16-19r, %S"},
4826
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4827
    0xea200000, 0xffe08000, "bic%20's%c.w\t%8-11r, %16-19r, %S"},
4828
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4829
    0xea400000, 0xffe08000, "orr%20's%c.w\t%8-11r, %16-19r, %S"},
4830
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4831
    0xea600000, 0xffe08000, "orn%20's%c\t%8-11r, %16-19r, %S"},
4832
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4833
    0xea800000, 0xffe08000, "eor%20's%c.w\t%8-11r, %16-19r, %S"},
4834
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4835
    0xeb000000, 0xffe08000, "add%20's%c.w\t%8-11r, %16-19r, %S"},
4836
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4837
    0xeb400000, 0xffe08000, "adc%20's%c.w\t%8-11r, %16-19r, %S"},
4838
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4839
    0xeb600000, 0xffe08000, "sbc%20's%c.w\t%8-11r, %16-19r, %S"},
4840
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4841
    0xeba00000, 0xffe08000, "sub%20's%c.w\t%8-11r, %16-19r, %S"},
4842
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4843
    0xebc00000, 0xffe08000, "rsb%20's%c\t%8-11r, %16-19r, %S"},
4844
  {ARM_FEATURE_CORE_HIGH (ARM_EXT2_V6T2_V8M),
4845
    0xe8400000, 0xfff00000, "strex%c\t%8-11r, %12-15r, [%16-19r, %{I:#%0-7W%}]"},
4846
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4847
    0xf0000000, 0xfbe08000, "and%20's%c.w\t%8-11r, %16-19r, %M"},
4848
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4849
    0xf0200000, 0xfbe08000, "bic%20's%c.w\t%8-11r, %16-19r, %M"},
4850
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4851
    0xf0400000, 0xfbe08000, "orr%20's%c.w\t%8-11r, %16-19r, %M"},
4852
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4853
    0xf0600000, 0xfbe08000, "orn%20's%c\t%8-11r, %16-19r, %M"},
4854
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4855
    0xf0800000, 0xfbe08000, "eor%20's%c.w\t%8-11r, %16-19r, %M"},
4856
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4857
    0xf1000000, 0xfbe08000, "add%20's%c.w\t%8-11r, %16-19r, %M"},
4858
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4859
    0xf1400000, 0xfbe08000, "adc%20's%c.w\t%8-11r, %16-19r, %M"},
4860
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4861
    0xf1600000, 0xfbe08000, "sbc%20's%c.w\t%8-11r, %16-19r, %M"},
4862
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4863
    0xf1a00000, 0xfbe08000, "sub%20's%c.w\t%8-11r, %16-19r, %M"},
4864
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4865
    0xf1c00000, 0xfbe08000, "rsb%20's%c\t%8-11r, %16-19r, %M"},
4866
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4867
    0xe8800000, 0xffd00000, "stmia%c.w\t%16-19r%21'!, %m"},
4868
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4869
    0xe8900000, 0xffd00000, "ldmia%c.w\t%16-19r%21'!, %m"},
4870
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4871
    0xe9000000, 0xffd00000, "stmdb%c\t%16-19r%21'!, %m"},
4872
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4873
    0xe9100000, 0xffd00000, "ldmdb%c\t%16-19r%21'!, %m"},
4874
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4875
    0xe9c00000, 0xffd000ff, "strd%c\t%12-15r, %8-11r, [%16-19r]"},
4876
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4877
    0xe9d00000, 0xffd000ff, "ldrd%c\t%12-15r, %8-11r, [%16-19r]"},
4878
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4879
    0xe9400000, 0xff500000,
4880
    "strd%c\t%12-15r, %8-11r, [%16-19r, %{I:#%23`-%0-7W%}]%21'!%L"},
4881
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4882
    0xe9500000, 0xff500000,
4883
    "ldrd%c\t%12-15r, %8-11r, [%16-19r, %{I:#%23`-%0-7W%}]%21'!%L"},
4884
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4885
    0xe8600000, 0xff700000,
4886
    "strd%c\t%12-15r, %8-11r, [%16-19r], %{I:#%23`-%0-7W%}%L"},
4887
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4888
    0xe8700000, 0xff700000,
4889
    "ldrd%c\t%12-15r, %8-11r, [%16-19r], %{I:#%23`-%0-7W%}%L"},
4890
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4891
    0xf8000000, 0xff100000, "str%w%c.w\t%12-15r, %a"},
4892
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4893
    0xf8100000, 0xfe100000, "ldr%w%c.w\t%12-15r, %a"},
4894
4895
  /* Filter out Bcc with cond=E or F, which are used for other instructions.  */
4896
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4897
    0xf3c08000, 0xfbc0d000, "undefined (bcc, cond=0xF)"},
4898
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4899
    0xf3808000, 0xfbc0d000, "undefined (bcc, cond=0xE)"},
4900
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4901
    0xf0008000, 0xf800d000, "b%22-25c.w\t%b%X"},
4902
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2),
4903
    0xf0009000, 0xf800d000, "b%c.w\t%B%x"},
4904
4905
  /* These have been 32-bit since the invention of Thumb.  */
4906
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4907
     0xf000c000, 0xf800d001, "blx%c\t%B%x"},
4908
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V4T),
4909
     0xf000d000, 0xf800d000, "bl%c\t%B%x"},
4910
4911
  /* Fallback.  */
4912
  {ARM_FEATURE_CORE_LOW (ARM_EXT_V1),
4913
      0x00000000, 0x00000000, UNDEFINED_INSTRUCTION},
4914
  {ARM_FEATURE_CORE_LOW (0), 0, 0, 0}
4915
};
4916
4917
static const char *const arm_conditional[] =
4918
{"eq", "ne", "cs", "cc", "mi", "pl", "vs", "vc",
4919
 "hi", "ls", "ge", "lt", "gt", "le", "al", "<und>", ""};
4920
4921
static const char *const arm_shift[] =
4922
{"lsl", "lsr", "asr", "ror"};
4923
4924
typedef struct
4925
{
4926
  const char *name;
4927
  const char *description;
4928
  const char *reg_names[16];
4929
}
4930
arm_regname;
4931
4932
static const arm_regname regnames[] =
4933
{
4934
  { "reg-names-raw", N_("Select raw register names"),
4935
    { "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"}},
4936
  { "reg-names-gcc", N_("Select register names used by GCC"),
4937
    { "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "sl",  "fp",  "ip",  "sp",  "lr",  "pc" }},
4938
  { "reg-names-std", N_("Select register names used in ARM's ISA documentation"),
4939
    { "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12", "sp",  "lr",  "pc" }},
4940
  { "force-thumb", N_("Assume all insns are Thumb insns"), {NULL} },
4941
  { "no-force-thumb", N_("Examine preceding label to determine an insn's type"), {NULL} },
4942
  { "reg-names-apcs", N_("Select register names used in the APCS"),
4943
    { "a1", "a2", "a3", "a4", "v1", "v2", "v3", "v4", "v5", "v6", "sl",  "fp",  "ip",  "sp",  "lr",  "pc" }},
4944
  { "reg-names-atpcs", N_("Select register names used in the ATPCS"),
4945
    { "a1", "a2", "a3", "a4", "v1", "v2", "v3", "v4", "v5", "v6", "v7",  "v8",  "IP",  "SP",  "LR",  "PC" }},
4946
  { "reg-names-special-atpcs", N_("Select special register names used in the ATPCS"),
4947
    { "a1", "a2", "a3", "a4", "v1", "v2", "v3", "WR", "v5", "SB", "SL",  "FP",  "IP",  "SP",  "LR",  "PC" }},
4948
  { "coproc<N>=(cde|generic)", N_("Enable CDE extensions for coprocessor N space"), { NULL } }
4949
};
4950
4951
static const char *const iwmmxt_wwnames[] =
4952
{"b", "h", "w", "d"};
4953
4954
static const char *const iwmmxt_wwssnames[] =
4955
{"b", "bus", "bc", "bss",
4956
 "h", "hus", "hc", "hss",
4957
 "w", "wus", "wc", "wss",
4958
 "d", "dus", "dc", "dss"
4959
};
4960
4961
static const char *const iwmmxt_regnames[] =
4962
{ "wr0", "wr1", "wr2", "wr3", "wr4", "wr5", "wr6", "wr7",
4963
  "wr8", "wr9", "wr10", "wr11", "wr12", "wr13", "wr14", "wr15"
4964
};
4965
4966
static const char *const iwmmxt_cregnames[] =
4967
{ "wcid", "wcon", "wcssf", "wcasf", "reserved", "reserved", "reserved", "reserved",
4968
  "wcgr0", "wcgr1", "wcgr2", "wcgr3", "reserved", "reserved", "reserved", "reserved"
4969
};
4970
4971
static const char *const vec_condnames[] =
4972
{ "eq", "ne", "cs", "hi", "ge", "lt", "gt", "le"
4973
};
4974
4975
static const char *const mve_predicatenames[] =
4976
{ "", "ttt", "tt", "tte", "t", "tee", "te", "tet", "",
4977
  "eee", "ee", "eet", "e", "ett", "et", "ete"
4978
};
4979
4980
/* Names for 2-bit size field for mve vector isntructions.  */
4981
static const char *const mve_vec_sizename[] =
4982
  { "8", "16", "32", "64"};
4983
4984
/* Indicates whether we are processing a then predicate,
4985
   else predicate or none at all.  */
4986
enum vpt_pred_state
4987
{
4988
  PRED_NONE,
4989
  PRED_THEN,
4990
  PRED_ELSE
4991
};
4992
4993
/* Information used to process a vpt block and subsequent instructions.  */
4994
struct vpt_block
4995
{
4996
  /* Are we in a vpt block.  */
4997
  bool in_vpt_block;
4998
4999
  /* Next predicate state if in vpt block.  */
5000
  enum vpt_pred_state next_pred_state;
5001
5002
  /* Mask from vpt/vpst instruction.  */
5003
  long predicate_mask;
5004
5005
  /* Instruction number in vpt block.  */
5006
  long current_insn_num;
5007
5008
  /* Number of instructions in vpt block..   */
5009
  long num_pred_insn;
5010
};
5011
5012
static struct vpt_block vpt_block_state =
5013
{
5014
  false,
5015
  PRED_NONE,
5016
  0,
5017
  0,
5018
  0
5019
};
5020
5021
/* Default to GCC register name set.  */
5022
static unsigned int regname_selected = 1;
5023
5024
2.62k
#define NUM_ARM_OPTIONS   ARRAY_SIZE (regnames)
5025
26.1M
#define arm_regnames      regnames[regname_selected].reg_names
5026
5027
static bool force_thumb = false;
5028
static uint16_t cde_coprocs = 0;
5029
5030
/* Current IT instruction state.  This contains the same state as the IT
5031
   bits in the CPSR.  */
5032
static unsigned int ifthen_state;
5033
/* IT state for the next instruction.  */
5034
static unsigned int ifthen_next_state;
5035
/* The address of the insn for which the IT state is valid.  */
5036
static bfd_vma ifthen_address;
5037
6.02M
#define IFTHEN_COND ((ifthen_state >> 4) & 0xf)
5038
/* Indicates that the current Conditional state is unconditional or outside
5039
   an IT block.  */
5040
627M
#define COND_UNCOND 16
5041
5042

5043
/* Functions.  */
5044
/* Extract the predicate mask for a VPT or VPST instruction.
5045
   The mask is composed of bits 13-15 (Mkl) and bit 22 (Mkh).  */
5046
5047
static long
5048
mve_extract_pred_mask (long given)
5049
28.2k
{
5050
28.2k
  return ((given & 0x00400000) >> 19) | ((given & 0xe000) >> 13);
5051
28.2k
}
5052
5053
/* Return the number of instructions in a MVE predicate block.  */
5054
static long
5055
num_instructions_vpt_block (long given)
5056
6.17k
{
5057
6.17k
  long mask = mve_extract_pred_mask (given);
5058
6.17k
  if (mask == 0)
5059
0
    return 0;
5060
5061
6.17k
  if (mask == 8)
5062
1.04k
    return 1;
5063
5064
5.12k
  if ((mask & 7) == 4)
5065
1.02k
    return 2;
5066
5067
4.09k
  if ((mask & 3) == 2)
5068
1.54k
    return 3;
5069
5070
2.55k
  if ((mask & 1) == 1)
5071
2.55k
    return 4;
5072
5073
0
  return 0;
5074
2.55k
}
5075
5076
static void
5077
mark_outside_vpt_block (void)
5078
6.17k
{
5079
6.17k
  vpt_block_state.in_vpt_block = false;
5080
6.17k
  vpt_block_state.next_pred_state = PRED_NONE;
5081
6.17k
  vpt_block_state.predicate_mask = 0;
5082
6.17k
  vpt_block_state.current_insn_num = 0;
5083
6.17k
  vpt_block_state.num_pred_insn = 0;
5084
6.17k
}
5085
5086
static void
5087
mark_inside_vpt_block (long given)
5088
6.17k
{
5089
6.17k
  vpt_block_state.in_vpt_block = true;
5090
6.17k
  vpt_block_state.next_pred_state = PRED_THEN;
5091
6.17k
  vpt_block_state.predicate_mask = mve_extract_pred_mask (given);
5092
6.17k
  vpt_block_state.current_insn_num = 0;
5093
6.17k
  vpt_block_state.num_pred_insn = num_instructions_vpt_block (given);
5094
6.17k
  assert (vpt_block_state.num_pred_insn >= 1);
5095
6.17k
}
5096
5097
static enum vpt_pred_state
5098
invert_next_predicate_state (enum vpt_pred_state astate)
5099
7.46k
{
5100
7.46k
  if (astate == PRED_THEN)
5101
4.31k
    return PRED_ELSE;
5102
3.15k
  else if (astate == PRED_ELSE)
5103
3.15k
    return PRED_THEN;
5104
0
  else
5105
0
    return PRED_NONE;
5106
7.46k
}
5107
5108
static enum vpt_pred_state
5109
update_next_predicate_state (void)
5110
11.7k
{
5111
11.7k
  long pred_mask = vpt_block_state.predicate_mask;
5112
11.7k
  long mask_for_insn = 0;
5113
5114
11.7k
  switch (vpt_block_state.current_insn_num)
5115
11.7k
    {
5116
5.12k
    case 1:
5117
5.12k
      mask_for_insn = 8;
5118
5.12k
      break;
5119
5120
4.09k
    case 2:
5121
4.09k
      mask_for_insn = 4;
5122
4.09k
      break;
5123
5124
2.55k
    case 3:
5125
2.55k
      mask_for_insn = 2;
5126
2.55k
      break;
5127
5128
0
    case 4:
5129
0
      return PRED_NONE;
5130
11.7k
    }
5131
5132
11.7k
  if (pred_mask & mask_for_insn)
5133
7.46k
    return invert_next_predicate_state (vpt_block_state.next_pred_state);
5134
4.31k
  else
5135
4.31k
    return vpt_block_state.next_pred_state;
5136
11.7k
}
5137
5138
static void
5139
update_vpt_block_state (void)
5140
17.9k
{
5141
17.9k
  vpt_block_state.current_insn_num++;
5142
17.9k
  if (vpt_block_state.current_insn_num == vpt_block_state.num_pred_insn)
5143
6.17k
    {
5144
      /* No more instructions to process in vpt block.  */
5145
6.17k
      mark_outside_vpt_block ();
5146
6.17k
      return;
5147
6.17k
    }
5148
5149
11.7k
  vpt_block_state.next_pred_state = update_next_predicate_state ();
5150
11.7k
}
5151
5152
/* Decode a bitfield of the form matching regexp (N(-N)?,)*N(-N)?.
5153
   Returns pointer to following character of the format string and
5154
   fills in *VALUEP and *WIDTHP with the extracted value and number of
5155
   bits extracted.  WIDTHP can be NULL.  */
5156
5157
static const char *
5158
arm_decode_bitfield (const char *ptr,
5159
         unsigned long insn,
5160
         unsigned long *valuep,
5161
         int *widthp)
5162
16.2M
{
5163
16.2M
  unsigned long value = 0;
5164
16.2M
  int width = 0;
5165
5166
16.2M
  do
5167
16.7M
    {
5168
16.7M
      int start, end;
5169
16.7M
      int bits;
5170
5171
47.1M
      for (start = 0; *ptr >= '0' && *ptr <= '9'; ptr++)
5172
30.3M
  start = start * 10 + *ptr - '0';
5173
16.7M
      if (*ptr == '-')
5174
32.1M
  for (end = 0, ptr++; *ptr >= '0' && *ptr <= '9'; ptr++)
5175
21.1M
    end = end * 10 + *ptr - '0';
5176
5.79M
      else
5177
5.79M
  end = start;
5178
16.7M
      bits = end - start;
5179
16.7M
      if (bits < 0)
5180
0
  abort ();
5181
16.7M
      value |= ((insn >> start) & ((2ul << bits) - 1)) << width;
5182
16.7M
      width += bits + 1;
5183
16.7M
    }
5184
16.7M
  while (*ptr++ == ',');
5185
16.2M
  *valuep = value;
5186
16.2M
  if (widthp)
5187
16.2M
    *widthp = width;
5188
16.2M
  return ptr - 1;
5189
16.2M
}
5190
5191
static void
5192
arm_decode_shift (long given, fprintf_styled_ftype func, void *stream,
5193
      bool print_shift)
5194
2.30M
{
5195
2.30M
  func (stream, dis_style_register, "%s", arm_regnames[given & 0xf]);
5196
5197
2.30M
  if ((given & 0xff0) != 0)
5198
1.55M
    {
5199
1.55M
      if ((given & 0x10) == 0)
5200
1.22M
  {
5201
1.22M
    int amount = (given & 0xf80) >> 7;
5202
1.22M
    int shift = (given & 0x60) >> 5;
5203
5204
1.22M
    if (amount == 0)
5205
175k
      {
5206
175k
        if (shift == 3)
5207
50.4k
    {
5208
50.4k
      func (stream, dis_style_text, ", ");
5209
50.4k
      func (stream, dis_style_sub_mnemonic, "rrx");
5210
50.4k
      return;
5211
50.4k
    }
5212
5213
125k
        amount = 32;
5214
125k
      }
5215
5216
1.17M
    if (print_shift)
5217
1.17M
      {
5218
1.17M
        func (stream, dis_style_text, ", ");
5219
1.17M
        func (stream, dis_style_sub_mnemonic, "%s ", arm_shift[shift]);
5220
1.17M
        func (stream, dis_style_immediate, "#%d", amount);
5221
1.17M
      }
5222
2.15k
    else
5223
2.15k
      {
5224
2.15k
        func (stream, dis_style_text, ", ");
5225
2.15k
        func (stream, dis_style_immediate, "#%d", amount);
5226
2.15k
      }
5227
1.17M
  }
5228
328k
      else if ((given & 0x80) == 0x80)
5229
2.47k
  func (stream, dis_style_comment_start,
5230
2.47k
        "\t@ <illegal shifter operand>");
5231
325k
      else if (print_shift)
5232
325k
  {
5233
325k
    func (stream, dis_style_text, ", ");
5234
325k
    func (stream, dis_style_sub_mnemonic, "%s ",
5235
325k
    arm_shift[(given & 0x60) >> 5]);
5236
325k
    func (stream, dis_style_register, "%s",
5237
325k
    arm_regnames[(given & 0xf00) >> 8]);
5238
325k
  }
5239
618
      else
5240
618
  {
5241
618
    func (stream, dis_style_text, ", ");
5242
618
    func (stream, dis_style_register, "%s",
5243
618
    arm_regnames[(given & 0xf00) >> 8]);
5244
618
  }
5245
1.55M
    }
5246
2.30M
}
5247
5248
/* Return TRUE if the MATCHED_INSN can be inside an IT block.  */
5249
5250
static bool
5251
is_mve_okay_in_it (enum mve_instructions matched_insn)
5252
12.0k
{
5253
12.0k
  switch (matched_insn)
5254
12.0k
    {
5255
219
    case MVE_VMOV_GP_TO_VEC_LANE:
5256
646
    case MVE_VMOV2_VEC_LANE_TO_GP:
5257
2.10k
    case MVE_VMOV2_GP_TO_VEC_LANE:
5258
2.38k
    case MVE_VMOV_VEC_LANE_TO_GP:
5259
2.63k
    case MVE_LSLL:
5260
2.97k
    case MVE_LSLLI:
5261
3.38k
    case MVE_LSRL:
5262
4.02k
    case MVE_ASRL:
5263
4.52k
    case MVE_ASRLI:
5264
4.92k
    case MVE_SQRSHRL:
5265
5.34k
    case MVE_SQRSHR:
5266
5.76k
    case MVE_UQRSHL:
5267
6.22k
    case MVE_UQRSHLL:
5268
6.47k
    case MVE_UQSHL:
5269
6.81k
    case MVE_UQSHLL:
5270
7.20k
    case MVE_URSHRL:
5271
7.41k
    case MVE_URSHR:
5272
7.97k
    case MVE_SRSHRL:
5273
8.28k
    case MVE_SRSHR:
5274
8.49k
    case MVE_SQSHLL:
5275
8.74k
    case MVE_SQSHL:
5276
8.74k
      return true;
5277
3.28k
    default:
5278
3.28k
      return false;
5279
12.0k
    }
5280
12.0k
}
5281
5282
static bool
5283
is_v81m_architecture (struct disassemble_info *info)
5284
1.19M
{
5285
1.19M
  struct arm_private_data *private_data = info->private_data;
5286
1.19M
  arm_feature_set allowed_arches = private_data->features;
5287
5288
1.19M
  arm_feature_set arm_ext_v8_1m_main
5289
1.19M
    = ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN);
5290
5291
1.19M
  if (ARM_CPU_HAS_FEATURE (arm_ext_v8_1m_main, allowed_arches)
5292
1.19M
      && !ARM_CPU_IS_ANY (allowed_arches))
5293
589k
    return true;
5294
603k
  else
5295
603k
    return false;
5296
1.19M
}
5297
5298
static bool
5299
is_vpt_instruction (long given)
5300
136k
{
5301
5302
  /* If mkh:mkl is '0000' then its not a vpt/vpst instruction.  */
5303
136k
  if ((given & 0x0040e000) == 0)
5304
13.8k
    return false;
5305
5306
  /* VPT floating point T1 variant.  */
5307
123k
  if (((given & 0xefb10f50) == 0xee310f00 && ((given & 0x1001) != 0x1))
5308
  /* VPT floating point T2 variant.  */
5309
123k
      || ((given & 0xefb10f50) == 0xee310f40)
5310
  /* VPT vector T1 variant.  */
5311
123k
      || ((given & 0xff811f51) == 0xfe010f00)
5312
  /* VPT vector T2 variant.  */
5313
123k
      || ((given & 0xff811f51) == 0xfe010f01
5314
119k
    && ((given & 0x300000) != 0x300000))
5315
  /* VPT vector T3 variant.  */
5316
123k
      || ((given & 0xff811f50) == 0xfe011f00)
5317
  /* VPT vector T4 variant.  */
5318
123k
      || ((given & 0xff811f70) == 0xfe010f40)
5319
  /* VPT vector T5 variant.  */
5320
123k
      || ((given & 0xff811f70) == 0xfe010f60)
5321
  /* VPT vector T6 variant.  */
5322
123k
      || ((given & 0xff811f50) == 0xfe011f40)
5323
  /* VPST vector T variant.  */
5324
123k
      || ((given & 0xffbf1fff) == 0xfe310f4d))
5325
6.17k
    return true;
5326
116k
  else
5327
116k
    return false;
5328
123k
}
5329
5330
/* Decode a bitfield from opcode GIVEN, with starting bitfield = START
5331
   and ending bitfield = END.  END must be greater than START.  */
5332
5333
static unsigned long
5334
arm_decode_field (unsigned long given, unsigned int start, unsigned int end)
5335
597k
{
5336
597k
  int bits = end - start;
5337
5338
597k
  if (bits < 0)
5339
0
    abort ();
5340
5341
597k
  return ((given >> start) & ((2ul << bits) - 1));
5342
597k
}
5343
5344
/* Decode a bitfield from opcode GIVEN, with multiple bitfields:
5345
   START:END and START2:END2.  END/END2 must be greater than
5346
   START/START2.  */
5347
5348
static unsigned long
5349
arm_decode_field_multiple (unsigned long given, unsigned int start,
5350
         unsigned int end, unsigned int start2,
5351
         unsigned int end2)
5352
67.8k
{
5353
67.8k
  int bits = end - start;
5354
67.8k
  int bits2 = end2 - start2;
5355
67.8k
  unsigned long value = 0;
5356
67.8k
  int width = 0;
5357
5358
67.8k
  if (bits2 < 0)
5359
0
    abort ();
5360
5361
67.8k
  value = arm_decode_field (given, start, end);
5362
67.8k
  width += bits + 1;
5363
5364
67.8k
  value |= ((given >> start2) & ((2ul << bits2) - 1)) << width;
5365
67.8k
  return value;
5366
67.8k
}
5367
5368
/* Return TRUE if the GIVEN encoding should not be decoded as MATCHED_INSN.
5369
   This helps us decode instructions that change mnemonic depending on specific
5370
   operand values/encodings.  */
5371
5372
static bool
5373
is_mve_encoding_conflict (unsigned long given,
5374
        enum mve_instructions matched_insn)
5375
211k
{
5376
211k
  switch (matched_insn)
5377
211k
    {
5378
876
    case MVE_VPST:
5379
876
      if (arm_decode_field_multiple (given, 13, 15, 22, 22) == 0)
5380
596
  return true;
5381
280
      else
5382
280
  return false;
5383
5384
5.47k
    case MVE_VPT_FP_T1:
5385
5.47k
      if (arm_decode_field_multiple (given, 13, 15, 22, 22) == 0)
5386
1.21k
  return true;
5387
4.25k
      if ((arm_decode_field (given, 12, 12) == 0)
5388
4.25k
    && (arm_decode_field (given, 0, 0) == 1))
5389
1.01k
  return true;
5390
3.24k
      return false;
5391
5392
6.74k
    case MVE_VPT_FP_T2:
5393
6.74k
      if (arm_decode_field_multiple (given, 13, 15, 22, 22) == 0)
5394
1.44k
  return true;
5395
5.30k
      if (arm_decode_field (given, 0, 3) == 0xd)
5396
281
  return true;
5397
5.02k
      return false;
5398
5399
2.52k
    case MVE_VPT_VEC_T1:
5400
4.64k
    case MVE_VPT_VEC_T2:
5401
5.83k
    case MVE_VPT_VEC_T3:
5402
8.30k
    case MVE_VPT_VEC_T4:
5403
10.1k
    case MVE_VPT_VEC_T5:
5404
12.0k
    case MVE_VPT_VEC_T6:
5405
12.0k
      if (arm_decode_field_multiple (given, 13, 15, 22, 22) == 0)
5406
3.63k
  return true;
5407
8.40k
      if (arm_decode_field (given, 20, 21) == 3)
5408
1.04k
  return true;
5409
7.36k
      return false;
5410
5411
1.21k
    case MVE_VCMP_FP_T1:
5412
1.21k
      if ((arm_decode_field (given, 12, 12) == 0)
5413
1.21k
    && (arm_decode_field (given, 0, 0) == 1))
5414
228
  return true;
5415
987
      else
5416
987
  return false;
5417
5418
1.44k
    case MVE_VCMP_FP_T2:
5419
1.44k
      if (arm_decode_field (given, 0, 3) == 0xd)
5420
890
  return true;
5421
554
      else
5422
554
  return false;
5423
5424
1.95k
    case MVE_VQADD_T2:
5425
2.72k
    case MVE_VQSUB_T2:
5426
3.65k
    case MVE_VMUL_VEC_T2:
5427
5.08k
    case MVE_VMULH:
5428
6.60k
    case MVE_VRMULH:
5429
6.96k
    case MVE_VMLA:
5430
7.30k
    case MVE_VMAX:
5431
7.93k
    case MVE_VMIN:
5432
9.39k
    case MVE_VBRSR:
5433
10.6k
    case MVE_VADD_VEC_T2:
5434
11.0k
    case MVE_VSUB_VEC_T2:
5435
11.3k
    case MVE_VABAV:
5436
11.6k
    case MVE_VQRSHL_T1:
5437
11.9k
    case MVE_VQSHL_T4:
5438
12.5k
    case MVE_VRSHL_T1:
5439
12.8k
    case MVE_VSHL_T3:
5440
14.0k
    case MVE_VCADD_VEC:
5441
15.4k
    case MVE_VHCADD:
5442
17.7k
    case MVE_VDDUP:
5443
18.1k
    case MVE_VIDUP:
5444
18.6k
    case MVE_VQRDMLADH:
5445
19.3k
    case MVE_VQDMLAH:
5446
19.6k
    case MVE_VQRDMLAH:
5447
19.9k
    case MVE_VQDMLASH:
5448
20.3k
    case MVE_VQRDMLASH:
5449
20.6k
    case MVE_VQDMLSDH:
5450
21.6k
    case MVE_VQRDMLSDH:
5451
22.8k
    case MVE_VQDMULH_T3:
5452
23.2k
    case MVE_VQRDMULH_T4:
5453
23.7k
    case MVE_VQDMLADH:
5454
24.1k
    case MVE_VMLAS:
5455
26.4k
    case MVE_VMULL_INT:
5456
27.0k
    case MVE_VHADD_T2:
5457
27.7k
    case MVE_VHSUB_T2:
5458
28.0k
    case MVE_VCMP_VEC_T1:
5459
28.2k
    case MVE_VCMP_VEC_T2:
5460
28.5k
    case MVE_VCMP_VEC_T3:
5461
29.7k
    case MVE_VCMP_VEC_T4:
5462
30.0k
    case MVE_VCMP_VEC_T5:
5463
30.2k
    case MVE_VCMP_VEC_T6:
5464
30.2k
      if (arm_decode_field (given, 20, 21) == 3)
5465
7.00k
  return true;
5466
23.2k
      else
5467
23.2k
  return false;
5468
5469
666
    case MVE_VLD2:
5470
1.07k
    case MVE_VLD4:
5471
2.50k
    case MVE_VST2:
5472
3.34k
    case MVE_VST4:
5473
3.34k
      if (arm_decode_field (given, 7, 8) == 3)
5474
245
  return true;
5475
3.10k
      else
5476
3.10k
  return false;
5477
5478
2.05k
    case MVE_VSTRB_T1:
5479
3.11k
    case MVE_VSTRH_T2:
5480
3.11k
      if ((arm_decode_field (given, 24, 24) == 0)
5481
3.11k
    && (arm_decode_field (given, 21, 21) == 0))
5482
1.45k
  {
5483
1.45k
      return true;
5484
1.45k
  }
5485
1.66k
      else if ((arm_decode_field (given, 7, 8) == 3))
5486
0
  return true;
5487
1.66k
      else
5488
1.66k
  return false;
5489
5490
2.23k
    case MVE_VLDRB_T1:
5491
3.71k
    case MVE_VLDRH_T2:
5492
4.98k
    case MVE_VLDRW_T7:
5493
5.86k
    case MVE_VSTRB_T5:
5494
6.82k
    case MVE_VSTRH_T6:
5495
8.03k
    case MVE_VSTRW_T7:
5496
8.03k
      if ((arm_decode_field (given, 24, 24) == 0)
5497
8.03k
    && (arm_decode_field (given, 21, 21) == 0))
5498
2.84k
  {
5499
2.84k
      return true;
5500
2.84k
  }
5501
5.19k
      else
5502
5.19k
  return false;
5503
5504
7.16k
    case MVE_VCVT_FP_FIX_VEC:
5505
7.16k
      return (arm_decode_field (given, 16, 21) & 0x38) == 0;
5506
5507
7.60k
    case MVE_VBIC_IMM:
5508
10.6k
    case MVE_VORR_IMM:
5509
10.6k
      {
5510
10.6k
  unsigned long cmode = arm_decode_field (given, 8, 11);
5511
5512
10.6k
  if ((cmode & 1) == 0)
5513
6.35k
    return true;
5514
4.28k
  else if ((cmode & 0xc) == 0xc)
5515
1.15k
    return true;
5516
3.13k
  else
5517
3.13k
    return false;
5518
10.6k
      }
5519
5520
3.54k
    case MVE_VMVN_IMM:
5521
3.54k
      {
5522
3.54k
  unsigned long cmode = arm_decode_field (given, 8, 11);
5523
5524
3.54k
  if (cmode == 0xe)
5525
0
    return true;
5526
3.54k
  else if ((cmode & 0x9) == 1)
5527
0
    return true;
5528
3.54k
  else if ((cmode & 0xd) == 9)
5529
0
    return true;
5530
3.54k
  else
5531
3.54k
    return false;
5532
3.54k
      }
5533
5534
7.21k
    case MVE_VMOV_IMM_TO_VEC:
5535
7.21k
      if ((arm_decode_field (given, 5, 5) == 1)
5536
7.21k
    && (arm_decode_field (given, 8, 11) != 0xe))
5537
3.70k
  return true;
5538
3.51k
      else
5539
3.51k
  return false;
5540
5541
1.33k
    case MVE_VMOVL:
5542
1.33k
      {
5543
1.33k
  unsigned long size = arm_decode_field (given, 19, 20);
5544
1.33k
  if ((size == 0) || (size == 3))
5545
0
    return true;
5546
1.33k
  else
5547
1.33k
    return false;
5548
1.33k
      }
5549
5550
770
    case MVE_VMAXA:
5551
1.36k
    case MVE_VMINA:
5552
2.01k
    case MVE_VMAXV:
5553
2.60k
    case MVE_VMAXAV:
5554
2.81k
    case MVE_VMINV:
5555
3.13k
    case MVE_VMINAV:
5556
3.37k
    case MVE_VQRSHL_T2:
5557
3.59k
    case MVE_VQSHL_T1:
5558
3.86k
    case MVE_VRSHL_T2:
5559
4.40k
    case MVE_VSHL_T2:
5560
4.95k
    case MVE_VSHLL_T2:
5561
5.17k
    case MVE_VADDV:
5562
5.84k
    case MVE_VMOVN:
5563
6.26k
    case MVE_VQMOVUN:
5564
6.62k
    case MVE_VQMOVN:
5565
6.62k
      if (arm_decode_field (given, 18, 19) == 3)
5566
852
  return true;
5567
5.77k
      else
5568
5.77k
  return false;
5569
5570
951
    case MVE_VMLSLDAV:
5571
1.30k
    case MVE_VRMLSLDAVH:
5572
3.58k
    case MVE_VMLALDAV:
5573
4.05k
    case MVE_VADDLV:
5574
4.05k
      if (arm_decode_field (given, 20, 22) == 7)
5575
1.08k
  return true;
5576
2.97k
      else
5577
2.97k
  return false;
5578
5579
1.79k
    case MVE_VRMLALDAVH:
5580
1.79k
      if ((arm_decode_field (given, 20, 22) & 6) == 6)
5581
234
  return true;
5582
1.55k
      else
5583
1.55k
  return false;
5584
5585
1.17k
    case MVE_VDWDUP:
5586
2.59k
    case MVE_VIWDUP:
5587
2.59k
      if ((arm_decode_field (given, 20, 21) == 3)
5588
2.59k
    || (arm_decode_field (given, 1, 3) == 7))
5589
696
  return true;
5590
1.89k
      else
5591
1.89k
  return false;
5592
5593
5594
2.45k
    case MVE_VSHLL_T1:
5595
2.45k
      if (arm_decode_field (given, 16, 18) == 0)
5596
1.54k
  {
5597
1.54k
    unsigned long sz = arm_decode_field (given, 19, 20);
5598
5599
1.54k
    if ((sz == 1) || (sz == 2))
5600
1.33k
      return true;
5601
211
    else
5602
211
      return false;
5603
1.54k
  }
5604
907
      else
5605
907
  return false;
5606
5607
710
    case MVE_VQSHL_T2:
5608
1.69k
    case MVE_VQSHLU_T3:
5609
2.61k
    case MVE_VRSHR:
5610
3.15k
    case MVE_VSHL_T1:
5611
4.71k
    case MVE_VSHR:
5612
5.00k
    case MVE_VSLI:
5613
5.45k
    case MVE_VSRI:
5614
5.45k
      if (arm_decode_field (given, 19, 21) == 0)
5615
787
  return true;
5616
4.66k
      else
5617
4.66k
  return false;
5618
5619
615
    case MVE_VCTP:
5620
615
    if (arm_decode_field (given, 16, 19) == 0xf)
5621
215
      return true;
5622
400
    else
5623
400
      return false;
5624
5625
774
    case MVE_ASRLI:
5626
1.71k
    case MVE_ASRL:
5627
2.69k
    case MVE_LSLLI:
5628
3.20k
    case MVE_LSLL:
5629
4.01k
    case MVE_LSRL:
5630
5.48k
    case MVE_SQRSHRL:
5631
6.05k
    case MVE_SQSHLL:
5632
6.88k
    case MVE_SRSHRL:
5633
8.04k
    case MVE_UQRSHLL:
5634
8.54k
    case MVE_UQSHLL:
5635
9.45k
    case MVE_URSHRL:
5636
9.45k
      if (arm_decode_field (given, 9, 11) == 0x7)
5637
3.08k
  return true;
5638
6.36k
      else
5639
6.36k
  return false;
5640
5641
749
    case MVE_CSINC:
5642
1.80k
    case MVE_CSINV:
5643
1.80k
      {
5644
1.80k
  unsigned long rm, rn;
5645
1.80k
  rm = arm_decode_field (given, 0, 3);
5646
1.80k
  rn = arm_decode_field (given, 16, 19);
5647
  /* CSET/CSETM.  */
5648
1.80k
  if (rm == 0xf && rn == 0xf)
5649
318
    return true;
5650
  /* CINC/CINV.  */
5651
1.48k
  else if (rn == rm && rn != 0xf)
5652
839
    return true;
5653
1.80k
      }
5654
    /* Fall through.  */
5655
1.31k
    case MVE_CSEL:
5656
2.41k
    case MVE_CSNEG:
5657
2.41k
      if (arm_decode_field (given, 0, 3) == 0xd)
5658
304
  return true;
5659
      /* CNEG.  */
5660
2.11k
      else if (matched_insn == MVE_CSNEG)
5661
900
  if (arm_decode_field (given, 0, 3) == arm_decode_field (given, 16, 19))
5662
268
    return true;
5663
1.84k
      return false;
5664
5665
71.5k
    default:
5666
71.9k
    case MVE_VADD_FP_T1:
5667
72.2k
    case MVE_VADD_FP_T2:
5668
72.4k
    case MVE_VADD_VEC_T1:
5669
72.4k
      return false;
5670
5671
211k
    }
5672
211k
}
5673
5674
static void
5675
print_mve_vld_str_addr (struct disassemble_info *info,
5676
      unsigned long given,
5677
      enum mve_instructions matched_insn)
5678
8.49k
{
5679
8.49k
  void *stream = info->stream;
5680
8.49k
  fprintf_styled_ftype func = info->fprintf_styled_func;
5681
5682
8.49k
  unsigned long p, w, gpr, imm, add, mod_imm;
5683
5684
8.49k
  imm = arm_decode_field (given, 0, 6);
5685
8.49k
  mod_imm = imm;
5686
5687
8.49k
  switch (matched_insn)
5688
8.49k
    {
5689
711
    case MVE_VLDRB_T1:
5690
1.52k
    case MVE_VSTRB_T1:
5691
1.52k
      gpr = arm_decode_field (given, 16, 18);
5692
1.52k
      break;
5693
5694
763
    case MVE_VLDRH_T2:
5695
1.61k
    case MVE_VSTRH_T2:
5696
1.61k
      gpr = arm_decode_field (given, 16, 18);
5697
1.61k
      mod_imm = imm << 1;
5698
1.61k
      break;
5699
5700
1.30k
    case MVE_VLDRH_T6:
5701
2.13k
    case MVE_VSTRH_T6:
5702
2.13k
      gpr = arm_decode_field (given, 16, 19);
5703
2.13k
      mod_imm = imm << 1;
5704
2.13k
      break;
5705
5706
1.11k
    case MVE_VLDRW_T7:
5707
2.07k
    case MVE_VSTRW_T7:
5708
2.07k
      gpr = arm_decode_field (given, 16, 19);
5709
2.07k
      mod_imm = imm << 2;
5710
2.07k
      break;
5711
5712
334
    case MVE_VLDRB_T5:
5713
1.15k
    case MVE_VSTRB_T5:
5714
1.15k
      gpr = arm_decode_field (given, 16, 19);
5715
1.15k
      break;
5716
5717
0
    default:
5718
0
      return;
5719
8.49k
    }
5720
5721
8.49k
  p = arm_decode_field (given, 24, 24);
5722
8.49k
  w = arm_decode_field (given, 21, 21);
5723
5724
8.49k
  add = arm_decode_field (given, 23, 23);
5725
5726
8.49k
  char * add_sub;
5727
5728
  /* Don't print anything for '+' as it is implied.  */
5729
8.49k
  if (add == 1)
5730
5.60k
    add_sub = "";
5731
2.89k
  else
5732
2.89k
    add_sub = "-";
5733
5734
8.49k
  func (stream, dis_style_text, "[");
5735
8.49k
  func (stream, dis_style_register, "%s", arm_regnames[gpr]);
5736
8.49k
  if (p == 1)
5737
4.58k
    {
5738
4.58k
      func (stream, dis_style_text, ", ");
5739
4.58k
      func (stream, dis_style_immediate, "#%s%lu", add_sub, mod_imm);
5740
      /* Offset mode.  */
5741
4.58k
      if (w == 0)
5742
2.11k
  func (stream, dis_style_text, "]");
5743
      /* Pre-indexed mode.  */
5744
2.47k
      else
5745
2.47k
  func (stream, dis_style_text, "]!");
5746
4.58k
    }
5747
3.91k
  else if ((p == 0) && (w == 1))
5748
3.61k
    {
5749
      /* Post-index mode.  */
5750
3.61k
      func (stream, dis_style_text, "], ");
5751
3.61k
      func (stream, dis_style_immediate, "#%s%lu", add_sub, mod_imm);
5752
3.61k
    }
5753
8.49k
}
5754
5755
/* Return FALSE if GIVEN is not an undefined encoding for MATCHED_INSN.
5756
   Otherwise, return TRUE and set UNDEFINED_CODE to give a reason as to why
5757
   this encoding is undefined.  */
5758
5759
static bool
5760
is_mve_undefined (unsigned long given, enum mve_instructions matched_insn,
5761
      enum mve_undefined *undefined_code)
5762
167k
{
5763
167k
  *undefined_code = UNDEF_NONE;
5764
5765
167k
  switch (matched_insn)
5766
167k
    {
5767
1.25k
    case MVE_VDUP:
5768
1.25k
      if (arm_decode_field_multiple (given, 5, 5, 22, 22) == 3)
5769
238
  {
5770
238
    *undefined_code = UNDEF_SIZE_3;
5771
238
    return true;
5772
238
  }
5773
1.01k
      else
5774
1.01k
  return false;
5775
5776
1.57k
    case MVE_VQADD_T1:
5777
1.86k
    case MVE_VQSUB_T1:
5778
2.38k
    case MVE_VMUL_VEC_T1:
5779
3.08k
    case MVE_VABD_VEC:
5780
3.30k
    case MVE_VADD_VEC_T1:
5781
3.57k
    case MVE_VSUB_VEC_T1:
5782
3.80k
    case MVE_VQDMULH_T1:
5783
4.03k
    case MVE_VQRDMULH_T2:
5784
5.73k
    case MVE_VRHADD:
5785
6.39k
    case MVE_VHADD_T1:
5786
6.76k
    case MVE_VHSUB_T1:
5787
6.76k
      if (arm_decode_field (given, 20, 21) == 3)
5788
675
  {
5789
675
    *undefined_code = UNDEF_SIZE_3;
5790
675
    return true;
5791
675
  }
5792
6.08k
      else
5793
6.08k
  return false;
5794
5795
711
    case MVE_VLDRB_T1:
5796
711
      if (arm_decode_field (given, 7, 8) == 3)
5797
254
  {
5798
254
    *undefined_code = UNDEF_SIZE_3;
5799
254
    return true;
5800
254
  }
5801
457
      else
5802
457
  return false;
5803
5804
763
    case MVE_VLDRH_T2:
5805
763
      if (arm_decode_field (given, 7, 8) <= 1)
5806
297
  {
5807
297
    *undefined_code = UNDEF_SIZE_LE_1;
5808
297
    return true;
5809
297
  }
5810
466
      else
5811
466
  return false;
5812
5813
812
    case MVE_VSTRB_T1:
5814
812
      if ((arm_decode_field (given, 7, 8) == 0))
5815
432
  {
5816
432
    *undefined_code = UNDEF_SIZE_0;
5817
432
    return true;
5818
432
  }
5819
380
      else
5820
380
  return false;
5821
5822
852
    case MVE_VSTRH_T2:
5823
852
      if ((arm_decode_field (given, 7, 8) <= 1))
5824
385
  {
5825
385
    *undefined_code = UNDEF_SIZE_LE_1;
5826
385
    return true;
5827
385
  }
5828
467
      else
5829
467
  return false;
5830
5831
1.02k
    case MVE_VLDRB_GATHER_T1:
5832
1.02k
      if (arm_decode_field (given, 7, 8) == 3)
5833
303
  {
5834
303
    *undefined_code = UNDEF_SIZE_3;
5835
303
    return true;
5836
303
  }
5837
724
      else if ((arm_decode_field (given, 28, 28) == 0)
5838
724
         && (arm_decode_field (given, 7, 8) == 0))
5839
251
  {
5840
251
    *undefined_code = UNDEF_NOT_UNS_SIZE_0;
5841
251
    return true;
5842
251
  }
5843
473
      else
5844
473
  return false;
5845
5846
1.51k
    case MVE_VLDRH_GATHER_T2:
5847
1.51k
      if (arm_decode_field (given, 7, 8) == 3)
5848
442
  {
5849
442
    *undefined_code = UNDEF_SIZE_3;
5850
442
    return true;
5851
442
  }
5852
1.07k
      else if ((arm_decode_field (given, 28, 28) == 0)
5853
1.07k
         && (arm_decode_field (given, 7, 8) == 1))
5854
233
  {
5855
233
    *undefined_code = UNDEF_NOT_UNS_SIZE_1;
5856
233
    return true;
5857
233
  }
5858
842
      else if (arm_decode_field (given, 7, 8) == 0)
5859
613
  {
5860
613
    *undefined_code = UNDEF_SIZE_0;
5861
613
    return true;
5862
613
  }
5863
229
      else
5864
229
  return false;
5865
5866
228
    case MVE_VLDRW_GATHER_T3:
5867
228
      if (arm_decode_field (given, 7, 8) != 2)
5868
0
  {
5869
0
    *undefined_code = UNDEF_SIZE_NOT_2;
5870
0
    return true;
5871
0
  }
5872
228
      else if (arm_decode_field (given, 28, 28) == 0)
5873
0
  {
5874
0
    *undefined_code = UNDEF_NOT_UNSIGNED;
5875
0
    return true;
5876
0
  }
5877
228
      else
5878
228
  return false;
5879
5880
597
    case MVE_VLDRD_GATHER_T4:
5881
597
      if (arm_decode_field (given, 7, 8) != 3)
5882
0
  {
5883
0
    *undefined_code = UNDEF_SIZE_NOT_3;
5884
0
    return true;
5885
0
  }
5886
597
      else if (arm_decode_field (given, 28, 28) == 0)
5887
346
  {
5888
346
    *undefined_code = UNDEF_NOT_UNSIGNED;
5889
346
    return true;
5890
346
  }
5891
251
      else
5892
251
  return false;
5893
5894
3.37k
    case MVE_VSTRB_SCATTER_T1:
5895
3.37k
      if (arm_decode_field (given, 7, 8) == 3)
5896
1.13k
  {
5897
1.13k
    *undefined_code = UNDEF_SIZE_3;
5898
1.13k
    return true;
5899
1.13k
  }
5900
2.23k
      else
5901
2.23k
  return false;
5902
5903
1.03k
    case MVE_VSTRH_SCATTER_T2:
5904
1.03k
      {
5905
1.03k
  unsigned long size = arm_decode_field (given, 7, 8);
5906
1.03k
  if (size == 3)
5907
459
    {
5908
459
      *undefined_code = UNDEF_SIZE_3;
5909
459
      return true;
5910
459
    }
5911
571
  else if (size == 0)
5912
349
    {
5913
349
      *undefined_code = UNDEF_SIZE_0;
5914
349
      return true;
5915
349
    }
5916
222
  else
5917
222
    return false;
5918
1.03k
      }
5919
5920
1.58k
    case MVE_VSTRW_SCATTER_T3:
5921
1.58k
      if (arm_decode_field (given, 7, 8) != 2)
5922
1.20k
  {
5923
1.20k
    *undefined_code = UNDEF_SIZE_NOT_2;
5924
1.20k
    return true;
5925
1.20k
  }
5926
383
      else
5927
383
  return false;
5928
5929
218
    case MVE_VSTRD_SCATTER_T4:
5930
218
      if (arm_decode_field (given, 7, 8) != 3)
5931
0
  {
5932
0
    *undefined_code = UNDEF_SIZE_NOT_3;
5933
0
    return true;
5934
0
  }
5935
218
      else
5936
218
  return false;
5937
5938
6.03k
    case MVE_VCVT_FP_FIX_VEC:
5939
6.03k
      {
5940
6.03k
  unsigned long imm6 = arm_decode_field (given, 16, 21);
5941
6.03k
  if ((imm6 & 0x20) == 0)
5942
427
    {
5943
427
      *undefined_code = UNDEF_VCVT_IMM6;
5944
427
      return true;
5945
427
    }
5946
5947
5.60k
  if ((arm_decode_field (given, 9, 9) == 0)
5948
5.60k
      && ((imm6 & 0x30) == 0x20))
5949
1.19k
    {
5950
1.19k
      *undefined_code = UNDEF_VCVT_FSI_IMM6;
5951
1.19k
      return true;
5952
1.19k
    }
5953
5954
4.40k
  return false;
5955
5.60k
      }
5956
5957
282
    case MVE_VNEG_FP:
5958
514
    case MVE_VABS_FP:
5959
3.67k
    case MVE_VCVT_BETWEEN_FP_INT:
5960
6.84k
    case MVE_VCVT_FROM_FP_TO_INT:
5961
6.84k
      {
5962
6.84k
  unsigned long size = arm_decode_field (given, 18, 19);
5963
6.84k
  if (size == 0)
5964
364
    {
5965
364
      *undefined_code = UNDEF_SIZE_0;
5966
364
      return true;
5967
364
    }
5968
6.48k
  else if (size == 3)
5969
1.93k
    {
5970
1.93k
      *undefined_code = UNDEF_SIZE_3;
5971
1.93k
      return true;
5972
1.93k
    }
5973
4.55k
  else
5974
4.55k
    return false;
5975
6.84k
      }
5976
5977
974
    case MVE_VMOV_VEC_LANE_TO_GP:
5978
974
      {
5979
974
  unsigned long op1 = arm_decode_field (given, 21, 22);
5980
974
  unsigned long op2 = arm_decode_field (given, 5, 6);
5981
974
  unsigned long u = arm_decode_field (given, 23, 23);
5982
5983
974
  if ((op2 == 0) && (u == 1))
5984
0
    {
5985
0
      if ((op1 == 0) || (op1 == 1))
5986
0
        {
5987
0
    *undefined_code = UNDEF_BAD_U_OP1_OP2;
5988
0
    return true;
5989
0
        }
5990
0
      else
5991
0
        return false;
5992
0
    }
5993
974
  else if (op2 == 2)
5994
974
    {
5995
974
      if ((op1 == 0) || (op1 == 1))
5996
974
        {
5997
974
    *undefined_code = UNDEF_BAD_OP1_OP2;
5998
974
    return true;
5999
974
        }
6000
0
      else
6001
0
        return false;
6002
974
    }
6003
6004
0
  return false;
6005
974
      }
6006
6007
816
    case MVE_VMOV_GP_TO_VEC_LANE:
6008
816
      if (arm_decode_field (given, 5, 6) == 2)
6009
816
  {
6010
816
    unsigned long op1 = arm_decode_field (given, 21, 22);
6011
816
    if ((op1 == 0) || (op1 == 1))
6012
816
      {
6013
816
        *undefined_code = UNDEF_BAD_OP1_OP2;
6014
816
        return true;
6015
816
      }
6016
0
    else
6017
0
      return false;
6018
816
  }
6019
0
      else
6020
0
  return false;
6021
6022
632
    case MVE_VMOV_VEC_TO_VEC:
6023
632
      if ((arm_decode_field (given, 5, 5) == 1)
6024
632
    || (arm_decode_field (given, 22, 22) == 1))
6025
437
    return true;
6026
195
      return false;
6027
6028
3.51k
    case MVE_VMOV_IMM_TO_VEC:
6029
3.51k
      if (arm_decode_field (given, 5, 5) == 0)
6030
2.74k
      {
6031
2.74k
  unsigned long cmode = arm_decode_field (given, 8, 11);
6032
6033
2.74k
  if (((cmode & 9) == 1) || ((cmode & 5) == 1))
6034
0
    {
6035
0
      *undefined_code = UNDEF_OP_0_BAD_CMODE;
6036
0
      return true;
6037
0
    }
6038
2.74k
  else
6039
2.74k
    return false;
6040
2.74k
      }
6041
769
      else
6042
769
  return false;
6043
6044
549
    case MVE_VSHLL_T2:
6045
1.21k
    case MVE_VMOVN:
6046
1.21k
      if (arm_decode_field (given, 18, 19) == 2)
6047
675
  {
6048
675
    *undefined_code = UNDEF_SIZE_2;
6049
675
    return true;
6050
675
  }
6051
542
      else
6052
542
  return false;
6053
6054
1.55k
    case MVE_VRMLALDAVH:
6055
2.07k
    case MVE_VMLADAV_T1:
6056
2.33k
    case MVE_VMLADAV_T2:
6057
4.10k
    case MVE_VMLALDAV:
6058
4.10k
      if ((arm_decode_field (given, 28, 28) == 1)
6059
4.10k
    && (arm_decode_field (given, 12, 12) == 1))
6060
719
  {
6061
719
    *undefined_code = UNDEF_XCHG_UNS;
6062
719
    return true;
6063
719
  }
6064
3.38k
      else
6065
3.38k
  return false;
6066
6067
261
    case MVE_VQSHRN:
6068
751
    case MVE_VQSHRUN:
6069
1.86k
    case MVE_VSHLL_T1:
6070
2.22k
    case MVE_VSHRN:
6071
2.22k
      {
6072
2.22k
  unsigned long sz = arm_decode_field (given, 19, 20);
6073
2.22k
  if (sz == 1)
6074
826
    return false;
6075
1.39k
  else if ((sz & 2) == 2)
6076
724
    return false;
6077
672
  else
6078
672
    {
6079
672
      *undefined_code = UNDEF_SIZE;
6080
672
      return true;
6081
672
    }
6082
2.22k
      }
6083
0
      break;
6084
6085
710
    case MVE_VQSHL_T2:
6086
1.49k
    case MVE_VQSHLU_T3:
6087
2.06k
    case MVE_VRSHR:
6088
2.60k
    case MVE_VSHL_T1:
6089
4.13k
    case MVE_VSHR:
6090
4.43k
    case MVE_VSLI:
6091
4.66k
    case MVE_VSRI:
6092
4.66k
      {
6093
4.66k
  unsigned long sz = arm_decode_field (given, 19, 21);
6094
4.66k
  if ((sz & 7) == 1)
6095
619
    return false;
6096
4.04k
  else if ((sz & 6) == 2)
6097
370
    return false;
6098
3.67k
  else if ((sz & 4) == 4)
6099
3.67k
    return false;
6100
0
  else
6101
0
    {
6102
0
      *undefined_code = UNDEF_SIZE;
6103
0
      return true;
6104
0
    }
6105
4.66k
      }
6106
6107
984
    case MVE_VQRSHRN:
6108
1.38k
    case MVE_VQRSHRUN:
6109
1.38k
      if (arm_decode_field (given, 19, 20) == 0)
6110
868
  {
6111
868
    *undefined_code = UNDEF_SIZE_0;
6112
868
    return true;
6113
868
  }
6114
515
      else
6115
515
  return false;
6116
6117
567
    case MVE_VABS_VEC:
6118
567
  if (arm_decode_field (given, 18, 19) == 3)
6119
339
  {
6120
339
    *undefined_code = UNDEF_SIZE_3;
6121
339
    return true;
6122
339
  }
6123
228
  else
6124
228
    return false;
6125
6126
234
    case MVE_VQNEG:
6127
633
    case MVE_VQABS:
6128
916
    case MVE_VNEG_VEC:
6129
1.14k
    case MVE_VCLS:
6130
1.36k
    case MVE_VCLZ:
6131
1.36k
      if (arm_decode_field (given, 18, 19) == 3)
6132
532
  {
6133
532
    *undefined_code = UNDEF_SIZE_3;
6134
532
    return true;
6135
532
  }
6136
833
      else
6137
833
  return false;
6138
6139
559
    case MVE_VREV16:
6140
559
      if (arm_decode_field (given, 18, 19) == 0)
6141
275
  return false;
6142
284
      else
6143
284
  {
6144
284
    *undefined_code = UNDEF_SIZE_NOT_0;
6145
284
    return true;
6146
284
  }
6147
6148
568
    case MVE_VREV32:
6149
568
      {
6150
568
  unsigned long size = arm_decode_field (given, 18, 19);
6151
568
  if ((size & 2) == 2)
6152
204
    {
6153
204
      *undefined_code = UNDEF_SIZE_2;
6154
204
      return true;
6155
204
    }
6156
364
  else
6157
364
    return false;
6158
568
      }
6159
6160
686
    case MVE_VREV64:
6161
686
      if (arm_decode_field (given, 18, 19) != 3)
6162
322
  return false;
6163
364
      else
6164
364
  {
6165
364
    *undefined_code = UNDEF_SIZE_3;
6166
364
    return true;
6167
364
  }
6168
6169
110k
    default:
6170
110k
      return false;
6171
167k
    }
6172
167k
}
6173
6174
/* Return FALSE if GIVEN is not an unpredictable encoding for MATCHED_INSN.
6175
   Otherwise, return TRUE and set UNPREDICTABLE_CODE to give a reason as to
6176
   why this encoding is unpredictable.  */
6177
6178
static bool
6179
is_mve_unpredictable (unsigned long given, enum mve_instructions matched_insn,
6180
          enum mve_unpredictable *unpredictable_code)
6181
164k
{
6182
164k
  *unpredictable_code = UNPRED_NONE;
6183
6184
164k
  switch (matched_insn)
6185
164k
    {
6186
554
    case MVE_VCMP_FP_T2:
6187
5.57k
    case MVE_VPT_FP_T2:
6188
5.57k
      if ((arm_decode_field (given, 12, 12) == 0)
6189
5.57k
    && (arm_decode_field (given, 5, 5) == 1))
6190
565
  {
6191
565
    *unpredictable_code = UNPRED_FCA_0_FCB_1;
6192
565
    return true;
6193
565
  }
6194
5.00k
      else
6195
5.00k
  return false;
6196
6197
1.17k
    case MVE_VPT_VEC_T4:
6198
2.48k
    case MVE_VPT_VEC_T5:
6199
4.11k
    case MVE_VPT_VEC_T6:
6200
4.50k
    case MVE_VCMP_VEC_T4:
6201
4.75k
    case MVE_VCMP_VEC_T5:
6202
4.97k
    case MVE_VCMP_VEC_T6:
6203
4.97k
      if (arm_decode_field (given, 0, 3) == 0xd)
6204
1.03k
  {
6205
1.03k
    *unpredictable_code = UNPRED_R13;
6206
1.03k
    return true;
6207
1.03k
  }
6208
3.94k
      else
6209
3.94k
  return false;
6210
6211
1.25k
    case MVE_VDUP:
6212
1.25k
      {
6213
1.25k
  unsigned long gpr = arm_decode_field (given, 12, 15);
6214
1.25k
  if (gpr == 0xd)
6215
207
    {
6216
207
      *unpredictable_code = UNPRED_R13;
6217
207
      return true;
6218
207
    }
6219
1.04k
  else if (gpr == 0xf)
6220
232
    {
6221
232
      *unpredictable_code = UNPRED_R15;
6222
232
      return true;
6223
232
    }
6224
6225
813
  return false;
6226
1.25k
      }
6227
6228
904
    case MVE_VQADD_T2:
6229
1.67k
    case MVE_VQSUB_T2:
6230
2.19k
    case MVE_VMUL_FP_T2:
6231
2.44k
    case MVE_VMUL_VEC_T2:
6232
2.79k
    case MVE_VMLA:
6233
3.66k
    case MVE_VBRSR:
6234
3.98k
    case MVE_VADD_FP_T2:
6235
4.30k
    case MVE_VSUB_FP_T2:
6236
5.36k
    case MVE_VADD_VEC_T2:
6237
5.71k
    case MVE_VSUB_VEC_T2:
6238
5.93k
    case MVE_VQRSHL_T2:
6239
6.15k
    case MVE_VQSHL_T1:
6240
6.42k
    case MVE_VRSHL_T2:
6241
6.95k
    case MVE_VSHL_T2:
6242
8.38k
    case MVE_VSHLC:
6243
8.94k
    case MVE_VQDMLAH:
6244
9.18k
    case MVE_VQRDMLAH:
6245
9.50k
    case MVE_VQDMLASH:
6246
9.93k
    case MVE_VQRDMLASH:
6247
11.1k
    case MVE_VQDMULH_T3:
6248
11.5k
    case MVE_VQRDMULH_T4:
6249
11.9k
    case MVE_VMLAS:
6250
12.1k
    case MVE_VFMA_FP_SCALAR:
6251
12.6k
    case MVE_VFMAS_FP_SCALAR:
6252
13.1k
    case MVE_VHADD_T2:
6253
13.5k
    case MVE_VHSUB_T2:
6254
13.5k
      {
6255
13.5k
  unsigned long gpr = arm_decode_field (given, 0, 3);
6256
13.5k
  if (gpr == 0xd)
6257
1.14k
    {
6258
1.14k
      *unpredictable_code = UNPRED_R13;
6259
1.14k
      return true;
6260
1.14k
    }
6261
12.3k
  else if (gpr == 0xf)
6262
2.72k
    {
6263
2.72k
      *unpredictable_code = UNPRED_R15;
6264
2.72k
      return true;
6265
2.72k
    }
6266
6267
9.64k
  return false;
6268
13.5k
      }
6269
6270
463
    case MVE_VLD2:
6271
1.87k
    case MVE_VST2:
6272
1.87k
      {
6273
1.87k
  unsigned long rn = arm_decode_field (given, 16, 19);
6274
6275
1.87k
  if ((rn == 0xd) && (arm_decode_field (given, 21, 21) == 1))
6276
845
    {
6277
845
      *unpredictable_code = UNPRED_R13_AND_WB;
6278
845
      return true;
6279
845
    }
6280
6281
1.02k
  if (rn == 0xf)
6282
268
    {
6283
268
      *unpredictable_code = UNPRED_R15;
6284
268
      return true;
6285
268
    }
6286
6287
760
  if (arm_decode_field_multiple (given, 13, 15, 22, 22) > 6)
6288
309
    {
6289
309
      *unpredictable_code = UNPRED_Q_GT_6;
6290
309
      return true;
6291
309
    }
6292
451
  else
6293
451
    return false;
6294
760
      }
6295
6296
404
    case MVE_VLD4:
6297
1.22k
    case MVE_VST4:
6298
1.22k
      {
6299
1.22k
  unsigned long rn = arm_decode_field (given, 16, 19);
6300
6301
1.22k
  if ((rn == 0xd) && (arm_decode_field (given, 21, 21) == 1))
6302
261
    {
6303
261
      *unpredictable_code = UNPRED_R13_AND_WB;
6304
261
      return true;
6305
261
    }
6306
6307
965
  if (rn == 0xf)
6308
348
    {
6309
348
      *unpredictable_code = UNPRED_R15;
6310
348
      return true;
6311
348
    }
6312
6313
617
  if (arm_decode_field_multiple (given, 13, 15, 22, 22) > 4)
6314
392
    {
6315
392
      *unpredictable_code = UNPRED_Q_GT_4;
6316
392
      return true;
6317
392
    }
6318
225
  else
6319
225
    return false;
6320
617
      }
6321
6322
334
    case MVE_VLDRB_T5:
6323
1.63k
    case MVE_VLDRH_T6:
6324
2.74k
    case MVE_VLDRW_T7:
6325
3.55k
    case MVE_VSTRB_T5:
6326
4.38k
    case MVE_VSTRH_T6:
6327
5.34k
    case MVE_VSTRW_T7:
6328
5.34k
      {
6329
5.34k
  unsigned long rn = arm_decode_field (given, 16, 19);
6330
6331
5.34k
  if ((rn == 0xd) && (arm_decode_field (given, 21, 21) == 1))
6332
534
    {
6333
534
      *unpredictable_code = UNPRED_R13_AND_WB;
6334
534
      return true;
6335
534
    }
6336
4.80k
  else if (rn == 0xf)
6337
904
    {
6338
904
      *unpredictable_code = UNPRED_R15;
6339
904
      return true;
6340
904
    }
6341
3.90k
  else
6342
3.90k
    return false;
6343
5.34k
      }
6344
6345
1.02k
    case MVE_VLDRB_GATHER_T1:
6346
1.02k
      if (arm_decode_field (given, 0, 0) == 1)
6347
565
  {
6348
565
    *unpredictable_code = UNPRED_OS;
6349
565
    return true;
6350
565
  }
6351
6352
      /*  fall through.  */
6353
      /* To handle common code with T2-T4 variants.  */
6354
1.97k
    case MVE_VLDRH_GATHER_T2:
6355
2.20k
    case MVE_VLDRW_GATHER_T3:
6356
2.80k
    case MVE_VLDRD_GATHER_T4:
6357
2.80k
      {
6358
2.80k
  unsigned long qd = arm_decode_field_multiple (given, 13, 15, 22, 22);
6359
2.80k
  unsigned long qm = arm_decode_field_multiple (given, 1, 3, 5, 5);
6360
6361
2.80k
  if (qd == qm)
6362
325
    {
6363
325
      *unpredictable_code = UNPRED_Q_REGS_EQUAL;
6364
325
      return true;
6365
325
    }
6366
6367
2.47k
  if (arm_decode_field (given, 16, 19) == 0xf)
6368
969
    {
6369
969
      *unpredictable_code = UNPRED_R15;
6370
969
      return true;
6371
969
    }
6372
6373
1.50k
  return false;
6374
2.47k
      }
6375
6376
1.00k
    case MVE_VLDRW_GATHER_T5:
6377
1.77k
    case MVE_VLDRD_GATHER_T6:
6378
1.77k
      {
6379
1.77k
  unsigned long qd = arm_decode_field_multiple (given, 13, 15, 22, 22);
6380
1.77k
  unsigned long qm = arm_decode_field_multiple (given, 17, 19, 7, 7);
6381
6382
1.77k
  if (qd == qm)
6383
597
    {
6384
597
      *unpredictable_code = UNPRED_Q_REGS_EQUAL;
6385
597
      return true;
6386
597
    }
6387
1.17k
  else
6388
1.17k
    return false;
6389
1.77k
      }
6390
6391
3.37k
    case MVE_VSTRB_SCATTER_T1:
6392
3.37k
      if (arm_decode_field (given, 16, 19) == 0xf)
6393
642
  {
6394
642
    *unpredictable_code = UNPRED_R15;
6395
642
    return true;
6396
642
  }
6397
2.73k
      else if (arm_decode_field (given, 0, 0) == 1)
6398
2.36k
  {
6399
2.36k
    *unpredictable_code = UNPRED_OS;
6400
2.36k
    return true;
6401
2.36k
  }
6402
370
      else
6403
370
  return false;
6404
6405
1.02k
    case MVE_VSTRH_SCATTER_T2:
6406
2.61k
    case MVE_VSTRW_SCATTER_T3:
6407
2.82k
    case MVE_VSTRD_SCATTER_T4:
6408
2.82k
      if (arm_decode_field (given, 16, 19) == 0xf)
6409
540
  {
6410
540
    *unpredictable_code = UNPRED_R15;
6411
540
    return true;
6412
540
  }
6413
2.28k
      else
6414
2.28k
  return false;
6415
6416
1.36k
    case MVE_VMOV2_VEC_LANE_TO_GP:
6417
3.36k
    case MVE_VMOV2_GP_TO_VEC_LANE:
6418
6.52k
    case MVE_VCVT_BETWEEN_FP_INT:
6419
9.68k
    case MVE_VCVT_FROM_FP_TO_INT:
6420
9.68k
      {
6421
9.68k
  unsigned long rt = arm_decode_field (given, 0, 3);
6422
9.68k
  unsigned long rt2 = arm_decode_field (given, 16, 19);
6423
6424
9.68k
  if ((rt == 0xd) || (rt2 == 0xd))
6425
690
    {
6426
690
      *unpredictable_code = UNPRED_R13;
6427
690
      return true;
6428
690
    }
6429
8.99k
  else if ((rt == 0xf) || (rt2 == 0xf))
6430
2.63k
    {
6431
2.63k
      *unpredictable_code = UNPRED_R15;
6432
2.63k
      return true;
6433
2.63k
    }
6434
6.35k
  else if (rt == rt2 && matched_insn != MVE_VMOV2_GP_TO_VEC_LANE)
6435
220
    {
6436
220
      *unpredictable_code = UNPRED_GP_REGS_EQUAL;
6437
220
      return true;
6438
220
    }
6439
6440
6.13k
  return false;
6441
9.68k
      }
6442
6443
650
    case MVE_VMAXV:
6444
1.23k
    case MVE_VMAXAV:
6445
1.51k
    case MVE_VMAXNMV_FP:
6446
1.86k
    case MVE_VMAXNMAV_FP:
6447
2.12k
    case MVE_VMINNMV_FP:
6448
2.35k
    case MVE_VMINNMAV_FP:
6449
2.56k
    case MVE_VMINV:
6450
2.88k
    case MVE_VMINAV:
6451
3.20k
    case MVE_VABAV:
6452
3.20k
    case MVE_VMOV_HFP_TO_GP:
6453
4.02k
    case MVE_VMOV_GP_TO_VEC_LANE:
6454
4.99k
    case MVE_VMOV_VEC_LANE_TO_GP:
6455
4.99k
      {
6456
4.99k
  unsigned long rda = arm_decode_field (given, 12, 15);
6457
4.99k
  if (rda == 0xd)
6458
239
    {
6459
239
      *unpredictable_code = UNPRED_R13;
6460
239
      return true;
6461
239
    }
6462
4.75k
  else if (rda == 0xf)
6463
904
    {
6464
904
      *unpredictable_code = UNPRED_R15;
6465
904
      return true;
6466
904
    }
6467
6468
3.85k
  return false;
6469
4.99k
      }
6470
6471
1.39k
    case MVE_VMULL_INT:
6472
1.39k
      {
6473
1.39k
  unsigned long Qd;
6474
1.39k
  unsigned long Qm;
6475
1.39k
  unsigned long Qn;
6476
6477
1.39k
  if (arm_decode_field (given, 20, 21) == 2)
6478
1.00k
    {
6479
1.00k
      Qd = arm_decode_field_multiple (given, 13, 15, 22, 22);
6480
1.00k
      Qm = arm_decode_field_multiple (given, 1, 3, 5, 5);
6481
1.00k
      Qn = arm_decode_field_multiple (given, 17, 19, 7, 7);
6482
6483
1.00k
      if ((Qd == Qn) || (Qd == Qm))
6484
498
        {
6485
498
    *unpredictable_code = UNPRED_Q_REGS_EQ_AND_SIZE_2;
6486
498
    return true;
6487
498
        }
6488
503
      else
6489
503
        return false;
6490
1.00k
    }
6491
391
  else
6492
391
    return false;
6493
1.39k
      }
6494
6495
2.13k
    case MVE_VCMUL_FP:
6496
3.23k
    case MVE_VQDMULL_T1:
6497
3.23k
      {
6498
3.23k
  unsigned long Qd;
6499
3.23k
  unsigned long Qm;
6500
3.23k
  unsigned long Qn;
6501
6502
3.23k
  if (arm_decode_field (given, 28, 28) == 1)
6503
2.09k
    {
6504
2.09k
      Qd = arm_decode_field_multiple (given, 13, 15, 22, 22);
6505
2.09k
      Qm = arm_decode_field_multiple (given, 1, 3, 5, 5);
6506
2.09k
      Qn = arm_decode_field_multiple (given, 17, 19, 7, 7);
6507
6508
2.09k
      if ((Qd == Qn) || (Qd == Qm))
6509
503
        {
6510
503
    *unpredictable_code = UNPRED_Q_REGS_EQ_AND_SIZE_1;
6511
503
    return true;
6512
503
        }
6513
1.59k
      else
6514
1.59k
        return false;
6515
2.09k
    }
6516
1.13k
  else
6517
1.13k
    return false;
6518
3.23k
      }
6519
6520
2.34k
    case MVE_VQDMULL_T2:
6521
2.34k
      {
6522
2.34k
  unsigned long gpr = arm_decode_field (given, 0, 3);
6523
2.34k
  if (gpr == 0xd)
6524
426
    {
6525
426
      *unpredictable_code = UNPRED_R13;
6526
426
      return true;
6527
426
    }
6528
1.91k
  else if (gpr == 0xf)
6529
326
    {
6530
326
      *unpredictable_code = UNPRED_R15;
6531
326
      return true;
6532
326
    }
6533
6534
1.59k
  if (arm_decode_field (given, 28, 28) == 1)
6535
753
    {
6536
753
      unsigned long Qd
6537
753
        = arm_decode_field_multiple (given, 13, 15, 22, 22);
6538
753
      unsigned long Qn = arm_decode_field_multiple (given, 17, 19, 7, 7);
6539
6540
753
      if (Qd == Qn)
6541
459
        {
6542
459
    *unpredictable_code = UNPRED_Q_REGS_EQ_AND_SIZE_1;
6543
459
    return true;
6544
459
        }
6545
294
      else
6546
294
        return false;
6547
753
    }
6548
6549
838
  return false;
6550
1.59k
      }
6551
6552
635
    case MVE_VMLSLDAV:
6553
947
    case MVE_VRMLSLDAVH:
6554
2.72k
    case MVE_VMLALDAV:
6555
2.96k
    case MVE_VADDLV:
6556
2.96k
      if (arm_decode_field (given, 20, 22) == 6)
6557
1.33k
  {
6558
1.33k
    *unpredictable_code = UNPRED_R13;
6559
1.33k
    return true;
6560
1.33k
  }
6561
1.63k
      else
6562
1.63k
  return false;
6563
6564
984
    case MVE_VDWDUP:
6565
1.89k
    case MVE_VIWDUP:
6566
1.89k
      if (arm_decode_field (given, 1, 3) == 6)
6567
547
  {
6568
547
    *unpredictable_code = UNPRED_R13;
6569
547
    return true;
6570
547
  }
6571
1.35k
      else
6572
1.35k
  return false;
6573
6574
556
    case MVE_VCADD_VEC:
6575
1.91k
    case MVE_VHCADD:
6576
1.91k
      {
6577
1.91k
  unsigned long Qd = arm_decode_field_multiple (given, 13, 15, 22, 22);
6578
1.91k
  unsigned long Qm = arm_decode_field_multiple (given, 1, 3, 5, 5);
6579
1.91k
  if ((Qd == Qm) && arm_decode_field (given, 20, 21) == 2)
6580
273
    {
6581
273
      *unpredictable_code = UNPRED_Q_REGS_EQ_AND_SIZE_2;
6582
273
      return true;
6583
273
    }
6584
1.64k
  else
6585
1.64k
    return false;
6586
1.91k
      }
6587
6588
689
    case MVE_VCADD_FP:
6589
689
      {
6590
689
  unsigned long Qd = arm_decode_field_multiple (given, 13, 15, 22, 22);
6591
689
  unsigned long Qm = arm_decode_field_multiple (given, 1, 3, 5, 5);
6592
689
  if ((Qd == Qm) && arm_decode_field (given, 20, 20) == 1)
6593
228
    {
6594
228
      *unpredictable_code = UNPRED_Q_REGS_EQ_AND_SIZE_1;
6595
228
      return true;
6596
228
    }
6597
461
  else
6598
461
    return false;
6599
689
      }
6600
6601
1.89k
    case MVE_VCMLA_FP:
6602
1.89k
      {
6603
1.89k
  unsigned long Qda;
6604
1.89k
  unsigned long Qm;
6605
1.89k
  unsigned long Qn;
6606
6607
1.89k
  if (arm_decode_field (given, 20, 20) == 1)
6608
958
    {
6609
958
      Qda = arm_decode_field_multiple (given, 13, 15, 22, 22);
6610
958
      Qm = arm_decode_field_multiple (given, 1, 3, 5, 5);
6611
958
      Qn = arm_decode_field_multiple (given, 17, 19, 7, 7);
6612
6613
958
      if ((Qda == Qn) || (Qda == Qm))
6614
549
        {
6615
549
    *unpredictable_code = UNPRED_Q_REGS_EQ_AND_SIZE_1;
6616
549
    return true;
6617
549
        }
6618
409
      else
6619
409
        return false;
6620
958
    }
6621
940
  else
6622
940
    return false;
6623
6624
1.89k
      }
6625
6626
400
    case MVE_VCTP:
6627
400
      if (arm_decode_field (given, 16, 19) == 0xd)
6628
194
  {
6629
194
    *unpredictable_code = UNPRED_R13;
6630
194
    return true;
6631
194
  }
6632
206
      else
6633
206
  return false;
6634
6635
686
    case MVE_VREV64:
6636
686
      {
6637
686
  unsigned long qd = arm_decode_field_multiple (given, 13, 15, 22, 22);
6638
686
  unsigned long qm = arm_decode_field_multiple (given, 1, 3, 6, 6);
6639
6640
686
  if (qd == qm)
6641
231
    {
6642
231
      *unpredictable_code = UNPRED_Q_REGS_EQUAL;
6643
231
      return true;
6644
231
    }
6645
455
  else
6646
455
    return false;
6647
686
      }
6648
6649
314
    case MVE_LSLL:
6650
863
    case MVE_LSLLI:
6651
1.49k
    case MVE_LSRL:
6652
2.22k
    case MVE_ASRL:
6653
2.87k
    case MVE_ASRLI:
6654
3.28k
    case MVE_UQSHLL:
6655
3.93k
    case MVE_UQRSHLL:
6656
4.56k
    case MVE_URSHRL:
6657
5.20k
    case MVE_SRSHRL:
6658
5.73k
    case MVE_SQSHLL:
6659
6.36k
    case MVE_SQRSHRL:
6660
6.36k
      {
6661
6.36k
  unsigned long gpr = arm_decode_field (given, 9, 11);
6662
6.36k
  gpr = ((gpr << 1) | 1);
6663
6.36k
  if (gpr == 0xd)
6664
2.70k
    {
6665
2.70k
      *unpredictable_code = UNPRED_R13;
6666
2.70k
      return true;
6667
2.70k
    }
6668
3.66k
  else if (gpr == 0xf)
6669
0
    {
6670
0
      *unpredictable_code = UNPRED_R15;
6671
0
      return true;
6672
0
    }
6673
6674
3.66k
  return false;
6675
6.36k
      }
6676
6677
80.4k
    default:
6678
80.4k
      return false;
6679
164k
    }
6680
164k
}
6681
6682
static void
6683
print_mve_vmov_index (struct disassemble_info *info, unsigned long given)
6684
1.79k
{
6685
1.79k
  unsigned long op1 = arm_decode_field (given, 21, 22);
6686
1.79k
  unsigned long op2 = arm_decode_field (given, 5, 6);
6687
1.79k
  unsigned long h = arm_decode_field (given, 16, 16);
6688
1.79k
  unsigned long index_operand, esize, targetBeat, idx;
6689
1.79k
  void *stream = info->stream;
6690
1.79k
  fprintf_styled_ftype func = info->fprintf_styled_func;
6691
6692
1.79k
  if ((op1 & 0x2) == 0x2)
6693
0
    {
6694
0
      index_operand = op2;
6695
0
      esize = 8;
6696
0
    }
6697
1.79k
  else if (((op1 & 0x2) == 0x0) && ((op2 & 0x1) == 0x1))
6698
0
    {
6699
0
      index_operand = op2  >> 1;
6700
0
      esize = 16;
6701
0
    }
6702
1.79k
  else if (((op1 & 0x2) == 0) && ((op2 & 0x3) == 0))
6703
0
    {
6704
0
      index_operand = 0;
6705
0
      esize = 32;
6706
0
    }
6707
1.79k
  else
6708
1.79k
    {
6709
1.79k
      func (stream, dis_style_text, "<undefined index>");
6710
1.79k
      return;
6711
1.79k
    }
6712
6713
0
  targetBeat =  (op1 & 0x1) | (h << 1);
6714
0
  idx = index_operand + targetBeat * (32/esize);
6715
6716
0
  func (stream, dis_style_immediate, "%lu", idx);
6717
0
}
6718
6719
/* Print neon and mve 8-bit immediate that can be a 8, 16, 32, or 64-bits
6720
   in length and integer of floating-point type.  */
6721
static void
6722
print_simd_imm8 (struct disassemble_info *info, unsigned long given,
6723
     unsigned int ibit_loc, const struct mopcode32 *insn)
6724
9.98k
{
6725
9.98k
  int bits = 0;
6726
9.98k
  int cmode = (given >> 8) & 0xf;
6727
9.98k
  int op = (given >> 5) & 0x1;
6728
9.98k
  unsigned long value = 0, hival = 0;
6729
9.98k
  unsigned shift;
6730
9.98k
  int size = 0;
6731
9.98k
  int isfloat = 0;
6732
9.98k
  void *stream = info->stream;
6733
9.98k
  fprintf_styled_ftype func = info->fprintf_styled_func;
6734
6735
  /* On Neon the 'i' bit is at bit 24, on mve it is
6736
     at bit 28.  */
6737
9.98k
  bits |= ((given >> ibit_loc) & 1) << 7;
6738
9.98k
  bits |= ((given >> 16) & 7) << 4;
6739
9.98k
  bits |= ((given >> 0) & 15) << 0;
6740
6741
9.98k
  if (cmode < 8)
6742
4.99k
    {
6743
4.99k
      shift = (cmode >> 1) & 3;
6744
4.99k
      value = (unsigned long) bits << (8 * shift);
6745
4.99k
      size = 32;
6746
4.99k
    }
6747
4.99k
  else if (cmode < 12)
6748
2.39k
    {
6749
2.39k
      shift = (cmode >> 1) & 1;
6750
2.39k
      value = (unsigned long) bits << (8 * shift);
6751
2.39k
      size = 16;
6752
2.39k
    }
6753
2.59k
  else if (cmode < 14)
6754
1.28k
    {
6755
1.28k
      shift = (cmode & 1) + 1;
6756
1.28k
      value = (unsigned long) bits << (8 * shift);
6757
1.28k
      value |= (1ul << (8 * shift)) - 1;
6758
1.28k
      size = 32;
6759
1.28k
    }
6760
1.30k
  else if (cmode == 14)
6761
1.02k
    {
6762
1.02k
      if (op)
6763
769
  {
6764
    /* Bit replication into bytes.  */
6765
769
    int ix;
6766
769
    unsigned long mask;
6767
6768
769
    value = 0;
6769
769
    hival = 0;
6770
6.92k
    for (ix = 7; ix >= 0; ix--)
6771
6.15k
      {
6772
6.15k
        mask = ((bits >> ix) & 1) ? 0xff : 0;
6773
6.15k
        if (ix <= 3)
6774
3.07k
    value = (value << 8) | mask;
6775
3.07k
        else
6776
3.07k
    hival = (hival << 8) | mask;
6777
6.15k
      }
6778
769
    size = 64;
6779
769
  }
6780
256
      else
6781
256
  {
6782
    /* Byte replication.  */
6783
256
    value = (unsigned long) bits;
6784
256
    size = 8;
6785
256
  }
6786
1.02k
    }
6787
279
  else if (!op)
6788
279
    {
6789
      /* Floating point encoding.  */
6790
279
      int tmp;
6791
6792
279
      value = (unsigned long)  (bits & 0x7f) << 19;
6793
279
      value |= (unsigned long) (bits & 0x80) << 24;
6794
279
      tmp = bits & 0x40 ? 0x3c : 0x40;
6795
279
      value |= (unsigned long) tmp << 24;
6796
279
      size = 32;
6797
279
      isfloat = 1;
6798
279
    }
6799
0
  else
6800
0
    {
6801
0
      func (stream, dis_style_text, "<illegal constant %.8x:%x:%x>",
6802
0
      bits, cmode, op);
6803
0
      size = 32;
6804
0
      return;
6805
0
    }
6806
6807
  /* printU determines whether the immediate value should be printed as
6808
     unsigned.  */
6809
9.98k
  unsigned printU = 0;
6810
9.98k
  switch (insn->mve_op)
6811
9.98k
    {
6812
0
    default:
6813
0
      break;
6814
    /* We want this for instructions that don't have a 'signed' type.  */
6815
2.83k
    case MVE_VBIC_IMM:
6816
3.13k
    case MVE_VORR_IMM:
6817
6.47k
    case MVE_VMVN_IMM:
6818
9.98k
    case MVE_VMOV_IMM_TO_VEC:
6819
9.98k
      printU = 1;
6820
9.98k
      break;
6821
9.98k
    }
6822
9.98k
  switch (size)
6823
9.98k
    {
6824
256
    case 8:
6825
256
      func (stream, dis_style_immediate, "#%ld", value);
6826
256
      func (stream, dis_style_comment_start, "\t@ 0x%.2lx", value);
6827
256
      break;
6828
6829
2.39k
    case 16:
6830
2.39k
      func (stream, dis_style_immediate, printU ? "#%lu" : "#%ld", value);
6831
2.39k
      func (stream, dis_style_comment_start, "\t@ 0x%.4lx", value);
6832
2.39k
      break;
6833
6834
6.55k
    case 32:
6835
6.55k
      if (isfloat)
6836
279
  {
6837
279
    unsigned char valbytes[4];
6838
279
    double fvalue;
6839
6840
    /* Do this a byte at a time so we don't have to
6841
       worry about the host's endianness.  */
6842
279
    valbytes[0] = value & 0xff;
6843
279
    valbytes[1] = (value >> 8) & 0xff;
6844
279
    valbytes[2] = (value >> 16) & 0xff;
6845
279
    valbytes[3] = (value >> 24) & 0xff;
6846
6847
279
    floatformat_to_double
6848
279
      (& floatformat_ieee_single_little, valbytes,
6849
279
       & fvalue);
6850
6851
279
    func (stream, dis_style_immediate, "#%.7g", fvalue);
6852
279
    func (stream, dis_style_comment_start, "\t@ 0x%.8lx", value);
6853
279
  }
6854
6.27k
      else
6855
6.27k
  {
6856
6.27k
    func (stream, dis_style_immediate,
6857
6.27k
    printU ? "#%lu" : "#%ld",
6858
6.27k
    (long) (((value & 0x80000000L) != 0)
6859
6.27k
      && !printU
6860
6.27k
      ? value | ~0xffffffffL : value));
6861
6.27k
    func (stream, dis_style_comment_start, "\t@ 0x%.8lx", value);
6862
6.27k
  }
6863
6.55k
      break;
6864
6865
769
    case 64:
6866
769
      func (stream, dis_style_immediate, "#0x%.8lx%.8lx", hival, value);
6867
769
      break;
6868
6869
0
    default:
6870
0
      abort ();
6871
9.98k
    }
6872
6873
9.98k
}
6874
6875
static void
6876
print_mve_undefined (struct disassemble_info *info,
6877
         enum mve_undefined undefined_code)
6878
19.9k
{
6879
19.9k
  void *stream = info->stream;
6880
19.9k
  fprintf_styled_ftype func = info->fprintf_styled_func;
6881
  /* Initialize REASON to avoid compiler warning about uninitialized
6882
     usage, though such usage should be impossible.  */
6883
19.9k
  const char *reason = "??";
6884
6885
19.9k
  switch (undefined_code)
6886
19.9k
    {
6887
672
    case UNDEF_SIZE:
6888
672
      reason = "illegal size";
6889
672
      break;
6890
6891
4.17k
    case UNDEF_SIZE_0:
6892
4.17k
      reason = "size equals zero";
6893
4.17k
      break;
6894
6895
879
    case UNDEF_SIZE_2:
6896
879
      reason = "size equals two";
6897
879
      break;
6898
6899
6.67k
    case UNDEF_SIZE_3:
6900
6.67k
      reason = "size equals three";
6901
6.67k
      break;
6902
6903
682
    case UNDEF_SIZE_LE_1:
6904
682
      reason = "size <= 1";
6905
682
      break;
6906
6907
284
    case UNDEF_SIZE_NOT_0:
6908
284
      reason = "size not equal to 0";
6909
284
      break;
6910
6911
1.20k
    case UNDEF_SIZE_NOT_2:
6912
1.20k
      reason = "size not equal to 2";
6913
1.20k
      break;
6914
6915
0
    case UNDEF_SIZE_NOT_3:
6916
0
      reason = "size not equal to 3";
6917
0
      break;
6918
6919
251
    case UNDEF_NOT_UNS_SIZE_0:
6920
251
      reason = "not unsigned and size = zero";
6921
251
      break;
6922
6923
233
    case UNDEF_NOT_UNS_SIZE_1:
6924
233
      reason = "not unsigned and size = one";
6925
233
      break;
6926
6927
346
    case UNDEF_NOT_UNSIGNED:
6928
346
      reason = "not unsigned";
6929
346
      break;
6930
6931
427
    case UNDEF_VCVT_IMM6:
6932
427
      reason = "invalid imm6";
6933
427
      break;
6934
6935
1.19k
    case UNDEF_VCVT_FSI_IMM6:
6936
1.19k
      reason = "fsi = 0 and invalid imm6";
6937
1.19k
      break;
6938
6939
1.79k
    case UNDEF_BAD_OP1_OP2:
6940
1.79k
      reason = "bad size with op2 = 2 and op1 = 0 or 1";
6941
1.79k
      break;
6942
6943
0
    case UNDEF_BAD_U_OP1_OP2:
6944
0
      reason = "unsigned with op2 = 0 and op1 = 0 or 1";
6945
0
      break;
6946
6947
0
    case UNDEF_OP_0_BAD_CMODE:
6948
0
      reason = "op field equal 0 and bad cmode";
6949
0
      break;
6950
6951
719
    case UNDEF_XCHG_UNS:
6952
719
      reason = "exchange and unsigned together";
6953
719
      break;
6954
6955
437
    case UNDEF_NONE:
6956
437
      reason = "";
6957
437
      break;
6958
19.9k
    }
6959
6960
19.9k
  func (stream, dis_style_text, "\t\tundefined instruction: %s", reason);
6961
19.9k
}
6962
6963
static void
6964
print_mve_unpredictable (struct disassemble_info *info,
6965
       enum mve_unpredictable unpredict_code)
6966
35.5k
{
6967
35.5k
  void *stream = info->stream;
6968
35.5k
  fprintf_styled_ftype func = info->fprintf_styled_func;
6969
  /* Initialize REASON to avoid compiler warning about uninitialized
6970
     usage, though such usage should be impossible.  */
6971
35.5k
  const char *reason = "??";
6972
6973
35.5k
  switch (unpredict_code)
6974
35.5k
    {
6975
3.28k
    case UNPRED_IT_BLOCK:
6976
3.28k
      reason = "mve instruction in it block";
6977
3.28k
      break;
6978
6979
565
    case UNPRED_FCA_0_FCB_1:
6980
565
      reason = "condition bits, fca = 0 and fcb = 1";
6981
565
      break;
6982
6983
8.52k
    case UNPRED_R13:
6984
8.52k
      reason = "use of r13 (sp)";
6985
8.52k
      break;
6986
6987
10.4k
    case UNPRED_R15:
6988
10.4k
      reason = "use of r15 (pc)";
6989
10.4k
      break;
6990
6991
392
    case UNPRED_Q_GT_4:
6992
392
      reason = "start register block > r4";
6993
392
      break;
6994
6995
309
    case UNPRED_Q_GT_6:
6996
309
      reason = "start register block > r6";
6997
309
      break;
6998
6999
1.64k
    case UNPRED_R13_AND_WB:
7000
1.64k
      reason = "use of r13 and write back";
7001
1.64k
      break;
7002
7003
1.15k
    case UNPRED_Q_REGS_EQUAL:
7004
1.15k
      reason = "same vector register used for destination and other operand";
7005
1.15k
      break;
7006
7007
2.93k
    case UNPRED_OS:
7008
2.93k
      reason = "use of offset scaled";
7009
2.93k
      break;
7010
7011
220
    case UNPRED_GP_REGS_EQUAL:
7012
220
      reason = "same general-purpose register used for both operands";
7013
220
      break;
7014
7015
1.73k
    case UNPRED_Q_REGS_EQ_AND_SIZE_1:
7016
1.73k
      reason = "use of identical q registers and size = 1";
7017
1.73k
      break;
7018
7019
771
    case UNPRED_Q_REGS_EQ_AND_SIZE_2:
7020
771
      reason = "use of identical q registers and size = 1";
7021
771
      break;
7022
7023
3.53k
    case UNPRED_NONE:
7024
3.53k
      reason = "";
7025
3.53k
      break;
7026
35.5k
    }
7027
7028
35.5k
  func (stream, dis_style_comment_start, "%s: %s",
7029
35.5k
  UNPREDICTABLE_INSTRUCTION, reason);
7030
35.5k
}
7031
7032
/* Print register block operand for mve vld2/vld4/vst2/vld4.  */
7033
7034
static void
7035
print_mve_register_blocks (struct disassemble_info *info,
7036
         unsigned long given,
7037
         enum mve_instructions matched_insn)
7038
3.10k
{
7039
3.10k
  void *stream = info->stream;
7040
3.10k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7041
7042
3.10k
  unsigned long q_reg_start = arm_decode_field_multiple (given,
7043
3.10k
               13, 15,
7044
3.10k
               22, 22);
7045
3.10k
  switch (matched_insn)
7046
3.10k
    {
7047
463
    case MVE_VLD2:
7048
1.87k
    case MVE_VST2:
7049
1.87k
      if (q_reg_start <= 6)
7050
453
  {
7051
453
    func (stream, dis_style_text, "{");
7052
453
    func (stream, dis_style_register, "q%ld", q_reg_start);
7053
453
    func (stream, dis_style_text, ", ");
7054
453
    func (stream, dis_style_register, "q%ld", q_reg_start + 1);
7055
453
    func (stream, dis_style_text, "}");
7056
453
  }
7057
1.42k
      else
7058
1.42k
  func (stream, dis_style_text, "<illegal reg q%ld>", q_reg_start);
7059
1.87k
      break;
7060
7061
404
    case MVE_VLD4:
7062
1.22k
    case MVE_VST4:
7063
1.22k
      if (q_reg_start <= 4)
7064
434
  {
7065
434
    func (stream, dis_style_text, "{");
7066
434
    func (stream, dis_style_register, "q%ld", q_reg_start);
7067
434
    func (stream, dis_style_text, ", ");
7068
434
    func (stream, dis_style_register, "q%ld", q_reg_start + 1);
7069
434
    func (stream, dis_style_text, ", ");
7070
434
    func (stream, dis_style_register, "q%ld", q_reg_start + 2);
7071
434
    func (stream, dis_style_text, ", ");
7072
434
    func (stream, dis_style_register, "q%ld", q_reg_start + 3);
7073
434
    func (stream, dis_style_text, "}");
7074
434
  }
7075
795
      else
7076
795
  func (stream, dis_style_text, "<illegal reg q%ld>", q_reg_start);
7077
1.22k
      break;
7078
7079
0
    default:
7080
0
      break;
7081
3.10k
    }
7082
3.10k
}
7083
7084
static void
7085
print_mve_rounding_mode (struct disassemble_info *info,
7086
       unsigned long given,
7087
       enum mve_instructions matched_insn)
7088
5.25k
{
7089
5.25k
  void *stream = info->stream;
7090
5.25k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7091
7092
5.25k
  switch (matched_insn)
7093
5.25k
    {
7094
3.17k
    case MVE_VCVT_FROM_FP_TO_INT:
7095
3.17k
      {
7096
3.17k
  switch (arm_decode_field (given, 8, 9))
7097
3.17k
    {
7098
1.10k
    case 0:
7099
1.10k
      func (stream, dis_style_mnemonic, "a");
7100
1.10k
      break;
7101
7102
608
    case 1:
7103
608
      func (stream, dis_style_mnemonic, "n");
7104
608
      break;
7105
7106
898
    case 2:
7107
898
      func (stream, dis_style_mnemonic, "p");
7108
898
      break;
7109
7110
564
    case 3:
7111
564
      func (stream, dis_style_mnemonic, "m");
7112
564
      break;
7113
7114
0
    default:
7115
0
      break;
7116
3.17k
    }
7117
3.17k
      }
7118
3.17k
      break;
7119
7120
3.17k
    case MVE_VRINT_FP:
7121
2.08k
      {
7122
2.08k
  switch (arm_decode_field (given, 7, 9))
7123
2.08k
    {
7124
248
    case 0:
7125
248
      func (stream, dis_style_mnemonic, "n");
7126
248
      break;
7127
7128
406
    case 1:
7129
406
      func (stream, dis_style_mnemonic, "x");
7130
406
      break;
7131
7132
206
    case 2:
7133
206
      func (stream, dis_style_mnemonic, "a");
7134
206
      break;
7135
7136
405
    case 3:
7137
405
      func (stream, dis_style_mnemonic, "z");
7138
405
      break;
7139
7140
213
    case 5:
7141
213
      func (stream, dis_style_mnemonic, "m");
7142
213
      break;
7143
7144
343
    case 7:
7145
343
      func (stream, dis_style_mnemonic, "p");
7146
7147
410
    case 4:
7148
605
    case 6:
7149
605
    default:
7150
605
      break;
7151
2.08k
    }
7152
2.08k
      }
7153
2.08k
      break;
7154
7155
2.08k
    default:
7156
0
      break;
7157
5.25k
    }
7158
5.25k
}
7159
7160
static void
7161
print_mve_vcvt_size (struct disassemble_info *info,
7162
         unsigned long given,
7163
         enum mve_instructions matched_insn)
7164
13.2k
{
7165
13.2k
  unsigned long mode = 0;
7166
13.2k
  void *stream = info->stream;
7167
13.2k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7168
7169
13.2k
  switch (matched_insn)
7170
13.2k
    {
7171
6.03k
    case MVE_VCVT_FP_FIX_VEC:
7172
6.03k
      {
7173
6.03k
  mode = (((given & 0x200) >> 7)
7174
6.03k
    | ((given & 0x10000000) >> 27)
7175
6.03k
    | ((given & 0x100) >> 8));
7176
7177
6.03k
  switch (mode)
7178
6.03k
    {
7179
244
    case 0:
7180
244
      func (stream, dis_style_mnemonic, "f16.s16");
7181
244
      break;
7182
7183
223
    case 1:
7184
223
      func (stream, dis_style_mnemonic, "s16.f16");
7185
223
      break;
7186
7187
304
    case 2:
7188
304
      func (stream, dis_style_mnemonic, "f16.u16");
7189
304
      break;
7190
7191
826
    case 3:
7192
826
      func (stream, dis_style_mnemonic, "u16.f16");
7193
826
      break;
7194
7195
722
    case 4:
7196
722
      func (stream, dis_style_mnemonic, "f32.s32");
7197
722
      break;
7198
7199
336
    case 5:
7200
336
      func (stream, dis_style_mnemonic, "s32.f32");
7201
336
      break;
7202
7203
221
    case 6:
7204
221
      func (stream, dis_style_mnemonic, "f32.u32");
7205
221
      break;
7206
7207
3.15k
    case 7:
7208
3.15k
      func (stream, dis_style_mnemonic, "u32.f32");
7209
3.15k
      break;
7210
7211
0
    default:
7212
0
      break;
7213
6.03k
    }
7214
6.03k
  break;
7215
6.03k
      }
7216
6.03k
    case MVE_VCVT_BETWEEN_FP_INT:
7217
3.16k
      {
7218
3.16k
  unsigned long size = arm_decode_field (given, 18, 19);
7219
3.16k
  unsigned long op = arm_decode_field (given, 7, 8);
7220
7221
3.16k
  if (size == 1)
7222
1.34k
    {
7223
1.34k
      switch (op)
7224
1.34k
        {
7225
329
        case 0:
7226
329
    func (stream, dis_style_mnemonic, "f16.s16");
7227
329
    break;
7228
7229
250
        case 1:
7230
250
    func (stream, dis_style_mnemonic, "f16.u16");
7231
250
    break;
7232
7233
318
        case 2:
7234
318
    func (stream, dis_style_mnemonic, "s16.f16");
7235
318
    break;
7236
7237
449
        case 3:
7238
449
    func (stream, dis_style_mnemonic, "u16.f16");
7239
449
    break;
7240
7241
0
        default:
7242
0
    break;
7243
1.34k
        }
7244
1.34k
    }
7245
1.81k
  else if (size == 2)
7246
1.22k
    {
7247
1.22k
      switch (op)
7248
1.22k
        {
7249
263
        case 0:
7250
263
    func (stream, dis_style_mnemonic, "f32.s32");
7251
263
    break;
7252
7253
273
        case 1:
7254
273
    func (stream, dis_style_mnemonic, "f32.u32");
7255
273
    break;
7256
7257
217
        case 2:
7258
217
    func (stream, dis_style_mnemonic, "s32.f32");
7259
217
    break;
7260
7261
471
        case 3:
7262
471
    func (stream, dis_style_mnemonic, "u32.f32");
7263
471
    break;
7264
1.22k
        }
7265
1.22k
    }
7266
3.16k
      }
7267
3.16k
      break;
7268
7269
3.16k
    case MVE_VCVT_FP_HALF_FP:
7270
918
      {
7271
918
  unsigned long op = arm_decode_field (given, 28, 28);
7272
918
  if (op == 0)
7273
538
    func (stream, dis_style_mnemonic, "f16.f32");
7274
380
  else if (op == 1)
7275
380
    func (stream, dis_style_mnemonic, "f32.f16");
7276
918
      }
7277
918
      break;
7278
7279
3.17k
    case MVE_VCVT_FROM_FP_TO_INT:
7280
3.17k
      {
7281
3.17k
  unsigned long size = arm_decode_field_multiple (given, 7, 7, 18, 19);
7282
7283
3.17k
  switch (size)
7284
3.17k
    {
7285
365
    case 2:
7286
365
      func (stream, dis_style_mnemonic, "s16.f16");
7287
365
      break;
7288
7289
260
    case 3:
7290
260
      func (stream, dis_style_mnemonic, "u16.f16");
7291
260
      break;
7292
7293
853
    case 4:
7294
853
      func (stream, dis_style_mnemonic, "s32.f32");
7295
853
      break;
7296
7297
232
    case 5:
7298
232
      func (stream, dis_style_mnemonic, "u32.f32");
7299
232
      break;
7300
7301
1.46k
    default:
7302
1.46k
      break;
7303
3.17k
    }
7304
3.17k
      }
7305
3.17k
      break;
7306
7307
3.17k
    default:
7308
0
      break;
7309
13.2k
    }
7310
13.2k
}
7311
7312
static void
7313
print_mve_rotate (struct disassemble_info *info, unsigned long rot,
7314
      unsigned long rot_width)
7315
6.75k
{
7316
6.75k
  void *stream = info->stream;
7317
6.75k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7318
7319
6.75k
  if (rot_width == 1)
7320
2.67k
    {
7321
2.67k
      switch (rot)
7322
2.67k
  {
7323
1.47k
  case 0:
7324
1.47k
    func (stream, dis_style_immediate, "90");
7325
1.47k
    break;
7326
1.20k
  case 1:
7327
1.20k
    func (stream, dis_style_immediate, "270");
7328
1.20k
    break;
7329
0
  default:
7330
0
    break;
7331
2.67k
  }
7332
2.67k
    }
7333
4.07k
  else if (rot_width == 2)
7334
4.07k
    {
7335
4.07k
      switch (rot)
7336
4.07k
  {
7337
272
  case 0:
7338
272
    func (stream, dis_style_immediate, "0");
7339
272
    break;
7340
1.67k
  case 1:
7341
1.67k
    func (stream, dis_style_immediate, "90");
7342
1.67k
    break;
7343
637
  case 2:
7344
637
    func (stream, dis_style_immediate, "180");
7345
637
    break;
7346
1.49k
  case 3:
7347
1.49k
    func (stream, dis_style_immediate, "270");
7348
1.49k
    break;
7349
0
  default:
7350
0
    break;
7351
4.07k
  }
7352
4.07k
    }
7353
6.75k
}
7354
7355
static void
7356
print_instruction_predicate (struct disassemble_info *info)
7357
129k
{
7358
129k
  void *stream = info->stream;
7359
129k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7360
7361
129k
  if (vpt_block_state.next_pred_state == PRED_THEN)
7362
5.06k
    func (stream, dis_style_mnemonic, "t");
7363
124k
  else if (vpt_block_state.next_pred_state == PRED_ELSE)
7364
2.93k
    func (stream, dis_style_mnemonic, "e");
7365
129k
}
7366
7367
static void
7368
print_mve_size (struct disassemble_info *info,
7369
    unsigned long size,
7370
    enum mve_instructions matched_insn)
7371
117k
{
7372
117k
  void *stream = info->stream;
7373
117k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7374
7375
117k
  switch (matched_insn)
7376
117k
    {
7377
324
    case MVE_VABAV:
7378
1.02k
    case MVE_VABD_VEC:
7379
1.25k
    case MVE_VABS_FP:
7380
1.82k
    case MVE_VABS_VEC:
7381
2.04k
    case MVE_VADD_VEC_T1:
7382
3.33k
    case MVE_VADD_VEC_T2:
7383
3.56k
    case MVE_VADDV:
7384
4.42k
    case MVE_VBRSR:
7385
5.05k
    case MVE_VCADD_VEC:
7386
5.28k
    case MVE_VCLS:
7387
5.50k
    case MVE_VCLZ:
7388
5.82k
    case MVE_VCMP_VEC_T1:
7389
6.05k
    case MVE_VCMP_VEC_T2:
7390
6.28k
    case MVE_VCMP_VEC_T3:
7391
6.67k
    case MVE_VCMP_VEC_T4:
7392
6.92k
    case MVE_VCMP_VEC_T5:
7393
7.14k
    case MVE_VCMP_VEC_T6:
7394
7.54k
    case MVE_VCTP:
7395
9.79k
    case MVE_VDDUP:
7396
10.7k
    case MVE_VDWDUP:
7397
11.4k
    case MVE_VHADD_T1:
7398
11.9k
    case MVE_VHADD_T2:
7399
13.3k
    case MVE_VHCADD:
7400
13.7k
    case MVE_VHSUB_T1:
7401
14.0k
    case MVE_VHSUB_T2:
7402
14.5k
    case MVE_VIDUP:
7403
15.4k
    case MVE_VIWDUP:
7404
15.9k
    case MVE_VLD2:
7405
16.3k
    case MVE_VLD4:
7406
17.3k
    case MVE_VLDRB_GATHER_T1:
7407
18.8k
    case MVE_VLDRH_GATHER_T2:
7408
18.8k
    case MVE_VLDRW_GATHER_T3:
7409
18.8k
    case MVE_VLDRD_GATHER_T4:
7410
19.5k
    case MVE_VLDRB_T1:
7411
20.3k
    case MVE_VLDRH_T2:
7412
20.6k
    case MVE_VMAX:
7413
20.8k
    case MVE_VMAXA:
7414
21.5k
    case MVE_VMAXV:
7415
22.1k
    case MVE_VMAXAV:
7416
22.5k
    case MVE_VMIN:
7417
22.9k
    case MVE_VMINA:
7418
23.1k
    case MVE_VMINV:
7419
23.4k
    case MVE_VMINAV:
7420
23.8k
    case MVE_VMLA:
7421
24.1k
    case MVE_VMLAS:
7422
24.6k
    case MVE_VMUL_VEC_T1:
7423
24.9k
    case MVE_VMUL_VEC_T2:
7424
25.7k
    case MVE_VMULH:
7425
26.5k
    case MVE_VRMULH:
7426
27.9k
    case MVE_VMULL_INT:
7427
28.2k
    case MVE_VNEG_FP:
7428
28.5k
    case MVE_VNEG_VEC:
7429
29.9k
    case MVE_VPT_VEC_T1:
7430
30.8k
    case MVE_VPT_VEC_T2:
7431
31.7k
    case MVE_VPT_VEC_T3:
7432
32.9k
    case MVE_VPT_VEC_T4:
7433
34.2k
    case MVE_VPT_VEC_T5:
7434
35.8k
    case MVE_VPT_VEC_T6:
7435
36.2k
    case MVE_VQABS:
7436
37.8k
    case MVE_VQADD_T1:
7437
38.7k
    case MVE_VQADD_T2:
7438
39.2k
    case MVE_VQDMLADH:
7439
39.7k
    case MVE_VQRDMLADH:
7440
40.3k
    case MVE_VQDMLAH:
7441
40.5k
    case MVE_VQRDMLAH:
7442
40.9k
    case MVE_VQDMLASH:
7443
41.3k
    case MVE_VQRDMLASH:
7444
41.6k
    case MVE_VQDMLSDH:
7445
42.5k
    case MVE_VQRDMLSDH:
7446
42.8k
    case MVE_VQDMULH_T1:
7447
43.0k
    case MVE_VQRDMULH_T2:
7448
44.2k
    case MVE_VQDMULH_T3:
7449
44.6k
    case MVE_VQRDMULH_T4:
7450
44.9k
    case MVE_VQNEG:
7451
45.1k
    case MVE_VQRSHL_T1:
7452
45.4k
    case MVE_VQRSHL_T2:
7453
45.6k
    case MVE_VQSHL_T1:
7454
45.9k
    case MVE_VQSHL_T4:
7455
46.2k
    case MVE_VQSUB_T1:
7456
47.0k
    case MVE_VQSUB_T2:
7457
47.5k
    case MVE_VREV32:
7458
48.2k
    case MVE_VREV64:
7459
49.9k
    case MVE_VRHADD:
7460
52.0k
    case MVE_VRINT_FP:
7461
52.3k
    case MVE_VRSHL_T1:
7462
52.6k
    case MVE_VRSHL_T2:
7463
53.1k
    case MVE_VSHL_T2:
7464
53.5k
    case MVE_VSHL_T3:
7465
54.0k
    case MVE_VSHLL_T2:
7466
55.4k
    case MVE_VST2:
7467
56.2k
    case MVE_VST4:
7468
59.6k
    case MVE_VSTRB_SCATTER_T1:
7469
60.7k
    case MVE_VSTRH_SCATTER_T2:
7470
62.2k
    case MVE_VSTRW_SCATTER_T3:
7471
63.1k
    case MVE_VSTRB_T1:
7472
63.9k
    case MVE_VSTRH_T2:
7473
64.2k
    case MVE_VSUB_VEC_T1:
7474
64.5k
    case MVE_VSUB_VEC_T2:
7475
64.5k
      if (size <= 3)
7476
64.5k
  func (stream, dis_style_mnemonic, "%s", mve_vec_sizename[size]);
7477
0
      else
7478
0
  func (stream, dis_style_text, "<undef size>");
7479
64.5k
      break;
7480
7481
230
    case MVE_VABD_FP:
7482
589
    case MVE_VADD_FP_T1:
7483
910
    case MVE_VADD_FP_T2:
7484
1.23k
    case MVE_VSUB_FP_T1:
7485
1.55k
    case MVE_VSUB_FP_T2:
7486
2.54k
    case MVE_VCMP_FP_T1:
7487
3.09k
    case MVE_VCMP_FP_T2:
7488
3.31k
    case MVE_VFMA_FP_SCALAR:
7489
3.63k
    case MVE_VFMA_FP:
7490
3.88k
    case MVE_VFMS_FP:
7491
4.41k
    case MVE_VFMAS_FP_SCALAR:
7492
5.03k
    case MVE_VMAXNM_FP:
7493
5.63k
    case MVE_VMAXNMA_FP:
7494
5.92k
    case MVE_VMAXNMV_FP:
7495
6.27k
    case MVE_VMAXNMAV_FP:
7496
6.72k
    case MVE_VMINNM_FP:
7497
6.99k
    case MVE_VMINNMA_FP:
7498
7.24k
    case MVE_VMINNMV_FP:
7499
7.48k
    case MVE_VMINNMAV_FP:
7500
7.76k
    case MVE_VMUL_FP_T1:
7501
8.28k
    case MVE_VMUL_FP_T2:
7502
11.5k
    case MVE_VPT_FP_T1:
7503
16.5k
    case MVE_VPT_FP_T2:
7504
16.5k
      if (size == 0)
7505
10.9k
  func (stream, dis_style_mnemonic, "32");
7506
5.56k
      else if (size == 1)
7507
5.56k
  func (stream, dis_style_mnemonic, "16");
7508
16.5k
      break;
7509
7510
689
    case MVE_VCADD_FP:
7511
2.58k
    case MVE_VCMLA_FP:
7512
4.76k
    case MVE_VCMUL_FP:
7513
5.28k
    case MVE_VMLADAV_T1:
7514
7.05k
    case MVE_VMLALDAV:
7515
7.36k
    case MVE_VMLSDAV_T1:
7516
8.00k
    case MVE_VMLSLDAV:
7517
8.67k
    case MVE_VMOVN:
7518
9.82k
    case MVE_VQDMULL_T1:
7519
12.1k
    case MVE_VQDMULL_T2:
7520
12.5k
    case MVE_VQMOVN:
7521
12.9k
    case MVE_VQMOVUN:
7522
12.9k
      if (size == 0)
7523
5.40k
  func (stream, dis_style_mnemonic, "16");
7524
7.53k
      else if (size == 1)
7525
6.58k
  func (stream, dis_style_mnemonic, "32");
7526
12.9k
      break;
7527
7528
1.33k
    case MVE_VMOVL:
7529
1.33k
      if (size == 1)
7530
489
  func (stream, dis_style_mnemonic, "8");
7531
847
      else if (size == 2)
7532
847
  func (stream, dis_style_mnemonic, "16");
7533
1.33k
      break;
7534
7535
1.25k
    case MVE_VDUP:
7536
1.25k
      switch (size)
7537
1.25k
  {
7538
196
  case 0:
7539
196
    func (stream, dis_style_mnemonic, "32");
7540
196
    break;
7541
241
  case 1:
7542
241
    func (stream, dis_style_mnemonic, "16");
7543
241
    break;
7544
577
  case 2:
7545
577
    func (stream, dis_style_mnemonic, "8");
7546
577
    break;
7547
238
  default:
7548
238
    break;
7549
1.25k
  }
7550
1.25k
      break;
7551
7552
1.25k
    case MVE_VMOV_GP_TO_VEC_LANE:
7553
1.79k
    case MVE_VMOV_VEC_LANE_TO_GP:
7554
1.79k
      switch (size)
7555
1.79k
  {
7556
0
  case 0: case 4:
7557
0
    func (stream, dis_style_mnemonic, "32");
7558
0
    break;
7559
7560
0
  case 1: case 3:
7561
0
  case 5: case 7:
7562
0
    func (stream, dis_style_mnemonic, "16");
7563
0
    break;
7564
7565
0
  case 8: case 9: case 10: case 11:
7566
0
  case 12: case 13: case 14: case 15:
7567
0
    func (stream, dis_style_mnemonic, "8");
7568
0
    break;
7569
7570
1.79k
  default:
7571
1.79k
    break;
7572
1.79k
  }
7573
1.79k
      break;
7574
7575
3.51k
    case MVE_VMOV_IMM_TO_VEC:
7576
3.51k
      switch (size)
7577
3.51k
  {
7578
880
  case 0: case 4: case 8:
7579
1.65k
  case 12: case 24: case 26:
7580
1.65k
    func (stream, dis_style_mnemonic, "i32");
7581
1.65k
    break;
7582
553
  case 16: case 20:
7583
553
    func (stream, dis_style_mnemonic, "i16");
7584
553
    break;
7585
256
  case 28:
7586
256
    func (stream, dis_style_mnemonic, "i8");
7587
256
    break;
7588
769
  case 29:
7589
769
    func (stream, dis_style_mnemonic, "i64");
7590
769
    break;
7591
279
  case 30:
7592
279
    func (stream, dis_style_mnemonic, "f32");
7593
279
    break;
7594
0
  default:
7595
0
    break;
7596
3.51k
  }
7597
3.51k
      break;
7598
7599
3.51k
    case MVE_VMULL_POLY:
7600
978
      if (size == 0)
7601
264
  func (stream, dis_style_mnemonic, "p8");
7602
714
      else if (size == 1)
7603
714
  func (stream, dis_style_mnemonic, "p16");
7604
978
      break;
7605
7606
3.33k
    case MVE_VMVN_IMM:
7607
3.33k
      switch (size)
7608
3.33k
  {
7609
1.52k
  case 0: case 2: case 4:
7610
2.57k
  case 6: case 12: case 13:
7611
2.57k
    func (stream, dis_style_mnemonic, "32");
7612
2.57k
    break;
7613
7614
760
  case 8: case 10:
7615
760
    func (stream, dis_style_mnemonic, "16");
7616
760
    break;
7617
7618
0
  default:
7619
0
    break;
7620
3.33k
  }
7621
3.33k
      break;
7622
7623
3.33k
    case MVE_VBIC_IMM:
7624
3.13k
    case MVE_VORR_IMM:
7625
3.13k
      switch (size)
7626
3.13k
  {
7627
762
  case 1: case 3:
7628
2.05k
  case 5: case 7:
7629
2.05k
    func (stream, dis_style_mnemonic, "32");
7630
2.05k
    break;
7631
7632
1.08k
  case 9: case 11:
7633
1.08k
    func (stream, dis_style_mnemonic, "16");
7634
1.08k
    break;
7635
7636
0
  default:
7637
0
    break;
7638
3.13k
  }
7639
3.13k
      break;
7640
7641
3.13k
    case MVE_VQSHRN:
7642
751
    case MVE_VQSHRUN:
7643
1.73k
    case MVE_VQRSHRN:
7644
2.13k
    case MVE_VQRSHRUN:
7645
2.45k
    case MVE_VRSHRN:
7646
2.81k
    case MVE_VSHRN:
7647
2.81k
      {
7648
2.81k
  switch (size)
7649
2.81k
  {
7650
793
  case 1:
7651
793
    func (stream, dis_style_mnemonic, "16");
7652
793
    break;
7653
7654
1.03k
  case 2: case 3:
7655
1.03k
    func (stream, dis_style_mnemonic, "32");
7656
1.03k
    break;
7657
7658
984
  default:
7659
984
    break;
7660
2.81k
  }
7661
2.81k
      }
7662
2.81k
      break;
7663
7664
2.81k
    case MVE_VQSHL_T2:
7665
1.49k
    case MVE_VQSHLU_T3:
7666
2.06k
    case MVE_VRSHR:
7667
2.60k
    case MVE_VSHL_T1:
7668
3.72k
    case MVE_VSHLL_T1:
7669
5.25k
    case MVE_VSHR:
7670
5.55k
    case MVE_VSLI:
7671
5.78k
    case MVE_VSRI:
7672
5.78k
      {
7673
5.78k
  switch (size)
7674
5.78k
  {
7675
876
  case 1:
7676
876
    func (stream, dis_style_mnemonic, "8");
7677
876
    break;
7678
7679
662
  case 2: case 3:
7680
662
    func (stream, dis_style_mnemonic, "16");
7681
662
    break;
7682
7683
3.67k
  case 4: case 5: case 6: case 7:
7684
3.67k
    func (stream, dis_style_mnemonic, "32");
7685
3.67k
    break;
7686
7687
569
  default:
7688
569
    break;
7689
5.78k
  }
7690
5.78k
      }
7691
5.78k
      break;
7692
7693
5.78k
    default:
7694
0
      break;
7695
117k
    }
7696
117k
}
7697
7698
/* Return true if INSN is a shift insn with an immediate shift amount
7699
   which needs decoding as per print_mve_shift_n.  */
7700
7701
static bool
7702
mve_shift_insn_p (enum mve_instructions insn)
7703
13.6k
{
7704
13.6k
  switch (insn)
7705
13.6k
    {
7706
710
    case MVE_VQSHL_T2:
7707
1.49k
    case MVE_VQSHLU_T3:
7708
1.76k
    case MVE_VQSHRN:
7709
2.25k
    case MVE_VQSHRUN:
7710
3.23k
    case MVE_VQRSHRN:
7711
3.63k
    case MVE_VQRSHRUN:
7712
4.19k
    case MVE_VRSHR:
7713
4.52k
    case MVE_VRSHRN:
7714
5.06k
    case MVE_VSHL_T1:
7715
6.17k
    case MVE_VSHLL_T1:
7716
7.71k
    case MVE_VSHR:
7717
8.06k
    case MVE_VSHRN:
7718
8.36k
    case MVE_VSLI:
7719
8.59k
    case MVE_VSRI:
7720
8.59k
      return true;
7721
5.08k
    default:
7722
5.08k
      return false;
7723
13.6k
    }
7724
13.6k
}
7725
7726
static void
7727
print_mve_shift_n (struct disassemble_info *info, long given,
7728
       enum mve_instructions matched_insn)
7729
8.59k
{
7730
8.59k
  void *stream = info->stream;
7731
8.59k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7732
7733
8.59k
  int startAt0
7734
8.59k
    = matched_insn == MVE_VQSHL_T2
7735
8.59k
      || matched_insn == MVE_VQSHLU_T3
7736
8.59k
      || matched_insn == MVE_VSHL_T1
7737
8.59k
      || matched_insn == MVE_VSHLL_T1
7738
8.59k
      || matched_insn == MVE_VSLI;
7739
7740
8.59k
  unsigned imm6 = (given & 0x3f0000) >> 16;
7741
7742
8.59k
  if (matched_insn == MVE_VSHLL_T1)
7743
1.11k
    imm6 &= 0x1f;
7744
7745
8.59k
  unsigned shiftAmount = 0;
7746
8.59k
  if ((imm6 & 0x20) != 0)
7747
3.67k
    shiftAmount = startAt0 ? imm6 - 32 : 64 - imm6;
7748
4.91k
  else if ((imm6 & 0x10) != 0)
7749
1.69k
    shiftAmount = startAt0 ? imm6 - 16 : 32 - imm6;
7750
3.22k
  else if ((imm6 & 0x08) != 0)
7751
1.66k
    shiftAmount = startAt0 ? imm6 - 8 : 16 - imm6;
7752
1.55k
  else
7753
1.55k
    print_mve_undefined (info, UNDEF_SIZE_0);
7754
7755
8.59k
  func (stream, dis_style_immediate, "%u", shiftAmount);
7756
8.59k
}
7757
7758
static void
7759
print_vec_condition (struct disassemble_info *info, long given,
7760
         enum mve_instructions matched_insn)
7761
18.8k
{
7762
18.8k
  void *stream = info->stream;
7763
18.8k
  fprintf_styled_ftype func = info->fprintf_styled_func;
7764
18.8k
  long vec_cond = 0;
7765
7766
18.8k
  switch (matched_insn)
7767
18.8k
    {
7768
3.24k
    case MVE_VPT_FP_T1:
7769
4.22k
    case MVE_VCMP_FP_T1:
7770
4.22k
      vec_cond = (((given & 0x1000) >> 10)
7771
4.22k
      | ((given & 1) << 1)
7772
4.22k
      | ((given & 0x0080) >> 7));
7773
4.22k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7774
4.22k
      break;
7775
7776
5.02k
    case MVE_VPT_FP_T2:
7777
5.57k
    case MVE_VCMP_FP_T2:
7778
5.57k
      vec_cond = (((given & 0x1000) >> 10)
7779
5.57k
      | ((given & 0x0020) >> 4)
7780
5.57k
      | ((given & 0x0080) >> 7));
7781
5.57k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7782
5.57k
      break;
7783
7784
1.42k
    case MVE_VPT_VEC_T1:
7785
1.74k
    case MVE_VCMP_VEC_T1:
7786
1.74k
      vec_cond = (given & 0x0080) >> 7;
7787
1.74k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7788
1.74k
      break;
7789
7790
865
    case MVE_VPT_VEC_T2:
7791
1.09k
    case MVE_VCMP_VEC_T2:
7792
1.09k
      vec_cond = 2 | ((given & 0x0080) >> 7);
7793
1.09k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7794
1.09k
      break;
7795
7796
959
    case MVE_VPT_VEC_T3:
7797
1.18k
    case MVE_VCMP_VEC_T3:
7798
1.18k
      vec_cond = 4 | ((given & 1) << 1) | ((given & 0x0080) >> 7);
7799
1.18k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7800
1.18k
      break;
7801
7802
1.17k
    case MVE_VPT_VEC_T4:
7803
1.56k
    case MVE_VCMP_VEC_T4:
7804
1.56k
      vec_cond = (given & 0x0080) >> 7;
7805
1.56k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7806
1.56k
      break;
7807
7808
1.30k
    case MVE_VPT_VEC_T5:
7809
1.56k
    case MVE_VCMP_VEC_T5:
7810
1.56k
      vec_cond = 2 | ((given & 0x0080) >> 7);
7811
1.56k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7812
1.56k
      break;
7813
7814
1.63k
    case MVE_VPT_VEC_T6:
7815
1.85k
    case MVE_VCMP_VEC_T6:
7816
1.85k
      vec_cond = 4 | ((given & 0x0020) >> 4) | ((given & 0x0080) >> 7);
7817
1.85k
      func (stream, dis_style_sub_mnemonic, "%s", vec_condnames[vec_cond]);
7818
1.85k
      break;
7819
7820
0
    case MVE_NONE:
7821
0
    case MVE_VPST:
7822
0
    default:
7823
0
      break;
7824
18.8k
    }
7825
18.8k
}
7826
7827
1.43M
#define W_BIT 21
7828
180k
#define I_BIT 22
7829
2.44M
#define U_BIT 23
7830
1.82M
#define P_BIT 24
7831
7832
1.82M
#define WRITEBACK_BIT_SET (given & (1 << W_BIT))
7833
244k
#define IMMEDIATE_BIT_SET (given & (1 << I_BIT))
7834
2.84M
#define NEGATIVE_BIT_SET  ((given & (1 << U_BIT)) == 0)
7835
2.26M
#define PRE_BIT_SET   (given & (1 << P_BIT))
7836
7837
/* The assembler string for an instruction can include %{X:...%} patterns,
7838
   where the 'X' is one of the characters understood by this function.
7839
7840
   This function takes the X character, and returns a new style.  This new
7841
   style will be used by the caller to temporarily change the current base
7842
   style.  */
7843
7844
static enum disassembler_style
7845
decode_base_style (const char x)
7846
7.18M
{
7847
7.18M
  switch (x)
7848
7.18M
    {
7849
0
    case 'A': return dis_style_address;
7850
9.21k
    case 'B': return dis_style_sub_mnemonic;
7851
0
    case 'C': return dis_style_comment_start;
7852
0
    case 'D': return dis_style_assembler_directive;
7853
5.28M
    case 'I': return dis_style_immediate;
7854
0
    case 'M': return dis_style_mnemonic;
7855
0
    case 'O': return dis_style_address_offset;
7856
1.88M
    case 'R': return dis_style_register;
7857
0
    case 'S': return dis_style_symbol;
7858
0
    case 'T': return dis_style_text;
7859
0
    default:
7860
0
      abort ();
7861
7.18M
    }
7862
7.18M
}
7863
7864
/* Print one coprocessor instruction on INFO->STREAM.
7865
   Return TRUE if the instuction matched, FALSE if this is not a
7866
   recognised coprocessor instruction.  */
7867
7868
static bool
7869
print_insn_coprocessor_1 (const struct sopcode32 *opcodes,
7870
        bfd_vma pc,
7871
        struct disassemble_info *info,
7872
        long given,
7873
        bool thumb)
7874
14.0M
{
7875
14.0M
  const struct sopcode32 *insn;
7876
14.0M
  void *stream = info->stream;
7877
14.0M
  fprintf_styled_ftype func = info->fprintf_styled_func;
7878
14.0M
  unsigned long mask;
7879
14.0M
  unsigned long value = 0;
7880
14.0M
  int cond;
7881
14.0M
  int cp_num;
7882
14.0M
  struct arm_private_data *private_data = info->private_data;
7883
14.0M
  arm_feature_set allowed_arches = ARM_ARCH_NONE;
7884
14.0M
  arm_feature_set arm_ext_v8_1m_main =
7885
14.0M
    ARM_FEATURE_CORE_HIGH (ARM_EXT2_V8_1M_MAIN);
7886
14.0M
  enum disassembler_style base_style = dis_style_mnemonic;
7887
14.0M
  enum disassembler_style old_base_style = base_style;
7888
7889
14.0M
  allowed_arches = private_data->features;
7890
7891
1.54G
  for (insn = opcodes; insn->assembler; insn++)
7892
1.53G
    {
7893
1.53G
      unsigned long u_reg = 16;
7894
1.53G
      bool is_unpredictable = false;
7895
1.53G
      signed long value_in_comment = 0;
7896
1.53G
      const char *c;
7897
7898
1.53G
      if (ARM_FEATURE_ZERO (insn->arch))
7899
14.3M
  switch (insn->value)
7900
14.3M
    {
7901
7.17M
    case SENTINEL_IWMMXT_START:
7902
7.17M
      if (info->mach != bfd_mach_arm_XScale
7903
7.17M
    && info->mach != bfd_mach_arm_iWMMXt
7904
7.17M
    && info->mach != bfd_mach_arm_iWMMXt2)
7905
7.10M
        do
7906
539M
    insn++;
7907
539M
        while ((! ARM_FEATURE_ZERO (insn->arch))
7908
539M
         && insn->value != SENTINEL_IWMMXT_END);
7909
7.17M
      continue;
7910
7911
62.8k
    case SENTINEL_IWMMXT_END:
7912
62.8k
      continue;
7913
7914
7.12M
    case SENTINEL_GENERIC_START:
7915
7.12M
      allowed_arches = private_data->features;
7916
7.12M
      continue;
7917
7918
0
    default:
7919
0
      abort ();
7920
14.3M
    }
7921
7922
1.52G
      mask = insn->mask;
7923
1.52G
      value = insn->value;
7924
1.52G
      cp_num = (given >> 8) & 0xf;
7925
7926
1.52G
      if (thumb)
7927
244M
  {
7928
    /* The high 4 bits are 0xe for Arm conditional instructions, and
7929
       0xe for arm unconditional instructions.  The rest of the
7930
       encoding is the same.  */
7931
244M
    mask |= 0xf0000000;
7932
244M
    value |= 0xe0000000;
7933
244M
    if (ifthen_state)
7934
5.65M
      cond = IFTHEN_COND;
7935
239M
    else
7936
239M
      cond = COND_UNCOND;
7937
244M
  }
7938
1.27G
      else
7939
1.27G
  {
7940
    /* Only match unconditional instuctions against unconditional
7941
       patterns.  */
7942
1.27G
    if ((given & 0xf0000000) == 0xf0000000)
7943
85.7M
      {
7944
85.7M
        mask |= 0xf0000000;
7945
85.7M
        cond = COND_UNCOND;
7946
85.7M
      }
7947
1.19G
    else
7948
1.19G
      {
7949
1.19G
        cond = (given >> 28) & 0xf;
7950
1.19G
        if (cond == 0xe)
7951
62.6M
    cond = COND_UNCOND;
7952
1.19G
      }
7953
1.27G
  }
7954
7955
1.52G
      if ((insn->isa == T32 && !thumb)
7956
1.52G
    || (insn->isa == ARM && thumb))
7957
12.0M
  continue;
7958
7959
1.51G
      if ((given & mask) != value)
7960
1.50G
  continue;
7961
7962
861k
      if (! ARM_CPU_HAS_FEATURE (insn->arch, allowed_arches))
7963
89.2k
  continue;
7964
7965
771k
      if (insn->value == 0xfe000010     /* mcr2  */
7966
771k
    || insn->value == 0xfe100010  /* mrc2  */
7967
771k
    || insn->value == 0xfc100000  /* ldc2  */
7968
771k
    || insn->value == 0xfc000000) /* stc2  */
7969
78.1k
  {
7970
78.1k
    if (cp_num == 9 || cp_num == 10 || cp_num == 11)
7971
6.66k
      is_unpredictable = true;
7972
7973
    /* Armv8.1-M Mainline FP & MVE instructions.  */
7974
78.1k
    if (ARM_CPU_HAS_FEATURE (arm_ext_v8_1m_main, allowed_arches)
7975
78.1k
        && !ARM_CPU_IS_ANY (allowed_arches)
7976
78.1k
        && (cp_num == 8 || cp_num == 14 || cp_num == 15))
7977
14.3k
      continue;
7978
7979
78.1k
  }
7980
693k
      else if (insn->value == 0x0e000000     /* cdp  */
7981
693k
         || insn->value == 0xfe000000  /* cdp2  */
7982
693k
         || insn->value == 0x0e000010  /* mcr  */
7983
693k
         || insn->value == 0x0e100010  /* mrc  */
7984
693k
         || insn->value == 0x0c100000  /* ldc  */
7985
693k
         || insn->value == 0x0c000000) /* stc  */
7986
609k
  {
7987
    /* Floating-point instructions.  */
7988
609k
    if (cp_num == 9 || cp_num == 10 || cp_num == 11)
7989
41.6k
      continue;
7990
7991
    /* Armv8.1-M Mainline FP & MVE instructions.  */
7992
568k
    if (ARM_CPU_HAS_FEATURE (arm_ext_v8_1m_main, allowed_arches)
7993
568k
        && !ARM_CPU_IS_ANY (allowed_arches)
7994
568k
        && (cp_num == 8 || cp_num == 14 || cp_num == 15))
7995
3.20k
      continue;
7996
568k
  }
7997
83.7k
      else if ((insn->value == 0xec100f80      /* vldr (system register) */
7998
83.7k
    || insn->value == 0xec000f80)  /* vstr (system register) */
7999
83.7k
         && arm_decode_field (given, 24, 24) == 0
8000
83.7k
         && arm_decode_field (given, 21, 21) == 0)
8001
  /* If the P and W bits are both 0 then these encodings match the MVE
8002
     VLDR and VSTR instructions, these are in a different table, so we
8003
     don't let it match here.  */
8004
4.46k
  continue;
8005
8006
18.7M
      for (c = insn->assembler; *c; c++)
8007
18.0M
  {
8008
18.0M
    if (*c == '%')
8009
8.17M
      {
8010
8.17M
        const char mod = *++c;
8011
8012
8.17M
        switch (mod)
8013
8.17M
    {
8014
2.12M
    case '{':
8015
2.12M
      ++c;
8016
2.12M
      if (*c == '\0')
8017
0
        abort ();
8018
2.12M
      old_base_style = base_style;
8019
2.12M
      base_style = decode_base_style (*c);
8020
2.12M
      ++c;
8021
2.12M
      if (*c != ':')
8022
0
        abort ();
8023
2.12M
      break;
8024
8025
2.12M
    case '}':
8026
2.12M
      base_style = old_base_style;
8027
2.12M
      break;
8028
8029
0
    case '%':
8030
0
      func (stream, base_style, "%%");
8031
0
      break;
8032
8033
415k
    case 'A':
8034
419k
    case 'K':
8035
419k
      {
8036
419k
        int rn = (given >> 16) & 0xf;
8037
419k
        bfd_vma offset = given & 0xff;
8038
8039
419k
        if (mod == 'K')
8040
4.41k
          offset = given & 0x7f;
8041
8042
419k
        func (stream, dis_style_text, "[");
8043
419k
        func (stream, dis_style_register, "%s",
8044
419k
        arm_regnames [(given >> 16) & 0xf]);
8045
8046
419k
        if (PRE_BIT_SET || WRITEBACK_BIT_SET)
8047
328k
          {
8048
      /* Not unindexed.  The offset is scaled.  */
8049
328k
      if (cp_num == 9)
8050
        /* vldr.16/vstr.16 will shift the address
8051
           left by 1 bit only.  */
8052
2.92k
        offset = offset * 2;
8053
325k
      else
8054
325k
        offset = offset * 4;
8055
8056
328k
      if (NEGATIVE_BIT_SET)
8057
208k
        offset = - offset;
8058
328k
      if (rn != 15)
8059
305k
        value_in_comment = offset;
8060
328k
          }
8061
8062
419k
        if (PRE_BIT_SET)
8063
210k
          {
8064
210k
      if (offset)
8065
183k
        {
8066
183k
          func (stream, dis_style_text, ", ");
8067
183k
          func (stream, dis_style_immediate, "#%d",
8068
183k
          (int) offset);
8069
183k
          func (stream, dis_style_text, "]%s",
8070
183k
          WRITEBACK_BIT_SET ? "!" : "");
8071
183k
        }
8072
27.0k
      else if (NEGATIVE_BIT_SET)
8073
21.5k
        {
8074
21.5k
          func (stream, dis_style_text, ", ");
8075
21.5k
          func (stream, dis_style_immediate, "#-0");
8076
21.5k
          func (stream, dis_style_text, "]");
8077
21.5k
        }
8078
5.54k
      else
8079
5.54k
        func (stream, dis_style_text, "]");
8080
210k
          }
8081
209k
        else
8082
209k
          {
8083
209k
      func (stream, dis_style_text, "]");
8084
8085
209k
      if (WRITEBACK_BIT_SET)
8086
117k
        {
8087
117k
          if (offset)
8088
111k
            {
8089
111k
        func (stream, dis_style_text, ", ");
8090
111k
        func (stream, dis_style_immediate,
8091
111k
              "#%d", (int) offset);
8092
111k
            }
8093
6.34k
          else if (NEGATIVE_BIT_SET)
8094
3.58k
            {
8095
3.58k
        func (stream, dis_style_text, ", ");
8096
3.58k
        func (stream, dis_style_immediate, "#-0");
8097
3.58k
            }
8098
117k
        }
8099
91.3k
      else
8100
91.3k
        {
8101
91.3k
          func (stream, dis_style_text, ", {");
8102
91.3k
          func (stream, dis_style_immediate, "%s%d",
8103
91.3k
          (NEGATIVE_BIT_SET && !offset) ? "-" : "",
8104
91.3k
          (int) offset);
8105
91.3k
          func (stream, dis_style_text, "}");
8106
91.3k
          value_in_comment = offset;
8107
91.3k
        }
8108
209k
          }
8109
419k
        if (rn == 15 && (PRE_BIT_SET || WRITEBACK_BIT_SET))
8110
22.5k
          {
8111
22.5k
      func (stream, dis_style_comment_start, "\t@ ");
8112
      /* For unaligned PCs, apply off-by-alignment
8113
         correction.  */
8114
22.5k
      info->print_address_func (offset + pc
8115
22.5k
              + info->bytes_per_chunk * 2
8116
22.5k
              - (pc & 3),
8117
22.5k
              info);
8118
22.5k
          }
8119
419k
      }
8120
419k
      break;
8121
8122
3.63k
    case 'B':
8123
3.63k
      {
8124
3.63k
        int regno = ((given >> 12) & 0xf) | ((given >> (22 - 4)) & 0x10);
8125
3.63k
        int offset = (given >> 1) & 0x3f;
8126
8127
3.63k
        func (stream, dis_style_text, "{");
8128
3.63k
        if (offset == 1)
8129
264
          func (stream, dis_style_register, "d%d", regno);
8130
3.36k
        else if (regno + offset > 32)
8131
2.35k
          {
8132
2.35k
      func (stream, dis_style_register, "d%d", regno);
8133
2.35k
      func (stream, dis_style_text, "-<overflow reg d%d>",
8134
2.35k
            regno + offset - 1);
8135
2.35k
          }
8136
1.01k
        else
8137
1.01k
          {
8138
1.01k
      func (stream, dis_style_register, "d%d", regno);
8139
1.01k
      func (stream, dis_style_text, "-");
8140
1.01k
      func (stream, dis_style_register, "d%d",
8141
1.01k
            regno + offset - 1);
8142
1.01k
          }
8143
3.63k
        func (stream, dis_style_text, "}");
8144
3.63k
      }
8145
3.63k
      break;
8146
8147
3.15k
    case 'C':
8148
3.15k
      {
8149
3.15k
        bool single = ((given >> 8) & 1) == 0;
8150
3.15k
        char reg_prefix = single ? 's' : 'd';
8151
3.15k
        int Dreg = (given >> 22) & 0x1;
8152
3.15k
        int Vdreg = (given >> 12) & 0xf;
8153
3.15k
        int reg = single ? ((Vdreg << 1) | Dreg)
8154
3.15k
             : ((Dreg << 4) | Vdreg);
8155
3.15k
        int num = (given >> (single ? 0 : 1)) & 0x7f;
8156
3.15k
        int maxreg = single ? 31 : 15;
8157
3.15k
        int topreg = reg + num - 1;
8158
8159
3.15k
        func (stream, dis_style_text, "{");
8160
3.15k
        if (!num)
8161
402
          {
8162
      /* Nothing.  */
8163
402
          }
8164
2.75k
        else if (num == 1)
8165
213
          {
8166
213
      func (stream, dis_style_register,
8167
213
            "%c%d", reg_prefix, reg);
8168
213
      func (stream, dis_style_text, ", ");
8169
213
          }
8170
2.53k
        else if (topreg > maxreg)
8171
2.28k
          {
8172
2.28k
      func (stream, dis_style_register, "%c%d",
8173
2.28k
            reg_prefix, reg);
8174
2.28k
      func (stream, dis_style_text, "-<overflow reg d%d, ",
8175
2.28k
            single ? topreg >> 1 : topreg);
8176
2.28k
          }
8177
249
        else
8178
249
          {
8179
249
      func (stream, dis_style_register,
8180
249
            "%c%d", reg_prefix, reg);
8181
249
      func (stream, dis_style_text, "-");
8182
249
      func (stream, dis_style_register, "%c%d",
8183
249
            reg_prefix, topreg);
8184
249
      func (stream, dis_style_text, ", ");
8185
249
          }
8186
3.15k
        func (stream, dis_style_register, "VPR");
8187
3.15k
        func (stream, dis_style_text, "}");
8188
3.15k
      }
8189
3.15k
      break;
8190
8191
3.45k
    case 'u':
8192
3.45k
      if (cond != COND_UNCOND)
8193
569
        is_unpredictable = true;
8194
8195
      /* Fall through.  */
8196
700k
    case 'c':
8197
700k
      if (cond != COND_UNCOND && cp_num == 9)
8198
4.40k
        is_unpredictable = true;
8199
8200
      /* Fall through.  */
8201
700k
    case 'b':
8202
700k
      func (stream, dis_style_mnemonic, "%s",
8203
700k
      arm_conditional[cond]);
8204
700k
      break;
8205
8206
4.41k
    case 'J':
8207
4.41k
      {
8208
4.41k
        unsigned long regno
8209
4.41k
          = arm_decode_field_multiple (given, 13, 15, 22, 22);
8210
8211
4.41k
        switch (regno)
8212
4.41k
          {
8213
287
          case 0x1:
8214
287
      func (stream, dis_style_register, "FPSCR");
8215
287
      break;
8216
224
          case 0x2:
8217
224
      func (stream, dis_style_register, "FPSCR_nzcvqc");
8218
224
      break;
8219
275
          case 0xc:
8220
275
      func (stream, dis_style_register, "VPR");
8221
275
      break;
8222
391
          case 0xd:
8223
391
      func (stream, dis_style_register, "P0");
8224
391
      break;
8225
607
          case 0xe:
8226
607
      func (stream, dis_style_register, "FPCXTNS");
8227
607
      break;
8228
238
          case 0xf:
8229
238
      func (stream, dis_style_register, "FPCXTS");
8230
238
      break;
8231
2.39k
          default:
8232
2.39k
      func (stream, dis_style_text, "<invalid reg %lu>",
8233
2.39k
            regno);
8234
2.39k
      break;
8235
4.41k
          }
8236
4.41k
      }
8237
4.41k
      break;
8238
8239
1.83M
    case '0': case '1': case '2': case '3': case '4':
8240
2.71M
    case '5': case '6': case '7': case '8': case '9':
8241
2.71M
      {
8242
2.71M
        int width;
8243
8244
2.71M
        c = arm_decode_bitfield (c, given, &value, &width);
8245
8246
2.71M
        switch (*c)
8247
2.71M
          {
8248
66.7k
          case 'R':
8249
66.7k
      if (value == 15)
8250
7.67k
        is_unpredictable = true;
8251
      /* Fall through.  */
8252
127k
          case 'r':
8253
127k
      if (c[1] == 'u')
8254
10.6k
        {
8255
          /* Eat the 'u' character.  */
8256
10.6k
          ++ c;
8257
8258
10.6k
          if (u_reg == value)
8259
630
            is_unpredictable = true;
8260
10.6k
          u_reg = value;
8261
10.6k
        }
8262
127k
      func (stream, dis_style_register, "%s",
8263
127k
            arm_regnames[value]);
8264
127k
      break;
8265
8.73k
          case 'V':
8266
8.73k
      if (given & (1 << 6))
8267
4.58k
        goto Q;
8268
      /* FALLTHROUGH */
8269
12.9k
          case 'D':
8270
12.9k
      func (stream, dis_style_register, "d%ld", value);
8271
12.9k
      break;
8272
1.64k
          case 'Q':
8273
6.22k
          Q:
8274
6.22k
      if (value & 1)
8275
2.26k
        func (stream, dis_style_text,
8276
2.26k
        "<illegal reg q%ld.5>", value >> 1);
8277
3.96k
      else
8278
3.96k
        func (stream, dis_style_register,
8279
3.96k
        "q%ld", value >> 1);
8280
6.22k
      break;
8281
2.11M
          case 'd':
8282
2.11M
      func (stream, base_style, "%ld", value);
8283
2.11M
      value_in_comment = value;
8284
2.11M
      break;
8285
963
          case 'E':
8286
963
                        {
8287
        /* Converts immediate 8 bit back to float value.  */
8288
963
        unsigned floatVal = (value & 0x80) << 24
8289
963
          | (value & 0x3F) << 19
8290
963
          | ((value & 0x40) ? (0xF8 << 22) : (1 << 30));
8291
8292
        /* Quarter float have a maximum value of 31.0.
8293
           Get floating point value multiplied by 1e7.
8294
           The maximum value stays in limit of a 32-bit int.  */
8295
963
        unsigned decVal =
8296
963
          (78125 << (((floatVal >> 23) & 0xFF) - 124)) *
8297
963
          (16 + (value & 0xF));
8298
8299
963
        if (!(decVal % 1000000))
8300
369
          {
8301
369
            func (stream, dis_style_immediate, "%ld", value);
8302
369
            func (stream, dis_style_comment_start,
8303
369
            "\t@ 0x%08x %c%u.%01u",
8304
369
            floatVal, value & 0x80 ? '-' : ' ',
8305
369
            decVal / 10000000,
8306
369
            decVal % 10000000 / 1000000);
8307
369
          }
8308
594
        else if (!(decVal % 10000))
8309
329
          {
8310
329
            func (stream, dis_style_immediate, "%ld", value);
8311
329
            func (stream, dis_style_comment_start,
8312
329
            "\t@ 0x%08x %c%u.%03u",
8313
329
            floatVal, value & 0x80 ? '-' : ' ',
8314
329
            decVal / 10000000,
8315
329
            decVal % 10000000 / 10000);
8316
329
          }
8317
265
        else
8318
265
          {
8319
265
            func (stream, dis_style_immediate, "%ld", value);
8320
265
            func (stream, dis_style_comment_start,
8321
265
            "\t@ 0x%08x %c%u.%07u",
8322
265
            floatVal, value & 0x80 ? '-' : ' ',
8323
265
            decVal / 10000000, decVal % 10000000);
8324
265
          }
8325
963
        break;
8326
1.64k
      }
8327
1.22k
          case 'k':
8328
1.22k
      {
8329
1.22k
        int from = (given & (1 << 7)) ? 32 : 16;
8330
1.22k
        func (stream, dis_style_immediate, "%ld",
8331
1.22k
        from - value);
8332
1.22k
      }
8333
1.22k
      break;
8334
8335
745
          case 'w':
8336
745
      if (width == 2)
8337
513
        func (stream, dis_style_mnemonic, "%s",
8338
513
        iwmmxt_wwnames[value]);
8339
232
      else
8340
232
        func (stream, dis_style_mnemonic, "%s",
8341
232
        iwmmxt_wwssnames[value]);
8342
745
      break;
8343
8344
11.1k
          case 'g':
8345
11.1k
      func (stream, dis_style_register, "%s",
8346
11.1k
            iwmmxt_regnames[value]);
8347
11.1k
      break;
8348
292
          case 'G':
8349
292
      func (stream, dis_style_register, "%s",
8350
292
            iwmmxt_cregnames[value]);
8351
292
      break;
8352
8353
194
          case 'x':
8354
194
      func (stream, dis_style_immediate, "0x%lx",
8355
194
            (value & 0xffffffffUL));
8356
194
      break;
8357
8358
2.44k
          case 'c':
8359
2.44k
      switch (value)
8360
2.44k
        {
8361
912
        case 0:
8362
912
          func (stream, dis_style_mnemonic, "eq");
8363
912
          break;
8364
8365
421
        case 1:
8366
421
          func (stream, dis_style_mnemonic, "vs");
8367
421
          break;
8368
8369
309
        case 2:
8370
309
          func (stream, dis_style_mnemonic, "ge");
8371
309
          break;
8372
8373
802
        case 3:
8374
802
          func (stream, dis_style_mnemonic, "gt");
8375
802
          break;
8376
8377
0
        default:
8378
0
          func (stream, dis_style_text, "??");
8379
0
          break;
8380
2.44k
        }
8381
2.44k
      break;
8382
8383
2.44k
          case '`':
8384
634
      c++;
8385
634
      if (value == 0)
8386
334
        func (stream, dis_style_mnemonic, "%c", *c);
8387
634
      break;
8388
417k
          case '\'':
8389
417k
      c++;
8390
417k
      if (value == ((1ul << width) - 1))
8391
193k
        func (stream, base_style, "%c", *c);
8392
417k
      break;
8393
16.2k
          case '?':
8394
16.2k
      func (stream, base_style, "%c",
8395
16.2k
            c[(1 << width) - (int) value]);
8396
16.2k
      c += 1 << width;
8397
16.2k
      break;
8398
0
          default:
8399
0
      abort ();
8400
2.71M
          }
8401
2.71M
      }
8402
2.71M
      break;
8403
8404
2.71M
    case 'y':
8405
61.5k
    case 'z':
8406
61.5k
      {
8407
61.5k
        int single = *c++ == 'y';
8408
61.5k
        int regno;
8409
8410
61.5k
        switch (*c)
8411
61.5k
          {
8412
721
          case '4': /* Sm pair */
8413
15.5k
          case '0': /* Sm, Dm */
8414
15.5k
      regno = given & 0x0000000f;
8415
15.5k
      if (single)
8416
10.0k
        {
8417
10.0k
          regno <<= 1;
8418
10.0k
          regno += (given >> 5) & 1;
8419
10.0k
        }
8420
5.56k
      else
8421
5.56k
        regno += ((given >> 5) & 1) << 4;
8422
15.5k
      break;
8423
8424
23.6k
          case '1': /* Sd, Dd */
8425
23.6k
      regno = (given >> 12) & 0x0000000f;
8426
23.6k
      if (single)
8427
16.4k
        {
8428
16.4k
          regno <<= 1;
8429
16.4k
          regno += (given >> 22) & 1;
8430
16.4k
        }
8431
7.23k
      else
8432
7.23k
        regno += ((given >> 22) & 1) << 4;
8433
23.6k
      break;
8434
8435
12.8k
          case '2': /* Sn, Dn */
8436
12.8k
      regno = (given >> 16) & 0x0000000f;
8437
12.8k
      if (single)
8438
7.97k
        {
8439
7.97k
          regno <<= 1;
8440
7.97k
          regno += (given >> 7) & 1;
8441
7.97k
        }
8442
4.83k
      else
8443
4.83k
        regno += ((given >> 7) & 1) << 4;
8444
12.8k
      break;
8445
8446
9.48k
          case '3': /* List */
8447
9.48k
      func (stream, dis_style_text, "{");
8448
9.48k
      regno = (given >> 12) & 0x0000000f;
8449
9.48k
      if (single)
8450
5.13k
        {
8451
5.13k
          regno <<= 1;
8452
5.13k
          regno += (given >> 22) & 1;
8453
5.13k
        }
8454
4.34k
      else
8455
4.34k
        regno += ((given >> 22) & 1) << 4;
8456
9.48k
      break;
8457
8458
0
          default:
8459
0
      abort ();
8460
61.5k
          }
8461
8462
61.5k
        func (stream, dis_style_register, "%c%d",
8463
61.5k
        single ? 's' : 'd', regno);
8464
8465
61.5k
        if (*c == '3')
8466
9.48k
          {
8467
9.48k
      int count = given & 0xff;
8468
8469
9.48k
      if (single == 0)
8470
4.34k
        count >>= 1;
8471
8472
9.48k
      if (--count)
8473
9.07k
        {
8474
9.07k
          func (stream, dis_style_text, "-");
8475
9.07k
          func (stream, dis_style_register, "%c%d",
8476
9.07k
          single ? 's' : 'd',
8477
9.07k
          regno + count);
8478
9.07k
        }
8479
8480
9.48k
      func (stream, dis_style_text, "}");
8481
9.48k
          }
8482
52.0k
        else if (*c == '4')
8483
721
          {
8484
721
      func (stream, dis_style_text, ", ");
8485
721
      func (stream, dis_style_register, "%c%d",
8486
721
            single ? 's' : 'd', regno + 1);
8487
721
          }
8488
61.5k
      }
8489
0
      break;
8490
8491
3.49k
    case 'L':
8492
3.49k
      switch (given & 0x00400100)
8493
3.49k
        {
8494
939
        case 0x00000000:
8495
939
          func (stream, dis_style_mnemonic, "b");
8496
939
          break;
8497
690
        case 0x00400000:
8498
690
          func (stream, dis_style_mnemonic, "h");
8499
690
          break;
8500
1.05k
        case 0x00000100:
8501
1.05k
          func (stream, dis_style_mnemonic, "w");
8502
1.05k
          break;
8503
813
        case 0x00400100:
8504
813
          func (stream, dis_style_mnemonic, "d");
8505
813
          break;
8506
0
        default:
8507
0
          break;
8508
3.49k
        }
8509
3.49k
      break;
8510
8511
3.49k
    case 'Z':
8512
366
      {
8513
        /* given (20, 23) | given (0, 3) */
8514
366
        value = ((given >> 16) & 0xf0) | (given & 0xf);
8515
366
        func (stream, dis_style_immediate, "%d", (int) value);
8516
366
      }
8517
366
      break;
8518
8519
3.49k
    case 'l':
8520
      /* This is like the 'A' operator, except that if
8521
         the width field "M" is zero, then the offset is
8522
         *not* multiplied by four.  */
8523
3.49k
      {
8524
3.49k
        int offset = given & 0xff;
8525
3.49k
        int multiplier = (given & 0x00000100) ? 4 : 1;
8526
8527
3.49k
        func (stream, dis_style_text, "[");
8528
3.49k
        func (stream, dis_style_register, "%s",
8529
3.49k
        arm_regnames [(given >> 16) & 0xf]);
8530
8531
3.49k
        if (multiplier > 1)
8532
1.87k
          {
8533
1.87k
      value_in_comment = offset * multiplier;
8534
1.87k
      if (NEGATIVE_BIT_SET)
8535
1.09k
        value_in_comment = - value_in_comment;
8536
1.87k
          }
8537
8538
3.49k
        if (offset)
8539
2.51k
          {
8540
2.51k
      if (PRE_BIT_SET)
8541
549
        {
8542
549
          func (stream, dis_style_text, ", ");
8543
549
          func (stream, dis_style_immediate, "#%s%d",
8544
549
          NEGATIVE_BIT_SET ? "-" : "",
8545
549
          offset * multiplier);
8546
549
          func (stream, dis_style_text, "]%s",
8547
549
          WRITEBACK_BIT_SET ? "!" : "");
8548
549
        }
8549
1.96k
      else
8550
1.96k
        {
8551
1.96k
          func (stream, dis_style_text, "], ");
8552
1.96k
          func (stream, dis_style_immediate, "#%s%d",
8553
1.96k
          NEGATIVE_BIT_SET ? "-" : "",
8554
1.96k
          offset * multiplier);
8555
1.96k
        }
8556
2.51k
          }
8557
981
        else
8558
981
          func (stream, dis_style_text, "]");
8559
3.49k
      }
8560
3.49k
      break;
8561
8562
2.47k
    case 'r':
8563
2.47k
      {
8564
2.47k
        int imm4 = (given >> 4) & 0xf;
8565
2.47k
        int puw_bits = ((given >> 22) & 6) | ((given >> W_BIT) & 1);
8566
2.47k
        int ubit = ! NEGATIVE_BIT_SET;
8567
2.47k
        const char *rm = arm_regnames [given & 0xf];
8568
2.47k
        const char *rn = arm_regnames [(given >> 16) & 0xf];
8569
8570
2.47k
        switch (puw_bits)
8571
2.47k
          {
8572
337
          case 1:
8573
901
          case 3:
8574
901
      func (stream, dis_style_text, "[");
8575
901
      func (stream, dis_style_register, "%s", rn);
8576
901
      func (stream, dis_style_text, "], ");
8577
901
      func (stream, dis_style_text, "%c", ubit ? '+' : '-');
8578
901
      func (stream, dis_style_register, "%s", rm);
8579
901
      if (imm4)
8580
509
        {
8581
509
          func (stream, dis_style_text, ", ");
8582
509
          func (stream, dis_style_sub_mnemonic, "lsl ");
8583
509
          func (stream, dis_style_immediate, "#%d", imm4);
8584
509
        }
8585
901
      break;
8586
8587
300
          case 4:
8588
574
          case 5:
8589
793
          case 6:
8590
1.32k
          case 7:
8591
1.32k
      func (stream, dis_style_text, "[");
8592
1.32k
      func (stream, dis_style_register, "%s", rn);
8593
1.32k
      func (stream, dis_style_text, ", ");
8594
1.32k
      func (stream, dis_style_text, "%c", ubit ? '+' : '-');
8595
1.32k
      func (stream, dis_style_register, "%s", rm);
8596
1.32k
      if (imm4 > 0)
8597
1.04k
        {
8598
1.04k
          func (stream, dis_style_text, ", ");
8599
1.04k
          func (stream, dis_style_sub_mnemonic, "lsl ");
8600
1.04k
          func (stream, dis_style_immediate, "#%d", imm4);
8601
1.04k
        }
8602
1.32k
      func (stream, dis_style_text, "]");
8603
1.32k
      if (puw_bits == 5 || puw_bits == 7)
8604
810
        func (stream, dis_style_text, "!");
8605
1.32k
      break;
8606
8607
249
          default:
8608
249
      func (stream, dis_style_text, "INVALID");
8609
2.47k
          }
8610
2.47k
      }
8611
2.47k
      break;
8612
8613
2.47k
    case 'i':
8614
477
      {
8615
477
        long imm5;
8616
477
        imm5 = ((given & 0x100) >> 4) | (given & 0xf);
8617
477
        func (stream, dis_style_immediate, "%ld",
8618
477
        (imm5 == 0) ? 32 : imm5);
8619
477
      }
8620
477
      break;
8621
8622
0
    default:
8623
0
      abort ();
8624
8.17M
    }
8625
8.17M
      }
8626
9.86M
    else
8627
9.86M
      {
8628
9.86M
        if (*c == '@')
8629
4.34k
    base_style = dis_style_comment_start;
8630
8631
9.86M
        if (*c == '\t')
8632
712k
    base_style = dis_style_text;
8633
8634
9.86M
        func (stream, base_style, "%c", *c);
8635
9.86M
      }
8636
18.0M
  }
8637
8638
708k
      if (value_in_comment > 32 || value_in_comment < -16)
8639
318k
  func (stream, dis_style_comment_start, "\t@ 0x%lx",
8640
318k
        (value_in_comment & 0xffffffffUL));
8641
8642
708k
      if (is_unpredictable)
8643
19.3k
  func (stream, dis_style_comment_start, UNPREDICTABLE_INSTRUCTION);
8644
8645
708k
      return true;
8646
708k
    }
8647
13.3M
  return false;
8648
14.0M
}
8649
8650
static bool
8651
print_insn_coprocessor (bfd_vma pc,
8652
      struct disassemble_info *info,
8653
      long given,
8654
      bool thumb)
8655
7.17M
{
8656
7.17M
  return print_insn_coprocessor_1 (coprocessor_opcodes,
8657
7.17M
           pc, info, given, thumb);
8658
7.17M
}
8659
8660
static bool
8661
print_insn_generic_coprocessor (bfd_vma pc,
8662
        struct disassemble_info *info,
8663
        long given,
8664
        bool thumb)
8665
6.85M
{
8666
6.85M
  return print_insn_coprocessor_1 (generic_coprocessor_opcodes,
8667
6.85M
           pc, info, given, thumb);
8668
6.85M
}
8669
8670
/* Decodes and prints ARM addressing modes.  Returns the offset
8671
   used in the address, if any, if it is worthwhile printing the
8672
   offset as a hexadecimal value in a comment at the end of the
8673
   line of disassembly.  */
8674
8675
static signed long
8676
print_arm_address (bfd_vma pc, struct disassemble_info *info, long given)
8677
825k
{
8678
825k
  void *stream = info->stream;
8679
825k
  fprintf_styled_ftype func = info->fprintf_styled_func;
8680
825k
  bfd_vma offset = 0;
8681
8682
825k
  if (((given & 0x000f0000) == 0x000f0000)
8683
825k
      && ((given & 0x02000000) == 0))
8684
33.3k
    {
8685
33.3k
      offset = given & 0xfff;
8686
8687
33.3k
      func (stream, dis_style_text, "[");
8688
33.3k
      func (stream, dis_style_register, "pc");
8689
8690
33.3k
      if (PRE_BIT_SET)
8691
18.7k
  {
8692
    /* Pre-indexed.  Elide offset of positive zero when
8693
       non-writeback.  */
8694
18.7k
    if (WRITEBACK_BIT_SET || NEGATIVE_BIT_SET || offset)
8695
17.1k
      {
8696
17.1k
        func (stream, dis_style_text, ", ");
8697
17.1k
        func (stream, dis_style_immediate, "#%s%d",
8698
17.1k
        NEGATIVE_BIT_SET ? "-" : "", (int) offset);
8699
17.1k
      }
8700
8701
18.7k
    if (NEGATIVE_BIT_SET)
8702
8.77k
      offset = -offset;
8703
8704
18.7k
    offset += pc + 8;
8705
8706
    /* Cope with the possibility of write-back
8707
       being used.  Probably a very dangerous thing
8708
       for the programmer to do, but who are we to
8709
       argue ?  */
8710
18.7k
    func (stream, dis_style_text, "]%s", WRITEBACK_BIT_SET ? "!" : "");
8711
18.7k
  }
8712
14.6k
      else  /* Post indexed.  */
8713
14.6k
  {
8714
14.6k
    func (stream, dis_style_text, "], ");
8715
14.6k
    func (stream, dis_style_immediate, "#%s%d",
8716
14.6k
    NEGATIVE_BIT_SET ? "-" : "", (int) offset);
8717
8718
    /* Ie ignore the offset.  */
8719
14.6k
    offset = pc + 8;
8720
14.6k
  }
8721
8722
33.3k
      func (stream, dis_style_comment_start, "\t@ ");
8723
33.3k
      info->print_address_func (offset, info);
8724
33.3k
      offset = 0;
8725
33.3k
    }
8726
792k
  else
8727
792k
    {
8728
792k
      func (stream, dis_style_text, "[");
8729
792k
      func (stream, dis_style_register, "%s",
8730
792k
      arm_regnames[(given >> 16) & 0xf]);
8731
8732
792k
      if (PRE_BIT_SET)
8733
374k
  {
8734
374k
    if ((given & 0x02000000) == 0)
8735
276k
      {
8736
        /* Elide offset of positive zero when non-writeback.  */
8737
276k
        offset = given & 0xfff;
8738
276k
        if (WRITEBACK_BIT_SET || NEGATIVE_BIT_SET || offset)
8739
268k
    {
8740
268k
      func (stream, dis_style_text, ", ");
8741
268k
      func (stream, dis_style_immediate, "#%s%d",
8742
268k
      NEGATIVE_BIT_SET ? "-" : "", (int) offset);
8743
268k
    }
8744
276k
      }
8745
97.9k
    else
8746
97.9k
      {
8747
97.9k
        func (stream, dis_style_text, ", %s",
8748
97.9k
        NEGATIVE_BIT_SET ? "-" : "");
8749
97.9k
        arm_decode_shift (given, func, stream, true);
8750
97.9k
      }
8751
8752
374k
    func (stream, dis_style_text, "]%s",
8753
374k
    WRITEBACK_BIT_SET ? "!" : "");
8754
374k
  }
8755
417k
      else
8756
417k
  {
8757
417k
    if ((given & 0x02000000) == 0)
8758
290k
      {
8759
        /* Always show offset.  */
8760
290k
        offset = given & 0xfff;
8761
290k
        func (stream, dis_style_text, "], ");
8762
290k
        func (stream, dis_style_immediate, "#%s%d",
8763
290k
        NEGATIVE_BIT_SET ? "-" : "", (int) offset);
8764
290k
      }
8765
127k
    else
8766
127k
      {
8767
127k
        func (stream, dis_style_text, "], %s",
8768
127k
        NEGATIVE_BIT_SET ? "-" : "");
8769
127k
        arm_decode_shift (given, func, stream, true);
8770
127k
      }
8771
417k
  }
8772
792k
      if (NEGATIVE_BIT_SET)
8773
550k
  offset = -offset;
8774
792k
    }
8775
8776
825k
  return (signed long) offset;
8777
825k
}
8778
8779
8780
/* Print one cde instruction on INFO->STREAM.
8781
   Return TRUE if the instuction matched, FALSE if this is not a
8782
   recognised cde instruction.  */
8783
static bool
8784
print_insn_cde (struct disassemble_info *info, long given, bool thumb)
8785
905k
{
8786
905k
  const struct cdeopcode32 *insn;
8787
905k
  void *stream = info->stream;
8788
905k
  fprintf_styled_ftype func = info->fprintf_styled_func;
8789
905k
  enum disassembler_style base_style = dis_style_mnemonic;
8790
905k
  enum disassembler_style old_base_style = base_style;
8791
8792
905k
  if (thumb)
8793
905k
  {
8794
    /* Manually extract the coprocessor code from a known point.
8795
       This position is the same across all CDE instructions.  */
8796
11.7M
    for (insn = cde_opcodes; insn->assembler; insn++)
8797
10.8M
    {
8798
10.8M
      uint16_t coproc = (given >> insn->coproc_shift) & insn->coproc_mask;
8799
10.8M
      uint16_t coproc_mask = 1 << coproc;
8800
10.8M
      if (! (coproc_mask & cde_coprocs))
8801
10.0M
  continue;
8802
8803
733k
      if ((given & insn->mask) == insn->value)
8804
6.66k
      {
8805
6.66k
  bool is_unpredictable = false;
8806
6.66k
  const char *c;
8807
8808
156k
  for (c = insn->assembler; *c; c++)
8809
149k
  {
8810
149k
    if (*c == '%')
8811
54.6k
    {
8812
54.6k
      switch (*++c)
8813
54.6k
      {
8814
6.66k
        case '{':
8815
6.66k
    ++c;
8816
6.66k
    if (*c == '\0')
8817
0
      abort ();
8818
6.66k
    old_base_style = base_style;
8819
6.66k
    base_style = decode_base_style (*c);
8820
6.66k
    ++c;
8821
6.66k
    if (*c != ':')
8822
0
      abort ();
8823
6.66k
    break;
8824
8825
6.66k
        case '}':
8826
6.66k
    base_style = old_base_style;
8827
6.66k
    break;
8828
8829
0
        case '%':
8830
0
    func (stream, base_style, "%%");
8831
0
    break;
8832
8833
28.0k
        case '0': case '1': case '2': case '3': case '4':
8834
28.0k
        case '5': case '6': case '7': case '8': case '9':
8835
28.0k
        {
8836
28.0k
    int width;
8837
28.0k
    unsigned long value;
8838
8839
28.0k
    c = arm_decode_bitfield (c, given, &value, &width);
8840
8841
28.0k
    switch (*c)
8842
28.0k
    {
8843
3.71k
      case 'S':
8844
3.71k
        if (value > 10)
8845
1.98k
          is_unpredictable = true;
8846
        /* Fall through.  */
8847
3.71k
      case 'R':
8848
3.71k
        if (value == 13)
8849
208
          is_unpredictable = true;
8850
        /* Fall through.  */
8851
3.71k
      case 'r':
8852
3.71k
        func (stream, dis_style_register, "%s",
8853
3.71k
        arm_regnames[value]);
8854
3.71k
        break;
8855
8856
8.25k
      case 'n':
8857
8.25k
        if (value == 15)
8858
667
          func (stream, dis_style_register, "%s", "APSR_nzcv");
8859
7.58k
        else
8860
7.58k
          func (stream, dis_style_register, "%s",
8861
7.58k
          arm_regnames[value]);
8862
8.25k
        break;
8863
8864
3.71k
      case 'T':
8865
3.71k
        func (stream, dis_style_register, "%s",
8866
3.71k
        arm_regnames[(value + 1) & 15]);
8867
3.71k
        break;
8868
8869
6.66k
      case 'd':
8870
6.66k
        func (stream, dis_style_immediate, "%ld", value);
8871
6.66k
        break;
8872
8873
5.67k
      case 'V':
8874
5.67k
        if (given & (1 << 6))
8875
2.67k
          func (stream, dis_style_register, "q%ld", value >> 1);
8876
2.99k
        else if (given & (1 << 24))
8877
1.33k
          func (stream, dis_style_register, "d%ld", value);
8878
1.66k
        else
8879
1.66k
          {
8880
      /* Encoding for S register is different than for D and
8881
         Q registers.  S registers are encoded using the top
8882
         single bit in position 22 as the lowest bit of the
8883
         register number, while for Q and D it represents the
8884
         highest bit of the register number.  */
8885
1.66k
      uint8_t top_bit = (value >> 4) & 1;
8886
1.66k
      uint8_t tmp = (value << 1) & 0x1e;
8887
1.66k
      uint8_t res = tmp | top_bit;
8888
1.66k
      func (stream, dis_style_register, "s%u", res);
8889
1.66k
          }
8890
5.67k
        break;
8891
8892
0
    default:
8893
0
      abort ();
8894
28.0k
    }
8895
28.0k
        }
8896
28.0k
      break;
8897
8898
28.0k
      case 'p':
8899
6.66k
        {
8900
6.66k
    uint8_t proc_number = (given >> 8) & 0x7;
8901
6.66k
    func (stream, dis_style_register, "p%u", proc_number);
8902
6.66k
    break;
8903
28.0k
        }
8904
8905
6.66k
      case 'a':
8906
6.66k
        {
8907
6.66k
    uint8_t a_offset = 28;
8908
6.66k
    if (given & (1 << a_offset))
8909
3.67k
      func (stream, dis_style_mnemonic, "a");
8910
6.66k
    break;
8911
28.0k
        }
8912
0
    default:
8913
0
      abort ();
8914
54.6k
    }
8915
54.6k
  }
8916
95.1k
  else
8917
95.1k
    {
8918
95.1k
      if (*c == '@')
8919
0
        base_style = dis_style_comment_start;
8920
95.1k
      if (*c == '\t')
8921
6.66k
        base_style = dis_style_text;
8922
8923
95.1k
      func (stream, base_style, "%c", *c);
8924
95.1k
    }
8925
149k
      }
8926
8927
6.66k
      if (is_unpredictable)
8928
1.98k
  func (stream, dis_style_comment_start, UNPREDICTABLE_INSTRUCTION);
8929
8930
6.66k
      return true;
8931
6.66k
      }
8932
733k
    }
8933
898k
    return false;
8934
905k
  }
8935
0
  else
8936
0
    return false;
8937
905k
}
8938
8939
8940
/* Print one neon instruction on INFO->STREAM.
8941
   Return TRUE if the instuction matched, FALSE if this is not a
8942
   recognised neon instruction.  */
8943
8944
static bool
8945
print_insn_neon (struct disassemble_info *info, long given, bool thumb)
8946
6.54M
{
8947
6.54M
  const struct opcode32 *insn;
8948
6.54M
  void *stream = info->stream;
8949
6.54M
  fprintf_styled_ftype func = info->fprintf_styled_func;
8950
6.54M
  enum disassembler_style base_style = dis_style_mnemonic;
8951
6.54M
  enum disassembler_style old_base_style = base_style;
8952
8953
6.54M
  if (thumb)
8954
571k
    {
8955
571k
      if ((given & 0xef000000) == 0xef000000)
8956
91.2k
  {
8957
    /* Move bit 28 to bit 24 to translate Thumb2 to ARM encoding.  */
8958
91.2k
    unsigned long bit28 = given & (1 << 28);
8959
8960
91.2k
    given &= 0x00ffffff;
8961
91.2k
    if (bit28)
8962
82.2k
            given |= 0xf3000000;
8963
9.07k
          else
8964
9.07k
      given |= 0xf2000000;
8965
91.2k
  }
8966
479k
      else if ((given & 0xff000000) == 0xf9000000)
8967
14.0k
  given ^= 0xf9000000 ^ 0xf4000000;
8968
      /* BFloat16 neon instructions without special top byte handling.  */
8969
465k
      else if ((given & 0xff000000) == 0xfe000000
8970
465k
         || (given & 0xff000000) == 0xfc000000)
8971
23.4k
  ;
8972
      /* vdup is also a valid neon instruction.  */
8973
442k
      else if ((given & 0xff900f5f) != 0xee800b10)
8974
442k
  return false;
8975
571k
    }
8976
8977
1.84G
  for (insn = neon_opcodes; insn->assembler; insn++)
8978
1.83G
    {
8979
1.83G
      unsigned long cond_mask = insn->mask;
8980
1.83G
      unsigned long cond_value = insn->value;
8981
1.83G
      int cond;
8982
8983
1.83G
      if (thumb)
8984
31.2M
        {
8985
31.2M
          if ((cond_mask & 0xf0000000) == 0) {
8986
              /* For the entries in neon_opcodes, an opcode mask/value with
8987
                 the high 4 bits equal to 0 indicates a conditional
8988
                 instruction. For thumb however, we need to include those
8989
                 bits in the instruction matching.  */
8990
772k
              cond_mask |= 0xf0000000;
8991
              /* Furthermore, the thumb encoding of a conditional instruction
8992
                 will have the high 4 bits equal to 0xe.  */
8993
772k
              cond_value |= 0xe0000000;
8994
772k
          }
8995
31.2M
          if (ifthen_state)
8996
268k
            cond = IFTHEN_COND;
8997
30.9M
          else
8998
30.9M
            cond = COND_UNCOND;
8999
31.2M
        }
9000
1.80G
      else
9001
1.80G
        {
9002
1.80G
          if ((given & 0xf0000000) == 0xf0000000)
9003
119M
            {
9004
              /* If the instruction is unconditional, update the mask to only
9005
                 match against unconditional opcode values.  */
9006
119M
              cond_mask |= 0xf0000000;
9007
119M
              cond = COND_UNCOND;
9008
119M
            }
9009
1.68G
          else
9010
1.68G
            {
9011
1.68G
              cond = (given >> 28) & 0xf;
9012
1.68G
              if (cond == 0xe)
9013
88.8M
                cond = COND_UNCOND;
9014
1.68G
            }
9015
1.80G
        }
9016
9017
1.83G
      if ((given & cond_mask) == cond_value)
9018
87.1k
  {
9019
87.1k
    signed long value_in_comment = 0;
9020
87.1k
    bool is_unpredictable = false;
9021
87.1k
    const char *c;
9022
9023
1.50M
    for (c = insn->assembler; *c; c++)
9024
1.42M
      {
9025
1.42M
        if (*c == '%')
9026
459k
    {
9027
459k
      switch (*++c)
9028
459k
        {
9029
15.8k
        case '{':
9030
15.8k
          ++c;
9031
15.8k
          if (*c == '\0')
9032
0
      abort ();
9033
15.8k
          old_base_style = base_style;
9034
15.8k
          base_style = decode_base_style (*c);
9035
15.8k
          ++c;
9036
15.8k
          if (*c != ':')
9037
0
      abort ();
9038
15.8k
          break;
9039
9040
15.8k
        case '}':
9041
15.8k
          base_style = old_base_style;
9042
15.8k
          break;
9043
9044
0
        case '%':
9045
0
          func (stream, base_style, "%%");
9046
0
          break;
9047
9048
8.42k
        case 'u':
9049
8.42k
          if (thumb && ifthen_state)
9050
301
      is_unpredictable = true;
9051
9052
          /* Fall through.  */
9053
85.9k
        case 'c':
9054
85.9k
          func (stream, dis_style_mnemonic, "%s",
9055
85.9k
          arm_conditional[cond]);
9056
85.9k
          break;
9057
9058
6.04k
        case 'A':
9059
6.04k
          {
9060
6.04k
      static const unsigned char enc[16] =
9061
6.04k
      {
9062
6.04k
        0x4, 0x14, /* st4 0,1 */
9063
6.04k
        0x4, /* st1 2 */
9064
6.04k
        0x4, /* st2 3 */
9065
6.04k
        0x3, /* st3 4 */
9066
6.04k
        0x13, /* st3 5 */
9067
6.04k
        0x3, /* st1 6 */
9068
6.04k
        0x1, /* st1 7 */
9069
6.04k
        0x2, /* st2 8 */
9070
6.04k
        0x12, /* st2 9 */
9071
6.04k
        0x2, /* st1 10 */
9072
6.04k
        0, 0, 0, 0, 0
9073
6.04k
      };
9074
6.04k
      int rd = ((given >> 12) & 0xf) | (((given >> 22) & 1) << 4);
9075
6.04k
      int rn = ((given >> 16) & 0xf);
9076
6.04k
      int rm = ((given >> 0) & 0xf);
9077
6.04k
      int align = ((given >> 4) & 0x3);
9078
6.04k
      int type = ((given >> 8) & 0xf);
9079
6.04k
      int n = enc[type] & 0xf;
9080
6.04k
      int stride = (enc[type] >> 4) + 1;
9081
6.04k
      int ix;
9082
9083
6.04k
      func (stream, dis_style_text, "{");
9084
6.04k
      if (stride > 1)
9085
8.22k
        for (ix = 0; ix != n; ix++)
9086
6.16k
          {
9087
6.16k
            if (ix > 0)
9088
4.11k
        func (stream, dis_style_text, ",");
9089
6.16k
            func (stream, dis_style_register, "d%d",
9090
6.16k
            rd + ix * stride);
9091
6.16k
          }
9092
3.98k
      else if (n == 1)
9093
659
        func (stream, dis_style_register, "d%d", rd);
9094
3.33k
      else
9095
3.33k
        {
9096
3.33k
          func (stream, dis_style_register, "d%d", rd);
9097
3.33k
          func (stream, dis_style_text, "-");
9098
3.33k
          func (stream, dis_style_register, "d%d",
9099
3.33k
          rd + n - 1);
9100
3.33k
        }
9101
6.04k
      func (stream, dis_style_text, "}, [");
9102
6.04k
      func (stream, dis_style_register, "%s",
9103
6.04k
            arm_regnames[rn]);
9104
6.04k
      if (align)
9105
4.10k
        {
9106
4.10k
          func (stream, dis_style_text, " :");
9107
4.10k
          func (stream, dis_style_immediate, "%d",
9108
4.10k
          32 << align);
9109
4.10k
        }
9110
6.04k
      func (stream, dis_style_text, "]");
9111
6.04k
      if (rm == 0xd)
9112
431
        func (stream, dis_style_text, "!");
9113
5.61k
      else if (rm != 0xf)
9114
5.04k
        {
9115
5.04k
          func (stream, dis_style_text, ", ");
9116
5.04k
          func (stream, dis_style_register, "%s",
9117
5.04k
          arm_regnames[rm]);
9118
5.04k
        }
9119
6.04k
          }
9120
6.04k
          break;
9121
9122
7.30k
        case 'B':
9123
7.30k
          {
9124
7.30k
      int rd = ((given >> 12) & 0xf) | (((given >> 22) & 1) << 4);
9125
7.30k
      int rn = ((given >> 16) & 0xf);
9126
7.30k
      int rm = ((given >> 0) & 0xf);
9127
7.30k
      int idx_align = ((given >> 4) & 0xf);
9128
7.30k
                        int align = 0;
9129
7.30k
      int size = ((given >> 10) & 0x3);
9130
7.30k
      int idx = idx_align >> (size + 1);
9131
7.30k
                        int length = ((given >> 8) & 3) + 1;
9132
7.30k
                        int stride = 1;
9133
7.30k
                        int i;
9134
9135
7.30k
                        if (length > 1 && size > 0)
9136
3.29k
                          stride = (idx_align & (1 << size)) ? 2 : 1;
9137
9138
7.30k
                        switch (length)
9139
7.30k
                          {
9140
2.55k
                          case 1:
9141
2.55k
                            {
9142
2.55k
                              int amask = (1 << size) - 1;
9143
2.55k
                              if ((idx_align & (1 << size)) != 0)
9144
904
                                return false;
9145
1.65k
                              if (size > 0)
9146
953
                                {
9147
953
                                  if ((idx_align & amask) == amask)
9148
246
                                    align = 8 << size;
9149
707
                                  else if ((idx_align & amask) != 0)
9150
283
                                    return false;
9151
953
                                }
9152
1.65k
                              }
9153
1.36k
                            break;
9154
9155
1.69k
                          case 2:
9156
1.69k
                            if (size == 2 && (idx_align & 2) != 0)
9157
302
                              return false;
9158
1.38k
                            align = (idx_align & 1) ? 16 << size : 0;
9159
1.38k
                            break;
9160
9161
1.14k
                          case 3:
9162
1.14k
                            if ((size == 2 && (idx_align & 3) != 0)
9163
1.14k
                                || (idx_align & 1) != 0)
9164
614
                              return false;
9165
533
                            break;
9166
9167
1.91k
                          case 4:
9168
1.91k
                            if (size == 2)
9169
682
                              {
9170
682
                                if ((idx_align & 3) == 3)
9171
260
                                  return false;
9172
422
                                align = (idx_align & 3) * 64;
9173
422
                              }
9174
1.23k
                            else
9175
1.23k
                              align = (idx_align & 1) ? 32 << size : 0;
9176
1.65k
                            break;
9177
9178
1.65k
                          default:
9179
0
                            abort ();
9180
7.30k
                          }
9181
9182
4.94k
      func (stream, dis_style_text, "{");
9183
17.2k
                        for (i = 0; i < length; i++)
9184
12.3k
        {
9185
12.3k
          if (i > 0)
9186
7.41k
            func (stream, dis_style_text, ",");
9187
12.3k
          func (stream, dis_style_register, "d%d[%d]",
9188
12.3k
          rd + i * stride, idx);
9189
12.3k
        }
9190
4.94k
      func (stream, dis_style_text, "}, [");
9191
4.94k
      func (stream, dis_style_register, "%s",
9192
4.94k
            arm_regnames[rn]);
9193
4.94k
      if (align)
9194
1.55k
        {
9195
1.55k
          func (stream, dis_style_text, " :");
9196
1.55k
          func (stream, dis_style_immediate, "%d", align);
9197
1.55k
        }
9198
4.94k
      func (stream, dis_style_text, "]");
9199
4.94k
      if (rm == 0xd)
9200
337
        func (stream, dis_style_text, "!");
9201
4.60k
      else if (rm != 0xf)
9202
4.02k
        {
9203
4.02k
          func (stream, dis_style_text, ", ");
9204
4.02k
          func (stream, dis_style_register, "%s",
9205
4.02k
          arm_regnames[rm]);
9206
4.02k
        }
9207
4.94k
          }
9208
0
          break;
9209
9210
2.37k
        case 'C':
9211
2.37k
          {
9212
2.37k
      int rd = ((given >> 12) & 0xf) | (((given >> 22) & 1) << 4);
9213
2.37k
      int rn = ((given >> 16) & 0xf);
9214
2.37k
      int rm = ((given >> 0) & 0xf);
9215
2.37k
      int align = ((given >> 4) & 0x1);
9216
2.37k
      int size = ((given >> 6) & 0x3);
9217
2.37k
      int type = ((given >> 8) & 0x3);
9218
2.37k
      int n = type + 1;
9219
2.37k
      int stride = ((given >> 5) & 0x1);
9220
2.37k
      int ix;
9221
9222
2.37k
      if (stride && (n == 1))
9223
592
        n++;
9224
1.78k
      else
9225
1.78k
        stride++;
9226
9227
2.37k
      func (stream, dis_style_text, "{");
9228
2.37k
      if (stride > 1)
9229
5.17k
        for (ix = 0; ix != n; ix++)
9230
4.08k
          {
9231
4.08k
            if (ix > 0)
9232
2.98k
        func (stream, dis_style_text, ",");
9233
4.08k
            func (stream, dis_style_register, "d%d[]",
9234
4.08k
            rd + ix * stride);
9235
4.08k
          }
9236
1.28k
      else if (n == 1)
9237
265
        func (stream, dis_style_register, "d%d[]", rd);
9238
1.01k
      else
9239
1.01k
        {
9240
1.01k
          func (stream, dis_style_register, "d%d[]", rd);
9241
1.01k
          func (stream, dis_style_text, "-");
9242
1.01k
          func (stream, dis_style_register, "d%d[]",
9243
1.01k
          rd + n - 1);
9244
1.01k
        }
9245
2.37k
      func (stream, dis_style_text, "}, [");
9246
2.37k
      func (stream, dis_style_register, "%s",
9247
2.37k
            arm_regnames[rn]);
9248
2.37k
      if (align)
9249
1.57k
        {
9250
1.57k
                            align = (8 * (type + 1)) << size;
9251
1.57k
                            if (type == 3)
9252
701
                              align = (size > 1) ? align >> 1 : align;
9253
1.57k
          if (type == 2 || (type == 0 && !size))
9254
495
            func (stream, dis_style_text,
9255
495
            " :<bad align %d>", align);
9256
1.08k
          else
9257
1.08k
            {
9258
1.08k
        func (stream, dis_style_text, " :");
9259
1.08k
        func (stream, dis_style_immediate,
9260
1.08k
              "%d", align);
9261
1.08k
            }
9262
1.57k
        }
9263
2.37k
      func (stream, dis_style_text, "]");
9264
2.37k
      if (rm == 0xd)
9265
318
        func (stream, dis_style_text, "!");
9266
2.05k
      else if (rm != 0xf)
9267
1.58k
        {
9268
1.58k
          func (stream, dis_style_text, ", ");
9269
1.58k
          func (stream, dis_style_register, "%s",
9270
1.58k
          arm_regnames[rm]);
9271
1.58k
        }
9272
2.37k
          }
9273
2.37k
          break;
9274
9275
5.65k
        case 'D':
9276
5.65k
          {
9277
5.65k
      int raw_reg = (given & 0xf) | ((given >> 1) & 0x10);
9278
5.65k
      int size = (given >> 20) & 3;
9279
5.65k
      int reg = raw_reg & ((4 << size) - 1);
9280
5.65k
      int ix = raw_reg >> size >> 2;
9281
9282
5.65k
      func (stream, dis_style_register, "d%d[%d]", reg, ix);
9283
5.65k
          }
9284
5.65k
          break;
9285
9286
3.43k
        case 'E':
9287
          /* Neon encoded constant for mov, mvn, vorr, vbic.  */
9288
3.43k
          {
9289
3.43k
      int bits = 0;
9290
3.43k
      int cmode = (given >> 8) & 0xf;
9291
3.43k
      int op = (given >> 5) & 0x1;
9292
3.43k
      unsigned long value = 0, hival = 0;
9293
3.43k
      unsigned shift;
9294
3.43k
                        int size = 0;
9295
3.43k
                        int isfloat = 0;
9296
9297
3.43k
      bits |= ((given >> 24) & 1) << 7;
9298
3.43k
      bits |= ((given >> 16) & 7) << 4;
9299
3.43k
      bits |= ((given >> 0) & 15) << 0;
9300
9301
3.43k
      if (cmode < 8)
9302
1.18k
        {
9303
1.18k
          shift = (cmode >> 1) & 3;
9304
1.18k
          value = (unsigned long) bits << (8 * shift);
9305
1.18k
                            size = 32;
9306
1.18k
        }
9307
2.25k
      else if (cmode < 12)
9308
470
        {
9309
470
          shift = (cmode >> 1) & 1;
9310
470
          value = (unsigned long) bits << (8 * shift);
9311
470
                            size = 16;
9312
470
        }
9313
1.78k
      else if (cmode < 14)
9314
345
        {
9315
345
          shift = (cmode & 1) + 1;
9316
345
          value = (unsigned long) bits << (8 * shift);
9317
345
          value |= (1ul << (8 * shift)) - 1;
9318
345
                            size = 32;
9319
345
        }
9320
1.43k
      else if (cmode == 14)
9321
1.05k
        {
9322
1.05k
          if (op)
9323
759
            {
9324
        /* Bit replication into bytes.  */
9325
759
        int ix;
9326
759
        unsigned long mask;
9327
9328
759
        value = 0;
9329
759
                                hival = 0;
9330
6.83k
        for (ix = 7; ix >= 0; ix--)
9331
6.07k
          {
9332
6.07k
            mask = ((bits >> ix) & 1) ? 0xff : 0;
9333
6.07k
                                    if (ix <= 3)
9334
3.03k
              value = (value << 8) | mask;
9335
3.03k
                                    else
9336
3.03k
                                      hival = (hival << 8) | mask;
9337
6.07k
          }
9338
759
                                size = 64;
9339
759
            }
9340
298
                            else
9341
298
                              {
9342
                                /* Byte replication.  */
9343
298
                                value = (unsigned long) bits;
9344
298
                                size = 8;
9345
298
                              }
9346
1.05k
        }
9347
378
      else if (!op)
9348
378
        {
9349
          /* Floating point encoding.  */
9350
378
          int tmp;
9351
9352
378
          value = (unsigned long)  (bits & 0x7f) << 19;
9353
378
          value |= (unsigned long) (bits & 0x80) << 24;
9354
378
          tmp = bits & 0x40 ? 0x3c : 0x40;
9355
378
          value |= (unsigned long) tmp << 24;
9356
378
                            size = 32;
9357
378
                            isfloat = 1;
9358
378
        }
9359
0
      else
9360
0
        {
9361
0
          func (stream, dis_style_text,
9362
0
          "<illegal constant %.8x:%x:%x>",
9363
0
                                  bits, cmode, op);
9364
0
                            size = 32;
9365
0
          break;
9366
0
        }
9367
3.43k
                        switch (size)
9368
3.43k
                          {
9369
298
                          case 8:
9370
298
          func (stream, dis_style_immediate, "#%ld", value);
9371
298
          func (stream, dis_style_comment_start,
9372
298
          "\t@ 0x%.2lx", value);
9373
298
                            break;
9374
9375
470
                          case 16:
9376
470
          func (stream, dis_style_immediate, "#%ld", value);
9377
470
          func (stream, dis_style_comment_start,
9378
470
          "\t@ 0x%.4lx", value);
9379
470
                            break;
9380
9381
1.90k
                          case 32:
9382
1.90k
                            if (isfloat)
9383
378
                              {
9384
378
                                unsigned char valbytes[4];
9385
378
                                double fvalue;
9386
9387
                                /* Do this a byte at a time so we don't have to
9388
                                   worry about the host's endianness.  */
9389
378
                                valbytes[0] = value & 0xff;
9390
378
                                valbytes[1] = (value >> 8) & 0xff;
9391
378
                                valbytes[2] = (value >> 16) & 0xff;
9392
378
                                valbytes[3] = (value >> 24) & 0xff;
9393
9394
378
                                floatformat_to_double
9395
378
                                  (& floatformat_ieee_single_little, valbytes,
9396
378
                                  & fvalue);
9397
9398
378
        func (stream, dis_style_immediate,
9399
378
              "#%.7g", fvalue);
9400
378
        func (stream, dis_style_comment_start,
9401
378
              "\t@ 0x%.8lx", value);
9402
378
                              }
9403
1.52k
                            else
9404
1.52k
            {
9405
1.52k
        func (stream, dis_style_immediate, "#%ld",
9406
1.52k
              (long) (((value & 0x80000000L) != 0)
9407
1.52k
                ? value | ~0xffffffffL : value));
9408
1.52k
        func (stream, dis_style_comment_start,
9409
1.52k
              "\t@ 0x%.8lx", value);
9410
1.52k
            }
9411
1.90k
                            break;
9412
9413
759
                          case 64:
9414
759
          func (stream, dis_style_immediate,
9415
759
          "#0x%.8lx%.8lx", hival, value);
9416
759
                            break;
9417
9418
0
                          default:
9419
0
                            abort ();
9420
3.43k
                          }
9421
3.43k
          }
9422
3.43k
          break;
9423
9424
3.43k
        case 'F':
9425
1.87k
          {
9426
1.87k
      int regno = ((given >> 16) & 0xf) | ((given >> (7 - 4)) & 0x10);
9427
1.87k
      int num = (given >> 8) & 0x3;
9428
9429
1.87k
      func (stream, dis_style_text, "{");
9430
1.87k
      if (!num)
9431
513
        func (stream, dis_style_register, "d%d", regno);
9432
1.36k
      else if (num + regno >= 32)
9433
622
        {
9434
622
          func (stream, dis_style_register, "d%d", regno);
9435
622
          func (stream, dis_style_text, "-<overflow reg d%d",
9436
622
          regno + num);
9437
622
        }
9438
740
      else
9439
740
        {
9440
740
          func (stream, dis_style_register, "d%d", regno);
9441
740
          func (stream, dis_style_text, "-");
9442
740
          func (stream, dis_style_register, "d%d",
9443
740
          regno + num);
9444
740
        }
9445
1.87k
      func (stream, dis_style_text, "}");
9446
1.87k
          }
9447
1.87k
          break;
9448
9449
9450
303k
        case '0': case '1': case '2': case '3': case '4':
9451
314k
        case '5': case '6': case '7': case '8': case '9':
9452
314k
          {
9453
314k
      int width;
9454
314k
      unsigned long value;
9455
9456
314k
      c = arm_decode_bitfield (c, given, &value, &width);
9457
9458
314k
      switch (*c)
9459
314k
        {
9460
438
        case 'r':
9461
438
          func (stream, dis_style_register, "%s",
9462
438
          arm_regnames[value]);
9463
438
          break;
9464
5.60k
        case 'd':
9465
5.60k
          func (stream, base_style, "%ld", value);
9466
5.60k
          value_in_comment = value;
9467
5.60k
          break;
9468
10.8k
        case 'e':
9469
10.8k
          func (stream, dis_style_immediate, "%ld",
9470
10.8k
          (1ul << width) - value);
9471
10.8k
          break;
9472
9473
48.4k
        case 'S':
9474
49.8k
        case 'T':
9475
49.8k
        case 'U':
9476
          /* Various width encodings.  */
9477
49.8k
          {
9478
49.8k
            int base = 8 << (*c - 'S'); /* 8,16 or 32 */
9479
49.8k
            int limit;
9480
49.8k
            unsigned low, high;
9481
9482
49.8k
            c++;
9483
49.8k
            if (*c >= '0' && *c <= '9')
9484
48.4k
        limit = *c - '0';
9485
1.44k
            else if (*c >= 'a' && *c <= 'f')
9486
1.44k
        limit = *c - 'a' + 10;
9487
0
            else
9488
0
        abort ();
9489
49.8k
            low = limit >> 2;
9490
49.8k
            high = limit & 3;
9491
9492
49.8k
            if (value < low || value > high)
9493
14.2k
        func (stream, dis_style_text,
9494
14.2k
              "<illegal width %d>", base << value);
9495
35.5k
            else
9496
35.5k
        func (stream, base_style, "%d",
9497
35.5k
              base << value);
9498
49.8k
          }
9499
0
          break;
9500
133k
        case 'R':
9501
133k
          if (given & (1 << 6))
9502
92.0k
            goto Q;
9503
          /* FALLTHROUGH */
9504
65.4k
        case 'D':
9505
65.4k
          func (stream, dis_style_register, "d%ld", value);
9506
65.4k
          break;
9507
25.5k
        case 'Q':
9508
117k
        Q:
9509
117k
          if (value & 1)
9510
58.5k
            func (stream, dis_style_text,
9511
58.5k
            "<illegal reg q%ld.5>", value >> 1);
9512
59.0k
          else
9513
59.0k
            func (stream, dis_style_register,
9514
59.0k
            "q%ld", value >> 1);
9515
117k
          break;
9516
9517
0
        case '`':
9518
0
          c++;
9519
0
          if (value == 0)
9520
0
            func (stream, dis_style_text, "%c", *c);
9521
0
          break;
9522
0
        case '\'':
9523
0
          c++;
9524
0
          if (value == ((1ul << width) - 1))
9525
0
            func (stream, dis_style_text, "%c", *c);
9526
0
          break;
9527
65.0k
        case '?':
9528
65.0k
          func (stream, dis_style_mnemonic, "%c",
9529
65.0k
          c[(1 << width) - (int) value]);
9530
65.0k
          c += 1 << width;
9531
65.0k
          break;
9532
0
        default:
9533
0
          abort ();
9534
314k
        }
9535
314k
          }
9536
314k
          break;
9537
9538
314k
        default:
9539
0
          abort ();
9540
459k
        }
9541
459k
    }
9542
965k
        else
9543
965k
    {
9544
965k
      if (*c == '@')
9545
0
        base_style = dis_style_comment_start;
9546
9547
965k
      if (*c == '\t')
9548
87.1k
        base_style = dis_style_text;
9549
9550
965k
      func (stream, base_style, "%c", *c);
9551
9552
965k
    }
9553
1.42M
      }
9554
9555
84.7k
    if (value_in_comment > 32 || value_in_comment < -16)
9556
1.64k
      func (stream, dis_style_comment_start, "\t@ 0x%lx",
9557
1.64k
      value_in_comment);
9558
9559
84.7k
    if (is_unpredictable)
9560
301
      func (stream, dis_style_comment_start, UNPREDICTABLE_INSTRUCTION);
9561
9562
84.7k
    return true;
9563
87.1k
  }
9564
1.83G
    }
9565
6.01M
  return false;
9566
6.10M
}
9567
9568
/* Print one mve instruction on INFO->STREAM.
9569
   Return TRUE if the instuction matched, FALSE if this is not a
9570
   recognised mve instruction.  */
9571
9572
static bool
9573
print_insn_mve (struct disassemble_info *info, long given)
9574
564k
{
9575
564k
  const struct mopcode32 *insn;
9576
564k
  void *stream = info->stream;
9577
564k
  fprintf_styled_ftype func = info->fprintf_styled_func;
9578
564k
  enum disassembler_style base_style = dis_style_mnemonic;
9579
564k
  enum disassembler_style old_base_style = base_style;
9580
9581
110M
  for (insn = mve_opcodes; insn->assembler; insn++)
9582
110M
    {
9583
110M
      if (((given & insn->mask) == insn->value)
9584
110M
    && !is_mve_encoding_conflict (given, insn->mve_op))
9585
167k
  {
9586
167k
    signed long value_in_comment = 0;
9587
167k
    bool is_unpredictable = false;
9588
167k
    bool is_undefined = false;
9589
167k
    const char *c;
9590
167k
    enum mve_unpredictable unpredictable_cond = UNPRED_NONE;
9591
167k
    enum mve_undefined undefined_cond = UNDEF_NONE;
9592
9593
    /* Most vector mve instruction are illegal in a it block.
9594
       There are a few exceptions; check for them.  */
9595
167k
    if (ifthen_state && !is_mve_okay_in_it (insn->mve_op))
9596
3.28k
      {
9597
3.28k
        is_unpredictable = true;
9598
3.28k
        unpredictable_cond = UNPRED_IT_BLOCK;
9599
3.28k
      }
9600
164k
    else if (is_mve_unpredictable (given, insn->mve_op,
9601
164k
           &unpredictable_cond))
9602
28.7k
      is_unpredictable = true;
9603
9604
167k
    if (is_mve_undefined (given, insn->mve_op, &undefined_cond))
9605
18.4k
      is_undefined = true;
9606
9607
    /* In "VORR Qd, Qm, Qn", if Qm==Qn, VORR is nothing but VMOV,
9608
       i.e "VMOV Qd, Qm".  */
9609
167k
    if ((insn->mve_op == MVE_VORR_REG)
9610
167k
        && (arm_decode_field (given, 1, 3)
9611
837
      == arm_decode_field (given, 17, 19)))
9612
632
      continue;
9613
9614
3.00M
    for (c = insn->assembler; *c; c++)
9615
2.83M
      {
9616
2.83M
        if (*c == '%')
9617
919k
    {
9618
919k
      switch (*++c)
9619
919k
        {
9620
40.5k
        case '{':
9621
40.5k
          ++c;
9622
40.5k
          if (*c == '\0')
9623
0
      abort ();
9624
40.5k
          old_base_style = base_style;
9625
40.5k
          base_style = decode_base_style (*c);
9626
40.5k
          ++c;
9627
40.5k
          if (*c != ':')
9628
0
      abort ();
9629
40.5k
          break;
9630
9631
40.5k
        case '}':
9632
40.5k
          base_style = old_base_style;
9633
40.5k
          break;
9634
9635
0
        case '%':
9636
0
          func (stream, base_style, "%%");
9637
0
          break;
9638
9639
4.05k
        case 'a':
9640
          /* Don't print anything for '+' as it is implied.  */
9641
4.05k
          if (arm_decode_field (given, 23, 23) == 0)
9642
2.85k
      func (stream, dis_style_immediate, "-");
9643
4.05k
          break;
9644
9645
14.8k
        case 'c':
9646
14.8k
          if (ifthen_state)
9647
8.74k
      func (stream, dis_style_mnemonic, "%s",
9648
8.74k
            arm_conditional[IFTHEN_COND]);
9649
14.8k
          break;
9650
9651
8.49k
        case 'd':
9652
8.49k
          print_mve_vld_str_addr (info, given, insn->mve_op);
9653
8.49k
          break;
9654
9655
15.9k
        case 'i':
9656
15.9k
          {
9657
15.9k
      long mve_mask = mve_extract_pred_mask (given);
9658
15.9k
      func (stream, dis_style_mnemonic, "%s",
9659
15.9k
            mve_predicatenames[mve_mask]);
9660
15.9k
          }
9661
15.9k
          break;
9662
9663
5.58k
        case 'j':
9664
5.58k
          {
9665
5.58k
      unsigned int imm5 = 0;
9666
5.58k
      imm5 |= arm_decode_field (given, 6, 7);
9667
5.58k
      imm5 |= (arm_decode_field (given, 12, 14) << 2);
9668
5.58k
      func (stream, dis_style_immediate, "#%u",
9669
5.58k
            (imm5 == 0) ? 32 : imm5);
9670
5.58k
          }
9671
5.58k
          break;
9672
9673
1.28k
        case 'k':
9674
1.28k
          func (stream, dis_style_immediate, "#%u",
9675
1.28k
          (arm_decode_field (given, 7, 7) == 0) ? 64 : 48);
9676
1.28k
          break;
9677
9678
18.8k
        case 'n':
9679
18.8k
          print_vec_condition (info, given, insn->mve_op);
9680
18.8k
          break;
9681
9682
5.17k
        case 'o':
9683
5.17k
          if (arm_decode_field (given, 0, 0) == 1)
9684
3.28k
      {
9685
3.28k
        unsigned long size
9686
3.28k
          = arm_decode_field (given, 4, 4)
9687
3.28k
            | (arm_decode_field (given, 6, 6) << 1);
9688
9689
3.28k
        func (stream, dis_style_text, ", ");
9690
3.28k
        func (stream, dis_style_sub_mnemonic, "uxtw ");
9691
3.28k
        func (stream, dis_style_immediate, "#%lu", size);
9692
3.28k
      }
9693
5.17k
          break;
9694
9695
5.25k
        case 'm':
9696
5.25k
          print_mve_rounding_mode (info, given, insn->mve_op);
9697
5.25k
          break;
9698
9699
13.2k
        case 's':
9700
13.2k
          print_mve_vcvt_size (info, given, insn->mve_op);
9701
13.2k
          break;
9702
9703
34.9k
        case 'u':
9704
34.9k
          {
9705
34.9k
      unsigned long op1 = arm_decode_field (given, 21, 22);
9706
9707
34.9k
      if ((insn->mve_op == MVE_VMOV_VEC_LANE_TO_GP))
9708
974
        {
9709
          /* Check for signed.  */
9710
974
          if (arm_decode_field (given, 23, 23) == 0)
9711
528
            {
9712
        /* We don't print 's' for S32.  */
9713
528
        if ((arm_decode_field (given, 5, 6) == 0)
9714
528
            && ((op1 == 0) || (op1 == 1)))
9715
0
          ;
9716
528
        else
9717
528
          func (stream, dis_style_mnemonic, "s");
9718
528
            }
9719
446
          else
9720
446
            func (stream, dis_style_mnemonic, "u");
9721
974
        }
9722
33.9k
      else
9723
33.9k
        {
9724
33.9k
          if (arm_decode_field (given, 28, 28) == 0)
9725
16.1k
            func (stream, dis_style_mnemonic, "s");
9726
17.8k
          else
9727
17.8k
            func (stream, dis_style_mnemonic, "u");
9728
33.9k
        }
9729
34.9k
          }
9730
34.9k
          break;
9731
9732
129k
        case 'v':
9733
129k
          print_instruction_predicate (info);
9734
129k
          break;
9735
9736
4.92k
        case 'w':
9737
4.92k
          if (arm_decode_field (given, 21, 21) == 1)
9738
2.37k
      func (stream, dis_style_text, "!");
9739
4.92k
          break;
9740
9741
3.10k
        case 'B':
9742
3.10k
          print_mve_register_blocks (info, given, insn->mve_op);
9743
3.10k
          break;
9744
9745
9.98k
        case 'E':
9746
          /* SIMD encoded constant for mov, mvn, vorr, vbic.  */
9747
9748
9.98k
          print_simd_imm8 (info, given, 28, insn);
9749
9.98k
          break;
9750
9751
1.79k
        case 'N':
9752
1.79k
          print_mve_vmov_index (info, given);
9753
1.79k
          break;
9754
9755
13.1k
        case 'T':
9756
13.1k
          if (arm_decode_field (given, 12, 12) == 0)
9757
7.47k
      func (stream, dis_style_mnemonic, "b");
9758
5.64k
          else
9759
5.64k
      func (stream, dis_style_mnemonic, "t");
9760
13.1k
          break;
9761
9762
3.57k
        case 'X':
9763
3.57k
          if (arm_decode_field (given, 12, 12) == 1)
9764
1.17k
      func (stream, dis_style_mnemonic, "x");
9765
3.57k
          break;
9766
9767
498k
        case '0': case '1': case '2': case '3': case '4':
9768
545k
        case '5': case '6': case '7': case '8': case '9':
9769
545k
          {
9770
545k
      int width;
9771
545k
      unsigned long value;
9772
9773
545k
      c = arm_decode_bitfield (c, given, &value, &width);
9774
9775
545k
      switch (*c)
9776
545k
        {
9777
15.6k
        case 'Z':
9778
15.6k
          if (value == 13)
9779
2.14k
            is_unpredictable = true;
9780
13.4k
          else if (value == 15)
9781
2.24k
            func (stream, dis_style_register, "zr");
9782
11.2k
          else
9783
11.2k
            func (stream, dis_style_register, "%s",
9784
11.2k
            arm_regnames[value]);
9785
15.6k
          break;
9786
9787
1.84k
        case 'c':
9788
1.84k
          func (stream, dis_style_sub_mnemonic, "%s",
9789
1.84k
          arm_conditional[value]);
9790
1.84k
          break;
9791
9792
1.68k
        case 'C':
9793
1.68k
          value ^= 1;
9794
1.68k
          func (stream, dis_style_sub_mnemonic, "%s",
9795
1.68k
          arm_conditional[value]);
9796
1.68k
          break;
9797
9798
10.9k
        case 'S':
9799
10.9k
          if (value == 13 || value == 15)
9800
2.98k
            is_unpredictable = true;
9801
7.92k
          else
9802
7.92k
            func (stream, dis_style_register, "%s",
9803
7.92k
            arm_regnames[value]);
9804
10.9k
          break;
9805
9806
117k
        case 's':
9807
117k
          print_mve_size (info,
9808
117k
              value,
9809
117k
              insn->mve_op);
9810
117k
          break;
9811
971
        case 'I':
9812
971
          if (value == 1)
9813
574
            func (stream, dis_style_mnemonic, "i");
9814
971
          break;
9815
5.88k
        case 'A':
9816
5.88k
          if (value == 1)
9817
2.10k
            func (stream, dis_style_mnemonic, "a");
9818
5.88k
          break;
9819
12.7k
        case 'h':
9820
12.7k
          {
9821
12.7k
            unsigned int odd_reg = (value << 1) | 1;
9822
12.7k
            func (stream, dis_style_register, "%s",
9823
12.7k
            arm_regnames[odd_reg]);
9824
12.7k
          }
9825
12.7k
          break;
9826
4.05k
        case 'i':
9827
4.05k
          {
9828
4.05k
            unsigned long imm
9829
4.05k
        = arm_decode_field (given, 0, 6);
9830
4.05k
            unsigned long mod_imm = imm;
9831
9832
4.05k
            switch (insn->mve_op)
9833
4.05k
        {
9834
1.00k
        case MVE_VLDRW_GATHER_T5:
9835
1.49k
        case MVE_VSTRW_SCATTER_T5:
9836
1.49k
          mod_imm = mod_imm << 2;
9837
1.49k
          break;
9838
1.79k
        case MVE_VSTRD_SCATTER_T6:
9839
2.55k
        case MVE_VLDRD_GATHER_T6:
9840
2.55k
          mod_imm = mod_imm << 3;
9841
2.55k
          break;
9842
9843
0
        default:
9844
0
          break;
9845
4.05k
        }
9846
9847
4.05k
            func (stream, dis_style_immediate, "%lu",
9848
4.05k
            mod_imm);
9849
4.05k
          }
9850
0
          break;
9851
6.03k
        case 'k':
9852
6.03k
          func (stream, dis_style_immediate, "%lu",
9853
6.03k
          64 - value);
9854
6.03k
          break;
9855
16.8k
        case 'l':
9856
16.8k
          {
9857
16.8k
            unsigned int even_reg = value << 1;
9858
16.8k
            func (stream, dis_style_register, "%s",
9859
16.8k
            arm_regnames[even_reg]);
9860
16.8k
          }
9861
16.8k
          break;
9862
4.60k
        case 'u':
9863
4.60k
          switch (value)
9864
4.60k
            {
9865
702
            case 0:
9866
702
        func (stream, dis_style_immediate, "1");
9867
702
        break;
9868
268
            case 1:
9869
268
        func (stream, dis_style_immediate, "2");
9870
268
        break;
9871
3.11k
            case 2:
9872
3.11k
        func (stream, dis_style_immediate, "4");
9873
3.11k
        break;
9874
515
            case 3:
9875
515
        func (stream, dis_style_immediate, "8");
9876
515
        break;
9877
0
            default:
9878
0
        break;
9879
4.60k
            }
9880
4.60k
          break;
9881
6.75k
        case 'o':
9882
6.75k
          print_mve_rotate (info, value, width);
9883
6.75k
          break;
9884
42.2k
        case 'r':
9885
42.2k
          func (stream, dis_style_register, "%s",
9886
42.2k
          arm_regnames[value]);
9887
42.2k
          break;
9888
13.6k
        case 'd':
9889
13.6k
          if (mve_shift_insn_p (insn->mve_op))
9890
8.59k
            print_mve_shift_n (info, given, insn->mve_op);
9891
5.08k
          else if (insn->mve_op == MVE_VSHLL_T2)
9892
549
            func (stream, dis_style_immediate, "%s",
9893
549
            mve_vec_sizename[value]);
9894
4.54k
          else
9895
4.54k
            {
9896
4.54k
        if (insn->mve_op == MVE_VSHLC && value == 0)
9897
1.03k
          value = 32;
9898
4.54k
        func (stream, base_style, "%ld", value);
9899
4.54k
        value_in_comment = value;
9900
4.54k
            }
9901
13.6k
          break;
9902
0
        case 'F':
9903
0
          func (stream, dis_style_register, "s%ld", value);
9904
0
          break;
9905
283k
        case 'Q':
9906
283k
          if (value & 0x8)
9907
126k
            func (stream, dis_style_text,
9908
126k
            "<illegal reg q%ld.5>", value);
9909
156k
          else
9910
156k
            func (stream, dis_style_register, "q%ld", value);
9911
283k
          break;
9912
215
        case 'x':
9913
215
          func (stream, dis_style_immediate,
9914
215
          "0x%08lx", value);
9915
215
          break;
9916
0
        default:
9917
0
          abort ();
9918
545k
        }
9919
545k
      break;
9920
545k
          default:
9921
0
      abort ();
9922
545k
          }
9923
919k
        }
9924
919k
    }
9925
1.91M
        else
9926
1.91M
    {
9927
1.91M
      if (*c == '@')
9928
215
        base_style = dis_style_comment_start;
9929
9930
1.91M
      if (*c == '\t')
9931
165k
        base_style = dis_style_text;
9932
9933
1.91M
      func (stream, base_style, "%c", *c);
9934
1.91M
    }
9935
2.83M
      }
9936
9937
166k
    if (value_in_comment > 32 || value_in_comment < -16)
9938
0
      func (stream, dis_style_comment_start, "\t@ 0x%lx",
9939
0
      value_in_comment);
9940
9941
166k
    if (is_unpredictable)
9942
35.5k
      print_mve_unpredictable (info, unpredictable_cond);
9943
9944
166k
    if (is_undefined)
9945
18.4k
      print_mve_undefined (info, undefined_cond);
9946
9947
166k
    if (!vpt_block_state.in_vpt_block
9948
166k
        && !ifthen_state
9949
166k
        && is_vpt_instruction (given))
9950
6.17k
      mark_inside_vpt_block (given);
9951
160k
    else if (vpt_block_state.in_vpt_block)
9952
17.9k
      update_vpt_block_state ();
9953
9954
166k
    return true;
9955
166k
  }
9956
110M
    }
9957
397k
  return false;
9958
564k
}
9959
9960
9961
/* Return the name of a v7A special register.  */
9962
9963
static const char *
9964
banked_regname (unsigned reg)
9965
56.3k
{
9966
56.3k
  switch (reg)
9967
56.3k
    {
9968
1.44k
      case 15: return "CPSR";
9969
859
      case 32: return "R8_usr";
9970
647
      case 33: return "R9_usr";
9971
466
      case 34: return "R10_usr";
9972
334
      case 35: return "R11_usr";
9973
246
      case 36: return "R12_usr";
9974
249
      case 37: return "SP_usr";
9975
248
      case 38: return "LR_usr";
9976
472
      case 40: return "R8_fiq";
9977
235
      case 41: return "R9_fiq";
9978
218
      case 42: return "R10_fiq";
9979
264
      case 43: return "R11_fiq";
9980
226
      case 44: return "R12_fiq";
9981
693
      case 45: return "SP_fiq";
9982
630
      case 46: return "LR_fiq";
9983
599
      case 48: return "LR_irq";
9984
290
      case 49: return "SP_irq";
9985
258
      case 50: return "LR_svc";
9986
263
      case 51: return "SP_svc";
9987
244
      case 52: return "LR_abt";
9988
347
      case 53: return "SP_abt";
9989
314
      case 54: return "LR_und";
9990
486
      case 55: return "SP_und";
9991
340
      case 60: return "LR_mon";
9992
671
      case 61: return "SP_mon";
9993
280
      case 62: return "ELR_hyp";
9994
346
      case 63: return "SP_hyp";
9995
252
      case 79: return "SPSR";
9996
309
      case 110: return "SPSR_fiq";
9997
360
      case 112: return "SPSR_irq";
9998
554
      case 114: return "SPSR_svc";
9999
226
      case 116: return "SPSR_abt";
10000
263
      case 118: return "SPSR_und";
10001
543
      case 124: return "SPSR_mon";
10002
332
      case 126: return "SPSR_hyp";
10003
41.8k
      default: return NULL;
10004
56.3k
    }
10005
56.3k
}
10006
10007
/* Return the name of the DMB/DSB option.  */
10008
static const char *
10009
data_barrier_option (unsigned option)
10010
1.37k
{
10011
1.37k
  switch (option & 0xf)
10012
1.37k
    {
10013
37
    case 0xf: return "sy";
10014
15
    case 0xe: return "st";
10015
4
    case 0xd: return "ld";
10016
6
    case 0xb: return "ish";
10017
191
    case 0xa: return "ishst";
10018
52
    case 0x9: return "ishld";
10019
40
    case 0x7: return "un";
10020
52
    case 0x6: return "unst";
10021
261
    case 0x5: return "nshld";
10022
5
    case 0x3: return "osh";
10023
2
    case 0x2: return "oshst";
10024
9
    case 0x1: return "oshld";
10025
697
    default:  return NULL;
10026
1.37k
    }
10027
1.37k
}
10028
10029
/* Print one ARM instruction from PC on INFO->STREAM.  */
10030
10031
static void
10032
print_insn_arm (bfd_vma pc, struct disassemble_info *info, long given)
10033
6.00M
{
10034
6.00M
  const struct opcode32 *insn;
10035
6.00M
  void *stream = info->stream;
10036
6.00M
  fprintf_styled_ftype func = info->fprintf_styled_func;
10037
6.00M
  struct arm_private_data *private_data = info->private_data;
10038
6.00M
  enum disassembler_style base_style = dis_style_mnemonic;
10039
6.00M
  enum disassembler_style old_base_style = base_style;
10040
10041
6.00M
  if (print_insn_coprocessor (pc, info, given, false))
10042
33.9k
    return;
10043
10044
5.97M
  if (print_insn_neon (info, given, false))
10045
21.2k
    return;
10046
10047
5.95M
  if (print_insn_generic_coprocessor (pc, info, given, false))
10048
564k
    return;
10049
10050
1.46G
  for (insn = arm_opcodes; insn->assembler; insn++)
10051
1.46G
    {
10052
1.46G
      if ((given & insn->mask) != insn->value)
10053
1.45G
  continue;
10054
10055
5.84M
      if (! ARM_CPU_HAS_FEATURE (insn->arch, private_data->features))
10056
89.5k
  continue;
10057
10058
      /* Special case: an instruction with all bits set in the condition field
10059
   (0xFnnn_nnnn) is only matched if all those bits are set in insn->mask,
10060
   or by the catchall at the end of the table.  */
10061
5.75M
      if ((given & 0xF0000000) != 0xF0000000
10062
5.75M
    || (insn->mask & 0xF0000000) == 0xF0000000
10063
5.75M
    || (insn->mask == 0 && insn->value == 0))
10064
5.38M
  {
10065
5.38M
    unsigned long u_reg = 16;
10066
5.38M
    unsigned long U_reg = 16;
10067
5.38M
    bool is_unpredictable = false;
10068
5.38M
    signed long value_in_comment = 0;
10069
5.38M
    const char *c;
10070
10071
78.7M
    for (c = insn->assembler; *c; c++)
10072
73.3M
      {
10073
73.3M
        if (*c == '%')
10074
22.5M
    {
10075
22.5M
      bool allow_unpredictable = false;
10076
10077
22.5M
      switch (*++c)
10078
22.5M
        {
10079
22.6k
        case '{':
10080
22.6k
          ++c;
10081
22.6k
          if (*c == '\0')
10082
0
      abort ();
10083
22.6k
          old_base_style = base_style;
10084
22.6k
          base_style = decode_base_style (*c);
10085
22.6k
          ++c;
10086
22.6k
          if (*c != ':')
10087
0
      abort ();
10088
22.6k
          break;
10089
10090
22.6k
        case '}':
10091
22.6k
          base_style = old_base_style;
10092
22.6k
          break;
10093
10094
0
        case '%':
10095
0
          func (stream, base_style, "%%");
10096
0
          break;
10097
10098
825k
        case 'a':
10099
825k
          value_in_comment = print_arm_address (pc, info, given);
10100
825k
          break;
10101
10102
217
        case 'P':
10103
          /* Set P address bit and use normal address
10104
       printing routine.  */
10105
217
          value_in_comment = print_arm_address (pc, info, given | (1 << P_BIT));
10106
217
          break;
10107
10108
981
        case 'T':
10109
          /* Armv4 does not have a BX instruction, however, when
10110
       assembled with the --fix-v4bx option GAS will accept
10111
       and assemble a BX instruction when assembling for
10112
       Armv4.  When disassembling we also disassemble it as a
10113
       BX instruction, but do make the user aware that this
10114
       instruction is only supported on HW from Armv4T
10115
       onwards.  */
10116
981
          if (info->mach == bfd_mach_arm_4)
10117
194
      func (stream, dis_style_text, "\t@ from Armv4T onwards");
10118
981
          break;
10119
10120
16.7k
        case 'S':
10121
16.7k
          allow_unpredictable = true;
10122
          /* Fall through.  */
10123
126k
        case 's':
10124
126k
                      if ((given & 0x004f0000) == 0x004f0000)
10125
10.7k
      {
10126
                          /* PC relative with immediate offset.  */
10127
10.7k
        bfd_vma offset = ((given & 0xf00) >> 4) | (given & 0xf);
10128
10129
10.7k
        if (PRE_BIT_SET)
10130
2.68k
          {
10131
            /* Elide positive zero offset.  */
10132
2.68k
            if (offset || NEGATIVE_BIT_SET)
10133
2.42k
        {
10134
2.42k
          func (stream, dis_style_text, "[");
10135
2.42k
          func (stream, dis_style_register, "pc");
10136
2.42k
          func (stream, dis_style_text, ", ");
10137
2.42k
          func (stream, dis_style_immediate, "#%s%d",
10138
2.42k
          (NEGATIVE_BIT_SET ? "-" : ""),
10139
2.42k
          (int) offset);
10140
2.42k
          func (stream, dis_style_text, "]");
10141
2.42k
        }
10142
264
            else
10143
264
        {
10144
264
          func (stream, dis_style_text, "[");
10145
264
          func (stream, dis_style_register, "pc");
10146
264
          func (stream, dis_style_text, "]");
10147
264
        }
10148
2.68k
            if (NEGATIVE_BIT_SET)
10149
593
        offset = -offset;
10150
2.68k
            func (stream, dis_style_comment_start, "\t@ ");
10151
2.68k
            info->print_address_func (offset + pc + 8, info);
10152
2.68k
          }
10153
8.08k
        else
10154
8.08k
          {
10155
            /* Always show the offset.  */
10156
8.08k
            func (stream, dis_style_text, "[");
10157
8.08k
            func (stream, dis_style_register, "pc");
10158
8.08k
            func (stream, dis_style_text, "], ");
10159
8.08k
            func (stream, dis_style_immediate, "#%s%d",
10160
8.08k
            NEGATIVE_BIT_SET ? "-" : "", (int) offset);
10161
8.08k
            if (! allow_unpredictable)
10162
3.29k
        is_unpredictable = true;
10163
8.08k
          }
10164
10.7k
      }
10165
115k
          else
10166
115k
      {
10167
115k
        int offset = ((given & 0xf00) >> 4) | (given & 0xf);
10168
10169
115k
        func (stream, dis_style_text, "[");
10170
115k
        func (stream, dis_style_register, "%s",
10171
115k
        arm_regnames[(given >> 16) & 0xf]);
10172
10173
115k
        if (PRE_BIT_SET)
10174
20.7k
          {
10175
20.7k
            if (IMMEDIATE_BIT_SET)
10176
14.4k
        {
10177
          /* Elide offset for non-writeback
10178
             positive zero.  */
10179
14.4k
          if (WRITEBACK_BIT_SET || NEGATIVE_BIT_SET
10180
14.4k
              || offset)
10181
14.1k
            {
10182
14.1k
              func (stream, dis_style_text, ", ");
10183
14.1k
              func (stream, dis_style_immediate,
10184
14.1k
              "#%s%d",
10185
14.1k
              (NEGATIVE_BIT_SET ? "-" : ""),
10186
14.1k
              offset);
10187
14.1k
            }
10188
10189
14.4k
          if (NEGATIVE_BIT_SET)
10190
4.83k
            offset = -offset;
10191
10192
14.4k
          value_in_comment = offset;
10193
14.4k
        }
10194
6.27k
            else
10195
6.27k
        {
10196
          /* Register Offset or Register Pre-Indexed.  */
10197
6.27k
          func (stream, dis_style_text, ", %s",
10198
6.27k
          NEGATIVE_BIT_SET ? "-" : "");
10199
6.27k
          func (stream, dis_style_register, "%s",
10200
6.27k
          arm_regnames[given & 0xf]);
10201
10202
          /* Writing back to the register that is the source/
10203
             destination of the load/store is unpredictable.  */
10204
6.27k
          if (! allow_unpredictable
10205
6.27k
              && WRITEBACK_BIT_SET
10206
6.27k
              && ((given & 0xf) == ((given >> 12) & 0xf)))
10207
897
            is_unpredictable = true;
10208
6.27k
        }
10209
10210
20.7k
            func (stream, dis_style_text, "]%s",
10211
20.7k
            WRITEBACK_BIT_SET ? "!" : "");
10212
20.7k
          }
10213
95.0k
        else
10214
95.0k
          {
10215
95.0k
            if (IMMEDIATE_BIT_SET)
10216
26.9k
        {
10217
          /* Immediate Post-indexed.  */
10218
          /* PR 10924: Offset must be printed, even if it is zero.  */
10219
26.9k
          func (stream, dis_style_text, "], ");
10220
26.9k
          func (stream, dis_style_immediate, "#%s%d",
10221
26.9k
          NEGATIVE_BIT_SET ? "-" : "", offset);
10222
26.9k
          if (NEGATIVE_BIT_SET)
10223
10.0k
            offset = -offset;
10224
26.9k
          value_in_comment = offset;
10225
26.9k
        }
10226
68.0k
            else
10227
68.0k
        {
10228
          /* Register Post-indexed.  */
10229
68.0k
          func (stream, dis_style_text, "], %s",
10230
68.0k
          NEGATIVE_BIT_SET ? "-" : "");
10231
68.0k
          func (stream, dis_style_register, "%s",
10232
68.0k
          arm_regnames[given & 0xf]);
10233
10234
          /* Writing back to the register that is the source/
10235
             destination of the load/store is unpredictable.  */
10236
68.0k
          if (! allow_unpredictable
10237
68.0k
              && (given & 0xf) == ((given >> 12) & 0xf))
10238
13.7k
            is_unpredictable = true;
10239
68.0k
        }
10240
10241
95.0k
            if (! allow_unpredictable)
10242
83.0k
        {
10243
          /* Writeback is automatically implied by post- addressing.
10244
             Setting the W bit is unnecessary and ARM specify it as
10245
             being unpredictable.  */
10246
83.0k
          if (WRITEBACK_BIT_SET
10247
              /* Specifying the PC register as the post-indexed
10248
           registers is also unpredictable.  */
10249
83.0k
              || (! IMMEDIATE_BIT_SET && ((given & 0xf) == 0xf)))
10250
30.6k
            is_unpredictable = true;
10251
83.0k
        }
10252
95.0k
          }
10253
115k
      }
10254
126k
          break;
10255
10256
348k
        case 'b':
10257
348k
          {
10258
348k
      bfd_vma disp = (((given & 0xffffff) ^ 0x800000) - 0x800000);
10259
348k
      bfd_vma target = disp * 4 + pc + 8;
10260
348k
      info->print_address_func (target, info);
10261
10262
      /* Fill in instruction information.  */
10263
348k
      info->insn_info_valid = 1;
10264
348k
      info->insn_type = dis_branch;
10265
348k
      info->target = target;
10266
348k
          }
10267
348k
          break;
10268
10269
4.72M
        case 'c':
10270
4.72M
          if (((given >> 28) & 0xf) != 0xe)
10271
4.47M
      func (stream, dis_style_mnemonic, "%s",
10272
4.47M
            arm_conditional [(given >> 28) & 0xf]);
10273
4.72M
          break;
10274
10275
520k
        case 'm':
10276
520k
          {
10277
520k
      int started = 0;
10278
520k
      int reg;
10279
10280
520k
      func (stream, dis_style_text, "{");
10281
8.84M
      for (reg = 0; reg < 16; reg++)
10282
8.32M
        if ((given & (1 << reg)) != 0)
10283
3.23M
          {
10284
3.23M
            if (started)
10285
2.75M
        func (stream, dis_style_text, ", ");
10286
3.23M
            started = 1;
10287
3.23M
            func (stream, dis_style_register, "%s",
10288
3.23M
            arm_regnames[reg]);
10289
3.23M
          }
10290
520k
      func (stream, dis_style_text, "}");
10291
520k
      if (! started)
10292
40.6k
        is_unpredictable = true;
10293
520k
          }
10294
520k
          break;
10295
10296
3.10k
        case 'q':
10297
3.10k
          arm_decode_shift (given, func, stream, false);
10298
3.10k
          break;
10299
10300
2.53M
        case 'o':
10301
2.53M
          if ((given & 0x02000000) != 0)
10302
464k
      {
10303
464k
        unsigned int rotate = (given & 0xf00) >> 7;
10304
464k
        unsigned int immed = (given & 0xff);
10305
464k
        unsigned int a, i;
10306
10307
464k
        a = (immed << ((32 - rotate) & 31)
10308
464k
             | immed >> rotate) & 0xffffffff;
10309
        /* If there is another encoding with smaller rotate,
10310
           the rotate should be specified directly.  */
10311
2.51M
        for (i = 0; i < 32; i += 2)
10312
2.51M
          if ((a << i | a >> ((32 - i) & 31)) <= 0xff)
10313
464k
            break;
10314
10315
464k
        if (i != rotate)
10316
113k
          {
10317
113k
            func (stream, dis_style_immediate, "#%d", immed);
10318
113k
            func (stream, dis_style_text, ", ");
10319
113k
            func (stream, dis_style_immediate, "%d", rotate);
10320
113k
          }
10321
351k
        else
10322
351k
          func (stream, dis_style_immediate, "#%d", a);
10323
464k
        value_in_comment = a;
10324
464k
      }
10325
2.07M
          else
10326
2.07M
      arm_decode_shift (given, func, stream, true);
10327
2.53M
          break;
10328
10329
272k
        case 'p':
10330
272k
          if ((given & 0x0000f000) == 0x0000f000)
10331
6.36k
      func (stream, dis_style_mnemonic, "p");
10332
272k
          break;
10333
272k
        case 'O':
10334
272k
          if ((given & 0x0000f000) == 0x0000f000)
10335
6.36k
      func (stream, dis_style_text,
10336
6.36k
            "\t@ p-variant is OBSOLETE");
10337
272k
          break;
10338
10339
692k
        case 't':
10340
692k
          if ((given & 0x01200000) == 0x00200000)
10341
203k
      func (stream, dis_style_mnemonic, "t");
10342
692k
          break;
10343
10344
0
        case 'A':
10345
0
          {
10346
0
      int offset = given & 0xff;
10347
10348
0
      value_in_comment = offset * 4;
10349
0
      if (NEGATIVE_BIT_SET)
10350
0
        value_in_comment = - value_in_comment;
10351
10352
0
      func (stream, dis_style_text, "[%s",
10353
0
            arm_regnames [(given >> 16) & 0xf]);
10354
10355
0
      if (PRE_BIT_SET)
10356
0
        {
10357
0
          if (offset)
10358
0
            func (stream, dis_style_text, ", #%d]%s",
10359
0
            (int) value_in_comment,
10360
0
            WRITEBACK_BIT_SET ? "!" : "");
10361
0
          else
10362
0
            func (stream, dis_style_text, "]");
10363
0
        }
10364
0
      else
10365
0
        {
10366
0
          func (stream, dis_style_text, "]");
10367
10368
0
          if (WRITEBACK_BIT_SET)
10369
0
            {
10370
0
        if (offset)
10371
0
          func (stream, dis_style_text,
10372
0
          ", #%d", (int) value_in_comment);
10373
0
            }
10374
0
          else
10375
0
            {
10376
0
        func (stream, dis_style_text,
10377
0
              ", {%d}", (int) offset);
10378
0
        value_in_comment = offset;
10379
0
            }
10380
0
        }
10381
0
          }
10382
0
          break;
10383
10384
12.7k
        case 'B':
10385
          /* Print ARM V5 BLX(1) address: pc+25 bits.  */
10386
12.7k
          {
10387
12.7k
      bfd_vma address;
10388
12.7k
      bfd_vma offset = 0;
10389
10390
12.7k
      if (! NEGATIVE_BIT_SET)
10391
        /* Is signed, hi bits should be ones.  */
10392
6.59k
        offset = (-1) ^ 0x00ffffff;
10393
10394
      /* Offset is (SignExtend(offset field)<<2).  */
10395
12.7k
      offset += given & 0x00ffffff;
10396
12.7k
      offset <<= 2;
10397
12.7k
      address = offset + pc + 8;
10398
10399
12.7k
      if (given & 0x01000000)
10400
        /* H bit allows addressing to 2-byte boundaries.  */
10401
6.85k
        address += 2;
10402
10403
12.7k
            info->print_address_func (address, info);
10404
10405
      /* Fill in instruction information.  */
10406
12.7k
      info->insn_info_valid = 1;
10407
12.7k
      info->insn_type = dis_branch;
10408
12.7k
      info->target = address;
10409
12.7k
          }
10410
12.7k
          break;
10411
10412
4.44k
        case 'C':
10413
4.44k
          if ((given & 0x02000200) == 0x200)
10414
1.89k
      {
10415
1.89k
        const char * name;
10416
1.89k
        unsigned sysm = (given & 0x004f0000) >> 16;
10417
10418
1.89k
        sysm |= (given & 0x300) >> 4;
10419
1.89k
        name = banked_regname (sysm);
10420
10421
1.89k
        if (name != NULL)
10422
1.51k
          func (stream, dis_style_register, "%s", name);
10423
375
        else
10424
375
          func (stream, dis_style_text,
10425
375
          "(UNDEF: %lu)", (unsigned long) sysm);
10426
1.89k
      }
10427
2.55k
          else
10428
2.55k
      {
10429
2.55k
        func (stream, dis_style_register, "%cPSR_",
10430
2.55k
        (given & 0x00400000) ? 'S' : 'C');
10431
10432
2.55k
        if (given & 0x80000)
10433
1.16k
          func (stream, dis_style_register, "f");
10434
2.55k
        if (given & 0x40000)
10435
1.18k
          func (stream, dis_style_register, "s");
10436
2.55k
        if (given & 0x20000)
10437
1.24k
          func (stream, dis_style_register, "x");
10438
2.55k
        if (given & 0x10000)
10439
1.23k
          func (stream, dis_style_register, "c");
10440
2.55k
      }
10441
4.44k
          break;
10442
10443
832
        case 'U':
10444
832
          if ((given & 0xf0) == 0x60)
10445
410
      {
10446
410
        switch (given & 0xf)
10447
410
          {
10448
194
          case 0xf:
10449
194
            func (stream, dis_style_sub_mnemonic, "sy");
10450
194
            break;
10451
216
          default:
10452
216
            func (stream, dis_style_immediate, "#%d",
10453
216
            (int) given & 0xf);
10454
216
            break;
10455
410
          }
10456
410
      }
10457
422
          else
10458
422
      {
10459
422
        const char * opt = data_barrier_option (given & 0xf);
10460
422
        if (opt != NULL)
10461
227
          func (stream, dis_style_sub_mnemonic, "%s", opt);
10462
195
        else
10463
195
          func (stream, dis_style_immediate,
10464
195
          "#%d", (int) given & 0xf);
10465
422
      }
10466
832
          break;
10467
10468
11.9M
        case '0': case '1': case '2': case '3': case '4':
10469
12.0M
        case '5': case '6': case '7': case '8': case '9':
10470
12.0M
          {
10471
12.0M
      int width;
10472
12.0M
      unsigned long value;
10473
10474
12.0M
      c = arm_decode_bitfield (c, given, &value, &width);
10475
10476
12.0M
      switch (*c)
10477
12.0M
        {
10478
1.92M
        case 'R':
10479
1.92M
          if (value == 15)
10480
70.9k
            is_unpredictable = true;
10481
          /* Fall through.  */
10482
6.50M
        case 'r':
10483
6.50M
        case 'T':
10484
          /* We want register + 1 when decoding T.  */
10485
6.50M
          if (*c == 'T')
10486
200
            value = (value + 1) & 0xf;
10487
10488
6.50M
          if (c[1] == 'u')
10489
22.6k
            {
10490
        /* Eat the 'u' character.  */
10491
22.6k
        ++ c;
10492
10493
22.6k
        if (u_reg == value)
10494
1.02k
          is_unpredictable = true;
10495
22.6k
        u_reg = value;
10496
22.6k
            }
10497
6.50M
          if (c[1] == 'U')
10498
2.48k
            {
10499
        /* Eat the 'U' character.  */
10500
2.48k
        ++ c;
10501
10502
2.48k
        if (U_reg == value)
10503
522
          is_unpredictable = true;
10504
2.48k
        U_reg = value;
10505
2.48k
            }
10506
6.50M
          func (stream, dis_style_register, "%s",
10507
6.50M
          arm_regnames[value]);
10508
6.50M
          break;
10509
11.1k
        case 'd':
10510
11.1k
          func (stream, base_style, "%ld", value);
10511
11.1k
          value_in_comment = value;
10512
11.1k
          break;
10513
0
        case 'b':
10514
0
          func (stream, dis_style_immediate,
10515
0
          "%ld", value * 8);
10516
0
          value_in_comment = value * 8;
10517
0
          break;
10518
4.21k
        case 'W':
10519
4.21k
          func (stream, dis_style_immediate,
10520
4.21k
          "%ld", value + 1);
10521
4.21k
          value_in_comment = value + 1;
10522
4.21k
          break;
10523
858k
        case 'x':
10524
858k
          func (stream, dis_style_immediate,
10525
858k
          "0x%08lx", value);
10526
10527
          /* Some SWI instructions have special
10528
             meanings.  */
10529
858k
          if ((given & 0x0fffffff) == 0x0FF00000)
10530
272
            func (stream, dis_style_comment_start,
10531
272
            "\t@ IMB");
10532
858k
          else if ((given & 0x0fffffff) == 0x0FF00001)
10533
218
            func (stream, dis_style_comment_start,
10534
218
            "\t@ IMBRange");
10535
858k
          break;
10536
344
        case 'X':
10537
344
          func (stream, dis_style_immediate,
10538
344
          "%01lx", value & 0xf);
10539
344
          value_in_comment = value;
10540
344
          break;
10541
0
        case '`':
10542
0
          c++;
10543
0
          if (value == 0)
10544
0
            func (stream, dis_style_text, "%c", *c);
10545
0
          break;
10546
3.73M
        case '\'':
10547
3.73M
          c++;
10548
3.73M
          if (value == ((1ul << width) - 1))
10549
1.09M
            func (stream, base_style, "%c", *c);
10550
3.73M
          break;
10551
979k
        case '?':
10552
979k
          func (stream, base_style, "%c",
10553
979k
          c[(1 << width) - (int) value]);
10554
979k
          c += 1 << width;
10555
979k
          break;
10556
0
        default:
10557
0
          abort ();
10558
12.0M
        }
10559
12.0M
          }
10560
12.0M
          break;
10561
10562
12.0M
        case 'e':
10563
3.80k
          {
10564
3.80k
      int imm;
10565
10566
3.80k
      imm = (given & 0xf) | ((given & 0xfff00) >> 4);
10567
3.80k
      func (stream, dis_style_immediate, "%d", imm);
10568
3.80k
      value_in_comment = imm;
10569
3.80k
          }
10570
3.80k
          break;
10571
10572
902
        case 'E':
10573
          /* LSB and WIDTH fields of BFI or BFC.  The machine-
10574
       language instruction encodes LSB and MSB.  */
10575
902
          {
10576
902
      long msb = (given & 0x001f0000) >> 16;
10577
902
      long lsb = (given & 0x00000f80) >> 7;
10578
902
      long w = msb - lsb + 1;
10579
10580
902
      if (w > 0)
10581
483
        {
10582
483
          func (stream, dis_style_immediate, "#%lu", lsb);
10583
483
          func (stream, dis_style_text, ", ");
10584
483
          func (stream, dis_style_immediate, "#%lu", w);
10585
483
        }
10586
419
      else
10587
419
        func (stream, dis_style_text,
10588
419
        "(invalid: %lu:%lu)", lsb, msb);
10589
902
          }
10590
902
          break;
10591
10592
42.9k
        case 'R':
10593
          /* Get the PSR/banked register name.  */
10594
42.9k
          {
10595
42.9k
      const char * name;
10596
42.9k
      unsigned sysm = (given & 0x004f0000) >> 16;
10597
10598
42.9k
      sysm |= (given & 0x300) >> 4;
10599
42.9k
      name = banked_regname (sysm);
10600
10601
42.9k
      if (name != NULL)
10602
3.27k
        func (stream, dis_style_register, "%s", name);
10603
39.7k
      else
10604
39.7k
        func (stream, dis_style_text,
10605
39.7k
        "(UNDEF: %lu)", (unsigned long) sysm);
10606
42.9k
          }
10607
42.9k
          break;
10608
10609
37.3k
        case 'V':
10610
          /* 16-bit unsigned immediate from a MOVT or MOVW
10611
       instruction, encoded in bits 0:11 and 15:19.  */
10612
37.3k
          {
10613
37.3k
      long hi = (given & 0x000f0000) >> 4;
10614
37.3k
      long lo = (given & 0x00000fff);
10615
37.3k
      long imm16 = hi | lo;
10616
10617
37.3k
      func (stream, dis_style_immediate, "#%lu", imm16);
10618
37.3k
      value_in_comment = imm16;
10619
37.3k
          }
10620
37.3k
          break;
10621
10622
0
        default:
10623
0
          abort ();
10624
22.5M
        }
10625
22.5M
    }
10626
50.8M
        else
10627
50.8M
    {
10628
10629
50.8M
      if (*c == '@')
10630
653k
        base_style = dis_style_comment_start;
10631
10632
50.8M
      if (*c == '\t')
10633
6.04M
        base_style = dis_style_text;
10634
10635
50.8M
      func (stream, base_style, "%c", *c);
10636
50.8M
    }
10637
73.3M
      }
10638
10639
5.38M
    if (value_in_comment > 32 || value_in_comment < -16)
10640
927k
      func (stream, dis_style_comment_start, "\t@ 0x%lx",
10641
927k
      (value_in_comment & 0xffffffffUL));
10642
10643
5.38M
    if (is_unpredictable)
10644
151k
      func (stream, dis_style_comment_start, UNPREDICTABLE_INSTRUCTION);
10645
10646
5.38M
    return;
10647
5.38M
  }
10648
5.75M
    }
10649
1.52k
  func (stream, dis_style_comment_start, UNKNOWN_INSTRUCTION_32BIT,
10650
1.52k
  (unsigned) given);
10651
1.52k
  return;
10652
5.39M
}
10653
10654
/* Print one 16-bit Thumb instruction from PC on INFO->STREAM.  */
10655
10656
static void
10657
print_insn_thumb16 (bfd_vma pc, struct disassemble_info *info, long given)
10658
7.34M
{
10659
7.34M
  const struct opcode16 *insn;
10660
7.34M
  void *stream = info->stream;
10661
7.34M
  fprintf_styled_ftype func = info->fprintf_styled_func;
10662
7.34M
  enum disassembler_style base_style = dis_style_mnemonic;
10663
7.34M
  enum disassembler_style old_base_style = base_style;
10664
10665
488M
  for (insn = thumb_opcodes; insn->assembler; insn++)
10666
488M
    if ((given & insn->mask) == insn->value)
10667
7.34M
      {
10668
7.34M
  signed long value_in_comment = 0;
10669
7.34M
  const char *c = insn->assembler;
10670
10671
105M
  for (; *c; c++)
10672
98.0M
    {
10673
98.0M
      int domaskpc = 0;
10674
98.0M
      int domasklr = 0;
10675
10676
98.0M
      if (*c != '%')
10677
63.0M
        {
10678
63.0M
    if (*c == '@')
10679
393k
      base_style = dis_style_comment_start;
10680
10681
63.0M
    if (*c == '\t')
10682
7.68M
      base_style = dis_style_text;
10683
10684
63.0M
    func (stream, base_style, "%c", *c);
10685
10686
63.0M
    continue;
10687
63.0M
        }
10688
10689
35.0M
      switch (*++c)
10690
35.0M
        {
10691
4.95M
    case '{':
10692
4.95M
      ++c;
10693
4.95M
      if (*c == '\0')
10694
0
        abort ();
10695
4.95M
      old_base_style = base_style;
10696
4.95M
      base_style = decode_base_style (*c);
10697
4.95M
      ++c;
10698
4.95M
      if (*c != ':')
10699
0
        abort ();
10700
4.95M
      break;
10701
10702
4.95M
    case '}':
10703
4.95M
      base_style = old_base_style;
10704
4.95M
      break;
10705
10706
0
        case '%':
10707
0
    func (stream, base_style, "%%");
10708
0
    break;
10709
10710
4.00M
        case 'c':
10711
4.00M
    if (ifthen_state)
10712
33.2k
      func (stream, dis_style_mnemonic, "%s",
10713
33.2k
      arm_conditional[IFTHEN_COND]);
10714
4.00M
    break;
10715
10716
2.72M
        case 'C':
10717
2.72M
    if (ifthen_state)
10718
30.5k
      func (stream, dis_style_mnemonic, "%s",
10719
30.5k
      arm_conditional[IFTHEN_COND]);
10720
2.69M
    else
10721
2.69M
      func (stream, dis_style_mnemonic, "s");
10722
2.72M
    break;
10723
10724
44.7k
        case 'I':
10725
44.7k
    {
10726
44.7k
      unsigned int tmp;
10727
10728
44.7k
      ifthen_next_state = given & 0xff;
10729
167k
      for (tmp = given << 1; tmp & 0xf; tmp <<= 1)
10730
123k
        func (stream, dis_style_mnemonic,
10731
123k
        ((given ^ tmp) & 0x10) ? "e" : "t");
10732
44.7k
      func (stream, dis_style_text, "\t");
10733
44.7k
      func (stream, dis_style_sub_mnemonic, "%s",
10734
44.7k
      arm_conditional[(given >> 4) & 0xf]);
10735
44.7k
    }
10736
44.7k
    break;
10737
10738
341k
        case 'x':
10739
341k
    if (ifthen_next_state)
10740
2.21k
      func (stream, dis_style_comment_start,
10741
2.21k
      "\t@ unpredictable branch in IT block\n");
10742
341k
    break;
10743
10744
568k
        case 'X':
10745
568k
    if (ifthen_state)
10746
24.0k
      func (stream, dis_style_comment_start,
10747
24.0k
      "\t@ unpredictable <IT:%s>",
10748
24.0k
      arm_conditional[IFTHEN_COND]);
10749
568k
    break;
10750
10751
509k
        case 'S':
10752
509k
    {
10753
509k
      long reg;
10754
10755
509k
      reg = (given >> 3) & 0x7;
10756
509k
      if (given & (1 << 6))
10757
389k
        reg += 8;
10758
10759
509k
      func (stream, dis_style_register, "%s", arm_regnames[reg]);
10760
509k
    }
10761
509k
    break;
10762
10763
499k
        case 'D':
10764
499k
    {
10765
499k
      long reg;
10766
10767
499k
      reg = given & 0x7;
10768
499k
      if (given & (1 << 7))
10769
123k
        reg += 8;
10770
10771
499k
      func (stream, dis_style_register, "%s", arm_regnames[reg]);
10772
499k
    }
10773
499k
    break;
10774
10775
56.4k
        case 'N':
10776
56.4k
    if (given & (1 << 8))
10777
40.4k
      domasklr = 1;
10778
    /* Fall through.  */
10779
134k
        case 'O':
10780
134k
    if (*c == 'O' && (given & (1 << 8)))
10781
55.0k
      domaskpc = 1;
10782
    /* Fall through.  */
10783
294k
        case 'M':
10784
294k
    {
10785
294k
      int started = 0;
10786
294k
      int reg;
10787
10788
294k
      func (stream, dis_style_text, "{");
10789
10790
      /* It would be nice if we could spot
10791
         ranges, and generate the rS-rE format: */
10792
2.65M
      for (reg = 0; (reg < 8); reg++)
10793
2.35M
        if ((given & (1 << reg)) != 0)
10794
1.00M
          {
10795
1.00M
      if (started)
10796
727k
        func (stream, dis_style_text, ", ");
10797
1.00M
      started = 1;
10798
1.00M
      func (stream, dis_style_register, "%s",
10799
1.00M
            arm_regnames[reg]);
10800
1.00M
          }
10801
10802
294k
      if (domasklr)
10803
40.4k
        {
10804
40.4k
          if (started)
10805
39.3k
      func (stream, dis_style_text, ", ");
10806
40.4k
          started = 1;
10807
40.4k
          func (stream, dis_style_register, "%s",
10808
40.4k
          arm_regnames[14] /* "lr" */);
10809
40.4k
        }
10810
10811
294k
      if (domaskpc)
10812
55.0k
        {
10813
55.0k
          if (started)
10814
54.3k
      func (stream, dis_style_text, ", ");
10815
55.0k
          func (stream, dis_style_register, "%s",
10816
55.0k
          arm_regnames[15] /* "pc" */);
10817
55.0k
        }
10818
10819
294k
      func (stream, dis_style_text, "}");
10820
294k
    }
10821
294k
    break;
10822
10823
83.7k
        case 'W':
10824
    /* Print writeback indicator for a LDMIA.  We are doing a
10825
       writeback if the base register is not in the register
10826
       mask.  */
10827
83.7k
    if ((given & (1 << ((given & 0x0700) >> 8))) == 0)
10828
41.8k
      func (stream, dis_style_text, "!");
10829
83.7k
    break;
10830
10831
37.0k
        case 'b':
10832
    /* Print ARM V6T2 CZB address: pc+4+6 bits.  */
10833
37.0k
    {
10834
37.0k
      bfd_vma address = (pc + 4
10835
37.0k
             + ((given & 0x00f8) >> 2)
10836
37.0k
             + ((given & 0x0200) >> 3));
10837
37.0k
      info->print_address_func (address, info);
10838
10839
      /* Fill in instruction information.  */
10840
37.0k
      info->insn_info_valid = 1;
10841
37.0k
      info->insn_type = dis_branch;
10842
37.0k
      info->target = address;
10843
37.0k
    }
10844
37.0k
    break;
10845
10846
243k
        case 's':
10847
    /* Right shift immediate -- bits 6..10; 1-31 print
10848
       as themselves, 0 prints as 32.  */
10849
243k
    {
10850
243k
      long imm = (given & 0x07c0) >> 6;
10851
243k
      if (imm == 0)
10852
22.5k
        imm = 32;
10853
243k
      func (stream, dis_style_immediate, "#%ld", imm);
10854
243k
    }
10855
243k
    break;
10856
10857
10.6M
        case '0': case '1': case '2': case '3': case '4':
10858
15.7M
        case '5': case '6': case '7': case '8': case '9':
10859
15.7M
    {
10860
15.7M
      int bitstart = *c++ - '0';
10861
15.7M
      int bitend = 0;
10862
10863
15.9M
      while (*c >= '0' && *c <= '9')
10864
203k
        bitstart = (bitstart * 10) + *c++ - '0';
10865
10866
15.7M
      switch (*c)
10867
15.7M
        {
10868
15.5M
        case '-':
10869
15.5M
          {
10870
15.5M
      bfd_vma reg;
10871
10872
15.5M
      c++;
10873
35.9M
      while (*c >= '0' && *c <= '9')
10874
20.4M
        bitend = (bitend * 10) + *c++ - '0';
10875
15.5M
      if (!bitend)
10876
0
        abort ();
10877
15.5M
      reg = given >> bitstart;
10878
15.5M
      reg &= ((bfd_vma) 2 << (bitend - bitstart)) - 1;
10879
10880
15.5M
      switch (*c)
10881
15.5M
        {
10882
9.75M
        case 'r':
10883
9.75M
          func (stream, dis_style_register, "%s",
10884
9.75M
          arm_regnames[reg]);
10885
9.75M
          break;
10886
10887
2.30M
        case 'd':
10888
2.30M
          func (stream, dis_style_immediate, "%ld",
10889
2.30M
          (long) reg);
10890
2.30M
          value_in_comment = reg;
10891
2.30M
          break;
10892
10893
200k
        case 'H':
10894
200k
          func (stream, dis_style_immediate, "%ld",
10895
200k
          (long) (reg << 1));
10896
200k
          value_in_comment = reg << 1;
10897
200k
          break;
10898
10899
1.59M
        case 'W':
10900
1.59M
          func (stream, dis_style_immediate, "%ld",
10901
1.59M
          (long) (reg << 2));
10902
1.59M
          value_in_comment = reg << 2;
10903
1.59M
          break;
10904
10905
367k
        case 'a':
10906
          /* PC-relative address -- the bottom two
10907
             bits of the address are dropped
10908
             before the calculation.  */
10909
367k
          info->print_address_func
10910
367k
            (((pc + 4) & ~3) + (reg << 2), info);
10911
367k
          value_in_comment = 0;
10912
367k
          break;
10913
10914
37.1k
        case 'x':
10915
37.1k
          func (stream, dis_style_immediate, "0x%04lx",
10916
37.1k
          (long) reg);
10917
37.1k
          break;
10918
10919
814k
        case 'B':
10920
814k
          reg = ((reg ^ (1 << bitend)) - (1 << bitend));
10921
814k
          bfd_vma target = reg * 2 + pc + 4;
10922
814k
          info->print_address_func (target, info);
10923
814k
          value_in_comment = 0;
10924
10925
          /* Fill in instruction information.  */
10926
814k
          info->insn_info_valid = 1;
10927
814k
          info->insn_type = dis_branch;
10928
814k
          info->target = target;
10929
814k
          break;
10930
10931
486k
        case 'c':
10932
486k
          func (stream, dis_style_mnemonic, "%s",
10933
486k
          arm_conditional [reg]);
10934
486k
          break;
10935
10936
0
        default:
10937
0
          abort ();
10938
15.5M
        }
10939
15.5M
          }
10940
15.5M
          break;
10941
10942
15.5M
        case '\'':
10943
114k
          c++;
10944
114k
          if ((given & (1 << bitstart)) != 0)
10945
56.8k
      func (stream, base_style, "%c", *c);
10946
114k
          break;
10947
10948
89.8k
        case '?':
10949
89.8k
          ++c;
10950
89.8k
          if ((given & (1 << bitstart)) != 0)
10951
40.3k
      func (stream, base_style, "%c", *c++);
10952
49.5k
          else
10953
49.5k
      func (stream, base_style, "%c", *++c);
10954
89.8k
          break;
10955
10956
0
        default:
10957
0
          abort ();
10958
15.7M
        }
10959
15.7M
    }
10960
15.7M
    break;
10961
10962
15.7M
        default:
10963
0
    abort ();
10964
35.0M
        }
10965
35.0M
    }
10966
10967
7.34M
  if (value_in_comment > 32 || value_in_comment < -16)
10968
1.07M
    func (stream, dis_style_comment_start,
10969
1.07M
    "\t@ 0x%lx", value_in_comment);
10970
7.34M
  return;
10971
7.34M
      }
10972
10973
  /* No match.  */
10974
0
  func (stream, dis_style_comment_start, UNKNOWN_INSTRUCTION_16BIT,
10975
0
  (unsigned) given);
10976
0
  return;
10977
7.34M
}
10978
10979
/* Return the name of an V7M special register.  */
10980
10981
static const char *
10982
psr_name (int regno)
10983
16.2k
{
10984
16.2k
  switch (regno)
10985
16.2k
    {
10986
307
    case 0x0: return "APSR";
10987
248
    case 0x1: return "IAPSR";
10988
378
    case 0x2: return "EAPSR";
10989
253
    case 0x3: return "PSR";
10990
488
    case 0x5: return "IPSR";
10991
244
    case 0x6: return "EPSR";
10992
230
    case 0x7: return "IEPSR";
10993
880
    case 0x8: return "MSP";
10994
393
    case 0x9: return "PSP";
10995
213
    case 0xa: return "MSPLIM";
10996
232
    case 0xb: return "PSPLIM";
10997
267
    case 0x10: return "PRIMASK";
10998
342
    case 0x11: return "BASEPRI";
10999
231
    case 0x12: return "BASEPRI_MAX";
11000
399
    case 0x13: return "FAULTMASK";
11001
216
    case 0x14: return "CONTROL";
11002
317
    case 0x20: return "PAC_KEY_P_0";
11003
214
    case 0x21: return "PAC_KEY_P_1";
11004
218
    case 0x22: return "PAC_KEY_P_2";
11005
221
    case 0x23: return "PAC_KEY_P_3";
11006
226
    case 0x24: return "PAC_KEY_U_0";
11007
328
    case 0x25: return "PAC_KEY_U_1";
11008
271
    case 0x26: return "PAC_KEY_U_2";
11009
215
    case 0x27: return "PAC_KEY_U_3";
11010
313
    case 0x88: return "MSP_NS";
11011
370
    case 0x89: return "PSP_NS";
11012
419
    case 0x8a: return "MSPLIM_NS";
11013
934
    case 0x8b: return "PSPLIM_NS";
11014
208
    case 0x90: return "PRIMASK_NS";
11015
266
    case 0x91: return "BASEPRI_NS";
11016
237
    case 0x93: return "FAULTMASK_NS";
11017
233
    case 0x94: return "CONTROL_NS";
11018
216
    case 0x98: return "SP_NS";
11019
1.58k
    case 0xa0: return "PAC_KEY_P_0_NS";
11020
325
    case 0xa1: return "PAC_KEY_P_1_NS";
11021
487
    case 0xa2: return "PAC_KEY_P_2_NS";
11022
218
    case 0xa3: return "PAC_KEY_P_3_NS";
11023
278
    case 0xa4: return "PAC_KEY_U_0_NS";
11024
273
    case 0xa5: return "PAC_KEY_U_1_NS";
11025
329
    case 0xa6: return "PAC_KEY_U_2_NS";
11026
227
    case 0xa7: return "PAC_KEY_U_3_NS";
11027
1.96k
    default: return "<unknown>";
11028
16.2k
    }
11029
16.2k
}
11030
11031
/* Print one 32-bit Thumb instruction from PC on INFO->STREAM.  */
11032
11033
static void
11034
print_insn_thumb32 (bfd_vma pc, struct disassemble_info *info, long given)
11035
1.16M
{
11036
1.16M
  const struct opcode32 *insn;
11037
1.16M
  void *stream = info->stream;
11038
1.16M
  fprintf_styled_ftype func = info->fprintf_styled_func;
11039
1.16M
  bool is_mve = is_v81m_architecture (info);
11040
1.16M
  enum disassembler_style base_style = dis_style_mnemonic;
11041
1.16M
  enum disassembler_style old_base_style = base_style;
11042
11043
1.16M
  if (print_insn_coprocessor (pc, info, given, true))
11044
30.1k
    return;
11045
11046
1.13M
  if (!is_mve && print_insn_neon (info, given, true))
11047
63.4k
    return;
11048
11049
1.07M
  if (is_mve && print_insn_mve (info, given))
11050
166k
    return;
11051
11052
905k
  if (print_insn_cde (info, given, true))
11053
6.66k
    return;
11054
11055
898k
  if (print_insn_generic_coprocessor (pc, info, given, true))
11056
79.4k
    return;
11057
11058
195M
  for (insn = thumb32_opcodes; insn->assembler; insn++)
11059
195M
    if ((given & insn->mask) == insn->value)
11060
819k
      {
11061
819k
  bool is_clrm = false;
11062
819k
  bool is_unpredictable = false;
11063
819k
  signed long value_in_comment = 0;
11064
819k
  const char *c = insn->assembler;
11065
11066
15.2M
  for (; *c; c++)
11067
14.4M
    {
11068
14.4M
      if (*c != '%')
11069
12.5M
        {
11070
12.5M
    if (*c == '@')
11071
354k
      base_style = dis_style_comment_start;
11072
12.5M
    if (*c == '\t')
11073
1.17M
      base_style = dis_style_text;
11074
12.5M
    func (stream, base_style, "%c", *c);
11075
12.5M
    continue;
11076
12.5M
        }
11077
11078
1.90M
      switch (*++c)
11079
1.90M
        {
11080
15.9k
        case '{':
11081
15.9k
    ++c;
11082
15.9k
    if (*c == '\0')
11083
0
      abort ();
11084
15.9k
    old_base_style = base_style;
11085
15.9k
    base_style = decode_base_style (*c);
11086
15.9k
    ++c;
11087
15.9k
    if (*c != ':')
11088
0
      abort ();
11089
15.9k
    break;
11090
11091
15.9k
        case '}':
11092
15.9k
    base_style = old_base_style;
11093
15.9k
    break;
11094
11095
0
        case '%':
11096
0
    func (stream, base_style, "%%");
11097
0
    break;
11098
11099
450k
        case 'c':
11100
450k
    if (ifthen_state)
11101
3.54k
      func (stream, dis_style_mnemonic, "%s",
11102
3.54k
      arm_conditional[IFTHEN_COND]);
11103
450k
    break;
11104
11105
324k
        case 'x':
11106
324k
    if (ifthen_next_state)
11107
1.12k
      func (stream, dis_style_comment_start,
11108
1.12k
      "\t@ unpredictable branch in IT block\n");
11109
324k
    break;
11110
11111
8.34k
        case 'X':
11112
8.34k
    if (ifthen_state)
11113
535
      func (stream, dis_style_comment_start,
11114
535
      "\t@ unpredictable <IT:%s>",
11115
535
      arm_conditional[IFTHEN_COND]);
11116
8.34k
    break;
11117
11118
2.41k
        case 'I':
11119
2.41k
    {
11120
2.41k
      unsigned int imm12 = 0;
11121
11122
2.41k
      imm12 |= (given & 0x000000ffu);
11123
2.41k
      imm12 |= (given & 0x00007000u) >> 4;
11124
2.41k
      imm12 |= (given & 0x04000000u) >> 15;
11125
2.41k
      func (stream, dis_style_immediate, "#%u", imm12);
11126
2.41k
      value_in_comment = imm12;
11127
2.41k
    }
11128
2.41k
    break;
11129
11130
15.8k
        case 'M':
11131
15.8k
    {
11132
15.8k
      unsigned int bits = 0, imm, imm8, mod;
11133
11134
15.8k
      bits |= (given & 0x000000ffu);
11135
15.8k
      bits |= (given & 0x00007000u) >> 4;
11136
15.8k
      bits |= (given & 0x04000000u) >> 15;
11137
15.8k
      imm8 = (bits & 0x0ff);
11138
15.8k
      mod = (bits & 0xf00) >> 8;
11139
15.8k
      switch (mod)
11140
15.8k
        {
11141
4.18k
        case 0: imm = imm8; break;
11142
757
        case 1: imm = ((imm8 << 16) | imm8); break;
11143
1.10k
        case 2: imm = ((imm8 << 24) | (imm8 << 8)); break;
11144
1.80k
        case 3: imm = ((imm8 << 24) | (imm8 << 16) | (imm8 << 8) | imm8); break;
11145
8.00k
        default:
11146
8.00k
          mod  = (bits & 0xf80) >> 7;
11147
8.00k
          imm8 = (bits & 0x07f) | 0x80;
11148
8.00k
          imm  = (((imm8 << (32 - mod)) | (imm8 >> mod)) & 0xffffffff);
11149
15.8k
        }
11150
15.8k
      func (stream, dis_style_immediate, "#%u", imm);
11151
15.8k
      value_in_comment = imm;
11152
15.8k
    }
11153
0
    break;
11154
11155
14.9k
        case 'J':
11156
14.9k
    {
11157
14.9k
      unsigned int imm = 0;
11158
11159
14.9k
      imm |= (given & 0x000000ffu);
11160
14.9k
      imm |= (given & 0x00007000u) >> 4;
11161
14.9k
      imm |= (given & 0x04000000u) >> 15;
11162
14.9k
      imm |= (given & 0x000f0000u) >> 4;
11163
14.9k
      func (stream, dis_style_immediate, "#%u", imm);
11164
14.9k
      value_in_comment = imm;
11165
14.9k
    }
11166
14.9k
    break;
11167
11168
320
        case 'K':
11169
320
    {
11170
320
      unsigned int imm = 0;
11171
11172
320
      imm |= (given & 0x000f0000u) >> 16;
11173
320
      imm |= (given & 0x00000ff0u) >> 0;
11174
320
      imm |= (given & 0x0000000fu) << 12;
11175
320
      func (stream, dis_style_immediate, "#%u", imm);
11176
320
      value_in_comment = imm;
11177
320
    }
11178
320
    break;
11179
11180
319
        case 'H':
11181
319
    {
11182
319
      unsigned int imm = 0;
11183
11184
319
      imm |= (given & 0x000f0000u) >> 4;
11185
319
      imm |= (given & 0x00000fffu) >> 0;
11186
319
      func (stream, dis_style_immediate, "#%u", imm);
11187
319
      value_in_comment = imm;
11188
319
    }
11189
319
    break;
11190
11191
334
        case 'V':
11192
334
    {
11193
334
      unsigned int imm = 0;
11194
11195
334
      imm |= (given & 0x00000fffu);
11196
334
      imm |= (given & 0x000f0000u) >> 4;
11197
334
      func (stream, dis_style_immediate, "#%u", imm);
11198
334
      value_in_comment = imm;
11199
334
    }
11200
334
    break;
11201
11202
6.81k
        case 'S':
11203
6.81k
    {
11204
6.81k
      unsigned int reg = (given & 0x0000000fu);
11205
6.81k
      unsigned int stp = (given & 0x00000030u) >> 4;
11206
6.81k
      unsigned int imm = 0;
11207
6.81k
      imm |= (given & 0x000000c0u) >> 6;
11208
6.81k
      imm |= (given & 0x00007000u) >> 10;
11209
11210
6.81k
      func (stream, dis_style_register, "%s", arm_regnames[reg]);
11211
6.81k
      switch (stp)
11212
6.81k
        {
11213
1.67k
        case 0:
11214
1.67k
          if (imm > 0)
11215
587
      {
11216
587
        func (stream, dis_style_text, ", ");
11217
587
        func (stream, dis_style_sub_mnemonic, "lsl ");
11218
587
        func (stream, dis_style_immediate, "#%u", imm);
11219
587
      }
11220
1.67k
          break;
11221
11222
1.49k
        case 1:
11223
1.49k
          if (imm == 0)
11224
422
      imm = 32;
11225
1.49k
          func (stream, dis_style_text, ", ");
11226
1.49k
          func (stream, dis_style_sub_mnemonic, "lsr ");
11227
1.49k
          func (stream, dis_style_immediate, "#%u", imm);
11228
1.49k
          break;
11229
11230
2.16k
        case 2:
11231
2.16k
          if (imm == 0)
11232
455
      imm = 32;
11233
2.16k
          func (stream, dis_style_text, ", ");
11234
2.16k
          func (stream, dis_style_sub_mnemonic, "asr ");
11235
2.16k
          func (stream, dis_style_immediate, "#%u", imm);
11236
2.16k
          break;
11237
11238
1.48k
        case 3:
11239
1.48k
          if (imm == 0)
11240
610
      {
11241
610
        func (stream, dis_style_text, ", ");
11242
610
        func (stream, dis_style_sub_mnemonic, "rrx");
11243
610
      }
11244
871
          else
11245
871
      {
11246
871
        func (stream, dis_style_text, ", ");
11247
871
        func (stream, dis_style_sub_mnemonic, "ror ");
11248
871
        func (stream, dis_style_immediate, "#%u", imm);
11249
871
      }
11250
6.81k
        }
11251
6.81k
    }
11252
6.81k
    break;
11253
11254
30.4k
        case 'a':
11255
30.4k
    {
11256
30.4k
      unsigned int Rn  = (given & 0x000f0000) >> 16;
11257
30.4k
      unsigned int U   = ! NEGATIVE_BIT_SET;
11258
30.4k
      unsigned int op  = (given & 0x00000f00) >> 8;
11259
30.4k
      unsigned int i12 = (given & 0x00000fff);
11260
30.4k
      unsigned int i8  = (given & 0x000000ff);
11261
30.4k
      bool writeback = false, postind = false;
11262
30.4k
      bfd_vma offset = 0;
11263
11264
30.4k
      func (stream, dis_style_text, "[");
11265
30.4k
      func (stream, dis_style_register, "%s", arm_regnames[Rn]);
11266
30.4k
      if (U) /* 12-bit positive immediate offset.  */
11267
19.6k
        {
11268
19.6k
          offset = i12;
11269
19.6k
          if (Rn != 15)
11270
16.4k
      value_in_comment = offset;
11271
19.6k
        }
11272
10.8k
      else if (Rn == 15) /* 12-bit negative immediate offset.  */
11273
901
        offset = - (int) i12;
11274
9.93k
      else if (op == 0x0) /* Shifted register offset.  */
11275
1.95k
        {
11276
1.95k
          unsigned int Rm = (i8 & 0x0f);
11277
1.95k
          unsigned int sh = (i8 & 0x30) >> 4;
11278
11279
1.95k
          func (stream, dis_style_text, ", ");
11280
1.95k
          func (stream, dis_style_register, "%s",
11281
1.95k
          arm_regnames[Rm]);
11282
1.95k
          if (sh)
11283
553
      {
11284
553
        func (stream, dis_style_text, ", ");
11285
553
        func (stream, dis_style_sub_mnemonic, "lsl ");
11286
553
        func (stream, dis_style_immediate, "#%u", sh);
11287
553
      }
11288
1.95k
          func (stream, dis_style_text, "]");
11289
1.95k
          break;
11290
1.95k
        }
11291
7.98k
      else switch (op)
11292
7.98k
        {
11293
890
        case 0xE:  /* 8-bit positive immediate offset.  */
11294
890
          offset = i8;
11295
890
          break;
11296
11297
1.23k
        case 0xC:  /* 8-bit negative immediate offset.  */
11298
1.23k
          offset = -i8;
11299
1.23k
          break;
11300
11301
954
        case 0xF:  /* 8-bit + preindex with wb.  */
11302
954
          offset = i8;
11303
954
          writeback = true;
11304
954
          break;
11305
11306
748
        case 0xD:  /* 8-bit - preindex with wb.  */
11307
748
          offset = -i8;
11308
748
          writeback = true;
11309
748
          break;
11310
11311
649
        case 0xB:  /* 8-bit + postindex.  */
11312
649
          offset = i8;
11313
649
          postind = true;
11314
649
          break;
11315
11316
656
        case 0x9:  /* 8-bit - postindex.  */
11317
656
          offset = -i8;
11318
656
          postind = true;
11319
656
          break;
11320
11321
2.84k
        default:
11322
2.84k
          func (stream, dis_style_text, ", <undefined>]");
11323
2.84k
          goto skip;
11324
7.98k
        }
11325
11326
25.6k
      if (postind)
11327
1.30k
        {
11328
1.30k
          func (stream, dis_style_text, "], ");
11329
1.30k
          func (stream, dis_style_immediate, "#%d", (int) offset);
11330
1.30k
        }
11331
24.3k
      else
11332
24.3k
        {
11333
24.3k
          if (offset)
11334
21.5k
      {
11335
21.5k
        func (stream, dis_style_text, ", ");
11336
21.5k
        func (stream, dis_style_immediate, "#%d",
11337
21.5k
        (int) offset);
11338
21.5k
      }
11339
24.3k
          func (stream, dis_style_text, writeback ? "]!" : "]");
11340
24.3k
        }
11341
11342
25.6k
      if (Rn == 15)
11343
4.12k
        {
11344
4.12k
          func (stream, dis_style_comment_start, "\t@ ");
11345
4.12k
          info->print_address_func (((pc + 4) & ~3) + offset, info);
11346
4.12k
        }
11347
25.6k
    }
11348
28.5k
        skip:
11349
28.5k
    break;
11350
11351
0
        case 'A':
11352
0
    {
11353
0
      unsigned int U   = ! NEGATIVE_BIT_SET;
11354
0
      unsigned int W   = WRITEBACK_BIT_SET;
11355
0
      unsigned int Rn  = (given & 0x000f0000) >> 16;
11356
0
      unsigned int off = (given & 0x000000ff);
11357
11358
0
      func (stream, dis_style_text, "[");
11359
0
      func (stream, dis_style_register, "%s", arm_regnames[Rn]);
11360
11361
0
      if (PRE_BIT_SET)
11362
0
        {
11363
0
          if (off || !U)
11364
0
      {
11365
0
        func (stream, dis_style_text, ", ");
11366
0
        func (stream, dis_style_immediate, "#%c%u",
11367
0
        U ? '+' : '-', off * 4);
11368
0
        value_in_comment = off * 4 * (U ? 1 : -1);
11369
0
      }
11370
0
          func (stream, dis_style_text, "]");
11371
0
          if (W)
11372
0
      func (stream, dis_style_text, "!");
11373
0
        }
11374
0
      else
11375
0
        {
11376
0
          func (stream, dis_style_text, "], ");
11377
0
          if (W)
11378
0
      {
11379
0
        func (stream, dis_style_immediate, "#%c%u",
11380
0
        U ? '+' : '-', off * 4);
11381
0
        value_in_comment = off * 4 * (U ? 1 : -1);
11382
0
      }
11383
0
          else
11384
0
      {
11385
0
        func (stream, dis_style_text, "{");
11386
0
        func (stream, dis_style_immediate, "%u", off);
11387
0
        func (stream, dis_style_text, "}");
11388
0
        value_in_comment = off;
11389
0
      }
11390
0
        }
11391
0
    }
11392
0
    break;
11393
11394
28.9k
        case 'w':
11395
28.9k
    {
11396
28.9k
      unsigned int Sbit = (given & 0x01000000) >> 24;
11397
28.9k
      unsigned int type = (given & 0x00600000) >> 21;
11398
11399
28.9k
      switch (type)
11400
28.9k
        {
11401
8.11k
        case 0:
11402
8.11k
          func (stream, dis_style_mnemonic, Sbit ? "sb" : "b");
11403
8.11k
          break;
11404
2.52k
        case 1:
11405
2.52k
          func (stream, dis_style_mnemonic, Sbit ? "sh" : "h");
11406
2.52k
          break;
11407
5.54k
        case 2:
11408
5.54k
          if (Sbit)
11409
818
      func (stream, dis_style_text, "??");
11410
5.54k
          break;
11411
12.7k
        case 3:
11412
12.7k
          func (stream, dis_style_text, "??");
11413
12.7k
          break;
11414
28.9k
        }
11415
28.9k
    }
11416
28.9k
    break;
11417
11418
28.9k
        case 'n':
11419
394
    is_clrm = true;
11420
    /* Fall through.  */
11421
3.98k
        case 'm':
11422
3.98k
    {
11423
3.98k
      int started = 0;
11424
3.98k
      int reg;
11425
11426
3.98k
      func (stream, dis_style_text, "{");
11427
67.7k
      for (reg = 0; reg < 16; reg++)
11428
63.7k
        if ((given & (1 << reg)) != 0)
11429
27.3k
          {
11430
27.3k
      if (started)
11431
23.5k
        func (stream, dis_style_text, ", ");
11432
27.3k
      started = 1;
11433
27.3k
      if (is_clrm && reg == 13)
11434
0
        func (stream, dis_style_text, "(invalid: %s)",
11435
0
        arm_regnames[reg]);
11436
27.3k
      else if (is_clrm && reg == 15)
11437
311
        func (stream, dis_style_register, "%s", "APSR");
11438
27.0k
      else
11439
27.0k
        func (stream, dis_style_register, "%s",
11440
27.0k
        arm_regnames[reg]);
11441
27.3k
          }
11442
3.98k
      func (stream, dis_style_text, "}");
11443
3.98k
    }
11444
3.98k
    break;
11445
11446
767
        case 'E':
11447
767
    {
11448
767
      unsigned int msb = (given & 0x0000001f);
11449
767
      unsigned int lsb = 0;
11450
11451
767
      lsb |= (given & 0x000000c0u) >> 6;
11452
767
      lsb |= (given & 0x00007000u) >> 10;
11453
767
      func (stream, dis_style_immediate, "#%u", lsb);
11454
767
      func (stream, dis_style_text, ", ");
11455
767
      func (stream, dis_style_immediate, "#%u", msb - lsb + 1);
11456
767
    }
11457
767
    break;
11458
11459
717
        case 'F':
11460
717
    {
11461
717
      unsigned int width = (given & 0x0000001f) + 1;
11462
717
      unsigned int lsb = 0;
11463
11464
717
      lsb |= (given & 0x000000c0u) >> 6;
11465
717
      lsb |= (given & 0x00007000u) >> 10;
11466
717
      func (stream, dis_style_immediate, "#%u", lsb);
11467
717
      func (stream, dis_style_text, ", ");
11468
717
      func (stream, dis_style_immediate, "#%u", width);
11469
717
    }
11470
717
    break;
11471
11472
4.93k
        case 'G':
11473
4.93k
    {
11474
4.93k
      unsigned int boff = (((given & 0x07800000) >> 23) << 1);
11475
4.93k
      func (stream, dis_style_immediate, "%x", boff);
11476
4.93k
    }
11477
4.93k
    break;
11478
11479
839
        case 'W':
11480
839
    {
11481
839
      unsigned int immA = (given & 0x001f0000u) >> 16;
11482
839
      unsigned int immB = (given & 0x000007feu) >> 1;
11483
839
      unsigned int immC = (given & 0x00000800u) >> 11;
11484
839
      bfd_vma offset = 0;
11485
11486
839
      offset |= immA << 12;
11487
839
      offset |= immB << 2;
11488
839
      offset |= immC << 1;
11489
      /* Sign extend.  */
11490
839
      offset = (offset & 0x10000) ? offset - (1 << 17) : offset;
11491
11492
839
      info->print_address_func (pc + 4 + offset, info);
11493
839
    }
11494
839
    break;
11495
11496
2.38k
        case 'Y':
11497
2.38k
    {
11498
2.38k
      unsigned int immA = (given & 0x007f0000u) >> 16;
11499
2.38k
      unsigned int immB = (given & 0x000007feu) >> 1;
11500
2.38k
      unsigned int immC = (given & 0x00000800u) >> 11;
11501
2.38k
      bfd_vma offset = 0;
11502
11503
2.38k
      offset |= immA << 12;
11504
2.38k
      offset |= immB << 2;
11505
2.38k
      offset |= immC << 1;
11506
      /* Sign extend.  */
11507
2.38k
      offset = (offset & 0x40000) ? offset - (1 << 19) : offset;
11508
11509
2.38k
      info->print_address_func (pc + 4 + offset, info);
11510
2.38k
    }
11511
2.38k
    break;
11512
11513
1.58k
        case 'Z':
11514
1.58k
    {
11515
1.58k
      unsigned int immA = (given & 0x00010000u) >> 16;
11516
1.58k
      unsigned int immB = (given & 0x000007feu) >> 1;
11517
1.58k
      unsigned int immC = (given & 0x00000800u) >> 11;
11518
1.58k
      bfd_vma offset = 0;
11519
11520
1.58k
      offset |= immA << 12;
11521
1.58k
      offset |= immB << 2;
11522
1.58k
      offset |= immC << 1;
11523
      /* Sign extend.  */
11524
1.58k
      offset = (offset & 0x1000) ? offset - (1 << 13) : offset;
11525
11526
1.58k
      info->print_address_func (pc + 4 + offset, info);
11527
11528
1.58k
      unsigned int T    = (given & 0x00020000u) >> 17;
11529
1.58k
      unsigned int endoffset = (((given & 0x07800000) >> 23) << 1);
11530
1.58k
      unsigned int boffset   = (T == 1) ? 4 : 2;
11531
1.58k
      func (stream, dis_style_text, ", ");
11532
1.58k
      func (stream, dis_style_immediate, "%x",
11533
1.58k
      endoffset + boffset);
11534
1.58k
    }
11535
1.58k
    break;
11536
11537
779
        case 'Q':
11538
779
    {
11539
779
      unsigned int immh = (given & 0x000007feu) >> 1;
11540
779
      unsigned int imml = (given & 0x00000800u) >> 11;
11541
779
      bfd_vma imm32 = 0;
11542
11543
779
      imm32 |= immh << 2;
11544
779
      imm32 |= imml << 1;
11545
11546
779
      info->print_address_func (pc + 4 + imm32, info);
11547
779
    }
11548
779
    break;
11549
11550
260
        case 'P':
11551
260
    {
11552
260
      unsigned int immh = (given & 0x000007feu) >> 1;
11553
260
      unsigned int imml = (given & 0x00000800u) >> 11;
11554
260
      bfd_vma imm32 = 0;
11555
11556
260
      imm32 |= immh << 2;
11557
260
      imm32 |= imml << 1;
11558
11559
260
      info->print_address_func (pc + 4 - imm32, info);
11560
260
    }
11561
260
    break;
11562
11563
8.08k
        case 'b':
11564
8.08k
    {
11565
8.08k
      unsigned int S = (given & 0x04000000u) >> 26;
11566
8.08k
      unsigned int J1 = (given & 0x00002000u) >> 13;
11567
8.08k
      unsigned int J2 = (given & 0x00000800u) >> 11;
11568
8.08k
      bfd_vma offset = 0;
11569
11570
8.08k
      offset |= !S << 20;
11571
8.08k
      offset |= J2 << 19;
11572
8.08k
      offset |= J1 << 18;
11573
8.08k
      offset |= (given & 0x003f0000) >> 4;
11574
8.08k
      offset |= (given & 0x000007ff) << 1;
11575
8.08k
      offset -= (1 << 20);
11576
11577
8.08k
      bfd_vma target = pc + 4 + offset;
11578
8.08k
      info->print_address_func (target, info);
11579
11580
      /* Fill in instruction information.  */
11581
8.08k
      info->insn_info_valid = 1;
11582
8.08k
      info->insn_type = dis_branch;
11583
8.08k
      info->target = target;
11584
8.08k
    }
11585
8.08k
    break;
11586
11587
324k
        case 'B':
11588
324k
    {
11589
324k
      unsigned int S = (given & 0x04000000u) >> 26;
11590
324k
      unsigned int I1 = (given & 0x00002000u) >> 13;
11591
324k
      unsigned int I2 = (given & 0x00000800u) >> 11;
11592
324k
      bfd_vma offset = 0;
11593
11594
324k
      offset |= !S << 24;
11595
324k
      offset |= !(I1 ^ S) << 23;
11596
324k
      offset |= !(I2 ^ S) << 22;
11597
324k
      offset |= (given & 0x03ff0000u) >> 4;
11598
324k
      offset |= (given & 0x000007ffu) << 1;
11599
324k
      offset -= (1 << 24);
11600
324k
      offset += pc + 4;
11601
11602
      /* BLX target addresses are always word aligned.  */
11603
324k
      if ((given & 0x00001000u) == 0)
11604
114k
          offset &= ~2u;
11605
11606
324k
      info->print_address_func (offset, info);
11607
11608
      /* Fill in instruction information.  */
11609
324k
      info->insn_info_valid = 1;
11610
324k
      info->insn_type = dis_branch;
11611
324k
      info->target = offset;
11612
324k
    }
11613
324k
    break;
11614
11615
2.28k
        case 's':
11616
2.28k
    {
11617
2.28k
      unsigned int shift = 0;
11618
11619
2.28k
      shift |= (given & 0x000000c0u) >> 6;
11620
2.28k
      shift |= (given & 0x00007000u) >> 10;
11621
2.28k
      if (WRITEBACK_BIT_SET)
11622
508
        {
11623
508
          func (stream, dis_style_text, ", ");
11624
508
          func (stream, dis_style_sub_mnemonic, "asr ");
11625
508
          func (stream, dis_style_immediate, "#%u", shift);
11626
508
        }
11627
1.77k
      else if (shift)
11628
824
        {
11629
824
          func (stream, dis_style_text, ", ");
11630
824
          func (stream, dis_style_sub_mnemonic, "lsl ");
11631
824
          func (stream, dis_style_immediate, "#%u", shift);
11632
824
        }
11633
      /* else print nothing - lsl #0 */
11634
2.28k
    }
11635
2.28k
    break;
11636
11637
696
        case 'R':
11638
696
    {
11639
696
      unsigned int rot = (given & 0x00000030) >> 4;
11640
11641
696
      if (rot)
11642
416
        {
11643
416
          func (stream, dis_style_text, ", ");
11644
416
          func (stream, dis_style_sub_mnemonic, "ror ");
11645
416
          func (stream, dis_style_immediate, "#%u", rot * 8);
11646
416
        }
11647
696
    }
11648
696
    break;
11649
11650
1.58k
        case 'U':
11651
1.58k
    if ((given & 0xf0) == 0x60)
11652
640
      {
11653
640
        switch (given & 0xf)
11654
640
          {
11655
289
          case 0xf:
11656
289
      func (stream, dis_style_sub_mnemonic, "sy");
11657
289
      break;
11658
351
          default:
11659
351
      func (stream, dis_style_immediate, "#%d",
11660
351
            (int) given & 0xf);
11661
351
      break;
11662
640
          }
11663
640
      }
11664
949
    else
11665
949
      {
11666
949
        const char * opt = data_barrier_option (given & 0xf);
11667
949
        if (opt != NULL)
11668
447
          func (stream, dis_style_sub_mnemonic, "%s", opt);
11669
502
        else
11670
502
          func (stream, dis_style_immediate, "#%d",
11671
502
          (int) given & 0xf);
11672
949
       }
11673
1.58k
    break;
11674
11675
11.5k
        case 'C':
11676
11.5k
    if ((given & 0xff) == 0)
11677
690
      {
11678
690
        func (stream, dis_style_register, "%cPSR_",
11679
690
        (given & 0x100000) ? 'S' : 'C');
11680
11681
690
        if (given & 0x800)
11682
240
          func (stream, dis_style_register, "f");
11683
690
        if (given & 0x400)
11684
342
          func (stream, dis_style_register, "s");
11685
690
        if (given & 0x200)
11686
268
          func (stream, dis_style_register, "x");
11687
690
        if (given & 0x100)
11688
445
          func (stream, dis_style_register, "c");
11689
690
      }
11690
10.8k
    else if (is_v81m_architecture (info))
11691
3.83k
      func (stream, dis_style_register, "%s",
11692
3.83k
      psr_name (given & 0xff));
11693
11694
7.05k
    else if ((given & 0x20) == 0x20)
11695
5.83k
      {
11696
5.83k
        char const* name;
11697
5.83k
        unsigned sysm = (given & 0xf00) >> 8;
11698
11699
5.83k
        sysm |= (given & 0x30);
11700
5.83k
        sysm |= (given & 0x00100000) >> 14;
11701
5.83k
        name = banked_regname (sysm);
11702
11703
5.83k
        if (name != NULL)
11704
5.12k
          func (stream, dis_style_register, "%s", name);
11705
709
        else
11706
709
          func (stream, dis_style_text,
11707
709
          "(UNDEF: %lu)", (unsigned long) sysm);
11708
5.83k
      }
11709
1.21k
    else
11710
1.21k
      {
11711
1.21k
        func (stream, dis_style_register, "%s",
11712
1.21k
        psr_name (given & 0xff));
11713
1.21k
      }
11714
11.5k
    break;
11715
11716
16.7k
        case 'D':
11717
16.7k
    if (is_v81m_architecture (info))
11718
6.12k
      func (stream, dis_style_register, "%s",
11719
6.12k
      psr_name (given & 0xff));
11720
10.6k
    else if (((given & 0xff) == 0)
11721
10.6k
       || ((given & 0x20) == 0x20))
11722
5.60k
      {
11723
5.60k
        char const* name;
11724
5.60k
        unsigned sm = (given & 0xf0000) >> 16;
11725
11726
5.60k
        sm |= (given & 0x30);
11727
5.60k
        sm |= (given & 0x00100000) >> 14;
11728
5.60k
        name = banked_regname (sm);
11729
11730
5.60k
        if (name != NULL)
11731
4.59k
          func (stream, dis_style_register, "%s", name);
11732
1.00k
        else
11733
1.00k
          func (stream, dis_style_text,
11734
1.00k
          "(UNDEF: %lu)", (unsigned long) sm);
11735
5.60k
      }
11736
5.03k
    else
11737
5.03k
      func (stream, dis_style_register, "%s",
11738
5.03k
      psr_name (given & 0xff));
11739
16.7k
    break;
11740
11741
522k
        case '0': case '1': case '2': case '3': case '4':
11742
598k
        case '5': case '6': case '7': case '8': case '9':
11743
598k
    {
11744
598k
      int width;
11745
598k
      unsigned long val;
11746
11747
598k
      c = arm_decode_bitfield (c, given, &val, &width);
11748
11749
598k
      switch (*c)
11750
598k
        {
11751
753
        case 's':
11752
753
          if (val <= 3)
11753
753
      func (stream, dis_style_mnemonic, "%s",
11754
753
            mve_vec_sizename[val]);
11755
0
          else
11756
0
      func (stream, dis_style_text, "<undef size>");
11757
753
          break;
11758
11759
637
        case 'd':
11760
637
          func (stream, base_style, "%lu", val);
11761
637
          value_in_comment = val;
11762
637
          break;
11763
11764
1.85k
        case 'D':
11765
1.85k
          func (stream, dis_style_immediate, "%lu", val + 1);
11766
1.85k
          value_in_comment = val + 1;
11767
1.85k
          break;
11768
11769
10.0k
        case 'W':
11770
10.0k
          func (stream, dis_style_immediate, "%lu", val * 4);
11771
10.0k
          value_in_comment = val * 4;
11772
10.0k
          break;
11773
11774
905
        case 'S':
11775
905
          if (val == 13)
11776
285
      is_unpredictable = true;
11777
          /* Fall through.  */
11778
7.56k
        case 'R':
11779
7.56k
          if (val == 15)
11780
1.08k
      is_unpredictable = true;
11781
          /* Fall through.  */
11782
176k
        case 'r':
11783
176k
          func (stream, dis_style_register, "%s",
11784
176k
          arm_regnames[val]);
11785
176k
          break;
11786
11787
9.66k
        case 'c':
11788
9.66k
          func (stream, base_style, "%s", arm_conditional[val]);
11789
9.66k
          break;
11790
11791
34.0k
        case '\'':
11792
34.0k
          c++;
11793
34.0k
          if (val == ((1ul << width) - 1))
11794
14.5k
      func (stream, base_style, "%c", *c);
11795
34.0k
          break;
11796
11797
9.71k
        case '`':
11798
9.71k
          c++;
11799
9.71k
          if (val == 0)
11800
2.01k
      func (stream, dis_style_immediate, "%c", *c);
11801
9.71k
          break;
11802
11803
1.14k
        case '?':
11804
1.14k
          func (stream, dis_style_mnemonic, "%c",
11805
1.14k
          c[(1 << width) - (int) val]);
11806
1.14k
          c += 1 << width;
11807
1.14k
          break;
11808
11809
354k
        case 'x':
11810
354k
          func (stream, dis_style_immediate, "0x%lx",
11811
354k
          val & 0xffffffffUL);
11812
354k
          break;
11813
11814
0
        default:
11815
0
          abort ();
11816
598k
        }
11817
598k
    }
11818
598k
    break;
11819
11820
598k
        case 'L':
11821
    /* PR binutils/12534
11822
       If we have a PC relative offset in an LDRD or STRD
11823
       instructions then display the decoded address.  */
11824
9.71k
    if (((given >> 16) & 0xf) == 0xf)
11825
2.19k
      {
11826
2.19k
        bfd_vma offset = (given & 0xff) * 4;
11827
11828
2.19k
        if ((given & (1 << 23)) == 0)
11829
457
          offset = - offset;
11830
2.19k
        func (stream, dis_style_comment_start, "\t@ ");
11831
2.19k
        info->print_address_func ((pc & ~3) + 4 + offset, info);
11832
2.19k
      }
11833
9.71k
    break;
11834
11835
0
        default:
11836
0
    abort ();
11837
1.90M
        }
11838
1.90M
    }
11839
11840
819k
  if (value_in_comment > 32 || value_in_comment < -16)
11841
46.2k
    func (stream, dis_style_comment_start, "\t@ 0x%lx",
11842
46.2k
    value_in_comment);
11843
11844
819k
  if (is_unpredictable)
11845
1.11k
    func (stream, dis_style_comment_start, UNPREDICTABLE_INSTRUCTION);
11846
11847
819k
  return;
11848
819k
      }
11849
11850
  /* No match.  */
11851
0
  func (stream, dis_style_comment_start, UNKNOWN_INSTRUCTION_32BIT,
11852
0
  (unsigned) given);
11853
0
  return;
11854
819k
}
11855
11856
/* Print data bytes on INFO->STREAM.  */
11857
11858
static void
11859
print_insn_data (bfd_vma pc ATTRIBUTE_UNUSED,
11860
     struct disassemble_info *info,
11861
     long given)
11862
0
{
11863
0
  fprintf_styled_ftype func = info->fprintf_styled_func;
11864
11865
0
  switch (info->bytes_per_chunk)
11866
0
    {
11867
0
    case 1:
11868
0
      func (info->stream, dis_style_assembler_directive, ".byte");
11869
0
      func (info->stream, dis_style_text, "\t");
11870
0
      func (info->stream, dis_style_immediate, "0x%02lx", given);
11871
0
      break;
11872
0
    case 2:
11873
0
      func (info->stream, dis_style_assembler_directive, ".short");
11874
0
      func (info->stream, dis_style_text, "\t");
11875
0
      func (info->stream, dis_style_immediate, "0x%04lx", given);
11876
0
      break;
11877
0
    case 4:
11878
0
      func (info->stream, dis_style_assembler_directive, ".word");
11879
0
      func (info->stream, dis_style_text, "\t");
11880
0
      func (info->stream, dis_style_immediate, "0x%08lx", given);
11881
0
      break;
11882
0
    default:
11883
0
      abort ();
11884
0
    }
11885
0
}
11886
11887
/* Disallow mapping symbols ($a, $b, $d, $t etc) from
11888
   being displayed in symbol relative addresses.
11889
11890
   Also disallow private symbol, with __tagsym$$ prefix,
11891
   from ARM RVCT toolchain being displayed.  */
11892
11893
bool
11894
arm_symbol_is_valid (asymbol * sym,
11895
         struct disassemble_info * info ATTRIBUTE_UNUSED)
11896
1.31M
{
11897
1.31M
  const char * name;
11898
11899
1.31M
  if (sym == NULL)
11900
0
    return false;
11901
11902
1.31M
  name = bfd_asymbol_name (sym);
11903
11904
1.31M
  return (name && *name != '$' && strncmp (name, "__tagsym$$", 10));
11905
1.31M
}
11906
11907
/* Parse the string of disassembler options.  */
11908
11909
static void
11910
parse_arm_disassembler_options (const char *options)
11911
14.1k
{
11912
14.1k
  const char *opt;
11913
11914
14.1k
  force_thumb = false;
11915
14.1k
  FOR_EACH_DISASSEMBLER_OPTION (opt, options)
11916
20.0k
    {
11917
20.0k
      if (startswith (opt, "reg-names-"))
11918
278
  {
11919
278
    unsigned int i;
11920
2.34k
    for (i = 0; i < NUM_ARM_OPTIONS; i++)
11921
2.12k
      if (disassembler_options_cmp (opt, regnames[i].name) == 0)
11922
54
        {
11923
54
    regname_selected = i;
11924
54
    break;
11925
54
        }
11926
11927
278
    if (i >= NUM_ARM_OPTIONS)
11928
      /* xgettext: c-format */
11929
224
      opcodes_error_handler (_("unrecognised register name set: %s"),
11930
224
           opt);
11931
278
  }
11932
19.7k
      else if (startswith (opt, "force-thumb"))
11933
3.25k
  force_thumb = 1;
11934
16.5k
      else if (startswith (opt, "no-force-thumb"))
11935
44
  force_thumb = 0;
11936
16.4k
      else if (startswith (opt, "coproc"))
11937
608
  {
11938
608
    const char *procptr = opt + sizeof ("coproc") - 1;
11939
608
    char *endptr;
11940
608
    uint8_t coproc_number = strtol (procptr, &endptr, 10);
11941
608
    if (endptr != procptr + 1 || coproc_number > 7)
11942
180
      {
11943
180
        opcodes_error_handler (_("cde coprocessor not between 0-7: %s"),
11944
180
             opt);
11945
180
        continue;
11946
180
      }
11947
428
    if (*endptr != '=')
11948
48
      {
11949
48
        opcodes_error_handler (_("coproc must have an argument: %s"),
11950
48
             opt);
11951
48
        continue;
11952
48
      }
11953
380
    endptr += 1;
11954
380
    if (startswith (endptr, "generic"))
11955
16
      cde_coprocs &= ~(1 << coproc_number);
11956
364
    else if (startswith (endptr, "cde")
11957
364
       || startswith (endptr, "CDE"))
11958
62
      cde_coprocs |= (1 << coproc_number);
11959
302
    else
11960
302
      {
11961
302
        opcodes_error_handler (
11962
302
      _("coprocN argument takes options \"generic\","
11963
302
        " \"cde\", or \"CDE\": %s"), opt);
11964
302
      }
11965
380
  }
11966
15.8k
      else
11967
  /* xgettext: c-format */
11968
15.8k
  opcodes_error_handler (_("unrecognised disassembler option: %s"), opt);
11969
20.0k
    }
11970
11971
14.1k
  return;
11972
14.1k
}
11973
11974
static bool
11975
mapping_symbol_for_insn (bfd_vma pc, struct disassemble_info *info,
11976
       enum map_type *map_symbol);
11977
11978
/* Search back through the insn stream to determine if this instruction is
11979
   conditionally executed.  */
11980
11981
static void
11982
find_ifthen_state (bfd_vma pc,
11983
       struct disassemble_info *info,
11984
       bool little)
11985
18.9k
{
11986
18.9k
  unsigned char b[2];
11987
18.9k
  unsigned int insn;
11988
18.9k
  int status;
11989
  /* COUNT is twice the number of instructions seen.  It will be odd if we
11990
     just crossed an instruction boundary.  */
11991
18.9k
  int count;
11992
18.9k
  int it_count;
11993
18.9k
  unsigned int seen_it;
11994
18.9k
  bfd_vma addr;
11995
11996
18.9k
  ifthen_address = pc;
11997
18.9k
  ifthen_state = 0;
11998
11999
18.9k
  addr = pc;
12000
18.9k
  count = 1;
12001
18.9k
  it_count = 0;
12002
18.9k
  seen_it = 0;
12003
  /* Scan backwards looking for IT instructions, keeping track of where
12004
     instruction boundaries are.  We don't know if something is actually an
12005
     IT instruction until we find a definite instruction boundary.  */
12006
18.9k
  for (;;)
12007
24.3k
    {
12008
24.3k
      if (addr == 0 || info->symbol_at_address_func (addr, info))
12009
2.44k
  {
12010
    /* A symbol must be on an instruction boundary, and will not
12011
       be within an IT block.  */
12012
2.44k
    if (seen_it && (count & 1))
12013
0
      break;
12014
12015
2.44k
    return;
12016
2.44k
  }
12017
21.8k
      addr -= 2;
12018
21.8k
      status = info->read_memory_func (addr, (bfd_byte *) b, 2, info);
12019
21.8k
      if (status)
12020
14.7k
  return;
12021
12022
7.14k
      if (little)
12023
7.14k
  insn = (b[0]) | (b[1] << 8);
12024
0
      else
12025
0
  insn = (b[1]) | (b[0] << 8);
12026
7.14k
      if (seen_it)
12027
0
  {
12028
0
    if ((insn & 0xf800) < 0xe800)
12029
0
      {
12030
        /* Addr + 2 is an instruction boundary.  See if this matches
12031
           the expected boundary based on the position of the last
12032
     IT candidate.  */
12033
0
        if (count & 1)
12034
0
    break;
12035
0
        seen_it = 0;
12036
0
      }
12037
0
  }
12038
7.14k
      if ((insn & 0xff00) == 0xbf00 && (insn & 0xf) != 0)
12039
0
  {
12040
0
    enum map_type type = MAP_ARM;
12041
0
    bool found = mapping_symbol_for_insn (addr, info, &type);
12042
12043
0
    if (!found || (found && type == MAP_THUMB))
12044
0
      {
12045
        /* This could be an IT instruction.  */
12046
0
        seen_it = insn;
12047
0
        it_count = count >> 1;
12048
0
      }
12049
0
  }
12050
7.14k
      if ((insn & 0xf800) >= 0xe800)
12051
0
  count++;
12052
7.14k
      else
12053
7.14k
  count = (count + 2) | 1;
12054
      /* IT blocks contain at most 4 instructions.  */
12055
7.14k
      if (count >= 8 && !seen_it)
12056
1.78k
  return;
12057
7.14k
    }
12058
  /* We found an IT instruction.  */
12059
0
  ifthen_state = (seen_it & 0xe0) | ((seen_it << it_count) & 0x1f);
12060
0
  if ((ifthen_state & 0xf) == 0)
12061
0
    ifthen_state = 0;
12062
0
}
12063
12064
/* Returns nonzero and sets *MAP_TYPE if the N'th symbol is a
12065
   mapping symbol.  */
12066
12067
static int
12068
is_mapping_symbol (struct disassemble_info *info,
12069
       int n,
12070
       enum map_type *map_type)
12071
73.2k
{
12072
73.2k
  const char *name = bfd_asymbol_name (info->symtab[n]);
12073
12074
73.2k
  if (name[0] == '$'
12075
73.2k
      && (name[1] == 'a' || name[1] == 't' || name[1] == 'd')
12076
73.2k
      && (name[2] == 0 || name[2] == '.'))
12077
0
    {
12078
0
      *map_type = ((name[1] == 'a') ? MAP_ARM
12079
0
       : (name[1] == 't') ? MAP_THUMB
12080
0
       : MAP_DATA);
12081
0
      return true;
12082
0
    }
12083
12084
73.2k
  return false;
12085
73.2k
}
12086
12087
/* Try to infer the code type (ARM or Thumb) from a mapping symbol.
12088
   Returns nonzero if *MAP_TYPE was set.  */
12089
12090
static int
12091
get_map_sym_type (struct disassemble_info *info,
12092
      int n,
12093
      enum map_type *map_type)
12094
9.12M
{
12095
  /* If the symbol is in a different section, ignore it.  */
12096
9.12M
  if (info->section != NULL && info->section != info->symtab[n]->section)
12097
9.05M
    return false;
12098
12099
73.2k
  return is_mapping_symbol (info, n, map_type);
12100
9.12M
}
12101
12102
/* Try to infer the code type (ARM or Thumb) from a non-mapping symbol.
12103
   Returns nonzero if *MAP_TYPE was set.  */
12104
12105
static int
12106
get_sym_code_type (struct disassemble_info *info,
12107
       int n,
12108
       enum map_type *map_type)
12109
1.34k
{
12110
1.34k
  elf_symbol_type *es;
12111
1.34k
  unsigned int type;
12112
1.34k
  asymbol * sym;
12113
12114
  /* If the symbol is in a different section, ignore it.  */
12115
1.34k
  if (info->section != NULL && info->section != info->symtab[n]->section)
12116
0
    return false;
12117
12118
  /* PR 30230: Reject non-ELF symbols, eg synthetic ones.  */
12119
1.34k
  sym = info->symtab[n];
12120
1.34k
  if (bfd_asymbol_flavour (sym) != bfd_target_elf_flavour)
12121
1.32k
    return false;
12122
12123
20
  es = (elf_symbol_type *) sym;
12124
20
  type = ELF_ST_TYPE (es->internal_elf_sym.st_info);
12125
12126
  /* If the symbol has function type then use that.  */
12127
20
  if (type == STT_FUNC || type == STT_GNU_IFUNC)
12128
20
    {
12129
20
      if (ARM_GET_SYM_BRANCH_TYPE (es->internal_elf_sym.st_target_internal)
12130
20
    == ST_BRANCH_TO_THUMB)
12131
0
  *map_type = MAP_THUMB;
12132
20
      else
12133
20
  *map_type = MAP_ARM;
12134
20
      return true;
12135
20
    }
12136
12137
0
  return false;
12138
20
}
12139
12140
/* Search the mapping symbol state for instruction at pc.  This is only
12141
   applicable for elf target.
12142
12143
   There is an assumption Here, info->private_data contains the correct AND
12144
   up-to-date information about current scan process.  The information will be
12145
   used to speed this search process.
12146
12147
   Return TRUE if the mapping state can be determined, and map_symbol
12148
   will be updated accordingly.  Otherwise, return FALSE.  */
12149
12150
static bool
12151
mapping_symbol_for_insn (bfd_vma pc, struct disassemble_info *info,
12152
       enum map_type *map_symbol)
12153
155k
{
12154
155k
  bfd_vma addr, section_vma = 0;
12155
155k
  int n, last_sym = -1;
12156
155k
  bool found = false;
12157
155k
  bool can_use_search_opt_p = false;
12158
12159
  /* Sanity check.  */
12160
155k
  if (info == NULL)
12161
0
    return false;
12162
12163
  /* Default to DATA.  A text section is required by the ABI to contain an
12164
     INSN mapping symbol at the start.  A data section has no such
12165
     requirement, hence if no mapping symbol is found the section must
12166
     contain only data.  This however isn't very useful if the user has
12167
     fully stripped the binaries.  If this is the case use the section
12168
     attributes to determine the default.  If we have no section default to
12169
     INSN as well, as we may be disassembling some raw bytes on a baremetal
12170
     HEX file or similar.  */
12171
155k
  enum map_type type = MAP_DATA;
12172
155k
  if ((info->section && info->section->flags & SEC_CODE) || !info->section)
12173
119k
    type = MAP_ARM;
12174
155k
  struct arm_private_data *private_data;
12175
12176
155k
  if (info->private_data == NULL || info->symtab == NULL
12177
155k
      || info->symtab_size == 0
12178
155k
      || bfd_asymbol_flavour (*info->symtab) != bfd_target_elf_flavour)
12179
0
    return false;
12180
12181
155k
  private_data = info->private_data;
12182
12183
  /* First, look for mapping symbols.  */
12184
155k
  if (pc <= private_data->last_mapping_addr)
12185
14
    private_data->last_mapping_sym = -1;
12186
12187
  /* Start scanning at the start of the function, or wherever
12188
     we finished last time.  */
12189
155k
  n = info->symtab_pos + 1;
12190
12191
  /* If the last stop offset is different from the current one it means we
12192
     are disassembling a different glob of bytes.  As such the optimization
12193
     would not be safe and we should start over.  */
12194
155k
  can_use_search_opt_p
12195
155k
    = (private_data->last_mapping_sym >= 0
12196
155k
       && info->stop_offset == private_data->last_stop_offset);
12197
12198
155k
  if (n >= private_data->last_mapping_sym && can_use_search_opt_p)
12199
12
    n = private_data->last_mapping_sym;
12200
12201
  /* Look down while we haven't passed the location being disassembled.
12202
     The reason for this is that there's no defined order between a symbol
12203
     and an mapping symbol that may be at the same address.  We may have to
12204
     look at least one position ahead.  */
12205
9.20M
  for (; n < info->symtab_size; n++)
12206
9.20M
    {
12207
9.20M
      addr = bfd_asymbol_value (info->symtab[n]);
12208
9.20M
      if (addr > pc)
12209
155k
  break;
12210
9.05M
      if (get_map_sym_type (info, n, &type))
12211
0
  {
12212
0
    last_sym = n;
12213
0
    found = true;
12214
0
  }
12215
9.05M
    }
12216
12217
155k
  if (!found)
12218
155k
    {
12219
155k
      n = info->symtab_pos;
12220
155k
      if (n >= private_data->last_mapping_sym && can_use_search_opt_p)
12221
12
  n = private_data->last_mapping_sym;
12222
12223
      /* No mapping symbol found at this address.  Look backwards
12224
   for a preceeding one, but don't go pass the section start
12225
   otherwise a data section with no mapping symbol can pick up
12226
   a text mapping symbol of a preceeding section.  The documentation
12227
   says section can be NULL, in which case we will seek up all the
12228
   way to the top.  */
12229
155k
      if (info->section)
12230
155k
  section_vma = info->section->vma;
12231
12232
228k
      for (; n >= 0; n--)
12233
74.6k
  {
12234
74.6k
    addr = bfd_asymbol_value (info->symtab[n]);
12235
74.6k
    if (addr < section_vma)
12236
1.32k
      break;
12237
12238
73.2k
    if (get_map_sym_type (info, n, &type))
12239
0
      {
12240
0
        last_sym = n;
12241
0
        found = true;
12242
0
        break;
12243
0
      }
12244
73.2k
  }
12245
155k
    }
12246
12247
  /* If no mapping symbol was found, try looking up without a mapping
12248
     symbol.  This is done by walking up from the current PC to the nearest
12249
     symbol.  We don't actually have to loop here since symtab_pos will
12250
     contain the nearest symbol already.  */
12251
155k
  if (!found)
12252
155k
    {
12253
155k
      n = info->symtab_pos;
12254
155k
      if (n >= 0 && get_sym_code_type (info, n, &type))
12255
20
  {
12256
20
    last_sym = n;
12257
20
    found = true;
12258
20
  }
12259
155k
    }
12260
12261
155k
  private_data->last_mapping_sym = last_sym;
12262
155k
  private_data->last_type = type;
12263
155k
  private_data->last_stop_offset = info->stop_offset;
12264
12265
155k
  *map_symbol = type;
12266
155k
  return found;
12267
155k
}
12268
12269
/* Given a bfd_mach_arm_XXX value, this function fills in the fields
12270
   of the supplied arm_feature_set structure with bitmasks indicating
12271
   the supported base architectures and coprocessor extensions.
12272
12273
   FIXME: This could more efficiently implemented as a constant array,
12274
   although it would also be less robust.  */
12275
12276
static void
12277
select_arm_features (unsigned long mach,
12278
         arm_feature_set * features)
12279
18.6k
{
12280
18.6k
  arm_feature_set arch_fset;
12281
18.6k
  const arm_feature_set fpu_any = FPU_ANY;
12282
12283
18.6k
#undef ARM_SET_FEATURES
12284
18.6k
#define ARM_SET_FEATURES(FSET) \
12285
18.6k
  {             \
12286
18.6k
    const arm_feature_set fset = FSET;      \
12287
18.6k
    arch_fset = fset;         \
12288
18.6k
  }
12289
12290
  /* When several architecture versions share the same bfd_mach_arm_XXX value
12291
     the most featureful is chosen.  */
12292
18.6k
  switch (mach)
12293
18.6k
    {
12294
270
    case bfd_mach_arm_2:  ARM_SET_FEATURES (ARM_ARCH_V2); break;
12295
127
    case bfd_mach_arm_2a:  ARM_SET_FEATURES (ARM_ARCH_V2S); break;
12296
148
    case bfd_mach_arm_3:  ARM_SET_FEATURES (ARM_ARCH_V3); break;
12297
444
    case bfd_mach_arm_3M:  ARM_SET_FEATURES (ARM_ARCH_V3M); break;
12298
215
    case bfd_mach_arm_4:  ARM_SET_FEATURES (ARM_ARCH_V4); break;
12299
0
    case bfd_mach_arm_ep9312:
12300
52
    case bfd_mach_arm_4T:  ARM_SET_FEATURES (ARM_ARCH_V4T); break;
12301
245
    case bfd_mach_arm_5:  ARM_SET_FEATURES (ARM_ARCH_V5); break;
12302
183
    case bfd_mach_arm_5T:  ARM_SET_FEATURES (ARM_ARCH_V5T); break;
12303
207
    case bfd_mach_arm_5TE:  ARM_SET_FEATURES (ARM_ARCH_V5TE); break;
12304
336
    case bfd_mach_arm_XScale:  ARM_SET_FEATURES (ARM_ARCH_XSCALE); break;
12305
355
    case bfd_mach_arm_iWMMXt:  ARM_SET_FEATURES (ARM_ARCH_IWMMXT); break;
12306
616
    case bfd_mach_arm_iWMMXt2:  ARM_SET_FEATURES (ARM_ARCH_IWMMXT2); break;
12307
35
    case bfd_mach_arm_5TEJ:  ARM_SET_FEATURES (ARM_ARCH_V5TEJ); break;
12308
97
    case bfd_mach_arm_6:  ARM_SET_FEATURES (ARM_ARCH_V6); break;
12309
130
    case bfd_mach_arm_6KZ:  ARM_SET_FEATURES (ARM_ARCH_V6KZ); break;
12310
90
    case bfd_mach_arm_6T2:  ARM_SET_FEATURES (ARM_ARCH_V6KZT2); break;
12311
51
    case bfd_mach_arm_6K:  ARM_SET_FEATURES (ARM_ARCH_V6K); break;
12312
126
    case bfd_mach_arm_7:  ARM_SET_FEATURES (ARM_ARCH_V7VE); break;
12313
111
    case bfd_mach_arm_6M:  ARM_SET_FEATURES (ARM_ARCH_V6M); break;
12314
77
    case bfd_mach_arm_6SM:  ARM_SET_FEATURES (ARM_ARCH_V6SM); break;
12315
120
    case bfd_mach_arm_7EM:  ARM_SET_FEATURES (ARM_ARCH_V7EM); break;
12316
52
    case bfd_mach_arm_8:
12317
52
  {
12318
    /* Add bits for extensions that Armv8.6-A recognizes.  */
12319
52
    arm_feature_set armv8_6_ext_fset
12320
52
      = ARM_FEATURE_CORE_HIGH (ARM_EXT2_FP16_INST);
12321
52
    ARM_SET_FEATURES (ARM_ARCH_V8_6A);
12322
52
    ARM_MERGE_FEATURE_SETS (arch_fset, arch_fset, armv8_6_ext_fset);
12323
52
    break;
12324
0
  }
12325
46
    case bfd_mach_arm_8R:  ARM_SET_FEATURES (ARM_ARCH_V8R_CRC); break;
12326
79
    case bfd_mach_arm_8M_BASE:  ARM_SET_FEATURES (ARM_ARCH_V8M_BASE); break;
12327
41
    case bfd_mach_arm_8M_MAIN:  ARM_SET_FEATURES (ARM_ARCH_V8M_MAIN); break;
12328
10.3k
    case bfd_mach_arm_8_1M_MAIN:
12329
10.3k
      ARM_SET_FEATURES (ARM_ARCH_V8_1M_MAIN);
12330
10.3k
      arm_feature_set mve_all
12331
10.3k
  = ARM_FEATURE_CORE_HIGH (ARM_EXT2_MVE | ARM_EXT2_MVE_FP);
12332
10.3k
      ARM_MERGE_FEATURE_SETS (arch_fset, arch_fset, mve_all);
12333
10.3k
      force_thumb = 1;
12334
10.3k
      break;
12335
83
    case bfd_mach_arm_9:         ARM_SET_FEATURES (ARM_ARCH_V9A); break;
12336
      /* If the machine type is unknown allow all architecture types and all
12337
   extensions, with the exception of MVE as that clashes with NEON.  */
12338
3.98k
    case bfd_mach_arm_unknown:
12339
3.98k
      ARM_SET_FEATURES (ARM_ARCH_UNKNOWN);
12340
3.98k
      break;
12341
0
    default:
12342
0
      abort ();
12343
18.6k
    }
12344
18.6k
#undef ARM_SET_FEATURES
12345
12346
  /* None of the feature bits related to -mfpu have an impact on Tag_CPU_arch
12347
     and thus on bfd_mach_arm_XXX value.  Therefore for a given
12348
     bfd_mach_arm_XXX value all coprocessor feature bits should be allowed.  */
12349
18.6k
  ARM_MERGE_FEATURE_SETS (*features, arch_fset, fpu_any);
12350
18.6k
}
12351
12352
12353
/* NOTE: There are no checks in these routines that
12354
   the relevant number of data bytes exist.  */
12355
12356
static int
12357
print_insn (bfd_vma pc, struct disassemble_info *info, bool little)
12358
14.5M
{
12359
14.5M
  unsigned char b[4];
12360
14.5M
  unsigned long given;
12361
14.5M
  int status;
12362
14.5M
  int is_thumb = false;
12363
14.5M
  int is_data = false;
12364
14.5M
  int little_code;
12365
14.5M
  unsigned int  size = 4;
12366
14.5M
  void (*printer) (bfd_vma, struct disassemble_info *, long);
12367
14.5M
  bool found = false;
12368
14.5M
  struct arm_private_data *private_data;
12369
12370
  /* Clear instruction information field.  */
12371
14.5M
  info->insn_info_valid = 0;
12372
14.5M
  info->branch_delay_insns = 0;
12373
14.5M
  info->data_size = 0;
12374
14.5M
  info->insn_type = dis_noninsn;
12375
14.5M
  info->target = 0;
12376
14.5M
  info->target2 = 0;
12377
12378
14.5M
  if (info->disassembler_options)
12379
14.1k
    {
12380
14.1k
      parse_arm_disassembler_options (info->disassembler_options);
12381
12382
      /* To avoid repeated parsing of these options, we remove them here.  */
12383
14.1k
      info->disassembler_options = NULL;
12384
14.1k
    }
12385
12386
  /* PR 10288: Control which instructions will be disassembled.  */
12387
14.5M
  if (info->private_data == NULL)
12388
18.6k
    {
12389
18.6k
      static struct arm_private_data private;
12390
12391
18.6k
      if (info->flavour != bfd_target_elf_flavour
12392
18.6k
    && (info->flags & USER_SPECIFIED_MACHINE_TYPE) == 0)
12393
  /* If the user did not use the -m command line switch then default to
12394
     disassembling all types of ARM instruction.
12395
12396
     If this is an arm elf target, build attributes will be used to
12397
     determine info->mach, which enable us to be more accurate when
12398
     disassembling since we know what the target architecture version is.
12399
     For any other target see the comment below:
12400
12401
     The info->mach value has to be ignored as this will be based on
12402
     the default archictecture for the target and/or hints in the notes
12403
     section, but it will never be greater than the current largest arm
12404
     machine value (iWMMXt2), which is only equivalent to the V5TE
12405
     architecture.  ARM architectures have advanced beyond the machine
12406
     value encoding, and these newer architectures would be ignored if
12407
     the machine value was used.
12408
12409
     Ie the -m switch is used to restrict which instructions will be
12410
     disassembled.  If it is necessary to use the -m switch to tell
12411
     objdump that an ARM binary is being disassembled, eg because the
12412
     input is a raw binary file, but it is also desired to disassemble
12413
     all ARM instructions then use "-marm".  This will select the
12414
     "unknown" arm architecture which is compatible with any ARM
12415
     instruction.  */
12416
246
    info->mach = bfd_mach_arm_unknown;
12417
12418
      /* Compute the architecture bitmask from the machine number.
12419
   Note: This assumes that the machine number will not change
12420
   during disassembly....  */
12421
18.6k
      select_arm_features (info->mach, & private.features);
12422
12423
18.6k
      private.last_mapping_sym = -1;
12424
18.6k
      private.last_mapping_addr = 0;
12425
18.6k
      private.last_stop_offset = 0;
12426
12427
18.6k
      info->private_data = & private;
12428
18.6k
    }
12429
12430
14.5M
  private_data = info->private_data;
12431
12432
  /* Decide if our code is going to be little-endian, despite what the
12433
     function argument might say.  */
12434
14.5M
  little_code = ((info->endian_code == BFD_ENDIAN_LITTLE) || little);
12435
12436
  /* For ELF, consult the symbol table to determine what kind of code
12437
     or data we have.  */
12438
14.5M
  if (info->symtab_size != 0
12439
14.5M
      && bfd_asymbol_flavour (*info->symtab) == bfd_target_elf_flavour)
12440
155k
    {
12441
155k
      bfd_vma addr;
12442
155k
      int n;
12443
155k
      int last_sym = -1;
12444
155k
      enum map_type type = MAP_ARM;
12445
12446
155k
      found = mapping_symbol_for_insn (pc, info, &type);
12447
155k
      last_sym = private_data->last_mapping_sym;
12448
12449
155k
      is_thumb = (private_data->last_type == MAP_THUMB);
12450
155k
      is_data = (private_data->last_type == MAP_DATA);
12451
12452
      /* Look a little bit ahead to see if we should print out
12453
   two or four bytes of data.  If there's a symbol,
12454
   mapping or otherwise, after two bytes then don't
12455
   print more.  */
12456
155k
      if (is_data)
12457
35.3k
  {
12458
35.3k
    size = 4 - (pc & 3);
12459
2.88M
    for (n = last_sym + 1; n < info->symtab_size; n++)
12460
2.84M
      {
12461
2.84M
        addr = bfd_asymbol_value (info->symtab[n]);
12462
2.84M
        if (addr > pc
12463
2.84M
      && (info->section == NULL
12464
1.26M
          || info->section == info->symtab[n]->section))
12465
371
    {
12466
371
      if (addr - pc < size)
12467
0
        size = addr - pc;
12468
371
      break;
12469
371
    }
12470
2.84M
      }
12471
    /* If the next symbol is after three bytes, we need to
12472
       print only part of the data, so that we can use either
12473
       .byte or .short.  */
12474
35.3k
    if (size == 3)
12475
0
      size = (pc & 1) ? 1 : 2;
12476
35.3k
  }
12477
155k
    }
12478
12479
14.5M
  if (info->symbols != NULL)
12480
5.12M
    {
12481
5.12M
      if (bfd_asymbol_flavour (*info->symbols) == bfd_target_coff_flavour)
12482
0
  {
12483
0
    coff_symbol_type * cs;
12484
12485
0
    cs = coffsymbol (*info->symbols);
12486
0
    is_thumb = (   cs->native->u.syment.n_sclass == C_THUMBEXT
12487
0
          || cs->native->u.syment.n_sclass == C_THUMBSTAT
12488
0
          || cs->native->u.syment.n_sclass == C_THUMBLABEL
12489
0
          || cs->native->u.syment.n_sclass == C_THUMBEXTFUNC
12490
0
          || cs->native->u.syment.n_sclass == C_THUMBSTATFUNC);
12491
0
  }
12492
5.12M
      else if (bfd_asymbol_flavour (*info->symbols) == bfd_target_elf_flavour
12493
5.12M
         && !found)
12494
0
  {
12495
    /* If no mapping symbol has been found then fall back to the type
12496
       of the function symbol.  */
12497
0
    elf_symbol_type *  es;
12498
0
    unsigned int       type;
12499
12500
0
    es = *(elf_symbol_type **)(info->symbols);
12501
0
    type = ELF_ST_TYPE (es->internal_elf_sym.st_info);
12502
12503
0
    is_thumb =
12504
0
      ((ARM_GET_SYM_BRANCH_TYPE (es->internal_elf_sym.st_target_internal)
12505
0
        == ST_BRANCH_TO_THUMB) || type == STT_ARM_16BIT);
12506
0
  }
12507
5.12M
      else if (bfd_asymbol_flavour (*info->symbols)
12508
5.12M
         == bfd_target_mach_o_flavour)
12509
5.12M
  {
12510
5.12M
    bfd_mach_o_asymbol *asym = (bfd_mach_o_asymbol *)*info->symbols;
12511
12512
5.12M
    is_thumb = (asym->n_desc & BFD_MACH_O_N_ARM_THUMB_DEF);
12513
5.12M
  }
12514
5.12M
    }
12515
12516
14.5M
  if (force_thumb)
12517
3.50M
    is_thumb = true;
12518
12519
14.5M
  if (is_data)
12520
35.3k
    info->display_endian = little ? BFD_ENDIAN_LITTLE : BFD_ENDIAN_BIG;
12521
14.4M
  else
12522
14.4M
    info->display_endian = little_code ? BFD_ENDIAN_LITTLE : BFD_ENDIAN_BIG;
12523
12524
14.5M
  info->bytes_per_line = 4;
12525
12526
  /* PR 10263: Disassemble data if requested to do so by the user.  */
12527
14.5M
  if (is_data && ((info->flags & DISASSEMBLE_DATA) == 0))
12528
0
    {
12529
0
      int i;
12530
12531
      /* Size was already set above.  */
12532
0
      info->bytes_per_chunk = size;
12533
0
      printer = print_insn_data;
12534
12535
0
      status = info->read_memory_func (pc, (bfd_byte *) b, size, info);
12536
0
      given = 0;
12537
0
      if (little)
12538
0
  for (i = size - 1; i >= 0; i--)
12539
0
    given = b[i] | (given << 8);
12540
0
      else
12541
0
  for (i = 0; i < (int) size; i++)
12542
0
    given = b[i] | (given << 8);
12543
0
    }
12544
14.5M
  else if (!is_thumb)
12545
6.01M
    {
12546
      /* In ARM mode endianness is a straightforward issue: the instruction
12547
   is four bytes long and is either ordered 0123 or 3210.  */
12548
6.01M
      printer = print_insn_arm;
12549
6.01M
      info->bytes_per_chunk = 4;
12550
6.01M
      size = 4;
12551
12552
6.01M
      status = info->read_memory_func (pc, (bfd_byte *) b, 4, info);
12553
6.01M
      if (little_code)
12554
4.39M
  given = (b[0]) | (b[1] << 8) | (b[2] << 16) | ((unsigned) b[3] << 24);
12555
1.61M
      else
12556
1.61M
  given = (b[3]) | (b[2] << 8) | (b[1] << 16) | ((unsigned) b[0] << 24);
12557
6.01M
    }
12558
8.50M
  else
12559
8.50M
    {
12560
      /* In Thumb mode we have the additional wrinkle of two
12561
   instruction lengths.  Fortunately, the bits that determine
12562
   the length of the current instruction are always to be found
12563
   in the first two bytes.  */
12564
8.50M
      printer = print_insn_thumb16;
12565
8.50M
      info->bytes_per_chunk = 2;
12566
8.50M
      size = 2;
12567
12568
8.50M
      status = info->read_memory_func (pc, (bfd_byte *) b, 2, info);
12569
8.50M
      if (little_code)
12570
8.22M
  given = (b[0]) | (b[1] << 8);
12571
283k
      else
12572
283k
  given = (b[1]) | (b[0] << 8);
12573
12574
8.50M
      if (!status)
12575
8.50M
  {
12576
    /* These bit patterns signal a four-byte Thumb
12577
       instruction.  */
12578
8.50M
    if ((given & 0xF800) == 0xF800
12579
8.50M
        || (given & 0xF800) == 0xF000
12580
8.50M
        || (given & 0xF800) == 0xE800)
12581
1.16M
      {
12582
1.16M
        status = info->read_memory_func (pc + 2, (bfd_byte *) b, 2, info);
12583
1.16M
        if (little_code)
12584
1.04M
    given = (b[0]) | (b[1] << 8) | (given << 16);
12585
121k
        else
12586
121k
    given = (b[1]) | (b[0] << 8) | (given << 16);
12587
12588
1.16M
        printer = print_insn_thumb32;
12589
1.16M
        size = 4;
12590
1.16M
      }
12591
8.50M
  }
12592
12593
8.50M
      if (ifthen_address != pc)
12594
18.9k
  find_ifthen_state (pc, info, little_code);
12595
12596
8.50M
      if (ifthen_state)
12597
116k
  {
12598
116k
    if ((ifthen_state & 0xf) == 0x8)
12599
25.5k
      ifthen_next_state = 0;
12600
90.8k
    else
12601
90.8k
      ifthen_next_state = (ifthen_state & 0xe0)
12602
90.8k
        | ((ifthen_state & 0xf) << 1);
12603
116k
  }
12604
8.50M
    }
12605
12606
14.5M
  if (status)
12607
5.42k
    {
12608
5.42k
      info->memory_error_func (status, pc, info);
12609
5.42k
      return -1;
12610
5.42k
    }
12611
14.5M
  if (info->flags & INSN_HAS_RELOC)
12612
    /* If the instruction has a reloc associated with it, then
12613
       the offset field in the instruction will actually be the
12614
       addend for the reloc.  (We are using REL type relocs).
12615
       In such cases, we can ignore the pc when computing
12616
       addresses, since the addend is not currently pc-relative.  */
12617
2
    pc = 0;
12618
12619
14.5M
  printer (pc, info, given);
12620
12621
14.5M
  if (is_thumb)
12622
8.50M
    {
12623
8.50M
      ifthen_state = ifthen_next_state;
12624
8.50M
      ifthen_address += size;
12625
8.50M
    }
12626
14.5M
  return size;
12627
14.5M
}
12628
12629
int
12630
print_insn_big_arm (bfd_vma pc, struct disassemble_info *info)
12631
2.07M
{
12632
  /* Detect BE8-ness and record it in the disassembler info.  */
12633
2.07M
  if (info->flavour == bfd_target_elf_flavour
12634
2.07M
      && info->section != NULL
12635
2.07M
      && (elf_elfheader (info->section->owner)->e_flags & EF_ARM_BE8))
12636
179k
    info->endian_code = BFD_ENDIAN_LITTLE;
12637
12638
2.07M
  return print_insn (pc, info, false);
12639
2.07M
}
12640
12641
int
12642
print_insn_little_arm (bfd_vma pc, struct disassemble_info *info)
12643
12.4M
{
12644
12.4M
  return print_insn (pc, info, true);
12645
12.4M
}
12646
12647
const disasm_options_and_args_t *
12648
disassembler_options_arm (void)
12649
0
{
12650
0
  static disasm_options_and_args_t *opts_and_args;
12651
12652
0
  if (opts_and_args == NULL)
12653
0
    {
12654
0
      disasm_options_t *opts;
12655
0
      unsigned int i;
12656
12657
0
      opts_and_args = XNEW (disasm_options_and_args_t);
12658
0
      opts_and_args->args = NULL;
12659
12660
0
      opts = &opts_and_args->options;
12661
0
      opts->name = XNEWVEC (const char *, NUM_ARM_OPTIONS + 1);
12662
0
      opts->description = XNEWVEC (const char *, NUM_ARM_OPTIONS + 1);
12663
0
      opts->arg = NULL;
12664
0
      for (i = 0; i < NUM_ARM_OPTIONS; i++)
12665
0
  {
12666
0
    opts->name[i] = regnames[i].name;
12667
0
    if (regnames[i].description != NULL)
12668
0
      opts->description[i] = _(regnames[i].description);
12669
0
    else
12670
0
      opts->description[i] = NULL;
12671
0
  }
12672
      /* The array we return must be NULL terminated.  */
12673
0
      opts->name[i] = NULL;
12674
0
      opts->description[i] = NULL;
12675
0
    }
12676
12677
0
  return opts_and_args;
12678
0
}
12679
12680
void
12681
print_arm_disassembler_options (FILE *stream)
12682
0
{
12683
0
  unsigned int i, max_len = 0;
12684
0
  fprintf (stream, _("\n\
12685
0
The following ARM specific disassembler options are supported for use with\n\
12686
0
the -M switch:\n"));
12687
12688
0
  for (i = 0; i < NUM_ARM_OPTIONS; i++)
12689
0
    {
12690
0
      unsigned int len = strlen (regnames[i].name);
12691
0
      if (max_len < len)
12692
0
  max_len = len;
12693
0
    }
12694
12695
0
  for (i = 0, max_len++; i < NUM_ARM_OPTIONS; i++)
12696
0
    fprintf (stream, "  %s%*c %s\n",
12697
0
       regnames[i].name,
12698
0
       (int)(max_len - strlen (regnames[i].name)), ' ',
12699
0
       _(regnames[i].description));
12700
0
}