aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2010-04-21 00:43:30 +0000
committerDan Gohman <gohman@apple.com>2010-04-21 00:43:30 +0000
commitd217cfcf468712780cb3b06a36e0ce53897592c1 (patch)
treee87c5a6e0e9d0da2bef62527aa1d8bebe4854a21
parenta040fffefbc7f653d68154b16b8d3c2ee2a6a639 (diff)
downloadexternal_llvm-d217cfcf468712780cb3b06a36e0ce53897592c1.tar.gz
external_llvm-d217cfcf468712780cb3b06a36e0ce53897592c1.tar.bz2
external_llvm-d217cfcf468712780cb3b06a36e0ce53897592c1.zip
Revert r101471. For tight recursive functions which have multiple
recursive callsites, inlining can reduce the number of calls by exponential factors, as it does in MultiSource/Benchmarks/Olden/treeadd. More involved heuristics will be needed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@101969 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Analysis/InlineCost.cpp7
-rw-r--r--test/Transforms/Inline/tail-recursion.ll29
2 files changed, 0 insertions, 36 deletions
diff --git a/lib/Analysis/InlineCost.cpp b/lib/Analysis/InlineCost.cpp
index 50400d3085..cb9e5526fc 100644
--- a/lib/Analysis/InlineCost.cpp
+++ b/lib/Analysis/InlineCost.cpp
@@ -263,13 +263,6 @@ InlineCost InlineCostAnalyzer::getInlineCost(CallSite CS,
CS.isNoInline())
return llvm::InlineCost::getNever();
- // Don't inline directly recursive calls, for now. Inlining a directly
- // recursive call is effectively unrolling a loop, so it calls for different
- // heuristics, which aren't implemented yet. Until then, err on the
- // conservative side.
- if (Callee == Caller)
- return llvm::InlineCost::getNever();
-
// InlineCost - This value measures how good of an inline candidate this call
// site is to inline. A lower inline cost make is more likely for the call to
// be inlined. This value may go negative.
diff --git a/test/Transforms/Inline/tail-recursion.ll b/test/Transforms/Inline/tail-recursion.ll
deleted file mode 100644
index 146bed4cd0..0000000000
--- a/test/Transforms/Inline/tail-recursion.ll
+++ /dev/null
@@ -1,29 +0,0 @@
-; RUN: opt -inline -tailcallelim -indvars -loop-deletion -S < %s | FileCheck %s
-
-; Inline shouldn't inline foo into itself because it's a tailcallelim
-; candidate. Tailcallelim should convert the call into a loop. Indvars
-; should calculate the exit value, making the loop dead. Loop deletion
-; should delete the loop.
-; PR6842
-
-; CHECK: define i32 @bar() nounwind {
-; CHECK-NEXT: ret i32 10000
-; CHECK-NEXT: }
-
-define internal i32 @foo(i32 %x) nounwind {
- %i = add i32 %x, 1 ; <i32> [#uses=3]
- %a = icmp slt i32 %i, 10000 ; <i1> [#uses=1]
- br i1 %a, label %more, label %done
-
-done: ; preds = %0
- ret i32 %i
-
-more: ; preds = %0
- %z = tail call i32 @foo(i32 %i) ; <i32> [#uses=1]
- ret i32 %z
-}
-
-define i32 @bar() nounwind {
- %z = call i32 @foo(i32 0) ; <i32> [#uses=1]
- ret i32 %z
-}