1 // RUN: %clang_cc1 -triple arm64-none-linux-gnu -target-feature +neon -target-feature +v8.5a\
2 // RUN: -flax-vector-conversions=none -S -disable-O0-optnone -emit-llvm -o - %s \
3 // RUN: | opt -S -passes=mem2reg \
6 // REQUIRES: aarch64-registered-target
10 // CHECK-LABEL: test_vrnd32x_f32
11 // CHECK: [[RND:%.*]] = call <2 x float> @llvm.aarch64.neon.frint32x.v2f32(<2 x float> %a)
12 // CHECK: ret <2 x float> [[RND]]
13 float32x2_t
test_vrnd32x_f32(float32x2_t a
) {
14 return vrnd32x_f32(a
);
17 // CHECK-LABEL: test_vrnd32xq_f32
18 // CHECK: [[RND:%.*]] = call <4 x float> @llvm.aarch64.neon.frint32x.v4f32(<4 x float> %a)
19 // CHECK: ret <4 x float> [[RND]]
20 float32x4_t
test_vrnd32xq_f32(float32x4_t a
) {
21 return vrnd32xq_f32(a
);
24 // CHECK-LABEL: test_vrnd32z_f32
25 // CHECK: [[RND:%.*]] = call <2 x float> @llvm.aarch64.neon.frint32z.v2f32(<2 x float> %a)
26 // CHECK: ret <2 x float> [[RND]]
27 float32x2_t
test_vrnd32z_f32(float32x2_t a
) {
28 return vrnd32z_f32(a
);
31 // CHECK-LABEL: test_vrnd32zq_f32
32 // CHECK: [[RND:%.*]] = call <4 x float> @llvm.aarch64.neon.frint32z.v4f32(<4 x float> %a)
33 // CHECK: ret <4 x float> [[RND]]
34 float32x4_t
test_vrnd32zq_f32(float32x4_t a
) {
35 return vrnd32zq_f32(a
);
38 // CHECK-LABEL: test_vrnd64x_f32
39 // CHECK: [[RND:%.*]] = call <2 x float> @llvm.aarch64.neon.frint64x.v2f32(<2 x float> %a)
40 // CHECK: ret <2 x float> [[RND]]
41 float32x2_t
test_vrnd64x_f32(float32x2_t a
) {
42 return vrnd64x_f32(a
);
45 // CHECK-LABEL: test_vrnd64xq_f32
46 // CHECK: [[RND:%.*]] = call <4 x float> @llvm.aarch64.neon.frint64x.v4f32(<4 x float> %a)
47 // CHECK: ret <4 x float> [[RND]]
48 float32x4_t
test_vrnd64xq_f32(float32x4_t a
) {
49 return vrnd64xq_f32(a
);
52 // CHECK-LABEL: test_vrnd64z_f32
53 // CHECK: [[RND:%.*]] = call <2 x float> @llvm.aarch64.neon.frint64z.v2f32(<2 x float> %a)
54 // CHECK: ret <2 x float> [[RND]]
55 float32x2_t
test_vrnd64z_f32(float32x2_t a
) {
56 return vrnd64z_f32(a
);
59 // CHECK-LABEL: test_vrnd64zq_f32
60 // CHECK: [[RND:%.*]] = call <4 x float> @llvm.aarch64.neon.frint64z.v4f32(<4 x float> %a)
61 // CHECK: ret <4 x float> [[RND]]
62 float32x4_t
test_vrnd64zq_f32(float32x4_t a
) {
63 return vrnd64zq_f32(a
);
66 // CHECK-LABEL: test_vrnd32x_f64
67 // CHECK: [[RND:%.*]] = call <1 x double> @llvm.aarch64.neon.frint32x.v1f64(<1 x double> %a)
68 // CHECK: ret <1 x double> [[RND]]
69 float64x1_t
test_vrnd32x_f64(float64x1_t a
) {
70 return vrnd32x_f64(a
);
73 // CHECK-LABEL: test_vrnd32xq_f64
74 // CHECK: [[RND:%.*]] = call <2 x double> @llvm.aarch64.neon.frint32x.v2f64(<2 x double> %a)
75 // CHECK: ret <2 x double> [[RND]]
76 float64x2_t
test_vrnd32xq_f64(float64x2_t a
) {
77 return vrnd32xq_f64(a
);
80 // CHECK-LABEL: test_vrnd32z_f64
81 // CHECK: [[RND:%.*]] = call <1 x double> @llvm.aarch64.neon.frint32z.v1f64(<1 x double> %a)
82 // CHECK: ret <1 x double> [[RND]]
83 float64x1_t
test_vrnd32z_f64(float64x1_t a
) {
84 return vrnd32z_f64(a
);
87 // CHECK-LABEL: test_vrnd32zq_f64
88 // CHECK: [[RND:%.*]] = call <2 x double> @llvm.aarch64.neon.frint32z.v2f64(<2 x double> %a)
89 // CHECK: ret <2 x double> [[RND]]
90 float64x2_t
test_vrnd32zq_f64(float64x2_t a
) {
91 return vrnd32zq_f64(a
);
94 // CHECK-LABEL: test_vrnd64x_f64
95 // CHECK: [[RND:%.*]] = call <1 x double> @llvm.aarch64.neon.frint64x.v1f64(<1 x double> %a)
96 // CHECK: ret <1 x double> [[RND]]
97 float64x1_t
test_vrnd64x_f64(float64x1_t a
) {
98 return vrnd64x_f64(a
);
101 // CHECK-LABEL: test_vrnd64xq_f64
102 // CHECK: [[RND:%.*]] = call <2 x double> @llvm.aarch64.neon.frint64x.v2f64(<2 x double> %a)
103 // CHECK: ret <2 x double> [[RND]]
104 float64x2_t
test_vrnd64xq_f64(float64x2_t a
) {
105 return vrnd64xq_f64(a
);
108 // CHECK-LABEL: test_vrnd64z_f64
109 // CHECK: [[RND:%.*]] = call <1 x double> @llvm.aarch64.neon.frint64z.v1f64(<1 x double> %a)
110 // CHECK: ret <1 x double> [[RND]]
111 float64x1_t
test_vrnd64z_f64(float64x1_t a
) {
112 return vrnd64z_f64(a
);
115 // CHECK-LABEL: test_vrnd64zq_f64
116 // CHECK: [[RND:%.*]] = call <2 x double> @llvm.aarch64.neon.frint64z.v2f64(<2 x double> %a)
117 // CHECK: ret <2 x double> [[RND]]
118 float64x2_t
test_vrnd64zq_f64(float64x2_t a
) {
119 return vrnd64zq_f64(a
);