blob: 44a44afe9af40208ebcff2aae395a369d3467394 [file] [log] [blame]
Bob Wilson9b379dc2009-09-15 20:58:02 +00001; RUN: llc < %s -march=arm -mattr=+vfp2 | FileCheck %s
Evan Cheng02b985c2007-01-19 09:20:23 +00002
Tanya Lattner6263f942008-02-17 20:02:20 +00003define void @test(float* %P, double* %D) {
4 %A = load float* %P ; <float> [#uses=1]
5 %B = load double* %D ; <double> [#uses=1]
6 store float %A, float* %P
7 store double %B, double* %D
8 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +00009}
10
Tanya Lattner6263f942008-02-17 20:02:20 +000011declare float @fabsf(float)
Evan Cheng02b985c2007-01-19 09:20:23 +000012
Tanya Lattner6263f942008-02-17 20:02:20 +000013declare double @fabs(double)
Evan Cheng02b985c2007-01-19 09:20:23 +000014
Tanya Lattner6263f942008-02-17 20:02:20 +000015define void @test_abs(float* %P, double* %D) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000016;CHECK: test_abs:
Tanya Lattner6263f942008-02-17 20:02:20 +000017 %a = load float* %P ; <float> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000018;CHECK: vabs.f32
Tanya Lattner6263f942008-02-17 20:02:20 +000019 %b = call float @fabsf( float %a ) ; <float> [#uses=1]
20 store float %b, float* %P
21 %A = load double* %D ; <double> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000022;CHECK: vabs.f64
Tanya Lattner6263f942008-02-17 20:02:20 +000023 %B = call double @fabs( double %A ) ; <double> [#uses=1]
24 store double %B, double* %D
25 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +000026}
27
Tanya Lattner6263f942008-02-17 20:02:20 +000028define void @test_add(float* %P, double* %D) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000029;CHECK: test_add:
Tanya Lattner6263f942008-02-17 20:02:20 +000030 %a = load float* %P ; <float> [#uses=2]
Dan Gohmanae3a0be2009-06-04 22:49:04 +000031 %b = fadd float %a, %a ; <float> [#uses=1]
Tanya Lattner6263f942008-02-17 20:02:20 +000032 store float %b, float* %P
33 %A = load double* %D ; <double> [#uses=2]
Dan Gohmanae3a0be2009-06-04 22:49:04 +000034 %B = fadd double %A, %A ; <double> [#uses=1]
Tanya Lattner6263f942008-02-17 20:02:20 +000035 store double %B, double* %D
36 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +000037}
38
Tanya Lattner6263f942008-02-17 20:02:20 +000039define void @test_ext_round(float* %P, double* %D) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000040;CHECK: test_ext_round:
Tanya Lattner6263f942008-02-17 20:02:20 +000041 %a = load float* %P ; <float> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000042;CHECK: vcvt.f64.f32
Tanya Lattner6263f942008-02-17 20:02:20 +000043 %b = fpext float %a to double ; <double> [#uses=1]
44 %A = load double* %D ; <double> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000045;CHECK: vcvt.f32.f64
Tanya Lattner6263f942008-02-17 20:02:20 +000046 %B = fptrunc double %A to float ; <float> [#uses=1]
47 store double %b, double* %D
48 store float %B, float* %P
49 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +000050}
51
Tanya Lattner6263f942008-02-17 20:02:20 +000052define void @test_fma(float* %P1, float* %P2, float* %P3) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000053;CHECK: test_fma:
Tanya Lattner6263f942008-02-17 20:02:20 +000054 %a1 = load float* %P1 ; <float> [#uses=1]
55 %a2 = load float* %P2 ; <float> [#uses=1]
56 %a3 = load float* %P3 ; <float> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000057;CHECK: vnmls.f32
Dan Gohmanae3a0be2009-06-04 22:49:04 +000058 %X = fmul float %a1, %a2 ; <float> [#uses=1]
59 %Y = fsub float %X, %a3 ; <float> [#uses=1]
Tanya Lattner6263f942008-02-17 20:02:20 +000060 store float %Y, float* %P1
61 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +000062}
63
Tanya Lattner6263f942008-02-17 20:02:20 +000064define i32 @test_ftoi(float* %P1) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000065;CHECK: test_ftoi:
Tanya Lattner6263f942008-02-17 20:02:20 +000066 %a1 = load float* %P1 ; <float> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000067;CHECK: vcvt.s32.f32
Tanya Lattner6263f942008-02-17 20:02:20 +000068 %b1 = fptosi float %a1 to i32 ; <i32> [#uses=1]
69 ret i32 %b1
Evan Cheng02b985c2007-01-19 09:20:23 +000070}
71
Tanya Lattner6263f942008-02-17 20:02:20 +000072define i32 @test_ftou(float* %P1) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000073;CHECK: test_ftou:
Tanya Lattner6263f942008-02-17 20:02:20 +000074 %a1 = load float* %P1 ; <float> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000075;CHECK: vcvt.u32.f32
Tanya Lattner6263f942008-02-17 20:02:20 +000076 %b1 = fptoui float %a1 to i32 ; <i32> [#uses=1]
77 ret i32 %b1
Evan Cheng02b985c2007-01-19 09:20:23 +000078}
79
Tanya Lattner6263f942008-02-17 20:02:20 +000080define i32 @test_dtoi(double* %P1) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000081;CHECK: test_dtoi:
Tanya Lattner6263f942008-02-17 20:02:20 +000082 %a1 = load double* %P1 ; <double> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000083;CHECK: vcvt.s32.f64
Tanya Lattner6263f942008-02-17 20:02:20 +000084 %b1 = fptosi double %a1 to i32 ; <i32> [#uses=1]
85 ret i32 %b1
Evan Cheng02b985c2007-01-19 09:20:23 +000086}
87
Tanya Lattner6263f942008-02-17 20:02:20 +000088define i32 @test_dtou(double* %P1) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000089;CHECK: test_dtou:
Tanya Lattner6263f942008-02-17 20:02:20 +000090 %a1 = load double* %P1 ; <double> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +000091;CHECK: vcvt.u32.f64
Tanya Lattner6263f942008-02-17 20:02:20 +000092 %b1 = fptoui double %a1 to i32 ; <i32> [#uses=1]
93 ret i32 %b1
Evan Cheng02b985c2007-01-19 09:20:23 +000094}
95
Tanya Lattner6263f942008-02-17 20:02:20 +000096define void @test_utod(double* %P1, i32 %X) {
Bob Wilson9b379dc2009-09-15 20:58:02 +000097;CHECK: test_utod:
Jim Grosbache5165492009-11-09 00:11:35 +000098;CHECK: vcvt.f64.u32
Tanya Lattner6263f942008-02-17 20:02:20 +000099 %b1 = uitofp i32 %X to double ; <double> [#uses=1]
100 store double %b1, double* %P1
101 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +0000102}
103
Tanya Lattner6263f942008-02-17 20:02:20 +0000104define void @test_utod2(double* %P1, i8 %X) {
Bob Wilson9b379dc2009-09-15 20:58:02 +0000105;CHECK: test_utod2:
Jim Grosbache5165492009-11-09 00:11:35 +0000106;CHECK: vcvt.f64.u32
Tanya Lattner6263f942008-02-17 20:02:20 +0000107 %b1 = uitofp i8 %X to double ; <double> [#uses=1]
108 store double %b1, double* %P1
109 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +0000110}
111
Tanya Lattner6263f942008-02-17 20:02:20 +0000112define void @test_cmp(float* %glob, i32 %X) {
Bob Wilson9b379dc2009-09-15 20:58:02 +0000113;CHECK: test_cmp:
Evan Cheng02b985c2007-01-19 09:20:23 +0000114entry:
Tanya Lattner6263f942008-02-17 20:02:20 +0000115 %tmp = load float* %glob ; <float> [#uses=2]
116 %tmp3 = getelementptr float* %glob, i32 2 ; <float*> [#uses=1]
117 %tmp4 = load float* %tmp3 ; <float> [#uses=2]
118 %tmp.upgrd.1 = fcmp oeq float %tmp, %tmp4 ; <i1> [#uses=1]
119 %tmp5 = fcmp uno float %tmp, %tmp4 ; <i1> [#uses=1]
120 %tmp6 = or i1 %tmp.upgrd.1, %tmp5 ; <i1> [#uses=1]
Bob Wilson9b379dc2009-09-15 20:58:02 +0000121;CHECK: bmi
122;CHECK-NEXT: bgt
Tanya Lattner6263f942008-02-17 20:02:20 +0000123 br i1 %tmp6, label %cond_true, label %cond_false
Evan Cheng02b985c2007-01-19 09:20:23 +0000124
Tanya Lattner6263f942008-02-17 20:02:20 +0000125cond_true: ; preds = %entry
126 %tmp.upgrd.2 = tail call i32 (...)* @bar( ) ; <i32> [#uses=0]
127 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +0000128
Tanya Lattner6263f942008-02-17 20:02:20 +0000129cond_false: ; preds = %entry
130 %tmp7 = tail call i32 (...)* @baz( ) ; <i32> [#uses=0]
131 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +0000132}
133
Tanya Lattner6263f942008-02-17 20:02:20 +0000134declare i1 @llvm.isunordered.f32(float, float)
Evan Cheng02b985c2007-01-19 09:20:23 +0000135
Tanya Lattner6263f942008-02-17 20:02:20 +0000136declare i32 @bar(...)
Evan Cheng02b985c2007-01-19 09:20:23 +0000137
Tanya Lattner6263f942008-02-17 20:02:20 +0000138declare i32 @baz(...)
Evan Cheng02b985c2007-01-19 09:20:23 +0000139
Tanya Lattner6263f942008-02-17 20:02:20 +0000140define void @test_cmpfp0(float* %glob, i32 %X) {
Bob Wilson9b379dc2009-09-15 20:58:02 +0000141;CHECK: test_cmpfp0:
Evan Cheng02b985c2007-01-19 09:20:23 +0000142entry:
Tanya Lattner6263f942008-02-17 20:02:20 +0000143 %tmp = load float* %glob ; <float> [#uses=1]
Jim Grosbache5165492009-11-09 00:11:35 +0000144;CHECK: vcmpe.f32
Tanya Lattner6263f942008-02-17 20:02:20 +0000145 %tmp.upgrd.3 = fcmp ogt float %tmp, 0.000000e+00 ; <i1> [#uses=1]
146 br i1 %tmp.upgrd.3, label %cond_true, label %cond_false
Evan Cheng02b985c2007-01-19 09:20:23 +0000147
Tanya Lattner6263f942008-02-17 20:02:20 +0000148cond_true: ; preds = %entry
149 %tmp.upgrd.4 = tail call i32 (...)* @bar( ) ; <i32> [#uses=0]
150 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +0000151
Tanya Lattner6263f942008-02-17 20:02:20 +0000152cond_false: ; preds = %entry
153 %tmp1 = tail call i32 (...)* @baz( ) ; <i32> [#uses=0]
154 ret void
Evan Cheng02b985c2007-01-19 09:20:23 +0000155}