[Frontend] Remove unused includes (NFC) (#116927)
[llvm-project.git] / llvm / test / MC / AArch64 / SME2p2 / fmop4as-fp64-non-widening.s
blobb0ad2984ad5acd10f4044bdb77515d6a2814501c
2 // RUN: llvm-mc -triple=aarch64 -show-encoding -mattr=+sme2p2,+sme-f64f64 < %s \
3 // RUN: | FileCheck %s --check-prefixes=CHECK-ENCODING,CHECK-INST
4 // RUN: not llvm-mc -triple=aarch64 -show-encoding < %s 2>&1 \
5 // RUN: | FileCheck %s --check-prefix=CHECK-ERROR
6 // RUN: llvm-mc -triple=aarch64 -filetype=obj -mattr=+sme2p2,+sme-f64f64 < %s \
7 // RUN: | llvm-objdump -d --mattr=+sme2p2,+sme-f64f64 - | FileCheck %s --check-prefix=CHECK-INST
8 // RUN: llvm-mc -triple=aarch64 -filetype=obj -mattr=+sme2p2,+sme-f64f64 < %s \
9 // RUN: | llvm-objdump -d --mattr=-sme2p2 - | FileCheck %s --check-prefix=CHECK-UNKNOWN
10 // Disassemble encoding and check the re-encoding (-show-encoding) matches.
11 // RUN: llvm-mc -triple=aarch64 -show-encoding -mattr=+sme2p2,+sme-f64f64 < %s \
12 // RUN: | sed '/.text/d' | sed 's/.*encoding: //g' \
13 // RUN: | llvm-mc -triple=aarch64 -mattr=+sme2p2,+sme-f64f64 -disassemble -show-encoding \
14 // RUN: | FileCheck %s --check-prefixes=CHECK-ENCODING,CHECK-INST
17 // FMOP4A
19 // Single vectors
21 fmop4a za0.d, z0.d, z16.d // 10000000-11000000-00000000-00001000
22 // CHECK-INST: fmop4a za0.d, z0.d, z16.d
23 // CHECK-ENCODING: [0x08,0x00,0xc0,0x80]
24 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
25 // CHECK-UNKNOWN: 80c00008 <unknown>
27 fmop4a za5.d, z10.d, z20.d // 10000000-11000100-00000001-01001101
28 // CHECK-INST: fmop4a za5.d, z10.d, z20.d
29 // CHECK-ENCODING: [0x4d,0x01,0xc4,0x80]
30 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
31 // CHECK-UNKNOWN: 80c4014d <unknown>
33 fmop4a za7.d, z14.d, z30.d // 10000000-11001110-00000001-11001111
34 // CHECK-INST: fmop4a za7.d, z14.d, z30.d
35 // CHECK-ENCODING: [0xcf,0x01,0xce,0x80]
36 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
37 // CHECK-UNKNOWN: 80ce01cf <unknown>
39 // Single and multiple vectors
41 fmop4a za0.d, z0.d, {z16.d-z17.d} // 10000000-11010000-00000000-00001000
42 // CHECK-INST: fmop4a za0.d, z0.d, { z16.d, z17.d }
43 // CHECK-ENCODING: [0x08,0x00,0xd0,0x80]
44 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
45 // CHECK-UNKNOWN: 80d00008 <unknown>
47 fmop4a za5.d, z10.d, {z20.d-z21.d} // 10000000-11010100-00000001-01001101
48 // CHECK-INST: fmop4a za5.d, z10.d, { z20.d, z21.d }
49 // CHECK-ENCODING: [0x4d,0x01,0xd4,0x80]
50 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
51 // CHECK-UNKNOWN: 80d4014d <unknown>
53 fmop4a za7.d, z14.d, {z30.d-z31.d} // 10000000-11011110-00000001-11001111
54 // CHECK-INST: fmop4a za7.d, z14.d, { z30.d, z31.d }
55 // CHECK-ENCODING: [0xcf,0x01,0xde,0x80]
56 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
57 // CHECK-UNKNOWN: 80de01cf <unknown>
59 // Multiple and single vectors
61 fmop4a za0.d, {z0.d-z1.d}, z16.d // 10000000-11000000-00000010-00001000
62 // CHECK-INST: fmop4a za0.d, { z0.d, z1.d }, z16.d
63 // CHECK-ENCODING: [0x08,0x02,0xc0,0x80]
64 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
65 // CHECK-UNKNOWN: 80c00208 <unknown>
67 fmop4a za5.d, {z10.d-z11.d}, z20.d // 10000000-11000100-00000011-01001101
68 // CHECK-INST: fmop4a za5.d, { z10.d, z11.d }, z20.d
69 // CHECK-ENCODING: [0x4d,0x03,0xc4,0x80]
70 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
71 // CHECK-UNKNOWN: 80c4034d <unknown>
73 fmop4a za7.d, {z14.d-z15.d}, z30.d // 10000000-11001110-00000011-11001111
74 // CHECK-INST: fmop4a za7.d, { z14.d, z15.d }, z30.d
75 // CHECK-ENCODING: [0xcf,0x03,0xce,0x80]
76 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
77 // CHECK-UNKNOWN: 80ce03cf <unknown>
79 // Multiple vectors
81 fmop4a za0.d, {z0.d-z1.d}, {z16.d-z17.d} // 10000000-11010000-00000010-00001000
82 // CHECK-INST: fmop4a za0.d, { z0.d, z1.d }, { z16.d, z17.d }
83 // CHECK-ENCODING: [0x08,0x02,0xd0,0x80]
84 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
85 // CHECK-UNKNOWN: 80d00208 <unknown>
87 fmop4a za5.d, {z10.d-z11.d}, {z20.d-z21.d} // 10000000-11010100-00000011-01001101
88 // CHECK-INST: fmop4a za5.d, { z10.d, z11.d }, { z20.d, z21.d }
89 // CHECK-ENCODING: [0x4d,0x03,0xd4,0x80]
90 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
91 // CHECK-UNKNOWN: 80d4034d <unknown>
93 fmop4a za7.d, {z14.d-z15.d}, {z30.d-z31.d} // 10000000-11011110-00000011-11001111
94 // CHECK-INST: fmop4a za7.d, { z14.d, z15.d }, { z30.d, z31.d }
95 // CHECK-ENCODING: [0xcf,0x03,0xde,0x80]
96 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
97 // CHECK-UNKNOWN: 80de03cf <unknown>
100 // FMOP4S
102 // Single vectors
104 fmop4s za0.d, z0.d, z16.d // 10000000-11000000-00000000-00011000
105 // CHECK-INST: fmop4s za0.d, z0.d, z16.d
106 // CHECK-ENCODING: [0x18,0x00,0xc0,0x80]
107 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
108 // CHECK-UNKNOWN: 80c00018 <unknown>
110 fmop4s za5.d, z10.d, z20.d // 10000000-11000100-00000001-01011101
111 // CHECK-INST: fmop4s za5.d, z10.d, z20.d
112 // CHECK-ENCODING: [0x5d,0x01,0xc4,0x80]
113 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
114 // CHECK-UNKNOWN: 80c4015d <unknown>
116 fmop4s za7.d, z14.d, z30.d // 10000000-11001110-00000001-11011111
117 // CHECK-INST: fmop4s za7.d, z14.d, z30.d
118 // CHECK-ENCODING: [0xdf,0x01,0xce,0x80]
119 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
120 // CHECK-UNKNOWN: 80ce01df <unknown>
122 // Single and multiple vectors
124 fmop4s za0.d, z0.d, {z16.d-z17.d} // 10000000-11010000-00000000-00011000
125 // CHECK-INST: fmop4s za0.d, z0.d, { z16.d, z17.d }
126 // CHECK-ENCODING: [0x18,0x00,0xd0,0x80]
127 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
128 // CHECK-UNKNOWN: 80d00018 <unknown>
130 fmop4s za5.d, z10.d, {z20.d-z21.d} // 10000000-11010100-00000001-01011101
131 // CHECK-INST: fmop4s za5.d, z10.d, { z20.d, z21.d }
132 // CHECK-ENCODING: [0x5d,0x01,0xd4,0x80]
133 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
134 // CHECK-UNKNOWN: 80d4015d <unknown>
136 fmop4s za7.d, z14.d, {z30.d-z31.d} // 10000000-11011110-00000001-11011111
137 // CHECK-INST: fmop4s za7.d, z14.d, { z30.d, z31.d }
138 // CHECK-ENCODING: [0xdf,0x01,0xde,0x80]
139 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
140 // CHECK-UNKNOWN: 80de01df <unknown>
142 // Multiple and single vectors
144 fmop4s za0.d, {z0.d-z1.d}, z16.d // 10000000-11000000-00000010-00011000
145 // CHECK-INST: fmop4s za0.d, { z0.d, z1.d }, z16.d
146 // CHECK-ENCODING: [0x18,0x02,0xc0,0x80]
147 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
148 // CHECK-UNKNOWN: 80c00218 <unknown>
150 fmop4s za5.d, {z10.d-z11.d}, z20.d // 10000000-11000100-00000011-01011101
151 // CHECK-INST: fmop4s za5.d, { z10.d, z11.d }, z20.d
152 // CHECK-ENCODING: [0x5d,0x03,0xc4,0x80]
153 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
154 // CHECK-UNKNOWN: 80c4035d <unknown>
156 fmop4s za7.d, {z14.d-z15.d}, z30.d // 10000000-11001110-00000011-11011111
157 // CHECK-INST: fmop4s za7.d, { z14.d, z15.d }, z30.d
158 // CHECK-ENCODING: [0xdf,0x03,0xce,0x80]
159 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
160 // CHECK-UNKNOWN: 80ce03df <unknown>
162 // Multiple vectors
164 fmop4s za0.d, {z0.d-z1.d}, {z16.d-z17.d} // 10000000-11010000-00000010-00011000
165 // CHECK-INST: fmop4s za0.d, { z0.d, z1.d }, { z16.d, z17.d }
166 // CHECK-ENCODING: [0x18,0x02,0xd0,0x80]
167 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
168 // CHECK-UNKNOWN: 80d00218 <unknown>
170 fmop4s za5.d, {z10.d-z11.d}, {z20.d-z21.d} // 10000000-11010100-00000011-01011101
171 // CHECK-INST: fmop4s za5.d, { z10.d, z11.d }, { z20.d, z21.d }
172 // CHECK-ENCODING: [0x5d,0x03,0xd4,0x80]
173 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
174 // CHECK-UNKNOWN: 80d4035d <unknown>
176 fmop4s za7.d, {z14.d-z15.d}, {z30.d-z31.d} // 10000000-11011110-00000011-11011111
177 // CHECK-INST: fmop4s za7.d, { z14.d, z15.d }, { z30.d, z31.d }
178 // CHECK-ENCODING: [0xdf,0x03,0xde,0x80]
179 // CHECK-ERROR: instruction requires: sme2p2 sme-f64f64
180 // CHECK-UNKNOWN: 80de03df <unknown>