diff options
author | Dan Gohman <sunfish@mozilla.com> | 2014-03-04 15:05:27 -0800 |
---|---|---|
committer | Dan Gohman <sunfish@mozilla.com> | 2014-03-04 21:19:33 -0800 |
commit | b0180f577b7fd17af324781bfd2ab5b2d66cb204 (patch) | |
tree | 67edf13f89401d7f3f5d874bce0832449b475af0 /lib/Target/JSBackend/AllocaManager.cpp | |
parent | b516d172312af1ff8efddfdf1f825897bd4ea9c6 (diff) |
Perform alloca coloring only at -O1 and higher.
Diffstat (limited to 'lib/Target/JSBackend/AllocaManager.cpp')
-rw-r--r-- | lib/Target/JSBackend/AllocaManager.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/lib/Target/JSBackend/AllocaManager.cpp b/lib/Target/JSBackend/AllocaManager.cpp index 6c4c49f0d0..4673a34644 100644 --- a/lib/Target/JSBackend/AllocaManager.cpp +++ b/lib/Target/JSBackend/AllocaManager.cpp @@ -450,7 +450,8 @@ void AllocaManager::computeFrameOffsets() { AllocaManager::AllocaManager() { } -void AllocaManager::analyze(const Function &Func, const DataLayout &Layout) { +void AllocaManager::analyze(const Function &Func, const DataLayout &Layout, + bool PerformColoring) { NamedRegionTimer Timer("AllocaManager", TimePassesIsEnabled); assert(Allocas.empty()); @@ -469,8 +470,11 @@ void AllocaManager::analyze(const Function &Func, const DataLayout &Layout) { LifetimeStart = M->getFunction(Intrinsic::getName(Intrinsic::lifetime_start)); LifetimeEnd = M->getFunction(Intrinsic::getName(Intrinsic::lifetime_end)); - if ((LifetimeStart && !LifetimeStart->use_empty()) || - (LifetimeEnd && !LifetimeEnd->use_empty())) { + // If we are optimizing and the module contains any lifetime intrinsics, run + // the alloca coloring algorithm. + if (PerformColoring && + ((LifetimeStart && !LifetimeStart->use_empty()) || + (LifetimeEnd && !LifetimeEnd->use_empty()))) { collectMarkedAllocas(); |