• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# RUN: not llvm-mc -disassemble %s -mcpu cortex-a15 -triple armv7 2>&1 | FileCheck %s
2
3# This file is checking ARMv7 encodings which are globally invalid, usually due
4# to the constraints of the instructions not being met. For example invalid
5# combinations of registers.
6
7
8#------------------------------------------------------------------------------
9# Undefined encodings for bfi
10#------------------------------------------------------------------------------
11
12# Opcode=60 Name=BFI Format=ARM_FORMAT_DPFRM(4)
13#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
14# -------------------------------------------------------------------------------------------------
15# | 1: 1: 1: 0| 0: 1: 1: 1| 1: 1: 0: 0| 1: 1: 1: 1| 1: 1: 1: 1| 0: 0: 0: 0| 0: 0: 0: 1| 0: 1: 1: 0|
16# -------------------------------------------------------------------------------------------------
17#
18# if d == 15 then UNPREDICTABLE;
19[0x16 0xf0 0xcf 0xe7]
20# CHECK: potentially undefined instruction encoding
21# CHECK-NEXT: [0x16 0xf0 0xcf 0xe7]
22
23#------------------------------------------------------------------------------
24# Undefined encodings for cdp2
25#------------------------------------------------------------------------------
26
27[0xe0 0x6a 0x0c 0xfe]
28# CHECK: invalid instruction encoding
29# CHECK-NEXT: [0xe0 0x6a 0x0c 0xfe]
30
31
32#------------------------------------------------------------------------------
33# Undefined encodings for cps*
34#------------------------------------------------------------------------------
35
36# invalid imod value (0b01)
37[0xc0 0x67 0x4 0xf1]
38# CHECK: invalid instruction encoding
39# CHECK-NEXT: [0xc0 0x67 0x4 0xf1]
40
41# invalid (imod, M, iflags) combination
42[0x93 0x00 0x02 0xf1]
43# CHECK: potentially undefined instruction encoding
44# CHECK-NEXT: [0x93 0x00 0x02 0xf1]
45
46# CPS: various encodings that are ambiguous with other instructions
47[0x9f 0xff 0x4e 0xf1]
48# CHECK: invalid instruction encoding
49# CHECK-NEXT: [0x9f 0xff 0x4e 0xf1]
50
51[0x80 0x80 0x2c 0xf1]
52# CHECK: invalid instruction encoding
53# CHECK-NEXT: [0x80 0x80 0x2c 0xf1]
54
55[0xce 0x3f 0x28 0xf1]
56# CHECK: invalid instruction encoding
57# CHECK-NEXT: [0xce 0x3f 0x28 0xf1]
58
59[0x80 0x00 0x20 0xf1]
60# CHECK: invalid instruction encoding
61# CHECK-NEXT: [0x80 0x00 0x20 0xf1]
62
63[0xa0 0x00 0x00 0xf1]
64# CHECK: invalid instruction encoding
65# CHECK-NEXT: [0xa0 0x00 0x00 0xf1]
66
67
68#------------------------------------------------------------------------------
69# Undefined encoding space for hint instructions
70#------------------------------------------------------------------------------
71
72# FIXME: is it "dbg #14" or not????
73[0xfe 0xf0 0x20 0xe3]
74# CHCK: invalid instruction encoding
75
76
77#------------------------------------------------------------------------------
78# Undefined encodings for ldc
79#------------------------------------------------------------------------------
80
81# Opcode=0 Name=PHI Format=(42)
82#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
83# -------------------------------------------------------------------------------------------------
84# | 1: 1: 0: 1| 1: 1: 0: 0| 0: 0: 0: 1| 1: 1: 1: 1| 1: 0: 1: 1| 0: 1: 0: 0| 1: 0: 0: 1| 0: 0: 1: 0|
85# -------------------------------------------------------------------------------------------------
86#
87# The bytes have 0b0000 for P,U,D,W; from A8.6.51, it is undefined.
88
89[0x92 0xb4 0x1f 0xdc]
90# CHECK: invalid instruction encoding
91# CHECK-NEXT: [0x92 0xb4 0x1f 0xdc]
92
93
94#------------------------------------------------------------------------------
95# Undefined encodings for ldm
96#------------------------------------------------------------------------------
97
98# Opcode=134 Name=LDMIA Format=ARM_FORMAT_LDSTMULFRM(10)
99# 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
100# -------------------------------------------------------------------------------------------------
101# | 1: 1: 1: 1| 1: 0: 0: 0| 1: 0: 0: 1| 1: 0: 0: 1| 1: 0: 1: 1| 0: 0: 0: 1| 0: 0: 1: 1| 0: 0: 1: 0|
102# -------------------------------------------------------------------------------------------------
103#
104# B6.1.8 RFE has Inst{15-0} as 0x0a00 ==> Not an RFE instruction
105# A8.6.53 LDM/LDMIA/LDMFD is predicated with Inst{31-28} as cond ==> Not an LDMIA instruction
106
107[0x32 0xb1 0x99 0xf8]
108# CHECK: invalid instruction encoding
109# CHECK-NEXT: [0x32 0xb1 0x99 0xf8]
110
111
112#------------------------------------------------------------------------------
113# Undefined encodings for ldr
114#------------------------------------------------------------------------------
115
116# Opcode=165 Name=LDR_PRE Format=ARM_FORMAT_LDFRM(6)
117#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
118# -------------------------------------------------------------------------------------------------
119# | 1: 1: 1: 0| 0: 1: 1: 1| 1: 0: 1: 1| 0: 1: 1: 1| 0: 1: 1: 0| 0: 0: 0: 0| 1: 0: 0: 0| 1: 1: 1: 1|
120# -------------------------------------------------------------------------------------------------
121#
122# if m == 15 then UNPREDICTABLE
123
124[0x8f 0x60 0xb7 0xe7]
125# CHECK: potentially undefined instruction encoding
126# CHECK-NEXT: [0x8f 0x60 0xb7 0xe7]
127
128# LDR (register) has encoding Inst{4} = 0.
129[0xba 0xae 0x9f 0x57]
130# CHECK: invalid instruction encoding
131# CHECK-NEXT: [0xba 0xae 0x9f 0x57]
132
133# LDR_PRE/POST has encoding Inst{4} = 0.
134[0xde 0x69 0x18 0x46]
135# CHECK: invalid instruction encoding
136# CHECK-NEXT: [0xde 0x69 0x18 0x46]
137
138# Opcode=140 Name=LDRB_POST Format=ARM_FORMAT_LDFRM(6)
139#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
140# -------------------------------------------------------------------------------------------------
141# | 1: 1: 1: 0| 0: 1: 1: 0| 1: 1: 0: 1| 0: 1: 1: 1| 0: 1: 1: 1| 0: 0: 0: 0| 0: 0: 0: 0| 0: 1: 0: 1|
142# -------------------------------------------------------------------------------------------------
143#
144# if wback && (n == 15 || n == t) then UNPREDICTABLE
145[0x05 0x70 0xd7 0xe6]
146# CHECK: potentially undefined instruction encoding
147# CHECK-NEXT: [0x05 0x70 0xd7 0xe6]
148
149
150
151#------------------------------------------------------------------------------
152# Undefined encodings for mcr
153#------------------------------------------------------------------------------
154
155# Opcode=171 Name=MCR Format=ARM_FORMAT_BRFRM(2)
156#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
157# -------------------------------------------------------------------------------------------------
158# | 0: 0: 1: 0| 1: 1: 1: 0| 1: 0: 1: 0| 0: 0: 0: 0| 0: 0: 0: 1| 1: 0: 1: 1| 0: 0: 0: 1| 1: 0: 1: 1|
159# -------------------------------------------------------------------------------------------------
160#
161# Encoding error: coproc == 10 or 11 for MCR[R]/MR[R]C
162
163[0x1b 0x1b 0xa0 0x2e]
164# CHECK: invalid instruction encoding
165# CHECK-NEXT: [0x1b 0x1b 0xa0 0x2e]
166
167
168#------------------------------------------------------------------------------
169# Undefined encodings for mov/lsl
170#------------------------------------------------------------------------------
171
172# Opcode=0 Name=PHI Format=(42)
173#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
174# -------------------------------------------------------------------------------------------------
175# | 1: 1: 1: 1| 0: 0: 0: 1| 1: 0: 1: 1| 1: 1: 0: 0| 1: 1: 0: 1| 0: 0: 0: 1| 0: 0: 0: 0| 0: 0: 1: 0|
176# -------------------------------------------------------------------------------------------------
177# To qualify as an LSL (immediate) instruction, Inst{19-16} "should" be 0b0000, instead it is = 0b1100.
178# The instruction is UNPREDICTABLE, and is not a valid instruction.
179#
180# See also
181# A8.6.88 LSL (immediate)
182# A8.6.98 MOV (shifted register), and
183# I.1 Instruction encoding diagrams and pseudocode
184
185[0x2 0xd1 0xbc 0xf1]
186# CHECK: invalid instruction encoding
187# CHECK-NEXT: [0x2 0xd1 0xbc 0xf1]
188
189
190# Opcode=0 Name=PHI Format=(42)
191#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
192# -------------------------------------------------------------------------------------------------
193# | 1: 1: 1: 1| 0: 0: 0: 1| 1: 0: 1: 1| 1: 1: 0: 0| 1: 1: 0: 1| 0: 0: 0: 0| 0: 0: 0: 0| 0: 0: 1: 0|
194# -------------------------------------------------------------------------------------------------
195# To qualify as a MOV (register) instruction, Inst{19-16} "should" be 0b0000, instead it is = 0b1100.
196# The instruction is UNPREDICTABLE, and is not a valid instruction.
197#
198# See also
199# A8.6.97 MOV (register)
200
201[0x2 0xd0 0xbc 0xf1]
202# CHECK: invalid instruction encoding
203# CHECK-NEXT: [0x2 0xd0 0xbc 0xf1]
204
205# Opcode=196 Name=MOVs Format=ARM_FORMAT_DPSOREGFRM(5)
206#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
207# -------------------------------------------------------------------------------------------------
208# | 1: 1: 0: 1| 0: 0: 0: 1| 1: 0: 1: 0| 0: 0: 0: 0| 0: 1: 0: 0| 0: 0: 1: 0| 1: 0: 0: 1| 0: 0: 1: 1|
209# -------------------------------------------------------------------------------------------------
210# A8.6.89 LSL (register): Inst{7-4} = 0b0001
211[0x93 0x42 0xa0 0xd1]
212# CHECK: invalid instruction encoding
213# CHECK-NEXT: [0x93 0x42 0xa0 0xd1]
214
215# Opcode=185 Name=MOVTi16 Format=ARM_FORMAT_DPFRM(4)
216#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
217# -------------------------------------------------------------------------------------------------
218# | 1: 1: 1: 0| 0: 0: 1: 1| 0: 1: 0: 0| 0: 0: 0: 1| 1: 1: 1: 1| 0: 0: 0: 0| 0: 0: 0: 0| 0: 0: 0: 0|
219# -------------------------------------------------------------------------------------------------
220#
221# if d == 15 then UNPREDICTABLE
222[0x00 0xf0 0x41 0xe3]
223# CHECK: potentially undefined instruction encoding
224# CHECK-NEXT: [0x00 0xf0 0x41 0xe3]
225
226
227#------------------------------------------------------------------------------
228# Undefined encodings for mrrc2
229#------------------------------------------------------------------------------
230
231[0x00 0x1a 0x50 0xfc]
232# CHECK: invalid instruction encoding
233# CHECK-NEXT: [0x00 0x1a 0x50 0xfc]
234
235
236#------------------------------------------------------------------------------
237# Undefined encodings for msr (imm)
238#------------------------------------------------------------------------------
239
240# Opcode=206 Name=MSRi Format=ARM_FORMAT_BRFRM(2)
241#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
242# -------------------------------------------------------------------------------------------------
243# | 0: 0: 0: 0| 0: 0: 1: 1| 0: 0: 1: 0| 0: 0: 0: 0| 1: 1: 1: 1| 0: 0: 0: 1| 1: 0: 1: 0| 0: 1: 1: 1|
244# -------------------------------------------------------------------------------------------------
245#
246# A5.2.11 MSR (immediate), and hints & B6.1.6 MSR (immediate)
247# The hints instructions have more specific encodings, so if mask == 0,
248# we should reject this as an invalid instruction.
249
250[0xa7 0xf1 0x20 0x3]
251# CHECK: invalid instruction encoding
252# CHECK-NEXT: [0xa7 0xf1 0x20 0x3]
253
254
255#------------------------------------------------------------------------------
256# Undefined encodings for sbfx
257#------------------------------------------------------------------------------
258
259# Opcode=271 Name=SBFX Format=ARM_FORMAT_DPFRM(4)
260#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
261# -------------------------------------------------------------------------------------------------
262# | 1: 1: 1: 0| 0: 1: 1: 1| 1: 0: 1: 0| 0: 1: 1: 1| 0: 1: 0: 1| 0: 1: 0: 0| 0: 1: 0: 1| 1: 1: 1: 1|
263# -------------------------------------------------------------------------------------------------
264#
265# if d == 15 || n == 15 then UNPREDICTABLE;
266
267[0x5f 0x54 0xa7 0xe7]
268# CHECK: potentially undefined instruction encoding
269# CHECK-NEXT: [0x5f 0x54 0xa7 0xe7]
270
271#------------------------------------------------------------------------------
272# Undefined encodings for smlad
273#------------------------------------------------------------------------------
274
275# Opcode=284 Name=SMLAD Format=ARM_FORMAT_MULFRM(1)
276#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
277# -------------------------------------------------------------------------------------------------
278# | 1: 0: 0: 1| 0: 1: 1: 1| 0: 0: 0: 0| 1: 1: 1: 1| 0: 1: 1: 0| 1: 0: 0: 0| 0: 0: 0: 1| 1: 0: 1: 1|
279# -------------------------------------------------------------------------------------------------
280#
281# A8.6.167
282# if d == 15 || n == 15 | m == 15 then UNPREDICTABLE
283
284[0x1b 0x68 0xf 0x97]
285# CHECK: potentially undefined instruction encoding
286# CHECK-NEXT: [0x1b 0x68 0xf 0x97]
287
288
289#------------------------------------------------------------------------------
290# Undefined encodings for srs
291#------------------------------------------------------------------------------
292
293# Opcode=0 Name=PHI Format=(42)
294#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
295# -------------------------------------------------------------------------------------------------
296# | 1: 1: 1: 1| 1: 0: 0: 0| 1: 1: 0: 0| 0: 1: 0: 1| 0: 0: 0: 1| 1: 1: 0: 0| 1: 0: 0: 0| 0: 0: 1: 1|
297# -------------------------------------------------------------------------------------------------
298# Unknown format
299#
300# B6.1.10 SRS
301# Inst{19-8} = 0xd05
302# Inst{7-5} = 0b000
303
304[0x83 0x1c 0xc5 0xf8]
305# CHECK: invalid instruction encoding
306# CHECK-NEXT: [0x83 0x1c 0xc5 0xf8]
307
308[0x00 0x00 0x20 0xf8]
309# CHECK: invalid instruction encoding
310# CHECK-NEXT: [0x00 0x00 0x20 0xf8]
311
312[0xff 0xff 0xaf 0xf8]
313# CHECK: invalid instruction encoding
314# CHECK-NEXT: [0xff 0xff 0xaf 0xf8]
315
316[0x13 0x00 0xa0 0xf8]
317# CHECK: invalid instruction encoding
318# CHECK-NEXT: [0x13 0x00 0xa0 0xf8]
319
320#------------------------------------------------------------------------------
321# Undefined encodings for sxtb
322#------------------------------------------------------------------------------
323
324# Opcode=390 Name=SXTBr_rot Format=ARM_FORMAT_EXTFRM(14)
325#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
326# -------------------------------------------------------------------------------------------------
327# | 1: 1: 1: 0| 0: 1: 1: 0| 1: 0: 1: 0| 1: 1: 1: 1| 1: 1: 1: 1| 0: 1: 0: 0| 0: 1: 1: 1| 0: 1: 0: 1|
328# -------------------------------------------------------------------------------------------------
329#
330# A8.6.223 SXTB
331# if d == 15 || m == 15 then UNPREDICTABLE;
332
333[0x75 0xf4 0xaf 0xe6]
334# CHECK: potentially undefined instruction encoding
335# CHECK-NEXT: [0x75 0xf4 0xaf 0xe6]
336
337#------------------------------------------------------------------------------
338# Undefined encodings for NEON umaal
339#------------------------------------------------------------------------------
340
341# Opcode=419 Name=UMAAL Format=ARM_FORMAT_MULFRM(1)
342#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
343# -------------------------------------------------------------------------------------------------
344# | 1: 1: 1: 1| 0: 0: 0: 0| 0: 1: 0: 0| 1: 1: 1: 1| 1: 0: 1: 1| 1: 1: 1: 1| 1: 0: 0: 1| 1: 0: 0: 0|
345# -------------------------------------------------------------------------------------------------
346#
347# A8.6.244 UMAAL
348# if dLo == 15 || dHi == 15 || n == 15 || m == 15 then UNPREDICTABLE;
349[0x98 0xbf 0x4f 0xf0]
350# CHECK: invalid instruction encoding
351# CHECK-NEXT: [0x98 0xbf 0x4f 0xf0]
352
353#------------------------------------------------------------------------------
354# Undefined encodings for NEON vcvt (float <-> fixed)
355#------------------------------------------------------------------------------
356
357# imm6=0b0xxxxx -> UNDEFINED
358[0x1e 0xcf 0x92 0xf3]
359# CHECK: invalid instruction encoding
360# CHECK-NEXT: [0x1e 0xcf 0x92 0xf3]
361
362[0x3e 0xcf 0x92 0xf3]
363# CHECK: invalid instruction encoding
364# CHECK-NEXT: [0x3e 0xcf 0x92 0xf3]
365
366
367#------------------------------------------------------------------------------
368# Undefined encodings for NEON vext
369#------------------------------------------------------------------------------
370
371# invalid imm4 value (0b1xxx)
372# A8.8.316: if Q == '0' && imm4<3> == '1' then UNDEFINED;
373[0x8f 0xf9 0xf7 0xf2]
374# CHECK: invalid instruction encoding
375# CHECK-NEXT: [0x8f 0xf9 0xf7 0xf2]
376
377#------------------------------------------------------------------------------
378# Undefined encodings for NEON vldmsdb
379#------------------------------------------------------------------------------
380
381# core registers out of range
382[0xa5 0xba 0x72 0xed]
383# CHECK: potentially undefined instruction encoding
384# CHECK-NEXT: [0xa5 0xba 0x72 0xed]
385
386
387#------------------------------------------------------------------------------
388# Undefined encodings for NEON vmov
389#------------------------------------------------------------------------------
390
391# VMOV cmode=0b1111 op=1 is UNDEFINED
392[0x70 0xef 0xc7 0xf3]
393# CHECK: invalid instruction encoding
394# CHECK-NEXT: [0x70 0xef 0xc7 0xf3]
395
396#  VMOV cmode=0b1111 op=1 is UNDEFINED
397[0x30 0x0f 0x80 0xf3]
398# CHECK: invalid instruction encoding
399# CHECK-NEXT: [0x30 0x0f 0x80 0xf3]
400
401
402#------------------------------------------------------------------------------
403# Undefined encodings for NEON vqadd
404#------------------------------------------------------------------------------
405
406# Opcode=1225 Name=VQADDsv16i8 Format=ARM_FORMAT_N3Reg(37)
407#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
408# -------------------------------------------------------------------------------------------------
409# | 1: 1: 1: 1| 0: 0: 1: 0| 0: 1: 0: 0| 0: 0: 0: 0| 1: 1: 1: 0| 0: 0: 0: 0| 1: 1: 0: 1| 1: 0: 1: 1|
410# -------------------------------------------------------------------------------------------------
411#
412# Qm -> bit[0] == 0, otherwise UNDEFINED
413[0xdb 0xe0 0x40 0xf2]
414# CHECK: invalid instruction encoding
415# CHECK-NEXT: [0xdb 0xe0 0x40 0xf2]
416
417
418#------------------------------------------------------------------------------
419# Undefined encodings for NEON vld/vst
420#------------------------------------------------------------------------------
421
422# A8.6.393 VST2 (multiple 2-element structures)
423[0xb3 0x09 0x03 0xf4]
424# CHECK: invalid instruction encoding
425# CHECK-NEXT: [0xb3 0x09 0x03 0xf4]
426
427# size == '11' ==> UNDEFINED
428[0xc3 0x08 0x03 0xf4]
429# CHECK: invalid instruction encoding
430# CHECK-NEXT: [0xc3 0x08 0x03 0xf4]
431
432# type == '1000' and align == '11' ==> UNDEFINED
433[0xb3 0x08 0x03 0xf4]
434# CHECK: invalid instruction encoding
435# CHECK-NEXT: [0xb3 0x08 0x03 0xf4]
436
437# VST1 multi-element, type == 0b0111, align == 0b10 -> undefined
438[0xaf 0xb7 0x07 0xf4]
439# CHECK: invalid instruction encoding
440# CHECK-NEXT: [0xaf 0xb7 0x07 0xf4]
441
442# VST1 multi-element, type == 0b0111, align == 0b11 -> undefined
443[0xbf 0xb7 0x07 0xf4]
444# CHECK: invalid instruction encoding
445# CHECK-NEXT: [0xbf 0xb7 0x07 0xf4]
446
447# VST1 multi-element, type == 0b1010, align == 0b11 -> undefined
448[0xbf 0x8a 0x03 0xf4]
449# CHECK: invalid instruction encoding
450# CHECK-NEXT: [0xbf 0x8a 0x03 0xf4]
451
452# VST1 multi-element, type == 0b0110, align == 0b10 -> undefined
453[0xaf 0xb6 0x07 0xf4]
454# CHECK: invalid instruction encoding
455# CHECK-NEXT: [0xaf 0xb6 0x07 0xf4]
456
457# VST1 multi-element, type == 0b0110, align == 0b11 -> undefined
458[0xbf 0xb6 0x07 0xf4]
459# CHECK: invalid instruction encoding
460# CHECK-NEXT: [0xbf 0xb6 0x07 0xf4]
461
462# VST2 multi-element, type == 0b0100, align == 0b11 -> undefined
463[0x4f 0xa8 0x07 0xf7]
464# CHECK: invalid instruction encoding
465# CHECK-NEXT: [0x4f 0xa8 0x07 0xf7]
466
467# VST2 multi-element, type == 0b0100, align == 0b11 -> undefined
468[0x4f 0xa9 0x07 0xf7]
469# CHECK: invalid instruction encoding
470# CHECK-NEXT: [0x4f 0xa9 0x07 0xf7]
471
472# VST3 multi-element, size = 0b11 -> undefined
473[0xbf 0xa4 0x0b 0xf4]
474# CHECK: invalid instruction encoding
475# CHECK-NEXT: [0xbf 0xa4 0x0b 0xf4]
476
477# VST3 multi-element, align = 0b10 -> undefined
478[0x6f 0xa4 0x0b 0xf4]
479# CHECK: invalid instruction encoding
480# CHECK-NEXT: [0x6f 0xa4 0x0b 0xf4]
481
482# VST3 multi-element, align = 0b11 -> undefined
483[0x7f 0xa4 0x0b 0xf4]
484# CHECK: invalid instruction encoding
485# CHECK-NEXT: [0x7f 0xa4 0x0b 0xf4]
486
487# VST4 multi-element, size = 0b11 -> undefined
488[0xcf 0x50 0x03 0xf4]
489# CHECK: invalid instruction encoding
490# CHECK-NEXT: [0xcf 0x50 0x03 0xf4]
491
492
493# Opcode=737 Name=VLD1DUPq8_UPD Format=ARM_FORMAT_NLdSt(30)
494#  31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10  9  8  7  6  5  4  3  2  1  0
495# -------------------------------------------------------------------------------------------------
496# | 1: 1: 1: 1| 0: 1: 0: 0| 1: 0: 1: 0| 0: 0: 0: 0| 0: 0: 1: 1| 1: 1: 0: 0| 0: 0: 1: 1| 1: 1: 0: 1|
497# -------------------------------------------------------------------------------------------------
498#
499# 'a' == 1 and data_size == 8 is invalid
500[0x3d 0x3c 0xa0 0xf4]
501# CHECK: invalid instruction encoding
502# CHECK-NEXT: [0x3d 0x3c 0xa0 0xf4]
503
504
505#------------------------------------------------------------------------------
506# Undefined encodings for MSR/MRS (banked register)
507#------------------------------------------------------------------------------
508# These have a banked register encoding of 0b111111, which is unallocated.
509
510# msr <invalid>, r0
511[0x00,0xf3,0x6f,0xe1]
512# CHECK: invalid instruction encoding
513# CHECK-NEXT: [0x00,0xf3,0x6f,0xe1]
514
515# mrs r0, <invalid>
516[0x00,0x03,0x4f,0xe1]
517# CHECK: invalid instruction encoding
518# CHECK-NEXT: [0x00,0x03,0x4f,0xe1]
519