[llvm-commits] [llvm] r94937 - in /llvm/trunk: lib/Transforms/Scalar/TailRecursionElimination.cpp test/Transforms/TailCallElim/no-return-calls.ll
Evan Cheng
evan.cheng at apple.com
Sat Jan 30 16:59:32 PST 2010
Author: evancheng
Date: Sat Jan 30 18:59:31 2010
New Revision: 94937
URL: http://llvm.org/viewvc/llvm-project?rev=94937&view=rev
Log:
Do not mark no-return calls tail calls. It'll screw up special calls like longjmp and it doesn't make much sense for performance reason. If my logic is faulty, please let me know.
Added:
llvm/trunk/test/Transforms/TailCallElim/no-return-calls.ll
Modified:
llvm/trunk/lib/Transforms/Scalar/TailRecursionElimination.cpp
Modified: llvm/trunk/lib/Transforms/Scalar/TailRecursionElimination.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/TailRecursionElimination.cpp?rev=94937&r1=94936&r2=94937&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/TailRecursionElimination.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/TailRecursionElimination.cpp Sat Jan 30 18:59:31 2010
@@ -184,10 +184,11 @@
if (!FunctionContainsEscapingAllocas)
for (Function::iterator BB = F.begin(), E = F.end(); BB != E; ++BB)
for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; ++I)
- if (CallInst *CI = dyn_cast<CallInst>(I)) {
- CI->setTailCall();
- MadeChange = true;
- }
+ if (CallInst *CI = dyn_cast<CallInst>(I))
+ if (!CI->doesNotReturn()) {
+ CI->setTailCall();
+ MadeChange = true;
+ }
return MadeChange;
}
Added: llvm/trunk/test/Transforms/TailCallElim/no-return-calls.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/TailCallElim/no-return-calls.ll?rev=94937&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/TailCallElim/no-return-calls.ll (added)
+++ llvm/trunk/test/Transforms/TailCallElim/no-return-calls.ll Sat Jan 30 18:59:31 2010
@@ -0,0 +1,12 @@
+; RUN: opt < %s -tailcallelim -S | FileCheck %s
+
+define void @t() nounwind ssp {
+entry:
+; CHECK: entry:
+; CHECK: %0 = call i32 @foo()
+; CHECK: ret void
+ %0 = call i32 @foo() nounwind noreturn
+ ret void
+}
+
+declare i32 @foo()
More information about the llvm-commits
mailing list