[llvm] r354013 - [NFC] Refactor LICM code for better readability
Max Kazantsev via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 14 01:04:12 PST 2019
Author: mkazantsev
Date: Thu Feb 14 01:04:12 2019
New Revision: 354013
URL: http://llvm.org/viewvc/llvm-project?rev=354013&view=rev
Log:
[NFC] Refactor LICM code for better readability
Modified:
llvm/trunk/lib/Transforms/Scalar/LICM.cpp
Modified: llvm/trunk/lib/Transforms/Scalar/LICM.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/LICM.cpp?rev=354013&r1=354012&r2=354013&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/LICM.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/LICM.cpp Thu Feb 14 01:04:12 2019
@@ -856,13 +856,18 @@ bool llvm::hoistRegion(DomTreeNode *N, A
continue;
}
- using namespace PatternMatch;
- if (((I.use_empty() &&
- match(&I, m_Intrinsic<Intrinsic::invariant_start>())) ||
- isGuard(&I)) &&
+ auto IsInvariantStart = [&](Instruction &I) {
+ using namespace PatternMatch;
+ return I.use_empty() &&
+ match(&I, m_Intrinsic<Intrinsic::invariant_start>());
+ };
+ auto MustExecuteWithoutWritesBefore = [&](Instruction &I) {
+ return SafetyInfo->isGuaranteedToExecute(I, DT, CurLoop) &&
+ SafetyInfo->doesNotWriteMemoryBefore(I, CurLoop);
+ };
+ if ((IsInvariantStart(I) || isGuard(&I)) &&
CurLoop->hasLoopInvariantOperands(&I) &&
- SafetyInfo->isGuaranteedToExecute(I, DT, CurLoop) &&
- SafetyInfo->doesNotWriteMemoryBefore(I, CurLoop)) {
+ MustExecuteWithoutWritesBefore(I)) {
hoist(I, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
MSSAU, ORE);
HoistedInstructions.push_back(&I);
More information about the llvm-commits
mailing list