diff options
author | Owen Anderson <resistor@mac.com> | 2010-09-29 18:05:19 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2010-09-29 18:05:19 +0000 |
commit | eabfd7cc064483a26734d8f7fe7a2f0605aee686 (patch) | |
tree | cf3b5cb98b6ca53db9bd91f148d0fcda33ce375f | |
parent | 356806702470ae0a561d25de0121a58126e7088b (diff) | |
download | external_llvm-eabfd7cc064483a26734d8f7fe7a2f0605aee686.tar.gz external_llvm-eabfd7cc064483a26734d8f7fe7a2f0605aee686.tar.bz2 external_llvm-eabfd7cc064483a26734d8f7fe7a2f0605aee686.zip |
Revert r114919, which caused some serious regressions on ARM.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@115053 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Transforms/Scalar/LoopUnrollPass.cpp | 7 |
1 files changed, 1 insertions, 6 deletions
diff --git a/lib/Transforms/Scalar/LoopUnrollPass.cpp b/lib/Transforms/Scalar/LoopUnrollPass.cpp index 99a38b1ed0..7da2b52da5 100644 --- a/lib/Transforms/Scalar/LoopUnrollPass.cpp +++ b/lib/Transforms/Scalar/LoopUnrollPass.cpp @@ -158,12 +158,7 @@ bool LoopUnroll::runOnLoop(Loop *L, LPPassManager &LPM) { DEBUG(dbgs() << " Not unrolling loop with inlinable calls.\n"); return false; } - - // NOTE: We multiply by the loop depth because unrolling inner loops of - // very deep nests tends to result in high register pressure, which we don't - // currently recover from very well. When and if the register allocator/ - // spiller improves to compensate, this should be re-evaluated. - uint64_t Size = (uint64_t)LoopSize*Count*L->getLoopDepth(); + uint64_t Size = (uint64_t)LoopSize*Count; if (TripCount != 1 && Size > CurrentThreshold) { DEBUG(dbgs() << " Too large to fully unroll with count: " << Count << " because size: " << Size << ">" << CurrentThreshold << "\n"); |