1 // RUN
: not llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sme2
2>&1 < %s | FileCheck
%s
3 // --------------------------------------------------------------------------//
6 sqrshr z0.
b, {z0.s-z4.s
}, #32
7 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: invalid number of vectors
8 // CHECK-NEXT
: sqrshr z0.
b, {z0.s-z4.s
}, #32
9 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
11 sqrshr z0.h
, {z10.s-z12.s
}, #15
12 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
13 // CHECK-NEXT
: sqrshr z0.h
, {z10.s-z12.s
}, #15
14 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
16 sqrshr z0.h
, {z1.d-z4.d
}, #1
17 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: Invalid vector list
, expected list with
4 consecutive SVE vectors
, where the first vector is
a multiple of
4 and with matching element types
18 // CHECK-NEXT
: sqrshr z0.h
, {z1.d-z4.d
}, #1
19 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
21 sqrshr z0.h
, {z1.s-z2.s
}, #1
22 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: Invalid vector list
, expected list with
2 consecutive SVE vectors
, where the first vector is
a multiple of
2 and with matching element types
23 // CHECK-NEXT
: sqrshr z0.h
, {z1.s-z2.s
}, #1
24 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
26 // --------------------------------------------------------------------------//
29 sqrshr z31.h
, {z28.d-z31.d
}, #65
30 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: immediate must
be an integer in range
[1, 64].
31 // CHECK-NEXT
: sqrshr z31.h
, {z28.d-z31.d
}, #65
32 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
34 sqrshr z31.h
, {z28.s-z29.s
}, #0
35 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: immediate must
be an integer in range
[1, 16].
36 // CHECK-NEXT
: sqrshr z31.h
, {z28.s-z29.s
}, #0
37 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
39 sqrshr z31.
b, {z28.s-z31.s
}, #33
40 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: immediate must
be an integer in range
[1, 32].
41 // CHECK-NEXT
: sqrshr z31.
b, {z28.s-z31.s
}, #33
42 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
44 // --------------------------------------------------------------------------//
45 // Invalid Register Suffix
47 sqrshr z23.s
, {z12.s-z15.s
}, #15
48 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: invalid element width
49 // CHECK-NEXT
: sqrshr z23.s
, {z12.s-z15.s
}, #15
50 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
52 sqrshr z23.
b, {z12.d-z15.d
}, #15
53 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
54 // CHECK-NEXT
: sqrshr z23.
b, {z12.d-z15.d
}, #15
55 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}: