For PR1319: Upgrade to use new test harness
[oota-llvm.git] / test / CodeGen / ARM / fp.ll
index 22382ea185e58949b66fc395de52d43a20a33000..b235fb215b742aac6e07ed6cb8a581e6fbbebe9c 100644 (file)
@@ -1,12 +1,21 @@
-; RUN: llvm-as < %s | llc -march=arm &&
-; RUN: llvm-as < %s | llc -march=arm | grep fmsr  | wc -l | grep 2 &&
-; RUN: llvm-as < %s | llc -march=arm | grep fsitos &&
-; RUN: llvm-as < %s | llc -march=arm | grep fmrs &&
-; RUN: llvm-as < %s | llc -march=arm | grep fsitod &&
-; RUN: llvm-as < %s | llc -march=arm | grep fmrrd | wc -l | grep 3 &&
-; RUN: llvm-as < %s | llc -march=arm | grep fmdrr | wc -l | grep 2 &&
-; RUN: llvm-as < %s | llc -march=arm | grep flds &&
-; RUN: llvm-as < %s | llc -march=arm | grep ".word.*1065353216"
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | \
+; RUN:   grep fmsr | wc -l | grep 4
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | \
+; RUN:   grep fsitos
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | \
+; RUN:   grep fmrs
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | \
+; RUN:   grep fsitod
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | \
+; RUN:   grep fmrrd | wc -l | grep 5
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | \
+; RUN:   grep fmdrr | wc -l | grep 2 &&
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | grep fldd
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | grep flds
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | grep fuitod
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | grep fuitos
+; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+vfp2 | \
+; RUN:   grep 1065353216
 
 float %f(int %a) {
 entry:
@@ -20,7 +29,26 @@ entry:
         ret double %tmp
 }
 
-float %h() {
+double %uint_to_double(uint %a) {
+entry:
+       %tmp = cast uint %a to double
+       ret double %tmp
+}
+
+float %uint_to_float(uint %a) {
+entry:
+       %tmp = cast uint %a to float
+       ret float %tmp
+}
+
+
+double %h(double* %v) {
+entry:
+       %tmp = load double* %v          ; <double> [#uses=1]
+       ret double %tmp
+}
+
+float %h2() {
 entry:
         ret float 1.000000e+00
 }
@@ -29,8 +57,12 @@ double %f2(double %a) {
         ret double %a
 }
 
-void %f3(double %a) {
-        call void %f4( double %a)
-        ret void
+void %f3() {
+entry:
+       %tmp = call double %f5()                ; <double> [#uses=1]
+       call void %f4(double %tmp )
+       ret void
 }
+
 declare void %f4(double)
+declare double %f5()