[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / MC / AArch64 / SVE / mov.s
blob5704e50c941a55b1615bff3954aceee9e37c554b
1 // RUN: llvm-mc -triple=aarch64 -show-encoding -mattr=+sve < %s \
2 // RUN: | FileCheck %s --check-prefixes=CHECK-ENCODING,CHECK-INST
3 // RUN: not llvm-mc -triple=aarch64 -show-encoding < %s 2>&1 \
4 // RUN: | FileCheck %s --check-prefix=CHECK-ERROR
5 // RUN: llvm-mc -triple=aarch64 -filetype=obj -mattr=+sve < %s \
6 // RUN: | llvm-objdump -d -mattr=+sve - | FileCheck %s --check-prefix=CHECK-INST
7 // RUN: llvm-mc -triple=aarch64 -filetype=obj -mattr=+sve < %s \
8 // RUN: | llvm-objdump -d - | FileCheck %s --check-prefix=CHECK-UNKNOWN
10 mov z0.b, w0
11 // CHECK-INST: mov z0.b, w0
12 // CHECK-ENCODING: [0x00,0x38,0x20,0x05]
13 // CHECK-ERROR: instruction requires: sve
14 // CHECK-UNKNOWN: 00 38 20 05 <unknown>
16 mov z0.h, w0
17 // CHECK-INST: mov z0.h, w0
18 // CHECK-ENCODING: [0x00,0x38,0x60,0x05]
19 // CHECK-ERROR: instruction requires: sve
20 // CHECK-UNKNOWN: 00 38 60 05 <unknown>
22 mov z0.s, w0
23 // CHECK-INST: mov z0.s, w0
24 // CHECK-ENCODING: [0x00,0x38,0xa0,0x05]
25 // CHECK-ERROR: instruction requires: sve
26 // CHECK-UNKNOWN: 00 38 a0 05 <unknown>
28 mov z0.d, x0
29 // CHECK-INST: mov z0.d, x0
30 // CHECK-ENCODING: [0x00,0x38,0xe0,0x05]
31 // CHECK-ERROR: instruction requires: sve
32 // CHECK-UNKNOWN: 00 38 e0 05 <unknown>
34 mov z31.h, wsp
35 // CHECK-INST: mov z31.h, wsp
36 // CHECK-ENCODING: [0xff,0x3b,0x60,0x05]
37 // CHECK-ERROR: instruction requires: sve
38 // CHECK-UNKNOWN: ff 3b 60 05 <unknown>
40 mov z31.s, wsp
41 // CHECK-INST: mov z31.s, wsp
42 // CHECK-ENCODING: [0xff,0x3b,0xa0,0x05]
43 // CHECK-ERROR: instruction requires: sve
44 // CHECK-UNKNOWN: ff 3b a0 05 <unknown>
46 mov z31.d, sp
47 // CHECK-INST: mov z31.d, sp
48 // CHECK-ENCODING: [0xff,0x3b,0xe0,0x05]
49 // CHECK-ERROR: instruction requires: sve
50 // CHECK-UNKNOWN: ff 3b e0 05 <unknown>
52 mov z31.b, wsp
53 // CHECK-INST: mov z31.b, wsp
54 // CHECK-ENCODING: [0xff,0x3b,0x20,0x05]
55 // CHECK-ERROR: instruction requires: sve
56 // CHECK-UNKNOWN: ff 3b 20 05 <unknown>
58 mov z0.d, z0.d
59 // CHECK-INST: mov z0.d, z0.d
60 // CHECK-ENCODING: [0x00,0x30,0x60,0x04]
61 // CHECK-ERROR: instruction requires: sve
62 // CHECK-UNKNOWN: 00 30 60 04 <unknown>
64 mov z31.d, z0.d
65 // CHECK-INST: mov z31.d, z0.d
66 // CHECK-ENCODING: [0x1f,0x30,0x60,0x04]
67 // CHECK-ERROR: instruction requires: sve
68 // CHECK-UNKNOWN: 1f 30 60 04 <unknown>
70 mov z5.b, #-128
71 // CHECK-INST: mov z5.b, #-128
72 // CHECK-ENCODING: [0x05,0xd0,0x38,0x25]
73 // CHECK-ERROR: instruction requires: sve
74 // CHECK-UNKNOWN: 05 d0 38 25 <unknown>
76 mov z5.b, #127
77 // CHECK-INST: mov z5.b, #127
78 // CHECK-ENCODING: [0xe5,0xcf,0x38,0x25]
79 // CHECK-ERROR: instruction requires: sve
80 // CHECK-UNKNOWN: e5 cf 38 25 <unknown>
82 mov z5.b, #255
83 // CHECK-INST: mov z5.b, #-1
84 // CHECK-ENCODING: [0xe5,0xdf,0x38,0x25]
85 // CHECK-ERROR: instruction requires: sve
86 // CHECK-UNKNOWN: e5 df 38 25 <unknown>
88 mov z21.h, #-128
89 // CHECK-INST: mov z21.h, #-128
90 // CHECK-ENCODING: [0x15,0xd0,0x78,0x25]
91 // CHECK-ERROR: instruction requires: sve
92 // CHECK-UNKNOWN: 15 d0 78 25 <unknown>
94 mov z21.h, #-128, lsl #8
95 // CHECK-INST: mov z21.h, #-32768
96 // CHECK-ENCODING: [0x15,0xf0,0x78,0x25]
97 // CHECK-ERROR: instruction requires: sve
98 // CHECK-UNKNOWN: 15 f0 78 25 <unknown>
100 mov z21.h, #-32768
101 // CHECK-INST: mov z21.h, #-32768
102 // CHECK-ENCODING: [0x15,0xf0,0x78,0x25]
103 // CHECK-ERROR: instruction requires: sve
104 // CHECK-UNKNOWN: 15 f0 78 25 <unknown>
106 mov z21.h, #127
107 // CHECK-INST: mov z21.h, #127
108 // CHECK-ENCODING: [0xf5,0xcf,0x78,0x25]
109 // CHECK-ERROR: instruction requires: sve
110 // CHECK-UNKNOWN: f5 cf 78 25 <unknown>
112 mov z21.h, #127, lsl #8
113 // CHECK-INST: mov z21.h, #32512
114 // CHECK-ENCODING: [0xf5,0xef,0x78,0x25]
115 // CHECK-ERROR: instruction requires: sve
116 // CHECK-UNKNOWN: f5 ef 78 25 <unknown>
118 mov z21.h, #32512
119 // CHECK-INST: mov z21.h, #32512
120 // CHECK-ENCODING: [0xf5,0xef,0x78,0x25]
121 // CHECK-ERROR: instruction requires: sve
122 // CHECK-UNKNOWN: f5 ef 78 25 <unknown>
124 mov z21.s, #-128
125 // CHECK-INST: mov z21.s, #-128
126 // CHECK-ENCODING: [0x15,0xd0,0xb8,0x25]
127 // CHECK-ERROR: instruction requires: sve
128 // CHECK-UNKNOWN: 15 d0 b8 25 <unknown>
130 mov z21.s, #-128, lsl #8
131 // CHECK-INST: mov z21.s, #-32768
132 // CHECK-ENCODING: [0x15,0xf0,0xb8,0x25]
133 // CHECK-ERROR: instruction requires: sve
134 // CHECK-UNKNOWN: 15 f0 b8 25 <unknown>
136 mov z21.s, #-32768
137 // CHECK-INST: mov z21.s, #-32768
138 // CHECK-ENCODING: [0x15,0xf0,0xb8,0x25]
139 // CHECK-ERROR: instruction requires: sve
140 // CHECK-UNKNOWN: 15 f0 b8 25 <unknown>
142 mov z21.s, #127
143 // CHECK-INST: mov z21.s, #127
144 // CHECK-ENCODING: [0xf5,0xcf,0xb8,0x25]
145 // CHECK-ERROR: instruction requires: sve
146 // CHECK-UNKNOWN: f5 cf b8 25 <unknown>
148 mov z21.s, #127, lsl #8
149 // CHECK-INST: mov z21.s, #32512
150 // CHECK-ENCODING: [0xf5,0xef,0xb8,0x25]
151 // CHECK-ERROR: instruction requires: sve
152 // CHECK-UNKNOWN: f5 ef b8 25 <unknown>
154 mov z21.s, #32512
155 // CHECK-INST: mov z21.s, #32512
156 // CHECK-ENCODING: [0xf5,0xef,0xb8,0x25]
157 // CHECK-ERROR: instruction requires: sve
158 // CHECK-UNKNOWN: f5 ef b8 25 <unknown>
160 mov z21.d, #-128
161 // CHECK-INST: mov z21.d, #-128
162 // CHECK-ENCODING: [0x15,0xd0,0xf8,0x25]
163 // CHECK-ERROR: instruction requires: sve
164 // CHECK-UNKNOWN: 15 d0 f8 25 <unknown>
166 mov z21.d, #-128, lsl #8
167 // CHECK-INST: mov z21.d, #-32768
168 // CHECK-ENCODING: [0x15,0xf0,0xf8,0x25]
169 // CHECK-ERROR: instruction requires: sve
170 // CHECK-UNKNOWN: 15 f0 f8 25 <unknown>
172 mov z21.d, #-32768
173 // CHECK-INST: mov z21.d, #-32768
174 // CHECK-ENCODING: [0x15,0xf0,0xf8,0x25]
175 // CHECK-ERROR: instruction requires: sve
176 // CHECK-UNKNOWN: 15 f0 f8 25 <unknown>
178 mov z21.d, #127
179 // CHECK-INST: mov z21.d, #127
180 // CHECK-ENCODING: [0xf5,0xcf,0xf8,0x25]
181 // CHECK-ERROR: instruction requires: sve
182 // CHECK-UNKNOWN: f5 cf f8 25 <unknown>
184 mov z21.d, #127, lsl #8
185 // CHECK-INST: mov z21.d, #32512
186 // CHECK-ENCODING: [0xf5,0xef,0xf8,0x25]
187 // CHECK-ERROR: instruction requires: sve
188 // CHECK-UNKNOWN: f5 ef f8 25 <unknown>
190 mov z21.d, #32512
191 // CHECK-INST: mov z21.d, #32512
192 // CHECK-ENCODING: [0xf5,0xef,0xf8,0x25]
193 // CHECK-ERROR: instruction requires: sve
194 // CHECK-UNKNOWN: f5 ef f8 25 <unknown>
196 mov z0.h, #32768
197 // CHECK-INST: mov z0.h, #-32768
198 // CHECK-ENCODING: [0x00,0xf0,0x78,0x25]
199 // CHECK-ERROR: instruction requires: sve
200 // CHECK-UNKNOWN: 00 f0 78 25 <unknown>
202 mov z0.h, #65280
203 // CHECK-INST: mov z0.h, #-256
204 // CHECK-ENCODING: [0xe0,0xff,0x78,0x25]
205 // CHECK-ERROR: instruction requires: sve
206 // CHECK-UNKNOWN: e0 ff 78 25 <unknown>
208 mov z0.s, #-32769
209 // CHECK-INST: mov z0.s, #0xffff7fff
210 // CHECK-ENCODING: [0xc0,0x83,0xc0,0x05]
211 // CHECK-ERROR: instruction requires: sve
212 // CHECK-UNKNOWN: c0 83 c0 05 <unknown>
214 mov z0.s, #32768
215 // CHECK-INST: mov z0.s, #32768
216 // CHECK-ENCODING: [0x00,0x88,0xc0,0x05]
217 // CHECK-ERROR: instruction requires: sve
218 // CHECK-UNKNOWN: 00 88 c0 05 <unknown>
220 mov z0.d, #-32769
221 // CHECK-INST: mov z0.d, #0xffffffffffff7fff
222 // CHECK-ENCODING: [0xc0,0x87,0xc3,0x05]
223 // CHECK-ERROR: instruction requires: sve
224 // CHECK-UNKNOWN: c0 87 c3 05 <unknown>
226 mov z0.d, #32768
227 // CHECK-INST: mov z0.d, #32768
228 // CHECK-ENCODING: [0x00,0x88,0xc3,0x05]
229 // CHECK-ERROR: instruction requires: sve
230 // CHECK-UNKNOWN: 00 88 c3 05 <unknown>
232 mov z0.d, #0xe0000000000003ff
233 // CHECK-INST: mov z0.d, #0xe0000000000003ff
234 // CHECK-ENCODING: [0x80,0x19,0xc2,0x05]
235 // CHECK-ERROR: instruction requires: sve
236 // CHECK-UNKNOWN: 80 19 c2 05 <unknown>
238 mov z5.b, p0/z, #-128
239 // CHECK-INST: mov z5.b, p0/z, #-128
240 // CHECK-ENCODING: [0x05,0x10,0x10,0x05]
241 // CHECK-ERROR: instruction requires: sve
242 // CHECK-UNKNOWN: 05 10 10 05 <unknown>
244 mov z5.b, p0/z, #127
245 // CHECK-INST: mov z5.b, p0/z, #127
246 // CHECK-ENCODING: [0xe5,0x0f,0x10,0x05]
247 // CHECK-ERROR: instruction requires: sve
248 // CHECK-UNKNOWN: e5 0f 10 05 <unknown>
250 mov z5.b, p0/z, #255
251 // CHECK-INST: mov z5.b, p0/z, #-1
252 // CHECK-ENCODING: [0xe5,0x1f,0x10,0x05]
253 // CHECK-ERROR: instruction requires: sve
254 // CHECK-UNKNOWN: e5 1f 10 05 <unknown>
256 mov z21.h, p0/z, #-128
257 // CHECK-INST: mov z21.h, p0/z, #-128
258 // CHECK-ENCODING: [0x15,0x10,0x50,0x05]
259 // CHECK-ERROR: instruction requires: sve
260 // CHECK-UNKNOWN: 15 10 50 05 <unknown>
262 mov z21.h, p0/z, #-128, lsl #8
263 // CHECK-INST: mov z21.h, p0/z, #-32768
264 // CHECK-ENCODING: [0x15,0x30,0x50,0x05]
265 // CHECK-ERROR: instruction requires: sve
266 // CHECK-UNKNOWN: 15 30 50 05 <unknown>
268 mov z21.h, p0/z, #-32768
269 // CHECK-INST: mov z21.h, p0/z, #-32768
270 // CHECK-ENCODING: [0x15,0x30,0x50,0x05]
271 // CHECK-ERROR: instruction requires: sve
272 // CHECK-UNKNOWN: 15 30 50 05 <unknown>
274 mov z21.h, p0/z, #127
275 // CHECK-INST: mov z21.h, p0/z, #127
276 // CHECK-ENCODING: [0xf5,0x0f,0x50,0x05]
277 // CHECK-ERROR: instruction requires: sve
278 // CHECK-UNKNOWN: f5 0f 50 05 <unknown>
280 mov z21.h, p0/z, #127, lsl #8
281 // CHECK-INST: mov z21.h, p0/z, #32512
282 // CHECK-ENCODING: [0xf5,0x2f,0x50,0x05]
283 // CHECK-ERROR: instruction requires: sve
284 // CHECK-UNKNOWN: f5 2f 50 05 <unknown>
286 mov z21.h, p0/z, #32512
287 // CHECK-INST: mov z21.h, p0/z, #32512
288 // CHECK-ENCODING: [0xf5,0x2f,0x50,0x05]
289 // CHECK-ERROR: instruction requires: sve
290 // CHECK-UNKNOWN: f5 2f 50 05 <unknown>
292 mov z21.s, p0/z, #-128
293 // CHECK-INST: mov z21.s, p0/z, #-128
294 // CHECK-ENCODING: [0x15,0x10,0x90,0x05]
295 // CHECK-ERROR: instruction requires: sve
296 // CHECK-UNKNOWN: 15 10 90 05 <unknown>
298 mov z21.s, p0/z, #-128, lsl #8
299 // CHECK-INST: mov z21.s, p0/z, #-32768
300 // CHECK-ENCODING: [0x15,0x30,0x90,0x05]
301 // CHECK-ERROR: instruction requires: sve
302 // CHECK-UNKNOWN: 15 30 90 05 <unknown>
304 mov z21.s, p0/z, #-32768
305 // CHECK-INST: mov z21.s, p0/z, #-32768
306 // CHECK-ENCODING: [0x15,0x30,0x90,0x05]
307 // CHECK-ERROR: instruction requires: sve
308 // CHECK-UNKNOWN: 15 30 90 05 <unknown>
310 mov z21.s, p0/z, #127
311 // CHECK-INST: mov z21.s, p0/z, #127
312 // CHECK-ENCODING: [0xf5,0x0f,0x90,0x05]
313 // CHECK-ERROR: instruction requires: sve
314 // CHECK-UNKNOWN: f5 0f 90 05 <unknown>
316 mov z21.s, p0/z, #127, lsl #8
317 // CHECK-INST: mov z21.s, p0/z, #32512
318 // CHECK-ENCODING: [0xf5,0x2f,0x90,0x05]
319 // CHECK-ERROR: instruction requires: sve
320 // CHECK-UNKNOWN: f5 2f 90 05 <unknown>
322 mov z21.s, p0/z, #32512
323 // CHECK-INST: mov z21.s, p0/z, #32512
324 // CHECK-ENCODING: [0xf5,0x2f,0x90,0x05]
325 // CHECK-ERROR: instruction requires: sve
326 // CHECK-UNKNOWN: f5 2f 90 05 <unknown>
328 mov z21.d, p0/z, #-128
329 // CHECK-INST: mov z21.d, p0/z, #-128
330 // CHECK-ENCODING: [0x15,0x10,0xd0,0x05]
331 // CHECK-ERROR: instruction requires: sve
332 // CHECK-UNKNOWN: 15 10 d0 05 <unknown>
334 mov z21.d, p0/z, #-128, lsl #8
335 // CHECK-INST: mov z21.d, p0/z, #-32768
336 // CHECK-ENCODING: [0x15,0x30,0xd0,0x05]
337 // CHECK-ERROR: instruction requires: sve
338 // CHECK-UNKNOWN: 15 30 d0 05 <unknown>
340 mov z21.d, p0/z, #-32768
341 // CHECK-INST: mov z21.d, p0/z, #-32768
342 // CHECK-ENCODING: [0x15,0x30,0xd0,0x05]
343 // CHECK-ERROR: instruction requires: sve
344 // CHECK-UNKNOWN: 15 30 d0 05 <unknown>
346 mov z21.d, p0/z, #127
347 // CHECK-INST: mov z21.d, p0/z, #127
348 // CHECK-ENCODING: [0xf5,0x0f,0xd0,0x05]
349 // CHECK-ERROR: instruction requires: sve
350 // CHECK-UNKNOWN: f5 0f d0 05 <unknown>
352 mov z21.d, p0/z, #127, lsl #8
353 // CHECK-INST: mov z21.d, p0/z, #32512
354 // CHECK-ENCODING: [0xf5,0x2f,0xd0,0x05]
355 // CHECK-ERROR: instruction requires: sve
356 // CHECK-UNKNOWN: f5 2f d0 05 <unknown>
358 mov z21.d, p0/z, #32512
359 // CHECK-INST: mov z21.d, p0/z, #32512
360 // CHECK-ENCODING: [0xf5,0x2f,0xd0,0x05]
361 // CHECK-ERROR: instruction requires: sve
362 // CHECK-UNKNOWN: f5 2f d0 05 <unknown>
365 // --------------------------------------------------------------------------//
366 // Tests for merging variant (/m) and testing the range of predicate (> 7)
367 // is allowed.
369 mov z5.b, p15/m, #-128
370 // CHECK-INST: mov z5.b, p15/m, #-128
371 // CHECK-ENCODING: [0x05,0x50,0x1f,0x05]
372 // CHECK-ERROR: instruction requires: sve
373 // CHECK-UNKNOWN: 05 50 1f 05 <unknown>
375 mov z21.h, p15/m, #-128
376 // CHECK-INST: mov z21.h, p15/m, #-128
377 // CHECK-ENCODING: [0x15,0x50,0x5f,0x05]
378 // CHECK-ERROR: instruction requires: sve
379 // CHECK-UNKNOWN: 15 50 5f 05 <unknown>
381 mov z21.h, p15/m, #-128, lsl #8
382 // CHECK-INST: mov z21.h, p15/m, #-32768
383 // CHECK-ENCODING: [0x15,0x70,0x5f,0x05]
384 // CHECK-ERROR: instruction requires: sve
385 // CHECK-UNKNOWN: 15 70 5f 05 <unknown>
387 mov z21.s, p15/m, #-128
388 // CHECK-INST: mov z21.s, p15/m, #-128
389 // CHECK-ENCODING: [0x15,0x50,0x9f,0x05]
390 // CHECK-ERROR: instruction requires: sve
391 // CHECK-UNKNOWN: 15 50 9f 05 <unknown>
393 mov z21.s, p15/m, #-128, lsl #8
394 // CHECK-INST: mov z21.s, p15/m, #-32768
395 // CHECK-ENCODING: [0x15,0x70,0x9f,0x05]
396 // CHECK-ERROR: instruction requires: sve
397 // CHECK-UNKNOWN: 15 70 9f 05 <unknown>
399 mov z21.d, p15/m, #-128
400 // CHECK-INST: mov z21.d, p15/m, #-128
401 // CHECK-ENCODING: [0x15,0x50,0xdf,0x05]
402 // CHECK-ERROR: instruction requires: sve
403 // CHECK-UNKNOWN: 15 50 df 05 <unknown>
405 mov z21.d, p15/m, #-128, lsl #8
406 // CHECK-INST: mov z21.d, p15/m, #-32768
407 // CHECK-ENCODING: [0x15,0x70,0xdf,0x05]
408 // CHECK-ERROR: instruction requires: sve
409 // CHECK-UNKNOWN: 15 70 df 05 <unknown>
411 // --------------------------------------------------------------------------//
412 // Tests for indexed variant
414 mov z0.b, z0.b[0]
415 // CHECK-INST: mov z0.b, b0
416 // CHECK-ENCODING: [0x00,0x20,0x21,0x05]
417 // CHECK-ERROR: instruction requires: sve
418 // CHECK-UNKNOWN: 00 20 21 05 <unknown>
420 mov z0.h, z0.h[0]
421 // CHECK-INST: mov z0.h, h0
422 // CHECK-ENCODING: [0x00,0x20,0x22,0x05]
423 // CHECK-ERROR: instruction requires: sve
424 // CHECK-UNKNOWN: 00 20 22 05 <unknown>
426 mov z0.s, z0.s[0]
427 // CHECK-INST: mov z0.s, s0
428 // CHECK-ENCODING: [0x00,0x20,0x24,0x05]
429 // CHECK-ERROR: instruction requires: sve
430 // CHECK-UNKNOWN: 00 20 24 05 <unknown>
432 mov z0.d, z0.d[0]
433 // CHECK-INST: mov z0.d, d0
434 // CHECK-ENCODING: [0x00,0x20,0x28,0x05]
435 // CHECK-ERROR: instruction requires: sve
436 // CHECK-UNKNOWN: 00 20 28 05 <unknown>
438 mov z0.q, z0.q[0]
439 // CHECK-INST: mov z0.q, q0
440 // CHECK-ENCODING: [0x00,0x20,0x30,0x05]
441 // CHECK-ERROR: instruction requires: sve
442 // CHECK-UNKNOWN: 00 20 30 05 <unknown>
444 mov z0.b, b0
445 // CHECK-INST: mov z0.b, b0
446 // CHECK-ENCODING: [0x00,0x20,0x21,0x05]
447 // CHECK-ERROR: instruction requires: sve
448 // CHECK-UNKNOWN: 00 20 21 05 <unknown>
450 mov z0.h, h0
451 // CHECK-INST: mov z0.h, h0
452 // CHECK-ENCODING: [0x00,0x20,0x22,0x05]
453 // CHECK-ERROR: instruction requires: sve
454 // CHECK-UNKNOWN: 00 20 22 05 <unknown>
456 mov z0.s, s0
457 // CHECK-INST: mov z0.s, s0
458 // CHECK-ENCODING: [0x00,0x20,0x24,0x05]
459 // CHECK-ERROR: instruction requires: sve
460 // CHECK-UNKNOWN: 00 20 24 05 <unknown>
462 mov z0.d, d0
463 // CHECK-INST: mov z0.d, d0
464 // CHECK-ENCODING: [0x00,0x20,0x28,0x05]
465 // CHECK-ERROR: instruction requires: sve
466 // CHECK-UNKNOWN: 00 20 28 05 <unknown>
468 mov z0.q, q0
469 // CHECK-INST: mov z0.q, q0
470 // CHECK-ENCODING: [0x00,0x20,0x30,0x05]
471 // CHECK-ERROR: instruction requires: sve
472 // CHECK-UNKNOWN: 00 20 30 05 <unknown>
474 mov z31.b, z31.b[63]
475 // CHECK-INST: mov z31.b, z31.b[63]
476 // CHECK-ENCODING: [0xff,0x23,0xff,0x05]
477 // CHECK-ERROR: instruction requires: sve
478 // CHECK-UNKNOWN: ff 23 ff 05 <unknown>
480 mov z31.h, z31.h[31]
481 // CHECK-INST: mov z31.h, z31.h[31]
482 // CHECK-ENCODING: [0xff,0x23,0xfe,0x05]
483 // CHECK-ERROR: instruction requires: sve
484 // CHECK-UNKNOWN: ff 23 fe 05 <unknown>
486 mov z31.s, z31.s[15]
487 // CHECK-INST: mov z31.s, z31.s[15]
488 // CHECK-ENCODING: [0xff,0x23,0xfc,0x05]
489 // CHECK-ERROR: instruction requires: sve
490 // CHECK-UNKNOWN: ff 23 fc 05 <unknown>
492 mov z31.d, z31.d[7]
493 // CHECK-INST: mov z31.d, z31.d[7]
494 // CHECK-ENCODING: [0xff,0x23,0xf8,0x05]
495 // CHECK-ERROR: instruction requires: sve
496 // CHECK-UNKNOWN: ff 23 f8 05 <unknown>
498 mov z5.q, z17.q[3]
499 // CHECK-INST: mov z5.q, z17.q[3]
500 // CHECK-ENCODING: [0x25,0x22,0xf0,0x05]
501 // CHECK-ERROR: instruction requires: sve
502 // CHECK-UNKNOWN: 25 22 f0 05 <unknown>
505 // --------------------------------------------------------------------------//
506 // Tests for predicated copy of SIMD/FP registers.
508 mov z0.b, p0/m, w0
509 // CHECK-INST: mov z0.b, p0/m, w0
510 // CHECK-ENCODING: [0x00,0xa0,0x28,0x05]
511 // CHECK-ERROR: instruction requires: sve
512 // CHECK-UNKNOWN: 00 a0 28 05 <unknown>
514 mov z0.h, p0/m, w0
515 // CHECK-INST: mov z0.h, p0/m, w0
516 // CHECK-ENCODING: [0x00,0xa0,0x68,0x05]
517 // CHECK-ERROR: instruction requires: sve
518 // CHECK-UNKNOWN: 00 a0 68 05 <unknown>
520 mov z0.s, p0/m, w0
521 // CHECK-INST: mov z0.s, p0/m, w0
522 // CHECK-ENCODING: [0x00,0xa0,0xa8,0x05]
523 // CHECK-ERROR: instruction requires: sve
524 // CHECK-UNKNOWN: 00 a0 a8 05 <unknown>
526 mov z0.d, p0/m, x0
527 // CHECK-INST: mov z0.d, p0/m, x0
528 // CHECK-ENCODING: [0x00,0xa0,0xe8,0x05]
529 // CHECK-ERROR: instruction requires: sve
530 // CHECK-UNKNOWN: 00 a0 e8 05 <unknown>
532 mov z31.b, p7/m, wsp
533 // CHECK-INST: mov z31.b, p7/m, wsp
534 // CHECK-ENCODING: [0xff,0xbf,0x28,0x05]
535 // CHECK-ERROR: instruction requires: sve
536 // CHECK-UNKNOWN: ff bf 28 05 <unknown>
538 mov z31.h, p7/m, wsp
539 // CHECK-INST: mov z31.h, p7/m, wsp
540 // CHECK-ENCODING: [0xff,0xbf,0x68,0x05]
541 // CHECK-ERROR: instruction requires: sve
542 // CHECK-UNKNOWN: ff bf 68 05 <unknown>
544 mov z31.s, p7/m, wsp
545 // CHECK-INST: mov z31.s, p7/m, wsp
546 // CHECK-ENCODING: [0xff,0xbf,0xa8,0x05]
547 // CHECK-ERROR: instruction requires: sve
548 // CHECK-UNKNOWN: ff bf a8 05 <unknown>
550 mov z31.d, p7/m, sp
551 // CHECK-INST: mov z31.d, p7/m, sp
552 // CHECK-ENCODING: [0xff,0xbf,0xe8,0x05]
553 // CHECK-ERROR: instruction requires: sve
554 // CHECK-UNKNOWN: ff bf e8 05 <unknown>
556 mov z0.b, p0/m, b0
557 // CHECK-INST: mov z0.b, p0/m, b0
558 // CHECK-ENCODING: [0x00,0x80,0x20,0x05]
559 // CHECK-ERROR: instruction requires: sve
560 // CHECK-UNKNOWN: 00 80 20 05 <unknown>
562 mov z31.b, p7/m, b31
563 // CHECK-INST: mov z31.b, p7/m, b31
564 // CHECK-ENCODING: [0xff,0x9f,0x20,0x05]
565 // CHECK-ERROR: instruction requires: sve
566 // CHECK-UNKNOWN: ff 9f 20 05 <unknown>
568 mov z0.h, p0/m, h0
569 // CHECK-INST: mov z0.h, p0/m, h0
570 // CHECK-ENCODING: [0x00,0x80,0x60,0x05]
571 // CHECK-ERROR: instruction requires: sve
572 // CHECK-UNKNOWN: 00 80 60 05 <unknown>
574 mov z31.h, p7/m, h31
575 // CHECK-INST: mov z31.h, p7/m, h31
576 // CHECK-ENCODING: [0xff,0x9f,0x60,0x05]
577 // CHECK-ERROR: instruction requires: sve
578 // CHECK-UNKNOWN: ff 9f 60 05 <unknown>
580 mov z0.s, p0/m, s0
581 // CHECK-INST: mov z0.s, p0/m, s0
582 // CHECK-ENCODING: [0x00,0x80,0xa0,0x05]
583 // CHECK-ERROR: instruction requires: sve
584 // CHECK-UNKNOWN: 00 80 a0 05 <unknown>
586 mov z31.s, p7/m, s31
587 // CHECK-INST: mov z31.s, p7/m, s31
588 // CHECK-ENCODING: [0xff,0x9f,0xa0,0x05]
589 // CHECK-ERROR: instruction requires: sve
590 // CHECK-UNKNOWN: ff 9f a0 05 <unknown>
592 mov z0.d, p0/m, d0
593 // CHECK-INST: mov z0.d, p0/m, d0
594 // CHECK-ENCODING: [0x00,0x80,0xe0,0x05]
595 // CHECK-ERROR: instruction requires: sve
596 // CHECK-UNKNOWN: 00 80 e0 05 <unknown>
598 mov z31.d, p7/m, d31
599 // CHECK-INST: mov z31.d, p7/m, d31
600 // CHECK-ENCODING: [0xff,0x9f,0xe0,0x05]
601 // CHECK-ERROR: instruction requires: sve
602 // CHECK-UNKNOWN: ff 9f e0 05 <unknown>
604 mov p0.b, p0/m, p0.b
605 // CHECK-INST: mov p0.b, p0/m, p0.b
606 // CHECK-ENCODING: [0x10,0x42,0x00,0x25]
607 // CHECK-ERROR: instruction requires: sve
608 // CHECK-UNKNOWN: 10 42 00 25 <unknown>
610 mov p15.b, p15/m, p15.b
611 // CHECK-INST: mov p15.b, p15/m, p15.b
612 // CHECK-ENCODING: [0xff,0x7f,0x0f,0x25]
613 // CHECK-ERROR: instruction requires: sve
614 // CHECK-UNKNOWN: ff 7f 0f 25 <unknown>
616 mov z31.b, p15/m, z31.b
617 // CHECK-INST: mov z31.b, p15/m, z31.b
618 // CHECK-ENCODING: [0xff,0xff,0x3f,0x05]
619 // CHECK-ERROR: instruction requires: sve
620 // CHECK-UNKNOWN: ff ff 3f 05 <unknown>
622 mov z31.h, p15/m, z31.h
623 // CHECK-INST: mov z31.h, p15/m, z31.h
624 // CHECK-ENCODING: [0xff,0xff,0x7f,0x05]
625 // CHECK-ERROR: instruction requires: sve
626 // CHECK-UNKNOWN: ff ff 7f 05 <unknown>
628 mov z31.s, p15/m, z31.s
629 // CHECK-INST: mov z31.s, p15/m, z31.s
630 // CHECK-ENCODING: [0xff,0xff,0xbf,0x05]
631 // CHECK-ERROR: instruction requires: sve
632 // CHECK-UNKNOWN: ff ff bf 05 <unknown>
634 mov z31.d, p15/m, z31.d
635 // CHECK-INST: mov z31.d, p15/m, z31.d
636 // CHECK-ENCODING: [0xff,0xff,0xff,0x05]
637 // CHECK-ERROR: instruction requires: sve
638 // CHECK-UNKNOWN: ff ff ff 05 <unknown>
640 mov p0.b, p0.b
641 // CHECK-INST: mov p0.b, p0.b
642 // CHECK-ENCODING: [0x00,0x40,0x80,0x25]
643 // CHECK-ERROR: instruction requires: sve
644 // CHECK-UNKNOWN: 00 40 80 25 <unknown>
646 mov p15.b, p15.b
647 // CHECK-INST: mov p15.b, p15.b
648 // CHECK-ENCODING: [0xef,0x7d,0x8f,0x25]
649 // CHECK-ERROR: instruction requires: sve
650 // CHECK-UNKNOWN: ef 7d 8f 25 <unknown>
652 mov p0.b, p0/z, p0.b
653 // CHECK-INST: mov p0.b, p0/z, p0.b
654 // CHECK-ENCODING: [0x00,0x40,0x00,0x25]
655 // CHECK-ERROR: instruction requires: sve
656 // CHECK-UNKNOWN: 00 40 00 25 <unknown>
658 mov p15.b, p15/z, p15.b
659 // CHECK-INST: mov p15.b, p15/z, p15.b
660 // CHECK-ENCODING: [0xef,0x7d,0x0f,0x25]
661 // CHECK-ERROR: instruction requires: sve
662 // CHECK-UNKNOWN: ef 7d 0f 25 <unknown>
665 // --------------------------------------------------------------------------//
666 // Test compatibility with MOVPRFX instruction.
668 movprfx z31.d, p7/z, z6.d
669 // CHECK-INST: movprfx z31.d, p7/z, z6.d
670 // CHECK-ENCODING: [0xdf,0x3c,0xd0,0x04]
671 // CHECK-ERROR: instruction requires: sve
672 // CHECK-UNKNOWN: df 3c d0 04 <unknown>
674 mov z31.d, p7/m, sp
675 // CHECK-INST: mov z31.d, p7/m, sp
676 // CHECK-ENCODING: [0xff,0xbf,0xe8,0x05]
677 // CHECK-ERROR: instruction requires: sve
678 // CHECK-UNKNOWN: ff bf e8 05 <unknown>
680 movprfx z31, z6
681 // CHECK-INST: movprfx z31, z6
682 // CHECK-ENCODING: [0xdf,0xbc,0x20,0x04]
683 // CHECK-ERROR: instruction requires: sve
684 // CHECK-UNKNOWN: df bc 20 04 <unknown>
686 mov z31.d, p7/m, sp
687 // CHECK-INST: mov z31.d, p7/m, sp
688 // CHECK-ENCODING: [0xff,0xbf,0xe8,0x05]
689 // CHECK-ERROR: instruction requires: sve
690 // CHECK-UNKNOWN: ff bf e8 05 <unknown>
692 movprfx z21.d, p7/z, z28.d
693 // CHECK-INST: movprfx z21.d, p7/z, z28.d
694 // CHECK-ENCODING: [0x95,0x3f,0xd0,0x04]
695 // CHECK-ERROR: instruction requires: sve
696 // CHECK-UNKNOWN: 95 3f d0 04 <unknown>
698 mov z21.d, p7/m, #-128, lsl #8
699 // CHECK-INST: mov z21.d, p7/m, #-32768
700 // CHECK-ENCODING: [0x15,0x70,0xd7,0x05]
701 // CHECK-ERROR: instruction requires: sve
702 // CHECK-UNKNOWN: 15 70 d7 05 <unknown>
704 movprfx z21, z28
705 // CHECK-INST: movprfx z21, z28
706 // CHECK-ENCODING: [0x95,0xbf,0x20,0x04]
707 // CHECK-ERROR: instruction requires: sve
708 // CHECK-UNKNOWN: 95 bf 20 04 <unknown>
710 mov z21.d, p15/m, #-128, lsl #8
711 // CHECK-INST: mov z21.d, p15/m, #-32768
712 // CHECK-ENCODING: [0x15,0x70,0xdf,0x05]
713 // CHECK-ERROR: instruction requires: sve
714 // CHECK-UNKNOWN: 15 70 df 05 <unknown>
716 movprfx z4.d, p7/z, z6.d
717 // CHECK-INST: movprfx z4.d, p7/z, z6.d
718 // CHECK-ENCODING: [0xc4,0x3c,0xd0,0x04]
719 // CHECK-ERROR: instruction requires: sve
720 // CHECK-UNKNOWN: c4 3c d0 04 <unknown>
722 mov z4.d, p7/m, d31
723 // CHECK-INST: mov z4.d, p7/m, d31
724 // CHECK-ENCODING: [0xe4,0x9f,0xe0,0x05]
725 // CHECK-ERROR: instruction requires: sve
726 // CHECK-UNKNOWN: e4 9f e0 05 <unknown>
728 movprfx z4, z6
729 // CHECK-INST: movprfx z4, z6
730 // CHECK-ENCODING: [0xc4,0xbc,0x20,0x04]
731 // CHECK-ERROR: instruction requires: sve
732 // CHECK-UNKNOWN: c4 bc 20 04 <unknown>
734 mov z4.d, p7/m, d31
735 // CHECK-INST: mov z4.d, p7/m, d31
736 // CHECK-ENCODING: [0xe4,0x9f,0xe0,0x05]
737 // CHECK-ERROR: instruction requires: sve
738 // CHECK-UNKNOWN: e4 9f e0 05 <unknown>