For PR1319: Upgrade to use new test harness
[oota-llvm.git] / test / CodeGen / ARM / fp.ll
index af5a69642c4490e4a985cc8b1519386c1acf0d46..b235fb215b742aac6e07ed6cb8a581e6fbbebe9c 100644 (file)
@@ -1,9 +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
+; 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:
@@ -16,3 +28,41 @@ entry:
         %tmp = cast int %a to double            ; <double> [#uses=1]
         ret double %tmp
 }
+
+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
+}
+
+double %f2(double %a) {
+        ret double %a
+}
+
+void %f3() {
+entry:
+       %tmp = call double %f5()                ; <double> [#uses=1]
+       call void %f4(double %tmp )
+       ret void
+}
+
+declare void %f4(double)
+declare double %f5()