diff options
| author | Saleem Abdulrasool <compnerd@compnerd.org> | 2014-10-16 03:27:30 +0000 |
|---|---|---|
| committer | Saleem Abdulrasool <compnerd@compnerd.org> | 2014-10-16 03:27:30 +0000 |
| commit | 7f52921976906112e9022006a1ca47cf80b16bc6 (patch) | |
| tree | 11d5c7a0c332bc01c9031196b84efacc8b64b79a /llvm/lib/Transforms | |
| parent | ce842e8c4a4daa48e8aa71336db7797ea91520dc (diff) | |
| download | bcm5719-llvm-7f52921976906112e9022006a1ca47cf80b16bc6.tar.gz bcm5719-llvm-7f52921976906112e9022006a1ca47cf80b16bc6.zip | |
TRE: make TRE a bit more aggressive
Make tail recursion elimination a bit more aggressive. This allows us to get
tail recursion on functions that are just branches to a different function. The
fact that the function takes a byval argument does not restrict it from being
optimised into just a tail call.
llvm-svn: 219899
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp | 10 |
1 files changed, 2 insertions, 8 deletions
diff --git a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp index b7580255150..f8eafc845db 100644 --- a/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp +++ b/llvm/lib/Transforms/Scalar/TailRecursionElimination.cpp @@ -249,12 +249,7 @@ 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)) @@ -310,9 +305,8 @@ bool TailCallElim::markTails(Function &F, bool &AllCallsAreTailCalls) { for (auto &Arg : CI->arg_operands()) { if (isa<Constant>(Arg.getUser())) continue; - if (Argument *A = dyn_cast<Argument>(Arg.getUser())) - if (!A->hasByValAttr()) - continue; + if (isa<Argument>(Arg.getUser())) + continue; SafeToTail = false; break; } |

