1; RUN: llc < %s -march=arm64 -aarch64-neon-syntax=apple | FileCheck %s
2
3;
4; Floating-point scalar convert to signed integer (to nearest with ties to away)
5;
6define i32 @fcvtas_1w1s(float %A) nounwind {
7;CHECK-LABEL: fcvtas_1w1s:
8;CHECK: fcvtas w0, s0
9;CHECK-NEXT: ret
10	%tmp3 = call i32 @llvm.aarch64.neon.fcvtas.i32.f32(float %A)
11	ret i32 %tmp3
12}
13
14define i64 @fcvtas_1x1s(float %A) nounwind {
15;CHECK-LABEL: fcvtas_1x1s:
16;CHECK: fcvtas x0, s0
17;CHECK-NEXT: ret
18	%tmp3 = call i64 @llvm.aarch64.neon.fcvtas.i64.f32(float %A)
19	ret i64 %tmp3
20}
21
22define i32 @fcvtas_1w1d(double %A) nounwind {
23;CHECK-LABEL: fcvtas_1w1d:
24;CHECK: fcvtas w0, d0
25;CHECK-NEXT: ret
26	%tmp3 = call i32 @llvm.aarch64.neon.fcvtas.i32.f64(double %A)
27	ret i32 %tmp3
28}
29
30define i64 @fcvtas_1x1d(double %A) nounwind {
31;CHECK-LABEL: fcvtas_1x1d:
32;CHECK: fcvtas x0, d0
33;CHECK-NEXT: ret
34	%tmp3 = call i64 @llvm.aarch64.neon.fcvtas.i64.f64(double %A)
35	ret i64 %tmp3
36}
37
38declare i32 @llvm.aarch64.neon.fcvtas.i32.f32(float) nounwind readnone
39declare i64 @llvm.aarch64.neon.fcvtas.i64.f32(float) nounwind readnone
40declare i32 @llvm.aarch64.neon.fcvtas.i32.f64(double) nounwind readnone
41declare i64 @llvm.aarch64.neon.fcvtas.i64.f64(double) nounwind readnone
42
43;
44; Floating-point scalar convert to unsigned integer
45;
46define i32 @fcvtau_1w1s(float %A) nounwind {
47;CHECK-LABEL: fcvtau_1w1s:
48;CHECK: fcvtau w0, s0
49;CHECK-NEXT: ret
50	%tmp3 = call i32 @llvm.aarch64.neon.fcvtau.i32.f32(float %A)
51	ret i32 %tmp3
52}
53
54define i64 @fcvtau_1x1s(float %A) nounwind {
55;CHECK-LABEL: fcvtau_1x1s:
56;CHECK: fcvtau x0, s0
57;CHECK-NEXT: ret
58	%tmp3 = call i64 @llvm.aarch64.neon.fcvtau.i64.f32(float %A)
59	ret i64 %tmp3
60}
61
62define i32 @fcvtau_1w1d(double %A) nounwind {
63;CHECK-LABEL: fcvtau_1w1d:
64;CHECK: fcvtau w0, d0
65;CHECK-NEXT: ret
66	%tmp3 = call i32 @llvm.aarch64.neon.fcvtau.i32.f64(double %A)
67	ret i32 %tmp3
68}
69
70define i64 @fcvtau_1x1d(double %A) nounwind {
71;CHECK-LABEL: fcvtau_1x1d:
72;CHECK: fcvtau x0, d0
73;CHECK-NEXT: ret
74	%tmp3 = call i64 @llvm.aarch64.neon.fcvtau.i64.f64(double %A)
75	ret i64 %tmp3
76}
77
78declare i32 @llvm.aarch64.neon.fcvtau.i32.f32(float) nounwind readnone
79declare i64 @llvm.aarch64.neon.fcvtau.i64.f32(float) nounwind readnone
80declare i32 @llvm.aarch64.neon.fcvtau.i32.f64(double) nounwind readnone
81declare i64 @llvm.aarch64.neon.fcvtau.i64.f64(double) nounwind readnone
82
83;
84; Floating-point scalar convert to signed integer (toward -Inf)
85;
86define i32 @fcvtms_1w1s(float %A) nounwind {
87;CHECK-LABEL: fcvtms_1w1s:
88;CHECK: fcvtms w0, s0
89;CHECK-NEXT: ret
90	%tmp3 = call i32 @llvm.aarch64.neon.fcvtms.i32.f32(float %A)
91	ret i32 %tmp3
92}
93
94define i64 @fcvtms_1x1s(float %A) nounwind {
95;CHECK-LABEL: fcvtms_1x1s:
96;CHECK: fcvtms x0, s0
97;CHECK-NEXT: ret
98	%tmp3 = call i64 @llvm.aarch64.neon.fcvtms.i64.f32(float %A)
99	ret i64 %tmp3
100}
101
102define i32 @fcvtms_1w1d(double %A) nounwind {
103;CHECK-LABEL: fcvtms_1w1d:
104;CHECK: fcvtms w0, d0
105;CHECK-NEXT: ret
106	%tmp3 = call i32 @llvm.aarch64.neon.fcvtms.i32.f64(double %A)
107	ret i32 %tmp3
108}
109
110define i64 @fcvtms_1x1d(double %A) nounwind {
111;CHECK-LABEL: fcvtms_1x1d:
112;CHECK: fcvtms x0, d0
113;CHECK-NEXT: ret
114	%tmp3 = call i64 @llvm.aarch64.neon.fcvtms.i64.f64(double %A)
115	ret i64 %tmp3
116}
117
118declare i32 @llvm.aarch64.neon.fcvtms.i32.f32(float) nounwind readnone
119declare i64 @llvm.aarch64.neon.fcvtms.i64.f32(float) nounwind readnone
120declare i32 @llvm.aarch64.neon.fcvtms.i32.f64(double) nounwind readnone
121declare i64 @llvm.aarch64.neon.fcvtms.i64.f64(double) nounwind readnone
122
123;
124; Floating-point scalar convert to unsigned integer (toward -Inf)
125;
126define i32 @fcvtmu_1w1s(float %A) nounwind {
127;CHECK-LABEL: fcvtmu_1w1s:
128;CHECK: fcvtmu w0, s0
129;CHECK-NEXT: ret
130	%tmp3 = call i32 @llvm.aarch64.neon.fcvtmu.i32.f32(float %A)
131	ret i32 %tmp3
132}
133
134define i64 @fcvtmu_1x1s(float %A) nounwind {
135;CHECK-LABEL: fcvtmu_1x1s:
136;CHECK: fcvtmu x0, s0
137;CHECK-NEXT: ret
138	%tmp3 = call i64 @llvm.aarch64.neon.fcvtmu.i64.f32(float %A)
139	ret i64 %tmp3
140}
141
142define i32 @fcvtmu_1w1d(double %A) nounwind {
143;CHECK-LABEL: fcvtmu_1w1d:
144;CHECK: fcvtmu w0, d0
145;CHECK-NEXT: ret
146	%tmp3 = call i32 @llvm.aarch64.neon.fcvtmu.i32.f64(double %A)
147	ret i32 %tmp3
148}
149
150define i64 @fcvtmu_1x1d(double %A) nounwind {
151;CHECK-LABEL: fcvtmu_1x1d:
152;CHECK: fcvtmu x0, d0
153;CHECK-NEXT: ret
154	%tmp3 = call i64 @llvm.aarch64.neon.fcvtmu.i64.f64(double %A)
155	ret i64 %tmp3
156}
157
158declare i32 @llvm.aarch64.neon.fcvtmu.i32.f32(float) nounwind readnone
159declare i64 @llvm.aarch64.neon.fcvtmu.i64.f32(float) nounwind readnone
160declare i32 @llvm.aarch64.neon.fcvtmu.i32.f64(double) nounwind readnone
161declare i64 @llvm.aarch64.neon.fcvtmu.i64.f64(double) nounwind readnone
162
163;
164; Floating-point scalar convert to signed integer (to nearest with ties to even)
165;
166define i32 @fcvtns_1w1s(float %A) nounwind {
167;CHECK-LABEL: fcvtns_1w1s:
168;CHECK: fcvtns w0, s0
169;CHECK-NEXT: ret
170	%tmp3 = call i32 @llvm.aarch64.neon.fcvtns.i32.f32(float %A)
171	ret i32 %tmp3
172}
173
174define i64 @fcvtns_1x1s(float %A) nounwind {
175;CHECK-LABEL: fcvtns_1x1s:
176;CHECK: fcvtns x0, s0
177;CHECK-NEXT: ret
178	%tmp3 = call i64 @llvm.aarch64.neon.fcvtns.i64.f32(float %A)
179	ret i64 %tmp3
180}
181
182define i32 @fcvtns_1w1d(double %A) nounwind {
183;CHECK-LABEL: fcvtns_1w1d:
184;CHECK: fcvtns w0, d0
185;CHECK-NEXT: ret
186	%tmp3 = call i32 @llvm.aarch64.neon.fcvtns.i32.f64(double %A)
187	ret i32 %tmp3
188}
189
190define i64 @fcvtns_1x1d(double %A) nounwind {
191;CHECK-LABEL: fcvtns_1x1d:
192;CHECK: fcvtns x0, d0
193;CHECK-NEXT: ret
194	%tmp3 = call i64 @llvm.aarch64.neon.fcvtns.i64.f64(double %A)
195	ret i64 %tmp3
196}
197
198declare i32 @llvm.aarch64.neon.fcvtns.i32.f32(float) nounwind readnone
199declare i64 @llvm.aarch64.neon.fcvtns.i64.f32(float) nounwind readnone
200declare i32 @llvm.aarch64.neon.fcvtns.i32.f64(double) nounwind readnone
201declare i64 @llvm.aarch64.neon.fcvtns.i64.f64(double) nounwind readnone
202
203;
204; Floating-point scalar convert to unsigned integer (to nearest with ties to even)
205;
206define i32 @fcvtnu_1w1s(float %A) nounwind {
207;CHECK-LABEL: fcvtnu_1w1s:
208;CHECK: fcvtnu w0, s0
209;CHECK-NEXT: ret
210	%tmp3 = call i32 @llvm.aarch64.neon.fcvtnu.i32.f32(float %A)
211	ret i32 %tmp3
212}
213
214define i64 @fcvtnu_1x1s(float %A) nounwind {
215;CHECK-LABEL: fcvtnu_1x1s:
216;CHECK: fcvtnu x0, s0
217;CHECK-NEXT: ret
218	%tmp3 = call i64 @llvm.aarch64.neon.fcvtnu.i64.f32(float %A)
219	ret i64 %tmp3
220}
221
222define i32 @fcvtnu_1w1d(double %A) nounwind {
223;CHECK-LABEL: fcvtnu_1w1d:
224;CHECK: fcvtnu w0, d0
225;CHECK-NEXT: ret
226	%tmp3 = call i32 @llvm.aarch64.neon.fcvtnu.i32.f64(double %A)
227	ret i32 %tmp3
228}
229
230define i64 @fcvtnu_1x1d(double %A) nounwind {
231;CHECK-LABEL: fcvtnu_1x1d:
232;CHECK: fcvtnu x0, d0
233;CHECK-NEXT: ret
234	%tmp3 = call i64 @llvm.aarch64.neon.fcvtnu.i64.f64(double %A)
235	ret i64 %tmp3
236}
237
238declare i32 @llvm.aarch64.neon.fcvtnu.i32.f32(float) nounwind readnone
239declare i64 @llvm.aarch64.neon.fcvtnu.i64.f32(float) nounwind readnone
240declare i32 @llvm.aarch64.neon.fcvtnu.i32.f64(double) nounwind readnone
241declare i64 @llvm.aarch64.neon.fcvtnu.i64.f64(double) nounwind readnone
242
243;
244; Floating-point scalar convert to signed integer (toward +Inf)
245;
246define i32 @fcvtps_1w1s(float %A) nounwind {
247;CHECK-LABEL: fcvtps_1w1s:
248;CHECK: fcvtps w0, s0
249;CHECK-NEXT: ret
250	%tmp3 = call i32 @llvm.aarch64.neon.fcvtps.i32.f32(float %A)
251	ret i32 %tmp3
252}
253
254define i64 @fcvtps_1x1s(float %A) nounwind {
255;CHECK-LABEL: fcvtps_1x1s:
256;CHECK: fcvtps x0, s0
257;CHECK-NEXT: ret
258	%tmp3 = call i64 @llvm.aarch64.neon.fcvtps.i64.f32(float %A)
259	ret i64 %tmp3
260}
261
262define i32 @fcvtps_1w1d(double %A) nounwind {
263;CHECK-LABEL: fcvtps_1w1d:
264;CHECK: fcvtps w0, d0
265;CHECK-NEXT: ret
266	%tmp3 = call i32 @llvm.aarch64.neon.fcvtps.i32.f64(double %A)
267	ret i32 %tmp3
268}
269
270define i64 @fcvtps_1x1d(double %A) nounwind {
271;CHECK-LABEL: fcvtps_1x1d:
272;CHECK: fcvtps x0, d0
273;CHECK-NEXT: ret
274	%tmp3 = call i64 @llvm.aarch64.neon.fcvtps.i64.f64(double %A)
275	ret i64 %tmp3
276}
277
278declare i32 @llvm.aarch64.neon.fcvtps.i32.f32(float) nounwind readnone
279declare i64 @llvm.aarch64.neon.fcvtps.i64.f32(float) nounwind readnone
280declare i32 @llvm.aarch64.neon.fcvtps.i32.f64(double) nounwind readnone
281declare i64 @llvm.aarch64.neon.fcvtps.i64.f64(double) nounwind readnone
282
283;
284; Floating-point scalar convert to unsigned integer (toward +Inf)
285;
286define i32 @fcvtpu_1w1s(float %A) nounwind {
287;CHECK-LABEL: fcvtpu_1w1s:
288;CHECK: fcvtpu w0, s0
289;CHECK-NEXT: ret
290	%tmp3 = call i32 @llvm.aarch64.neon.fcvtpu.i32.f32(float %A)
291	ret i32 %tmp3
292}
293
294define i64 @fcvtpu_1x1s(float %A) nounwind {
295;CHECK-LABEL: fcvtpu_1x1s:
296;CHECK: fcvtpu x0, s0
297;CHECK-NEXT: ret
298	%tmp3 = call i64 @llvm.aarch64.neon.fcvtpu.i64.f32(float %A)
299	ret i64 %tmp3
300}
301
302define i32 @fcvtpu_1w1d(double %A) nounwind {
303;CHECK-LABEL: fcvtpu_1w1d:
304;CHECK: fcvtpu w0, d0
305;CHECK-NEXT: ret
306	%tmp3 = call i32 @llvm.aarch64.neon.fcvtpu.i32.f64(double %A)
307	ret i32 %tmp3
308}
309
310define i64 @fcvtpu_1x1d(double %A) nounwind {
311;CHECK-LABEL: fcvtpu_1x1d:
312;CHECK: fcvtpu x0, d0
313;CHECK-NEXT: ret
314	%tmp3 = call i64 @llvm.aarch64.neon.fcvtpu.i64.f64(double %A)
315	ret i64 %tmp3
316}
317
318declare i32 @llvm.aarch64.neon.fcvtpu.i32.f32(float) nounwind readnone
319declare i64 @llvm.aarch64.neon.fcvtpu.i64.f32(float) nounwind readnone
320declare i32 @llvm.aarch64.neon.fcvtpu.i32.f64(double) nounwind readnone
321declare i64 @llvm.aarch64.neon.fcvtpu.i64.f64(double) nounwind readnone
322
323;
324;  Floating-point scalar convert to signed integer (toward zero)
325;
326define i32 @fcvtzs_1w1s(float %A) nounwind {
327;CHECK-LABEL: fcvtzs_1w1s:
328;CHECK: fcvtzs w0, s0
329;CHECK-NEXT: ret
330	%tmp3 = call i32 @llvm.aarch64.neon.fcvtzs.i32.f32(float %A)
331	ret i32 %tmp3
332}
333
334define i64 @fcvtzs_1x1s(float %A) nounwind {
335;CHECK-LABEL: fcvtzs_1x1s:
336;CHECK: fcvtzs x0, s0
337;CHECK-NEXT: ret
338	%tmp3 = call i64 @llvm.aarch64.neon.fcvtzs.i64.f32(float %A)
339	ret i64 %tmp3
340}
341
342define i32 @fcvtzs_1w1d(double %A) nounwind {
343;CHECK-LABEL: fcvtzs_1w1d:
344;CHECK: fcvtzs w0, d0
345;CHECK-NEXT: ret
346	%tmp3 = call i32 @llvm.aarch64.neon.fcvtzs.i32.f64(double %A)
347	ret i32 %tmp3
348}
349
350define i64 @fcvtzs_1x1d(double %A) nounwind {
351;CHECK-LABEL: fcvtzs_1x1d:
352;CHECK: fcvtzs x0, d0
353;CHECK-NEXT: ret
354	%tmp3 = call i64 @llvm.aarch64.neon.fcvtzs.i64.f64(double %A)
355	ret i64 %tmp3
356}
357
358declare i32 @llvm.aarch64.neon.fcvtzs.i32.f32(float) nounwind readnone
359declare i64 @llvm.aarch64.neon.fcvtzs.i64.f32(float) nounwind readnone
360declare i32 @llvm.aarch64.neon.fcvtzs.i32.f64(double) nounwind readnone
361declare i64 @llvm.aarch64.neon.fcvtzs.i64.f64(double) nounwind readnone
362
363;
364; Floating-point scalar convert to unsigned integer (toward zero)
365;
366define i32 @fcvtzu_1w1s(float %A) nounwind {
367;CHECK-LABEL: fcvtzu_1w1s:
368;CHECK: fcvtzu w0, s0
369;CHECK-NEXT: ret
370	%tmp3 = call i32 @llvm.aarch64.neon.fcvtzu.i32.f32(float %A)
371	ret i32 %tmp3
372}
373
374define i64 @fcvtzu_1x1s(float %A) nounwind {
375;CHECK-LABEL: fcvtzu_1x1s:
376;CHECK: fcvtzu x0, s0
377;CHECK-NEXT: ret
378	%tmp3 = call i64 @llvm.aarch64.neon.fcvtzu.i64.f32(float %A)
379	ret i64 %tmp3
380}
381
382define i32 @fcvtzu_1w1d(double %A) nounwind {
383;CHECK-LABEL: fcvtzu_1w1d:
384;CHECK: fcvtzu w0, d0
385;CHECK-NEXT: ret
386	%tmp3 = call i32 @llvm.aarch64.neon.fcvtzu.i32.f64(double %A)
387	ret i32 %tmp3
388}
389
390define i64 @fcvtzu_1x1d(double %A) nounwind {
391;CHECK-LABEL: fcvtzu_1x1d:
392;CHECK: fcvtzu x0, d0
393;CHECK-NEXT: ret
394	%tmp3 = call i64 @llvm.aarch64.neon.fcvtzu.i64.f64(double %A)
395	ret i64 %tmp3
396}
397
398declare i32 @llvm.aarch64.neon.fcvtzu.i32.f32(float) nounwind readnone
399declare i64 @llvm.aarch64.neon.fcvtzu.i64.f32(float) nounwind readnone
400declare i32 @llvm.aarch64.neon.fcvtzu.i32.f64(double) nounwind readnone
401declare i64 @llvm.aarch64.neon.fcvtzu.i64.f64(double) nounwind readnone
402