xref: /aosp_15_r20/external/clang/test/CodeGen/aarch64-neon-fcvt-intrinsics.c (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 -triple arm64-none-linux-gnu -target-feature +neon \
2*67e74705SXin Li // RUN:   -emit-llvm -o - %s | opt -S -mem2reg | FileCheck %s
3*67e74705SXin Li 
4*67e74705SXin Li // Test new aarch64 intrinsics and types
5*67e74705SXin Li 
6*67e74705SXin Li #include <arm_neon.h>
7*67e74705SXin Li 
8*67e74705SXin Li // CHECK-LABEL: define float @test_vcvtxd_f32_f64(double %a) #0 {
9*67e74705SXin Li // CHECK:   [[VCVTXD_F32_F64_I:%.*]] = call float @llvm.aarch64.sisd.fcvtxn(double %a) #2
10*67e74705SXin Li // CHECK:   ret float [[VCVTXD_F32_F64_I]]
test_vcvtxd_f32_f64(float64_t a)11*67e74705SXin Li float32_t test_vcvtxd_f32_f64(float64_t a) {
12*67e74705SXin Li   return (float32_t)vcvtxd_f32_f64(a);
13*67e74705SXin Li }
14*67e74705SXin Li 
15*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtas_s32_f32(float %a) #0 {
16*67e74705SXin Li // CHECK:   [[VCVTAS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtas.i32.f32(float %a) #2
17*67e74705SXin Li // CHECK:   ret i32 [[VCVTAS_S32_F32_I]]
test_vcvtas_s32_f32(float32_t a)18*67e74705SXin Li int32_t test_vcvtas_s32_f32(float32_t a) {
19*67e74705SXin Li   return (int32_t)vcvtas_s32_f32(a);
20*67e74705SXin Li }
21*67e74705SXin Li 
22*67e74705SXin Li // CHECK-LABEL: define i64 @test_test_vcvtad_s64_f64(double %a) #0 {
23*67e74705SXin Li // CHECK:   [[VCVTAD_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtas.i64.f64(double %a) #2
24*67e74705SXin Li // CHECK:   ret i64 [[VCVTAD_S64_F64_I]]
test_test_vcvtad_s64_f64(float64_t a)25*67e74705SXin Li int64_t test_test_vcvtad_s64_f64(float64_t a) {
26*67e74705SXin Li   return (int64_t)vcvtad_s64_f64(a);
27*67e74705SXin Li }
28*67e74705SXin Li 
29*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtas_u32_f32(float %a) #0 {
30*67e74705SXin Li // CHECK:   [[VCVTAS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtau.i32.f32(float %a) #2
31*67e74705SXin Li // CHECK:   ret i32 [[VCVTAS_U32_F32_I]]
test_vcvtas_u32_f32(float32_t a)32*67e74705SXin Li uint32_t test_vcvtas_u32_f32(float32_t a) {
33*67e74705SXin Li   return (uint32_t)vcvtas_u32_f32(a);
34*67e74705SXin Li }
35*67e74705SXin Li 
36*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtad_u64_f64(double %a) #0 {
37*67e74705SXin Li // CHECK:   [[VCVTAD_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtau.i64.f64(double %a) #2
38*67e74705SXin Li // CHECK:   ret i64 [[VCVTAD_U64_F64_I]]
test_vcvtad_u64_f64(float64_t a)39*67e74705SXin Li uint64_t test_vcvtad_u64_f64(float64_t a) {
40*67e74705SXin Li   return (uint64_t)vcvtad_u64_f64(a);
41*67e74705SXin Li }
42*67e74705SXin Li 
43*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtms_s32_f32(float %a) #0 {
44*67e74705SXin Li // CHECK:   [[VCVTMS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtms.i32.f32(float %a) #2
45*67e74705SXin Li // CHECK:   ret i32 [[VCVTMS_S32_F32_I]]
test_vcvtms_s32_f32(float32_t a)46*67e74705SXin Li int32_t test_vcvtms_s32_f32(float32_t a) {
47*67e74705SXin Li   return (int32_t)vcvtms_s32_f32(a);
48*67e74705SXin Li }
49*67e74705SXin Li 
50*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtmd_s64_f64(double %a) #0 {
51*67e74705SXin Li // CHECK:   [[VCVTMD_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtms.i64.f64(double %a) #2
52*67e74705SXin Li // CHECK:   ret i64 [[VCVTMD_S64_F64_I]]
test_vcvtmd_s64_f64(float64_t a)53*67e74705SXin Li int64_t test_vcvtmd_s64_f64(float64_t a) {
54*67e74705SXin Li   return (int64_t)vcvtmd_s64_f64(a);
55*67e74705SXin Li }
56*67e74705SXin Li 
57*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtms_u32_f32(float %a) #0 {
58*67e74705SXin Li // CHECK:   [[VCVTMS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtmu.i32.f32(float %a) #2
59*67e74705SXin Li // CHECK:   ret i32 [[VCVTMS_U32_F32_I]]
test_vcvtms_u32_f32(float32_t a)60*67e74705SXin Li uint32_t test_vcvtms_u32_f32(float32_t a) {
61*67e74705SXin Li   return (uint32_t)vcvtms_u32_f32(a);
62*67e74705SXin Li }
63*67e74705SXin Li 
64*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtmd_u64_f64(double %a) #0 {
65*67e74705SXin Li // CHECK:   [[VCVTMD_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtmu.i64.f64(double %a) #2
66*67e74705SXin Li // CHECK:   ret i64 [[VCVTMD_U64_F64_I]]
test_vcvtmd_u64_f64(float64_t a)67*67e74705SXin Li uint64_t test_vcvtmd_u64_f64(float64_t a) {
68*67e74705SXin Li   return (uint64_t)vcvtmd_u64_f64(a);
69*67e74705SXin Li }
70*67e74705SXin Li 
71*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtns_s32_f32(float %a) #0 {
72*67e74705SXin Li // CHECK:   [[VCVTNS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtns.i32.f32(float %a) #2
73*67e74705SXin Li // CHECK:   ret i32 [[VCVTNS_S32_F32_I]]
test_vcvtns_s32_f32(float32_t a)74*67e74705SXin Li int32_t test_vcvtns_s32_f32(float32_t a) {
75*67e74705SXin Li   return (int32_t)vcvtns_s32_f32(a);
76*67e74705SXin Li }
77*67e74705SXin Li 
78*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtnd_s64_f64(double %a) #0 {
79*67e74705SXin Li // CHECK:   [[VCVTND_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtns.i64.f64(double %a) #2
80*67e74705SXin Li // CHECK:   ret i64 [[VCVTND_S64_F64_I]]
test_vcvtnd_s64_f64(float64_t a)81*67e74705SXin Li int64_t test_vcvtnd_s64_f64(float64_t a) {
82*67e74705SXin Li   return (int64_t)vcvtnd_s64_f64(a);
83*67e74705SXin Li }
84*67e74705SXin Li 
85*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtns_u32_f32(float %a) #0 {
86*67e74705SXin Li // CHECK:   [[VCVTNS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtnu.i32.f32(float %a) #2
87*67e74705SXin Li // CHECK:   ret i32 [[VCVTNS_U32_F32_I]]
test_vcvtns_u32_f32(float32_t a)88*67e74705SXin Li uint32_t test_vcvtns_u32_f32(float32_t a) {
89*67e74705SXin Li   return (uint32_t)vcvtns_u32_f32(a);
90*67e74705SXin Li }
91*67e74705SXin Li 
92*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtnd_u64_f64(double %a) #0 {
93*67e74705SXin Li // CHECK:   [[VCVTND_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtnu.i64.f64(double %a) #2
94*67e74705SXin Li // CHECK:   ret i64 [[VCVTND_U64_F64_I]]
test_vcvtnd_u64_f64(float64_t a)95*67e74705SXin Li uint64_t test_vcvtnd_u64_f64(float64_t a) {
96*67e74705SXin Li   return (uint64_t)vcvtnd_u64_f64(a);
97*67e74705SXin Li }
98*67e74705SXin Li 
99*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtps_s32_f32(float %a) #0 {
100*67e74705SXin Li // CHECK:   [[VCVTPS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtps.i32.f32(float %a) #2
101*67e74705SXin Li // CHECK:   ret i32 [[VCVTPS_S32_F32_I]]
test_vcvtps_s32_f32(float32_t a)102*67e74705SXin Li int32_t test_vcvtps_s32_f32(float32_t a) {
103*67e74705SXin Li   return (int32_t)vcvtps_s32_f32(a);
104*67e74705SXin Li }
105*67e74705SXin Li 
106*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtpd_s64_f64(double %a) #0 {
107*67e74705SXin Li // CHECK:   [[VCVTPD_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtps.i64.f64(double %a) #2
108*67e74705SXin Li // CHECK:   ret i64 [[VCVTPD_S64_F64_I]]
test_vcvtpd_s64_f64(float64_t a)109*67e74705SXin Li int64_t test_vcvtpd_s64_f64(float64_t a) {
110*67e74705SXin Li   return (int64_t)vcvtpd_s64_f64(a);
111*67e74705SXin Li }
112*67e74705SXin Li 
113*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvtps_u32_f32(float %a) #0 {
114*67e74705SXin Li // CHECK:   [[VCVTPS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtpu.i32.f32(float %a) #2
115*67e74705SXin Li // CHECK:   ret i32 [[VCVTPS_U32_F32_I]]
test_vcvtps_u32_f32(float32_t a)116*67e74705SXin Li uint32_t test_vcvtps_u32_f32(float32_t a) {
117*67e74705SXin Li   return (uint32_t)vcvtps_u32_f32(a);
118*67e74705SXin Li }
119*67e74705SXin Li 
120*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtpd_u64_f64(double %a) #0 {
121*67e74705SXin Li // CHECK:   [[VCVTPD_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtpu.i64.f64(double %a) #2
122*67e74705SXin Li // CHECK:   ret i64 [[VCVTPD_U64_F64_I]]
test_vcvtpd_u64_f64(float64_t a)123*67e74705SXin Li uint64_t test_vcvtpd_u64_f64(float64_t a) {
124*67e74705SXin Li   return (uint64_t)vcvtpd_u64_f64(a);
125*67e74705SXin Li }
126*67e74705SXin Li 
127*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvts_s32_f32(float %a) #0 {
128*67e74705SXin Li // CHECK:   [[TMP0:%.*]] = fptosi float %a to i32
129*67e74705SXin Li // CHECK:   ret i32 [[TMP0]]
test_vcvts_s32_f32(float32_t a)130*67e74705SXin Li int32_t test_vcvts_s32_f32(float32_t a) {
131*67e74705SXin Li   return (int32_t)vcvts_s32_f32(a);
132*67e74705SXin Li }
133*67e74705SXin Li 
134*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtd_s64_f64(double %a) #0 {
135*67e74705SXin Li // CHECK:   [[TMP0:%.*]] = fptosi double %a to i64
136*67e74705SXin Li // CHECK:   ret i64 [[TMP0]]
test_vcvtd_s64_f64(float64_t a)137*67e74705SXin Li int64_t test_vcvtd_s64_f64(float64_t a) {
138*67e74705SXin Li   return (int64_t)vcvtd_s64_f64(a);
139*67e74705SXin Li }
140*67e74705SXin Li 
141*67e74705SXin Li // CHECK-LABEL: define i32 @test_vcvts_u32_f32(float %a) #0 {
142*67e74705SXin Li // CHECK:   [[TMP0:%.*]] = fptoui float %a to i32
143*67e74705SXin Li // CHECK:   ret i32 [[TMP0]]
test_vcvts_u32_f32(float32_t a)144*67e74705SXin Li uint32_t test_vcvts_u32_f32(float32_t a) {
145*67e74705SXin Li   return (uint32_t)vcvts_u32_f32(a);
146*67e74705SXin Li }
147*67e74705SXin Li 
148*67e74705SXin Li // CHECK-LABEL: define i64 @test_vcvtd_u64_f64(double %a) #0 {
149*67e74705SXin Li // CHECK:   [[TMP0:%.*]] = fptoui double %a to i64
150*67e74705SXin Li // CHECK:   ret i64 [[TMP0]]
test_vcvtd_u64_f64(float64_t a)151*67e74705SXin Li uint64_t test_vcvtd_u64_f64(float64_t a) {
152*67e74705SXin Li   return (uint64_t)vcvtd_u64_f64(a);
153*67e74705SXin Li }
154