1; RUN: llc -o - %s -verify-machineinstrs -mtriple=aarch64-linux-gnu -mattr=+neon | FileCheck %s
2
3
4define <2 x float> @test_cos_v2f64(<2 x double> %v1) {
5; CHECK-LABEL: test_cos_v2f64:
6; CHECK: bl cos
7; CHECK: bl cos
8  %1 = call <2 x double> @llvm.cos.v2f64(<2 x double> %v1)
9  %2 = fptrunc <2 x double> %1 to <2 x float>
10  ret <2 x float> %2
11}
12
13define <2 x float> @test_sin_v2f64(<2 x double> %v1) {
14; CHECK-LABEL: test_sin_v2f64:
15; CHECK: bl sin
16; CHECK: bl sin
17  %1 = call <2 x double> @llvm.sin.v2f64(<2 x double> %v1)
18  %2 = fptrunc <2 x double> %1 to <2 x float>
19  ret <2 x float> %2
20}
21
22define <2 x float> @test_pow_v2f64(<2 x double> %v1, <2 x double> %v2) {
23; CHECK-LABEL: test_pow_v2f64:
24; CHECK: bl pow
25; CHECK: bl pow
26  %1 = call <2 x double> @llvm.pow.v2f64(<2 x double> %v1, <2 x double> %v2)
27  %2 = fptrunc <2 x double> %1 to <2 x float>
28  ret <2 x float> %2
29}
30
31declare <2 x double> @llvm.cos.v2f64(<2 x double>)
32declare <2 x double> @llvm.sin.v2f64(<2 x double>)
33declare <2 x double> @llvm.pow.v2f64(<2 x double>, <2 x double>)
34
35define <2 x float> @test_cos_v2f32(<2 x float> %v1) {
36; CHECK-LABEL: test_cos_v2f32:
37; CHECK: bl cos
38; CHECK: bl cos
39  %1 = call <2 x float> @llvm.cos.v2f32(<2 x float> %v1)
40  ret <2 x float> %1
41}
42
43define <2 x float> @test_sin_v2f32(<2 x float> %v1) {
44; CHECK-LABEL: test_sin_v2f32:
45; CHECK: bl sin
46; CHECK: bl sin
47  %1 = call <2 x float> @llvm.sin.v2f32(<2 x float> %v1)
48  ret <2 x float> %1
49}
50
51define <2 x float> @test_pow_v2f32(<2 x float> %v1, <2 x float> %v2) {
52; CHECK-LABEL: test_pow_v2f32:
53; CHECK: bl pow
54; CHECK: bl pow
55  %1 = call <2 x float> @llvm.pow.v2f32(<2 x float> %v1, <2 x float> %v2)
56  ret <2 x float> %1
57}
58
59declare <2 x float> @llvm.cos.v2f32(<2 x float>)
60declare <2 x float> @llvm.sin.v2f32(<2 x float>)
61declare <2 x float> @llvm.pow.v2f32(<2 x float>, <2 x float>)
62
63define <4 x float> @test_cos_v4f32(<4 x float> %v1) {
64; CHECK-LABEL: test_cos_v4f32:
65; CHECK: bl cos
66; CHECK: bl cos
67; CHECK: bl cos
68; CHECK: bl cos
69  %1 = call <4 x float> @llvm.cos.v4f32(<4 x float> %v1)
70  ret <4 x float> %1
71}
72
73define <4 x float> @test_sin_v4f32(<4 x float> %v1) {
74; CHECK-LABEL: test_sin_v4f32:
75; CHECK: bl sin
76; CHECK: bl sin
77; CHECK: bl sin
78; CHECK: bl sin
79  %1 = call <4 x float> @llvm.sin.v4f32(<4 x float> %v1)
80  ret <4 x float> %1
81}
82
83define <4 x float> @test_pow_v4f32(<4 x float> %v1, <4 x float> %v2) {
84; CHECK-LABEL: test_pow_v4f32:
85; CHECK: bl pow
86; CHECK: bl pow
87; CHECK: bl pow
88; CHECK: bl pow
89  %1 = call <4 x float> @llvm.pow.v4f32(<4 x float> %v1, <4 x float> %v2)
90  ret <4 x float> %1
91}
92
93declare <4 x float> @llvm.cos.v4f32(<4 x float>)
94declare <4 x float> @llvm.sin.v4f32(<4 x float>)
95declare <4 x float> @llvm.pow.v4f32(<4 x float>, <4 x float>)
96
97