diff options
Diffstat (limited to 'test/CodeGen/ARM/vfp.ll')
| -rw-r--r-- | test/CodeGen/ARM/vfp.ll | 156 |
1 files changed, 0 insertions, 156 deletions
diff --git a/test/CodeGen/ARM/vfp.ll b/test/CodeGen/ARM/vfp.ll deleted file mode 100644 index 03c0354aa1df..000000000000 --- a/test/CodeGen/ARM/vfp.ll +++ /dev/null @@ -1,156 +0,0 @@ -; RUN: llc < %s -mtriple=arm-apple-ios -mattr=+vfp2 -disable-post-ra | FileCheck %s -; RUN: llc < %s -mtriple=arm-apple-ios -mattr=+vfp2 -disable-post-ra -regalloc=basic | FileCheck %s - -define void @test(float* %P, double* %D) { - %A = load float, float* %P ; <float> [#uses=1] - %B = load double, double* %D ; <double> [#uses=1] - store float %A, float* %P - store double %B, double* %D - ret void -} - -declare float @fabsf(float) - -declare double @fabs(double) - -define void @test_abs(float* %P, double* %D) { -;CHECK-LABEL: test_abs: - %a = load float, float* %P ; <float> [#uses=1] -;CHECK: vabs.f32 - %b = call float @fabsf( float %a ) readnone ; <float> [#uses=1] - store float %b, float* %P - %A = load double, double* %D ; <double> [#uses=1] -;CHECK: vabs.f64 - %B = call double @fabs( double %A ) readnone ; <double> [#uses=1] - store double %B, double* %D - ret void -} - -define void @test_add(float* %P, double* %D) { -;CHECK-LABEL: test_add: - %a = load float, float* %P ; <float> [#uses=2] - %b = fadd float %a, %a ; <float> [#uses=1] - store float %b, float* %P - %A = load double, double* %D ; <double> [#uses=2] - %B = fadd double %A, %A ; <double> [#uses=1] - store double %B, double* %D - ret void -} - -define void @test_ext_round(float* %P, double* %D) { -;CHECK-LABEL: test_ext_round: - %a = load float, float* %P ; <float> [#uses=1] -;CHECK: vcvt.f64.f32 -;CHECK: vcvt.f32.f64 - %b = fpext float %a to double ; <double> [#uses=1] - %A = load double, double* %D ; <double> [#uses=1] - %B = fptrunc double %A to float ; <float> [#uses=1] - store double %b, double* %D - store float %B, float* %P - ret void -} - -define void @test_fma(float* %P1, float* %P2, float* %P3) { -;CHECK-LABEL: test_fma: - %a1 = load float, float* %P1 ; <float> [#uses=1] - %a2 = load float, float* %P2 ; <float> [#uses=1] - %a3 = load float, float* %P3 ; <float> [#uses=1] -;CHECK: vnmls.f32 - %X = fmul float %a1, %a2 ; <float> [#uses=1] - %Y = fsub float %X, %a3 ; <float> [#uses=1] - store float %Y, float* %P1 - ret void -} - -define i32 @test_ftoi(float* %P1) { -;CHECK-LABEL: test_ftoi: - %a1 = load float, float* %P1 ; <float> [#uses=1] -;CHECK: vcvt.s32.f32 - %b1 = fptosi float %a1 to i32 ; <i32> [#uses=1] - ret i32 %b1 -} - -define i32 @test_ftou(float* %P1) { -;CHECK-LABEL: test_ftou: - %a1 = load float, float* %P1 ; <float> [#uses=1] -;CHECK: vcvt.u32.f32 - %b1 = fptoui float %a1 to i32 ; <i32> [#uses=1] - ret i32 %b1 -} - -define i32 @test_dtoi(double* %P1) { -;CHECK-LABEL: test_dtoi: - %a1 = load double, double* %P1 ; <double> [#uses=1] -;CHECK: vcvt.s32.f64 - %b1 = fptosi double %a1 to i32 ; <i32> [#uses=1] - ret i32 %b1 -} - -define i32 @test_dtou(double* %P1) { -;CHECK-LABEL: test_dtou: - %a1 = load double, double* %P1 ; <double> [#uses=1] -;CHECK: vcvt.u32.f64 - %b1 = fptoui double %a1 to i32 ; <i32> [#uses=1] - ret i32 %b1 -} - -define void @test_utod(double* %P1, i32 %X) { -;CHECK-LABEL: test_utod: -;CHECK: vcvt.f64.u32 - %b1 = uitofp i32 %X to double ; <double> [#uses=1] - store double %b1, double* %P1 - ret void -} - -define void @test_utod2(double* %P1, i8 %X) { -;CHECK-LABEL: test_utod2: -;CHECK: vcvt.f64.u32 - %b1 = uitofp i8 %X to double ; <double> [#uses=1] - store double %b1, double* %P1 - ret void -} - -define void @test_cmp(float* %glob, i32 %X) { -;CHECK-LABEL: test_cmp: -entry: - %tmp = load float, float* %glob ; <float> [#uses=2] - %tmp3 = getelementptr float, float* %glob, i32 2 ; <float*> [#uses=1] - %tmp4 = load float, float* %tmp3 ; <float> [#uses=2] - %tmp.upgrd.1 = fcmp oeq float %tmp, %tmp4 ; <i1> [#uses=1] - %tmp5 = fcmp uno float %tmp, %tmp4 ; <i1> [#uses=1] - %tmp6 = or i1 %tmp.upgrd.1, %tmp5 ; <i1> [#uses=1] -;CHECK: bmi -;CHECK-NEXT: bgt - br i1 %tmp6, label %cond_true, label %cond_false - -cond_true: ; preds = %entry - %tmp.upgrd.2 = tail call i32 (...) @bar( ) ; <i32> [#uses=0] - ret void - -cond_false: ; preds = %entry - %tmp7 = tail call i32 (...) @baz( ) ; <i32> [#uses=0] - ret void -} - -declare i1 @llvm.isunordered.f32(float, float) - -declare i32 @bar(...) - -declare i32 @baz(...) - -define void @test_cmpfp0(float* %glob, i32 %X) { -;CHECK-LABEL: test_cmpfp0: -entry: - %tmp = load float, float* %glob ; <float> [#uses=1] -;CHECK: vcmpe.f32 - %tmp.upgrd.3 = fcmp ogt float %tmp, 0.000000e+00 ; <i1> [#uses=1] - br i1 %tmp.upgrd.3, label %cond_true, label %cond_false - -cond_true: ; preds = %entry - %tmp.upgrd.4 = tail call i32 (...) @bar( ) ; <i32> [#uses=0] - ret void - -cond_false: ; preds = %entry - %tmp1 = tail call i32 (...) @baz( ) ; <i32> [#uses=0] - ret void -} |
