[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / MC / ARM / fullfp16-neon-neg.s
blob00bf48aa3b613da638d07e5dd8632e95c11b3b84
1 @ RUN: not llvm-mc -triple armv8a-none-eabi -mattr=-fullfp16,+neon -show-encoding < %s 2>&1 | FileCheck %s
2 @ RUN: not llvm-mc -triple armv8a-none-eabi -mattr=+fullfp16,-neon -show-encoding < %s 2>&1 | FileCheck %s
3 @ RUN: not llvm-mc -triple thumbv8a-none-eabi -mattr=-fullfp16,+neon -show-encoding < %s 2>&1 | FileCheck %s
4 @ RUN: not llvm-mc -triple thumbv8a-none-eabi -mattr=+fullfp16,-neon -show-encoding < %s 2>&1 | FileCheck %s
6 vadd.f16 d0, d1, d2
7 vadd.f16 q0, q1, q2
8 @ CHECK: instruction requires: {{full half-float|NEON}}
9 @ CHECK: instruction requires: {{full half-float|NEON}}
11 vsub.f16 d0, d1, d2
12 vsub.f16 q0, q1, q2
13 @ CHECK: instruction requires: {{full half-float|NEON}}
14 @ CHECK: instruction requires: {{full half-float|NEON}}
16 vmul.f16 d0, d1, d2
17 vmul.f16 q0, q1, q2
18 @ CHECK: instruction requires: {{full half-float|NEON}}
19 @ CHECK: instruction requires: {{full half-float|NEON}}
21 vmul.f16 d1, d2, d3[2]
22 vmul.f16 q4, q5, d6[3]
23 @ CHECK: instruction requires: {{full half-float|NEON}}
24 @ CHECK: instruction requires: {{full half-float|NEON}}
26 vmla.f16 d0, d1, d2
27 vmla.f16 q0, q1, q2
28 @ CHECK: instruction requires: {{full half-float|NEON}}
29 @ CHECK: instruction requires: {{full half-float|NEON}}
31 vmla.f16 d5, d6, d7[2]
32 vmla.f16 q5, q6, d7[3]
33 @ CHECK: instruction requires: {{full half-float|NEON}}
34 @ CHECK: instruction requires: {{full half-float|NEON}}
36 vmls.f16 d0, d1, d2
37 vmls.f16 q0, q1, q2
38 @ CHECK: instruction requires: {{full half-float|NEON}}
39 @ CHECK: instruction requires: {{full half-float|NEON}}
41 vmls.f16 d5, d6, d7[2]
42 vmls.f16 q5, q6, d7[3]
43 @ CHECK: instruction requires: {{full half-float|NEON}}
44 @ CHECK: instruction requires: {{full half-float|NEON}}
46 vfma.f16 d0, d1, d2
47 vfma.f16 q0, q1, q2
48 @ CHECK: instruction requires: {{full half-float|NEON}}
49 @ CHECK: instruction requires: {{full half-float|NEON}}
51 vfms.f16 d0, d1, d2
52 vfms.f16 q0, q1, q2
53 @ CHECK: instruction requires: {{full half-float|NEON}}
54 @ CHECK: instruction requires: {{full half-float|NEON}}
56 vceq.f16 d2, d3, d4
57 vceq.f16 q2, q3, q4
58 @ CHECK: instruction requires: {{full half-float|NEON}}
59 @ CHECK: instruction requires: {{full half-float|NEON}}
61 vceq.f16 d2, d3, #0
62 vceq.f16 q2, q3, #0
63 @ CHECK: instruction requires: {{full half-float|NEON}}
64 @ CHECK: instruction requires: {{full half-float|NEON}}
66 vcge.f16 d2, d3, d4
67 vcge.f16 q2, q3, q4
68 @ CHECK: instruction requires: {{full half-float|NEON}}
69 @ CHECK: instruction requires: {{full half-float|NEON}}
71 vcge.f16 d2, d3, #0
72 vcge.f16 q2, q3, #0
73 @ CHECK: instruction requires: {{full half-float|NEON}}
74 @ CHECK: instruction requires: {{full half-float|NEON}}
76 vcgt.f16 d2, d3, d4
77 vcgt.f16 q2, q3, q4
78 @ CHECK: instruction requires: {{full half-float|NEON}}
79 @ CHECK: instruction requires: {{full half-float|NEON}}
81 vcgt.f16 d2, d3, #0
82 vcgt.f16 q2, q3, #0
83 @ CHECK: instruction requires: {{full half-float|NEON}}
84 @ CHECK: instruction requires: {{full half-float|NEON}}
86 vcle.f16 d2, d3, d4
87 vcle.f16 q2, q3, q4
88 @ CHECK: instruction requires: {{full half-float|NEON}}
89 @ CHECK: instruction requires: {{full half-float|NEON}}
91 vcle.f16 d2, d3, #0
92 vcle.f16 q2, q3, #0
93 @ CHECK: instruction requires: {{full half-float|NEON}}
94 @ CHECK: instruction requires: {{full half-float|NEON}}
96 vclt.f16 d2, d3, d4
97 vclt.f16 q2, q3, q4
98 @ CHECK: instruction requires: {{full half-float|NEON}}
99 @ CHECK: instruction requires: {{full half-float|NEON}}
101 vclt.f16 d2, d3, #0
102 vclt.f16 q2, q3, #0
103 @ CHECK: instruction requires: {{full half-float|NEON}}
104 @ CHECK: instruction requires: {{full half-float|NEON}}
106 vacge.f16 d0, d1, d2
107 vacge.f16 q0, q1, q2
108 @ CHECK: instruction requires: {{full half-float|NEON}}
109 @ CHECK: instruction requires: {{full half-float|NEON}}
111 vacgt.f16 d0, d1, d2
112 vacgt.f16 q0, q1, q2
113 @ CHECK: instruction requires: {{full half-float|NEON}}
114 @ CHECK: instruction requires: {{full half-float|NEON}}
116 vacle.f16 d0, d1, d2
117 vacle.f16 q0, q1, q2
118 @ CHECK: instruction requires: {{full half-float|NEON}}
119 @ CHECK: instruction requires: {{full half-float|NEON}}
121 vaclt.f16 d0, d1, d2
122 vaclt.f16 q0, q1, q2
123 @ CHECK: instruction requires: {{full half-float|NEON}}
124 @ CHECK: instruction requires: {{full half-float|NEON}}
126 vabd.f16 d0, d1, d2
127 vabd.f16 q0, q1, q2
128 @ CHECK: instruction requires: {{full half-float|NEON}}
129 @ CHECK: instruction requires: {{full half-float|NEON}}
131 vabs.f16 d0, d1
132 vabs.f16 q0, q1
133 @ CHECK: instruction requires: {{full half-float|NEON}}
134 @ CHECK: instruction requires: {{full half-float|NEON}}
136 vmax.f16 d0, d1, d2
137 vmax.f16 q0, q1, q2
138 @ CHECK: instruction requires: {{full half-float|NEON}}
139 @ CHECK: instruction requires: {{full half-float|NEON}}
141 vmin.f16 d0, d1, d2
142 vmin.f16 q0, q1, q2
143 @ CHECK: instruction requires: {{full half-float|NEON}}
144 @ CHECK: instruction requires: {{full half-float|NEON}}
146 vmaxnm.f16 d0, d1, d2
147 vmaxnm.f16 q0, q1, q2
148 @ CHECK: instruction requires: {{full half-float|NEON}}
149 @ CHECK: instruction requires: {{full half-float|NEON}}
151 vminnm.f16 d0, d1, d2
152 vminnm.f16 q0, q1, q2
153 @ CHECK: instruction requires: {{full half-float|NEON}}
154 @ CHECK: instruction requires: {{full half-float|NEON}}
156 vpadd.f16 d0, d1, d2
157 @ CHECK: instruction requires: {{full half-float|NEON}}
159 vpmax.f16 d0, d1, d2
160 @ CHECK: instruction requires: {{full half-float|NEON}}
162 vpmin.f16 d0, d1, d2
163 @ CHECK: instruction requires: {{full half-float|NEON}}
165 vrecpe.f16 d0, d1
166 vrecpe.f16 q0, q1
167 @ CHECK: instruction requires: {{full half-float|NEON}}
168 @ CHECK: instruction requires: {{full half-float|NEON}}
170 vrecps.f16 d0, d1, d2
171 vrecps.f16 q0, q1, q2
172 @ CHECK: instruction requires: {{full half-float|NEON}}
173 @ CHECK: instruction requires: {{full half-float|NEON}}
175 vrsqrte.f16 d0, d1
176 vrsqrte.f16 q0, q1
177 @ CHECK: instruction requires: {{full half-float|NEON}}
178 @ CHECK: instruction requires: {{full half-float|NEON}}
180 vrsqrts.f16 d0, d1, d2
181 vrsqrts.f16 q0, q1, q2
182 @ CHECK: instruction requires: {{full half-float|NEON}}
183 @ CHECK: instruction requires: {{full half-float|NEON}}
185 vneg.f16 d0, d1
186 vneg.f16 q0, q1
187 @ CHECK: instruction requires: {{full half-float|NEON}}
188 @ CHECK: instruction requires: {{full half-float|NEON}}
190 vcvt.s16.f16 d0, d1
191 vcvt.u16.f16 d0, d1
192 vcvt.f16.s16 d0, d1
193 vcvt.f16.u16 d0, d1
194 vcvt.s16.f16 q0, q1
195 vcvt.u16.f16 q0, q1
196 vcvt.f16.s16 q0, q1
197 vcvt.f16.u16 q0, q1
198 @ CHECK: instruction requires: {{full half-float|NEON}}
199 @ CHECK: instruction requires: {{full half-float|NEON}}
200 @ CHECK: instruction requires: {{full half-float|NEON}}
201 @ CHECK: instruction requires: {{full half-float|NEON}}
202 @ CHECK: instruction requires: {{full half-float|NEON}}
203 @ CHECK: instruction requires: {{full half-float|NEON}}
204 @ CHECK: instruction requires: {{full half-float|NEON}}
205 @ CHECK: instruction requires: {{full half-float|NEON}}
207 vcvta.s16.f16 d0, d1
208 vcvta.s16.f16 q0, q1
209 vcvta.u16.f16 d0, d1
210 vcvta.u16.f16 q0, q1
211 @ CHECK: instruction requires: {{full half-float|NEON}}
212 @ CHECK: instruction requires: {{full half-float|NEON}}
213 @ CHECK: instruction requires: {{full half-float|NEON}}
214 @ CHECK: instruction requires: {{full half-float|NEON}}
216 vcvtm.s16.f16 d0, d1
217 vcvtm.s16.f16 q0, q1
218 vcvtm.u16.f16 d0, d1
219 vcvtm.u16.f16 q0, q1
220 @ CHECK: instruction requires: {{full half-float|NEON}}
221 @ CHECK: instruction requires: {{full half-float|NEON}}
222 @ CHECK: instruction requires: {{full half-float|NEON}}
223 @ CHECK: instruction requires: {{full half-float|NEON}}
225 vcvtn.s16.f16 d0, d1
226 vcvtn.s16.f16 q0, q1
227 vcvtn.u16.f16 d0, d1
228 vcvtn.u16.f16 q0, q1
229 @ CHECK: instruction requires: {{full half-float|NEON}}
230 @ CHECK: instruction requires: {{full half-float|NEON}}
231 @ CHECK: instruction requires: {{full half-float|NEON}}
232 @ CHECK: instruction requires: {{full half-float|NEON}}
234 vcvtp.s16.f16 d0, d1
235 vcvtp.s16.f16 q0, q1
236 vcvtp.u16.f16 d0, d1
237 vcvtp.u16.f16 q0, q1
238 @ CHECK: instruction requires: {{full half-float|NEON}}
239 @ CHECK: instruction requires: {{full half-float|NEON}}
240 @ CHECK: instruction requires: {{full half-float|NEON}}
241 @ CHECK: instruction requires: {{full half-float|NEON}}
244 vcvt.s16.f16 d0, d1, #1
245 vcvt.u16.f16 d0, d1, #2
246 vcvt.f16.s16 d0, d1, #3
247 vcvt.f16.u16 d0, d1, #4
248 vcvt.s16.f16 q0, q1, #5
249 vcvt.u16.f16 q0, q1, #6
250 vcvt.f16.s16 q0, q1, #7
251 vcvt.f16.u16 q0, q1, #8
252 @ CHECK: instruction requires: {{full half-float|NEON}}
253 @ CHECK: instruction requires: {{full half-float|NEON}}
254 @ CHECK: instruction requires: {{full half-float|NEON}}
255 @ CHECK: instruction requires: {{full half-float|NEON}}
256 @ CHECK: instruction requires: {{full half-float|NEON}}
257 @ CHECK: instruction requires: {{full half-float|NEON}}
258 @ CHECK: instruction requires: {{full half-float|NEON}}
259 @ CHECK: instruction requires: {{full half-float|NEON}}
261 vrinta.f16.f16 d0, d1
262 vrinta.f16.f16 q0, q1
263 @ CHECK: instruction requires: {{full half-float|NEON}}
264 @ CHECK: instruction requires: {{full half-float|NEON}}
266 vrintm.f16.f16 d0, d1
267 vrintm.f16.f16 q0, q1
268 @ CHECK: instruction requires: {{full half-float|NEON}}
269 @ CHECK: instruction requires: {{full half-float|NEON}}
271 vrintn.f16.f16 d0, d1
272 vrintn.f16.f16 q0, q1
273 @ CHECK: instruction requires: {{full half-float|NEON}}
274 @ CHECK: instruction requires: {{full half-float|NEON}}
276 vrintp.f16.f16 d0, d1
277 vrintp.f16.f16 q0, q1
278 @ CHECK: instruction requires: {{full half-float|NEON}}
279 @ CHECK: instruction requires: {{full half-float|NEON}}
281 vrintx.f16.f16 d0, d1
282 vrintx.f16.f16 q0, q1
283 @ CHECK: instruction requires: {{full half-float|NEON}}
284 @ CHECK: instruction requires: {{full half-float|NEON}}
286 vrintz.f16.f16 d0, d1
287 vrintz.f16.f16 q0, q1
288 @ CHECK: instruction requires: {{full half-float|NEON}}
289 @ CHECK: instruction requires: {{full half-float|NEON}}