1 // RUN
: llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sme2
< %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
=+sme2
< %s \
6 // RUN
: | llvm-objdump
-d
--mattr
=+sme2
- | FileCheck
%s
--check-prefix
=CHECK-INST
7 // RUN
: llvm-mc
-triple
=aarch64
-filetype
=obj
-mattr
=+sme2
< %s \
8 // RUN
: | llvm-objdump
-d
--mattr
=-sme2
- | FileCheck
%s
--check-prefix
=CHECK-UNKNOWN
9 // RUN
: llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sme2
< %s \
10 // RUN
: | sed
'/.text/d' | sed
's/.*encoding: //g' \
11 // RUN
: | llvm-mc
-triple
=aarch64
-mattr
=+sme2
-disassemble
-show-encoding \
12 // RUN
: | FileCheck
%s
--check-prefixes
=CHECK-ENCODING
,CHECK-INST
15 uqcvt z0.h
, {z0.s
, z1.s
} // 11000001-00100011-11100000-00100000
16 // CHECK-INST
: uqcvt z0.h
, { z0.s
, z1.s
}
17 // CHECK-ENCODING
: [0x20,0xe0,0x23,0xc1]
18 // CHECK-ERROR
: instruction requires
: sme2
19 // CHECK-UNKNOWN
: c123e020
<unknown
>
21 uqcvt z21.h
, {z10.s
, z11.s
} // 11000001-00100011-11100001-01110101
22 // CHECK-INST
: uqcvt z21.h
, { z10.s
, z11.s
}
23 // CHECK-ENCODING
: [0x75,0xe1,0x23,0xc1]
24 // CHECK-ERROR
: instruction requires
: sme2
25 // CHECK-UNKNOWN
: c123e175
<unknown
>
27 uqcvt z23.h
, {z12.s
, z13.s
} // 11000001-00100011-11100001-10110111
28 // CHECK-INST
: uqcvt z23.h
, { z12.s
, z13.s
}
29 // CHECK-ENCODING
: [0xb7,0xe1,0x23,0xc1]
30 // CHECK-ERROR
: instruction requires
: sme2
31 // CHECK-UNKNOWN
: c123e1b7
<unknown
>
33 uqcvt z31.h
, {z30.s
, z31.s
} // 11000001-00100011-11100011-11111111
34 // CHECK-INST
: uqcvt z31.h
, { z30.s
, z31.s
}
35 // CHECK-ENCODING
: [0xff,0xe3,0x23,0xc1]
36 // CHECK-ERROR
: instruction requires
: sme2
37 // CHECK-UNKNOWN
: c123e3ff
<unknown
>
40 uqcvt z0.
b, {z0.s
- z3.s
} // 11000001-00110011-11100000-00100000
41 // CHECK-INST
: uqcvt z0.
b, { z0.s
- z3.s
}
42 // CHECK-ENCODING
: [0x20,0xe0,0x33,0xc1]
43 // CHECK-ERROR
: instruction requires
: sme2
44 // CHECK-UNKNOWN
: c133e020
<unknown
>
46 uqcvt z21.
b, {z8.s
- z11.s
} // 11000001-00110011-11100001-00110101
47 // CHECK-INST
: uqcvt z21.
b, { z8.s
- z11.s
}
48 // CHECK-ENCODING
: [0x35,0xe1,0x33,0xc1]
49 // CHECK-ERROR
: instruction requires
: sme2
50 // CHECK-UNKNOWN
: c133e135
<unknown
>
52 uqcvt z23.
b, {z12.s
- z15.s
} // 11000001-00110011-11100001-10110111
53 // CHECK-INST
: uqcvt z23.
b, { z12.s
- z15.s
}
54 // CHECK-ENCODING
: [0xb7,0xe1,0x33,0xc1]
55 // CHECK-ERROR
: instruction requires
: sme2
56 // CHECK-UNKNOWN
: c133e1b7
<unknown
>
58 uqcvt z31.
b, {z28.s
- z31.s
} // 11000001-00110011-11100011-10111111
59 // CHECK-INST
: uqcvt z31.
b, { z28.s
- z31.s
}
60 // CHECK-ENCODING
: [0xbf,0xe3,0x33,0xc1]
61 // CHECK-ERROR
: instruction requires
: sme2
62 // CHECK-UNKNOWN
: c133e3bf
<unknown
>
65 uqcvt z0.h
, {z0.d
- z3.d
} // 11000001-10110011-11100000-00100000
66 // CHECK-INST
: uqcvt z0.h
, { z0.d
- z3.d
}
67 // CHECK-ENCODING
: [0x20,0xe0,0xb3,0xc1]
68 // CHECK-ERROR
: instruction requires
: sme2
69 // CHECK-UNKNOWN
: c1b3e020
<unknown
>
71 uqcvt z21.h
, {z8.d
- z11.d
} // 11000001-10110011-11100001-00110101
72 // CHECK-INST
: uqcvt z21.h
, { z8.d
- z11.d
}
73 // CHECK-ENCODING
: [0x35,0xe1,0xb3,0xc1]
74 // CHECK-ERROR
: instruction requires
: sme2
75 // CHECK-UNKNOWN
: c1b3e135
<unknown
>
77 uqcvt z23.h
, {z12.d
- z15.d
} // 11000001-10110011-11100001-10110111
78 // CHECK-INST
: uqcvt z23.h
, { z12.d
- z15.d
}
79 // CHECK-ENCODING
: [0xb7,0xe1,0xb3,0xc1]
80 // CHECK-ERROR
: instruction requires
: sme2
81 // CHECK-UNKNOWN
: c1b3e1b7
<unknown
>
83 uqcvt z31.h
, {z28.d
- z31.d
} // 11000001-10110011-11100011-10111111
84 // CHECK-INST
: uqcvt z31.h
, { z28.d
- z31.d
}
85 // CHECK-ENCODING
: [0xbf,0xe3,0xb3,0xc1]
86 // CHECK-ERROR
: instruction requires
: sme2
87 // CHECK-UNKNOWN
: c1b3e3bf
<unknown
>