diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-10-17 21:25:48 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-10-17 21:25:48 +0000 |
commit | 7da1ea83a9fd020b73a7c368b64fe231fb789966 (patch) | |
tree | dffe60ad9ef6b77222989ed443510ae5833ddd34 /llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp | |
parent | ba637db2986af2db841ac09cf11300d6bb6d155a (diff) | |
download | bcm5719-llvm-7da1ea83a9fd020b73a7c368b64fe231fb789966.tar.gz bcm5719-llvm-7da1ea83a9fd020b73a7c368b64fe231fb789966.zip |
Revert "TRE: make TRE a bit more aggressive"
This reverts commit r219899.
This also updates byval-tail-call.ll to make it clear what was breaking.
Adding r219899 again will cause the load/store to disappear.
llvm-svn: 220093
Diffstat (limited to 'llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp index f8eafc845db..b7580255150 100644 --- a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp +++ b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp @@ -249,7 +249,12 @@ bool TailCallElim::markTails(Function &F, bool &AllCallsAreTailCalls) { return false; AllCallsAreTailCalls = true; + // The local stack holds all alloca instructions and all byval arguments. AllocaDerivedValueTracker Tracker; + for (Argument &Arg : F.args()) { + if (Arg.hasByValAttr()) + Tracker.walk(&Arg); + } for (auto &BB : F) { for (auto &I : BB) if (AllocaInst *AI = dyn_cast<AllocaInst>(&I)) @@ -305,8 +310,9 @@ bool TailCallElim::markTails(Function &F, bool &AllCallsAreTailCalls) { for (auto &Arg : CI->arg_operands()) { if (isa<Constant>(Arg.getUser())) continue; - if (isa<Argument>(Arg.getUser())) - continue; + if (Argument *A = dyn_cast<Argument>(Arg.getUser())) + if (!A->hasByValAttr()) + continue; SafeToTail = false; break; } |