1 // RUN
: llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sve
< %s \
2 // RUN
: | FileCheck
%s
--check-prefixes
=CHECK-ENCODING
,CHECK-INST
3 // RUN
: llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sme
< %s \
4 // RUN
: | FileCheck
%s
--check-prefixes
=CHECK-ENCODING
,CHECK-INST
5 // RUN
: not llvm-mc
-triple
=aarch64
-show-encoding
< %s
2>&1 \
6 // RUN
: | FileCheck
%s
--check-prefix
=CHECK-ERROR
7 // RUN
: llvm-mc
-triple
=aarch64
-filetype
=obj
-mattr
=+sve
< %s \
8 // RUN
: | llvm-objdump
--no-print-imm-hex
-d
--mattr
=+sve
- | FileCheck
%s
--check-prefix
=CHECK-INST
9 // RUN
: llvm-mc
-triple
=aarch64
-filetype
=obj
-mattr
=+sve
< %s \
10 // RUN
: | llvm-objdump
--no-print-imm-hex
-d
--mattr
=-sve
- | FileCheck
%s
--check-prefix
=CHECK-UNKNOWN
12 // ---------------------------------------------------------------------------//
13 // Test
64-bit form
(x0
) and its aliases
14 // ---------------------------------------------------------------------------//
17 // CHECK-INST
: sqdecd x0
18 // CHECK-ENCODING
: [0xe0,0xfb,0xf0,0x04]
19 // CHECK-ERROR
: instruction requires
: sve
or sme
20 // CHECK-UNKNOWN
: 04f0fbe0
<unknown
>
23 // CHECK-INST
: sqdecd x0
24 // CHECK-ENCODING
: [0xe0,0xfb,0xf0,0x04]
25 // CHECK-ERROR
: instruction requires
: sve
or sme
26 // CHECK-UNKNOWN
: 04f0fbe0
<unknown
>
28 sqdecd x0
, all
, mul #1
29 // CHECK-INST
: sqdecd x0
30 // CHECK-ENCODING
: [0xe0,0xfb,0xf0,0x04]
31 // CHECK-ERROR
: instruction requires
: sve
or sme
32 // CHECK-UNKNOWN
: 04f0fbe0
<unknown
>
34 sqdecd x0
, all
, mul #16
35 // CHECK-INST
: sqdecd x0
, all
, mul #16
36 // CHECK-ENCODING
: [0xe0,0xfb,0xff,0x04]
37 // CHECK-ERROR
: instruction requires
: sve
or sme
38 // CHECK-UNKNOWN
: 04fffbe0
<unknown
>
41 // ---------------------------------------------------------------------------//
42 // Test
32-bit form
(x0
, w0
) and its aliases
43 // ---------------------------------------------------------------------------//
46 // CHECK-INST
: sqdecd x0
, w0
47 // CHECK-ENCODING
: [0xe0,0xfb,0xe0,0x04]
48 // CHECK-ERROR
: instruction requires
: sve
or sme
49 // CHECK-UNKNOWN
: 04e0fbe0
<unknown
>
52 // CHECK-INST
: sqdecd x0
, w0
53 // CHECK-ENCODING
: [0xe0,0xfb,0xe0,0x04]
54 // CHECK-ERROR
: instruction requires
: sve
or sme
55 // CHECK-UNKNOWN
: 04e0fbe0
<unknown
>
57 sqdecd x0
, w0
, all
, mul #1
58 // CHECK-INST
: sqdecd x0
, w0
59 // CHECK-ENCODING
: [0xe0,0xfb,0xe0,0x04]
60 // CHECK-ERROR
: instruction requires
: sve
or sme
61 // CHECK-UNKNOWN
: 04e0fbe0
<unknown
>
63 sqdecd x0
, w0
, all
, mul #16
64 // CHECK-INST
: sqdecd x0
, w0
, all
, mul #16
65 // CHECK-ENCODING
: [0xe0,0xfb,0xef,0x04]
66 // CHECK-ERROR
: instruction requires
: sve
or sme
67 // CHECK-UNKNOWN
: 04effbe0
<unknown
>
70 // CHECK-INST
: sqdecd x0
, w0
, pow2
71 // CHECK-ENCODING
: [0x00,0xf8,0xe0,0x04]
72 // CHECK-ERROR
: instruction requires
: sve
or sme
73 // CHECK-UNKNOWN
: 04e0f800
<unknown
>
75 sqdecd x0
, w0
, pow2
, mul #16
76 // CHECK-INST
: sqdecd x0
, w0
, pow2
, mul #16
77 // CHECK-ENCODING
: [0x00,0xf8,0xef,0x04]
78 // CHECK-ERROR
: instruction requires
: sve
or sme
79 // CHECK-UNKNOWN
: 04eff800
<unknown
>
82 // ---------------------------------------------------------------------------//
83 // Test vector form
and aliases.
84 // ---------------------------------------------------------------------------//
86 // CHECK-INST
: sqdecd z0.d
87 // CHECK-ENCODING
: [0xe0,0xcb,0xe0,0x04]
88 // CHECK-ERROR
: instruction requires
: sve
or sme
89 // CHECK-UNKNOWN
: 04e0cbe0
<unknown
>
92 // CHECK-INST
: sqdecd z0.d
93 // CHECK-ENCODING
: [0xe0,0xcb,0xe0,0x04]
94 // CHECK-ERROR
: instruction requires
: sve
or sme
95 // CHECK-UNKNOWN
: 04e0cbe0
<unknown
>
97 sqdecd z0.d
, all
, mul #1
98 // CHECK-INST
: sqdecd z0.d
99 // CHECK-ENCODING
: [0xe0,0xcb,0xe0,0x04]
100 // CHECK-ERROR
: instruction requires
: sve
or sme
101 // CHECK-UNKNOWN
: 04e0cbe0
<unknown
>
103 sqdecd z0.d
, all
, mul #16
104 // CHECK-INST
: sqdecd z0.d
, all
, mul #16
105 // CHECK-ENCODING
: [0xe0,0xcb,0xef,0x04]
106 // CHECK-ERROR
: instruction requires
: sve
or sme
107 // CHECK-UNKNOWN
: 04efcbe0
<unknown
>
110 // CHECK-INST
: sqdecd z0.d
, pow2
111 // CHECK-ENCODING
: [0x00,0xc8,0xe0,0x04]
112 // CHECK-ERROR
: instruction requires
: sve
or sme
113 // CHECK-UNKNOWN
: 04e0c800
<unknown
>
115 sqdecd z0.d
, pow2
, mul #16
116 // CHECK-INST
: sqdecd z0.d
, pow2
, mul #16
117 // CHECK-ENCODING
: [0x00,0xc8,0xef,0x04]
118 // CHECK-ERROR
: instruction requires
: sve
or sme
119 // CHECK-UNKNOWN
: 04efc800
<unknown
>
122 // ---------------------------------------------------------------------------//
123 // Test all patterns for
64-bit form
124 // ---------------------------------------------------------------------------//
127 // CHECK-INST
: sqdecd x0
, pow2
128 // CHECK-ENCODING
: [0x00,0xf8,0xf0,0x04]
129 // CHECK-ERROR
: instruction requires
: sve
or sme
130 // CHECK-UNKNOWN
: 04f0f800
<unknown
>
133 // CHECK-INST
: sqdecd x0
, vl1
134 // CHECK-ENCODING
: [0x20,0xf8,0xf0,0x04]
135 // CHECK-ERROR
: instruction requires
: sve
or sme
136 // CHECK-UNKNOWN
: 04f0f820
<unknown
>
139 // CHECK-INST
: sqdecd x0
, vl2
140 // CHECK-ENCODING
: [0x40,0xf8,0xf0,0x04]
141 // CHECK-ERROR
: instruction requires
: sve
or sme
142 // CHECK-UNKNOWN
: 04f0f840
<unknown
>
145 // CHECK-INST
: sqdecd x0
, vl3
146 // CHECK-ENCODING
: [0x60,0xf8,0xf0,0x04]
147 // CHECK-ERROR
: instruction requires
: sve
or sme
148 // CHECK-UNKNOWN
: 04f0f860
<unknown
>
151 // CHECK-INST
: sqdecd x0
, vl4
152 // CHECK-ENCODING
: [0x80,0xf8,0xf0,0x04]
153 // CHECK-ERROR
: instruction requires
: sve
or sme
154 // CHECK-UNKNOWN
: 04f0f880
<unknown
>
157 // CHECK-INST
: sqdecd x0
, vl5
158 // CHECK-ENCODING
: [0xa0,0xf8,0xf0,0x04]
159 // CHECK-ERROR
: instruction requires
: sve
or sme
160 // CHECK-UNKNOWN
: 04f0f8a0
<unknown
>
163 // CHECK-INST
: sqdecd x0
, vl6
164 // CHECK-ENCODING
: [0xc0,0xf8,0xf0,0x04]
165 // CHECK-ERROR
: instruction requires
: sve
or sme
166 // CHECK-UNKNOWN
: 04f0f8c0
<unknown
>
169 // CHECK-INST
: sqdecd x0
, vl7
170 // CHECK-ENCODING
: [0xe0,0xf8,0xf0,0x04]
171 // CHECK-ERROR
: instruction requires
: sve
or sme
172 // CHECK-UNKNOWN
: 04f0f8e0
<unknown
>
175 // CHECK-INST
: sqdecd x0
, vl8
176 // CHECK-ENCODING
: [0x00,0xf9,0xf0,0x04]
177 // CHECK-ERROR
: instruction requires
: sve
or sme
178 // CHECK-UNKNOWN
: 04f0f900
<unknown
>
181 // CHECK-INST
: sqdecd x0
, vl16
182 // CHECK-ENCODING
: [0x20,0xf9,0xf0,0x04]
183 // CHECK-ERROR
: instruction requires
: sve
or sme
184 // CHECK-UNKNOWN
: 04f0f920
<unknown
>
187 // CHECK-INST
: sqdecd x0
, vl32
188 // CHECK-ENCODING
: [0x40,0xf9,0xf0,0x04]
189 // CHECK-ERROR
: instruction requires
: sve
or sme
190 // CHECK-UNKNOWN
: 04f0f940
<unknown
>
193 // CHECK-INST
: sqdecd x0
, vl64
194 // CHECK-ENCODING
: [0x60,0xf9,0xf0,0x04]
195 // CHECK-ERROR
: instruction requires
: sve
or sme
196 // CHECK-UNKNOWN
: 04f0f960
<unknown
>
199 // CHECK-INST
: sqdecd x0
, vl128
200 // CHECK-ENCODING
: [0x80,0xf9,0xf0,0x04]
201 // CHECK-ERROR
: instruction requires
: sve
or sme
202 // CHECK-UNKNOWN
: 04f0f980
<unknown
>
205 // CHECK-INST
: sqdecd x0
, vl256
206 // CHECK-ENCODING
: [0xa0,0xf9,0xf0,0x04]
207 // CHECK-ERROR
: instruction requires
: sve
or sme
208 // CHECK-UNKNOWN
: 04f0f9a0
<unknown
>
211 // CHECK-INST
: sqdecd x0
, #14
212 // CHECK-ENCODING
: [0xc0,0xf9,0xf0,0x04]
213 // CHECK-ERROR
: instruction requires
: sve
or sme
214 // CHECK-UNKNOWN
: 04f0f9c0
<unknown
>
217 // CHECK-INST
: sqdecd x0
, #15
218 // CHECK-ENCODING
: [0xe0,0xf9,0xf0,0x04]
219 // CHECK-ERROR
: instruction requires
: sve
or sme
220 // CHECK-UNKNOWN
: 04f0f9e0
<unknown
>
223 // CHECK-INST
: sqdecd x0
, #16
224 // CHECK-ENCODING
: [0x00,0xfa,0xf0,0x04]
225 // CHECK-ERROR
: instruction requires
: sve
or sme
226 // CHECK-UNKNOWN
: 04f0fa00
<unknown
>
229 // CHECK-INST
: sqdecd x0
, #17
230 // CHECK-ENCODING
: [0x20,0xfa,0xf0,0x04]
231 // CHECK-ERROR
: instruction requires
: sve
or sme
232 // CHECK-UNKNOWN
: 04f0fa20
<unknown
>
235 // CHECK-INST
: sqdecd x0
, #18
236 // CHECK-ENCODING
: [0x40,0xfa,0xf0,0x04]
237 // CHECK-ERROR
: instruction requires
: sve
or sme
238 // CHECK-UNKNOWN
: 04f0fa40
<unknown
>
241 // CHECK-INST
: sqdecd x0
, #19
242 // CHECK-ENCODING
: [0x60,0xfa,0xf0,0x04]
243 // CHECK-ERROR
: instruction requires
: sve
or sme
244 // CHECK-UNKNOWN
: 04f0fa60
<unknown
>
247 // CHECK-INST
: sqdecd x0
, #20
248 // CHECK-ENCODING
: [0x80,0xfa,0xf0,0x04]
249 // CHECK-ERROR
: instruction requires
: sve
or sme
250 // CHECK-UNKNOWN
: 04f0fa80
<unknown
>
253 // CHECK-INST
: sqdecd x0
, #21
254 // CHECK-ENCODING
: [0xa0,0xfa,0xf0,0x04]
255 // CHECK-ERROR
: instruction requires
: sve
or sme
256 // CHECK-UNKNOWN
: 04f0faa0
<unknown
>
259 // CHECK-INST
: sqdecd x0
, #22
260 // CHECK-ENCODING
: [0xc0,0xfa,0xf0,0x04]
261 // CHECK-ERROR
: instruction requires
: sve
or sme
262 // CHECK-UNKNOWN
: 04f0fac0
<unknown
>
265 // CHECK-INST
: sqdecd x0
, #23
266 // CHECK-ENCODING
: [0xe0,0xfa,0xf0,0x04]
267 // CHECK-ERROR
: instruction requires
: sve
or sme
268 // CHECK-UNKNOWN
: 04f0fae0
<unknown
>
271 // CHECK-INST
: sqdecd x0
, #24
272 // CHECK-ENCODING
: [0x00,0xfb,0xf0,0x04]
273 // CHECK-ERROR
: instruction requires
: sve
or sme
274 // CHECK-UNKNOWN
: 04f0fb00
<unknown
>
277 // CHECK-INST
: sqdecd x0
, #25
278 // CHECK-ENCODING
: [0x20,0xfb,0xf0,0x04]
279 // CHECK-ERROR
: instruction requires
: sve
or sme
280 // CHECK-UNKNOWN
: 04f0fb20
<unknown
>
283 // CHECK-INST
: sqdecd x0
, #26
284 // CHECK-ENCODING
: [0x40,0xfb,0xf0,0x04]
285 // CHECK-ERROR
: instruction requires
: sve
or sme
286 // CHECK-UNKNOWN
: 04f0fb40
<unknown
>
289 // CHECK-INST
: sqdecd x0
, #27
290 // CHECK-ENCODING
: [0x60,0xfb,0xf0,0x04]
291 // CHECK-ERROR
: instruction requires
: sve
or sme
292 // CHECK-UNKNOWN
: 04f0fb60
<unknown
>
295 // CHECK-INST
: sqdecd x0
, #28
296 // CHECK-ENCODING
: [0x80,0xfb,0xf0,0x04]
297 // CHECK-ERROR
: instruction requires
: sve
or sme
298 // CHECK-UNKNOWN
: 04f0fb80
<unknown
>
301 // --------------------------------------------------------------------------//
302 // Test compatibility with MOVPRFX instruction.
305 // CHECK-INST
: movprfx z0
, z7
306 // CHECK-ENCODING
: [0xe0,0xbc,0x20,0x04]
307 // CHECK-ERROR
: instruction requires
: sve
or sme
308 // CHECK-UNKNOWN
: 0420bce0
<unknown
>
311 // CHECK-INST
: sqdecd z0.d
312 // CHECK-ENCODING
: [0xe0,0xcb,0xe0,0x04]
313 // CHECK-ERROR
: instruction requires
: sve
or sme
314 // CHECK-UNKNOWN
: 04e0cbe0
<unknown
>
317 // CHECK-INST
: movprfx z0
, z7
318 // CHECK-ENCODING
: [0xe0,0xbc,0x20,0x04]
319 // CHECK-ERROR
: instruction requires
: sve
or sme
320 // CHECK-UNKNOWN
: 0420bce0
<unknown
>
322 sqdecd z0.d
, pow2
, mul #16
323 // CHECK-INST
: sqdecd z0.d
, pow2
, mul #16
324 // CHECK-ENCODING
: [0x00,0xc8,0xef,0x04]
325 // CHECK-ERROR
: instruction requires
: sve
or sme
326 // CHECK-UNKNOWN
: 04efc800
<unknown
>
329 // CHECK-INST
: movprfx z0
, z7
330 // CHECK-ENCODING
: [0xe0,0xbc,0x20,0x04]
331 // CHECK-ERROR
: instruction requires
: sve
or sme
332 // CHECK-UNKNOWN
: 0420bce0
<unknown
>
335 // CHECK-INST
: sqdecd z0.d
, pow2
336 // CHECK-ENCODING
: [0x00,0xc8,0xe0,0x04]
337 // CHECK-ERROR
: instruction requires
: sve
or sme
338 // CHECK-UNKNOWN
: 04e0c800
<unknown
>