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