summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-09-10 20:58:55 +0000
committerChris Lattner <sabre@nondot.org>2007-09-10 20:58:55 +0000
commitc75cbe6473d7be8c6eab57c1652394fbc57d9dd3 (patch)
tree070911b8bae70a0d9f39879671cbd961cd647ecb /llvm/lib/Transforms
parentacb1e7478f470e55851250348bdff2ae5e5330ba (diff)
downloadbcm5719-llvm-c75cbe6473d7be8c6eab57c1652394fbc57d9dd3.tar.gz
bcm5719-llvm-c75cbe6473d7be8c6eab57c1652394fbc57d9dd3.zip
Prevent tailcallelim from breaking "recursive" calls to builtins.
llvm-svn: 41804
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp9
1 files changed, 9 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp
index 497b81fecde..7eb47ddaa4f 100644
--- a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp
+++ b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp
@@ -302,6 +302,15 @@ bool TailCallElim::ProcessReturningBlock(ReturnInst *Ret, BasicBlock *&OldEntry,
if (&BB->front() == Ret) // Make sure there is something before the ret...
return false;
+
+ // If the return is in the entry block, then making this transformation would
+ // turn infinite recursion into an infinite loop. This transformation is ok
+ // in theory, but breaks some code like:
+ // double fabs(double f) { return __builtin_fabs(f); } // a 'fabs' call
+ // disable this xform in this case, because the code generator will lower the
+ // call to fabs into inline code.
+ if (BB == &F->getEntryBlock())
+ return false;
// Scan backwards from the return, checking to see if there is a tail call in
// this block. If so, set CI to it.
OpenPOWER on IntegriCloud