diff options
author | Dan Gohman <gohman@apple.com> | 2008-09-15 19:46:03 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2008-09-15 19:46:03 +0000 |
commit | 5eb0cecbc5dd370e33d4e0ab1abee7ce8597ca9c (patch) | |
tree | 4f5fefe12cb40aa66a64bb645792b7b7c712245e /test/CodeGen/ARM | |
parent | f19063b33f69dd4c1087f98e7b4d8a9a1155229a (diff) | |
download | external_llvm-5eb0cecbc5dd370e33d4e0ab1abee7ce8597ca9c.zip external_llvm-5eb0cecbc5dd370e33d4e0ab1abee7ce8597ca9c.tar.gz external_llvm-5eb0cecbc5dd370e33d4e0ab1abee7ce8597ca9c.tar.bz2 |
Re-enable SelectionDAG CSE for calls. It matters in the case of
libcalls, as in this testcase on ARM.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56226 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/ARM')
-rw-r--r-- | test/CodeGen/ARM/cse-libcalls.ll | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/test/CodeGen/ARM/cse-libcalls.ll b/test/CodeGen/ARM/cse-libcalls.ll new file mode 100644 index 0000000..3b499a4 --- /dev/null +++ b/test/CodeGen/ARM/cse-libcalls.ll @@ -0,0 +1,30 @@ +; RUN: llvm-as < %s | llc -march=arm | grep {bl.\*__ltdf} | count 1 +target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128" +target triple = "i386-apple-darwin8" + +; Without CSE of libcalls, there are two calls in the output instead of one. + +define i32 @u_f_nonbon(double %lambda) nounwind { +entry: + %tmp19.i.i = load double* null, align 4 ; <double> [#uses=2] + %tmp6.i = fcmp olt double %tmp19.i.i, 1.000000e+00 ; <i1> [#uses=1] + %dielectric.0.i = select i1 %tmp6.i, double 1.000000e+00, double %tmp19.i.i ; <double> [#uses=1] + %tmp10.i4 = fdiv double 0x4074C2D71F36262D, %dielectric.0.i ; <double> [#uses=1] + br i1 false, label %bb28.i, label %bb508.i + +bb28.i: ; preds = %bb28.i, %entry + br i1 false, label %bb502.loopexit.i, label %bb28.i + +bb.nph53.i: ; preds = %bb502.loopexit.i + %tmp354.i = sub double -0.000000e+00, %tmp10.i4 ; <double> [#uses=0] + br label %bb244.i + +bb244.i: ; preds = %bb244.i, %bb.nph53.i + br label %bb244.i + +bb502.loopexit.i: ; preds = %bb28.i + br i1 false, label %bb.nph53.i, label %bb508.i + +bb508.i: ; preds = %bb502.loopexit.i, %entry + ret i32 1 +} |