94#define DEBUG_TYPE "licm"
96STATISTIC(NumCreatedBlocks,
"Number of blocks created");
97STATISTIC(NumClonedBranches,
"Number of branches cloned");
98STATISTIC(NumSunk,
"Number of instructions sunk out of loop");
99STATISTIC(NumHoisted,
"Number of instructions hoisted out of loop");
100STATISTIC(NumMovedLoads,
"Number of load insts hoisted or sunk");
101STATISTIC(NumMovedCalls,
"Number of call insts hoisted or sunk");
102STATISTIC(NumPromotionCandidates,
"Number of promotion candidates");
103STATISTIC(NumLoadPromoted,
"Number of load-only promotions");
104STATISTIC(NumLoadStorePromoted,
"Number of load and store promotions");
106 "Number of min/max expressions hoisted out of the loop");
108 "Number of geps reassociated and hoisted out of the loop");
109STATISTIC(NumAddSubHoisted,
"Number of add/subtract expressions reassociated "
110 "and hoisted out of the loop");
111STATISTIC(NumFPAssociationsHoisted,
"Number of invariant FP expressions "
112 "reassociated and hoisted out of the loop");
114 "Number of invariant int expressions "
115 "reassociated and hoisted out of the loop");
116STATISTIC(NumBOAssociationsHoisted,
"Number of invariant BinaryOp expressions "
117 "reassociated and hoisted out of the loop");
122 cl::desc(
"Disable memory promotion in LICM pass"));
126 cl::desc(
"Enable control flow (and PHI) hoisting in LICM"));
130 cl::desc(
"Force thread model single in LICM pass"));
134 cl::desc(
"Max num uses visited for identifying load "
135 "invariance in loop using invariant start (default = 8)"));
140 "Set upper limit for the number of transformations performed "
141 "during a single round of hoisting the reassociated expressions."));
146 "Set upper limit for the number of transformations performed "
147 "during a single round of hoisting the reassociated expressions."));
159 cl::desc(
"Enable imprecision in LICM in pathological cases, in exchange "
160 "for faster compile. Caps the MemorySSA clobbering calls."));
167 cl::desc(
"[LICM & MemorySSA] When MSSA in LICM is disabled, this has no "
168 "effect. When MSSA in LICM is enabled, then this is the maximum "
169 "number of accesses allowed to be present in a loop in order to "
170 "enable memory promotion."));
178 bool &FoldableInLoop,
bool LoopNestMode);
197 bool InvariantGroup);
219 std::pair<SmallSetVector<Value *, 8>,
bool>;
224struct LoopInvariantCodeMotion {
230 LoopInvariantCodeMotion(
unsigned LicmMssaOptCap,
231 unsigned LicmMssaNoAccForPromotionCap,
232 bool LicmAllowSpeculation)
233 : LicmMssaOptCap(LicmMssaOptCap),
234 LicmMssaNoAccForPromotionCap(LicmMssaNoAccForPromotionCap),
235 LicmAllowSpeculation(LicmAllowSpeculation) {}
238 unsigned LicmMssaOptCap;
239 unsigned LicmMssaNoAccForPromotionCap;
240 bool LicmAllowSpeculation;
243struct LegacyLICMPass :
public LoopPass {
248 bool LicmAllowSpeculation =
true)
249 :
LoopPass(
ID), LICM(LicmMssaOptCap, LicmMssaNoAccForPromotionCap,
250 LicmAllowSpeculation) {
259 <<
L->getHeader()->getNameOrAsOperand() <<
"\n");
263 auto *SE = getAnalysisIfAvailable<ScalarEvolutionWrapperPass>();
264 MemorySSA *MSSA = &getAnalysis<MemorySSAWrapperPass>().getMSSA();
269 return LICM.runOnLoop(
270 L, &getAnalysis<AAResultsWrapperPass>().getAAResults(),
271 &getAnalysis<LoopInfoWrapperPass>().getLoopInfo(),
272 &getAnalysis<DominatorTreeWrapperPass>().getDomTree(),
273 &getAnalysis<AssumptionCacheTracker>().getAssumptionCache(*
F),
274 &getAnalysis<TargetLibraryInfoWrapperPass>().getTLI(*
F),
275 &getAnalysis<TargetTransformInfoWrapperPass>().getTTI(*
F),
276 SE ? &SE->getSE() :
nullptr, MSSA, &ORE);
297 LoopInvariantCodeMotion LICM;
313 if (!LICM.runOnLoop(&L, &AR.
AA, &AR.
LI, &AR.
DT, &AR.
AC, &AR.
TLI, &AR.
TTI,
326 OS, MapClassName2PassName);
348 bool Changed = LICM.runOnLoop(&OutermostLoop, &AR.
AA, &AR.
LI, &AR.
DT, &AR.
AC,
366 OS, MapClassName2PassName);
373char LegacyLICMPass::ID = 0;
392 unsigned LicmMssaOptCap,
unsigned LicmMssaNoAccForPromotionCap,
bool IsSink,
394 : LicmMssaOptCap(LicmMssaOptCap),
395 LicmMssaNoAccForPromotionCap(LicmMssaNoAccForPromotionCap),
397 unsigned AccessCapCount = 0;
398 for (
auto *BB : L.getBlocks())
420 bool Changed =
false;
422 assert(L->isLCSSAForm(*DT) &&
"Loop is not in LCSSA form.");
440 return llvm::any_of(*BB, [](Instruction &I) {
441 IntrinsicInst *II = dyn_cast<IntrinsicInst>(&I);
442 return II && II->getIntrinsicID() == Intrinsic::coro_suspend;
466 if (
L->hasDedicatedExits())
470 TLI,
TTI, L, MSSAU, &SafetyInfo, Flags, ORE)
472 MSSAU, &SafetyInfo,
Flags, ORE);
473 Flags.setIsSink(
false);
476 MSSAU, SE, &SafetyInfo, Flags, ORE, LoopNestMode,
477 LicmAllowSpeculation, HasCoroSuspendInst);
487 !
Flags.tooManyMemoryAccesses() && !HasCoroSuspendInst) {
490 L->getUniqueExitBlocks(ExitBlocks);
494 return isa<CatchSwitchInst>(
Exit->getTerminator());
497 if (!HasCatchSwitch) {
503 InsertPts.
push_back(ExitBlock->getFirstInsertionPt());
511 bool Promoted =
false;
514 LocalPromoted =
false;
515 for (
auto [PointerMustAliases, HasReadsOutsideSet] :
518 PointerMustAliases, ExitBlocks, InsertPts, MSSAInsertPts,
PIC, LI,
519 DT, AC, TLI,
TTI, L, MSSAU, &SafetyInfo, ORE,
520 LicmAllowSpeculation, HasReadsOutsideSet);
522 Promoted |= LocalPromoted;
523 }
while (LocalPromoted);
541 assert(
L->isLCSSAForm(*DT) &&
"Loop not left in LCSSA form after LICM!");
542 assert((
L->isOutermost() ||
L->getParentLoop()->isLCSSAForm(*DT)) &&
543 "Parent loop not left in LCSSA form after LICM!");
566 assert(
N !=
nullptr && AA !=
nullptr && LI !=
nullptr && DT !=
nullptr &&
567 CurLoop !=
nullptr && SafetyInfo !=
nullptr &&
568 "Unexpected input to sinkRegion.");
576 bool Changed =
false;
602 bool FoldableInLoop =
false;
603 bool LoopNestMode = OutermostLoop !=
nullptr;
604 if (!
I.mayHaveSideEffects() &&
606 SafetyInfo,
TTI, FoldableInLoop,
609 if (
sink(
I, LI, DT, CurLoop, SafetyInfo, MSSAU, ORE)) {
610 if (!FoldableInLoop) {
633 bool Changed =
false;
637 while (!Worklist.
empty()) {
640 MSSAU, SafetyInfo, Flags, ORE, CurLoop);
653class ControlFlowHoister {
672 : LI(LI), DT(DT), CurLoop(CurLoop), MSSAU(MSSAU) {}
674 void registerPossiblyHoistableBranch(
BranchInst *BI) {
686 TrueDest == FalseDest)
699 if (TrueDestSucc.count(FalseDest)) {
700 CommonSucc = FalseDest;
701 }
else if (FalseDestSucc.count(TrueDest)) {
702 CommonSucc = TrueDest;
706 if (TrueDestSucc.size() == 1)
707 CommonSucc = *TrueDestSucc.
begin();
711 else if (!TrueDestSucc.empty()) {
713 auto IsSucc = [&](
BasicBlock &BB) {
return TrueDestSucc.count(&BB); };
715 assert(It !=
F->end() &&
"Could not find successor in function");
727 if (CommonSucc && DT->
dominates(BI, CommonSucc))
728 HoistableBranches[BI] = CommonSucc;
731 bool canHoistPHI(
PHINode *PN) {
745 if (PredecessorBlocks.size() !=
pred_size(BB))
747 for (
auto &Pair : HoistableBranches) {
748 if (Pair.second == BB) {
751 if (Pair.first->getSuccessor(0) == BB) {
752 PredecessorBlocks.erase(Pair.first->getParent());
753 PredecessorBlocks.erase(Pair.first->getSuccessor(1));
754 }
else if (Pair.first->getSuccessor(1) == BB) {
755 PredecessorBlocks.erase(Pair.first->getParent());
756 PredecessorBlocks.erase(Pair.first->getSuccessor(0));
758 PredecessorBlocks.erase(Pair.first->getSuccessor(0));
759 PredecessorBlocks.erase(Pair.first->getSuccessor(1));
765 return PredecessorBlocks.empty();
772 if (
auto It = HoistDestinationMap.
find(BB); It != HoistDestinationMap.
end())
776 auto HasBBAsSuccessor =
778 return BB != Pair.second && (Pair.first->getSuccessor(0) == BB ||
779 Pair.first->getSuccessor(1) == BB);
781 auto It =
llvm::find_if(HoistableBranches, HasBBAsSuccessor);
785 if (It == HoistableBranches.end()) {
788 <<
" as hoist destination for "
790 HoistDestinationMap[BB] = InitialPreheader;
791 return InitialPreheader;
794 assert(std::none_of(std::next(It), HoistableBranches.end(),
796 "BB is expected to be the target of at most one branch");
801 BasicBlock *CommonSucc = HoistableBranches[BI];
805 auto CreateHoistedBlock = [&](
BasicBlock *Orig) {
817 <<
" as hoist destination for " << Orig->getName()
821 BasicBlock *HoistTrueDest = CreateHoistedBlock(TrueDest);
822 BasicBlock *HoistFalseDest = CreateHoistedBlock(FalseDest);
823 BasicBlock *HoistCommonSucc = CreateHoistedBlock(CommonSucc);
830 assert(TargetSucc &&
"Expected hoist target to have a single successor");
845 if (HoistTarget == InitialPreheader) {
856 for (
auto &Pair : HoistDestinationMap)
857 if (Pair.second == InitialPreheader && Pair.first != BI->
getParent())
858 Pair.second = HoistCommonSucc;
869 NewBI->copyMetadata(*BI, {LLVMContext::MD_prof});
877 "Hoisting blocks should not have destroyed preheader");
878 return HoistDestinationMap[BB];
895 bool AllowSpeculation,
bool HasCoroSuspendInst) {
897 assert(
N !=
nullptr && AA !=
nullptr && LI !=
nullptr && DT !=
nullptr &&
898 CurLoop !=
nullptr && SafetyInfo !=
nullptr &&
899 "Unexpected input to hoistRegion.");
901 ControlFlowHoister CFH(LI, DT, CurLoop, MSSAU);
912 bool Changed =
false;
917 if (!LoopNestMode &&
inSubLoop(BB, CurLoop, LI))
933 hoist(
I, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
942 if (
I.getOpcode() == Instruction::FDiv &&
I.hasAllowReciprocal() &&
944 auto Divisor =
I.getOperand(1);
945 auto One = llvm::ConstantFP::get(Divisor->getType(), 1.0);
946 auto ReciprocalDivisor = BinaryOperator::CreateFDiv(One, Divisor);
947 ReciprocalDivisor->setFastMathFlags(
I.getFastMathFlags());
949 ReciprocalDivisor->insertBefore(
I.getIterator());
950 ReciprocalDivisor->setDebugLoc(
I.getDebugLoc());
953 BinaryOperator::CreateFMul(
I.getOperand(0), ReciprocalDivisor);
954 Product->setFastMathFlags(
I.getFastMathFlags());
956 Product->insertAfter(
I.getIterator());
957 Product->setDebugLoc(
I.getDebugLoc());
958 I.replaceAllUsesWith(Product);
961 hoist(*ReciprocalDivisor, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB),
962 SafetyInfo, MSSAU, SE, ORE);
963 HoistedInstructions.
push_back(ReciprocalDivisor);
969 using namespace PatternMatch;
970 return I.use_empty() &&
971 match(&
I, m_Intrinsic<Intrinsic::invariant_start>());
973 auto MustExecuteWithoutWritesBefore = [&](
Instruction &
I) {
977 if ((IsInvariantStart(
I) ||
isGuard(&
I)) &&
979 MustExecuteWithoutWritesBefore(
I)) {
980 hoist(
I, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
987 if (
PHINode *PN = dyn_cast<PHINode>(&
I)) {
988 if (CFH.canHoistPHI(PN)) {
994 hoist(*PN, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
1012 CFH.registerPossiblyHoistableBranch(BI);
1027 [&](
Use &U) { return DT->dominates(I, U); })) {
1033 "New hoist point expected to dominate old hoist point");
1037 << HoistPoint->
getParent()->getNameOrAsOperand()
1038 <<
": " << *
I <<
"\n");
1051#ifdef EXPENSIVE_CHECKS
1053 assert(DT->
verify(DominatorTree::VerificationLevel::Fast) &&
1054 "Dominator tree verification failed");
1086 if (isa<Constant>(
Addr))
1089 unsigned UsesVisited = 0;
1092 for (
auto *U :
Addr->users()) {
1099 if (!
II ||
II->getIntrinsicID() != Intrinsic::invariant_start ||
1102 ConstantInt *InvariantSize = cast<ConstantInt>(
II->getArgOperand(0));
1126 return (isa<LoadInst>(
I) || isa<StoreInst>(
I) || isa<CallInst>(
I) ||
1127 isa<FenceInst>(
I) || isa<CastInst>(
I) || isa<UnaryOperator>(
I) ||
1128 isa<BinaryOperator>(
I) || isa<SelectInst>(
I) ||
1129 isa<GetElementPtrInst>(
I) || isa<CmpInst>(
I) ||
1130 isa<InsertElementInst>(
I) || isa<ExtractElementInst>(
I) ||
1131 isa<ShuffleVectorInst>(
I) || isa<ExtractValueInst>(
I) ||
1132 isa<InsertValueInst>(
I) || isa<FreezeInst>(
I));
1138 for (
auto *BB :
L->getBlocks())
1141 for (
const auto &Acc : *Accs) {
1142 if (isa<MemoryPhi>(&Acc))
1144 const auto *MUD = cast<MemoryUseOrDef>(&Acc);
1145 if (MUD->getMemoryInst() !=
I || NotAPhi++ == 1)
1158 if (Flags.tooManyClobberingCalls())
1163 Flags.incrementClobberingCalls();
1169 bool TargetExecutesOncePerLoop,
1173 if (!isHoistableAndSinkableInst(
I))
1178 if (
LoadInst *LI = dyn_cast<LoadInst>(&
I)) {
1179 if (!LI->isUnordered())
1186 if (LI->hasMetadata(LLVMContext::MD_invariant_load))
1189 if (LI->isAtomic() && !TargetExecutesOncePerLoop)
1198 bool InvariantGroup = LI->hasMetadata(LLVMContext::MD_invariant_group);
1201 MSSA, MU, CurLoop,
I, Flags, InvariantGroup);
1204 if (ORE && Invalidated && CurLoop->
isLoopInvariant(LI->getPointerOperand()))
1207 DEBUG_TYPE,
"LoadWithLoopInvariantAddressInvalidated", LI)
1208 <<
"failed to move load with loop-invariant address "
1209 "because the loop may invalidate its value";
1212 return !Invalidated;
1213 }
else if (
CallInst *CI = dyn_cast<CallInst>(&
I)) {
1222 if (CI->isConvergent())
1230 if (CI->getFunction()->isPresplitCoroutine())
1233 using namespace PatternMatch;
1234 if (
match(CI, m_Intrinsic<Intrinsic::assume>()))
1253 MSSA, MU, CurLoop,
I, Flags,
false);
1263 }
else if (
auto *FI = dyn_cast<FenceInst>(&
I)) {
1266 return isOnlyMemoryAccess(FI, CurLoop, MSSAU);
1267 }
else if (
auto *SI = dyn_cast<StoreInst>(&
I)) {
1268 if (!SI->isUnordered())
1276 if (isOnlyMemoryAccess(SI, CurLoop, MSSAU))
1281 assert(!
I.mayReadOrWriteMemory() &&
"unhandled aliasing");
1304 if (
auto *
GEP = dyn_cast<GetElementPtrInst>(&
I)) {
1313 for (
const User *U :
GEP->users()) {
1317 (!isa<StoreInst>(UI) && !isa<LoadInst>(UI))))
1335 bool &FoldableInLoop,
bool LoopNestMode) {
1338 for (
const User *U :
I.users()) {
1340 if (
const PHINode *PN = dyn_cast<PHINode>(UI)) {
1348 if (isa<CallInst>(
I))
1349 if (!BlockColors.empty() &&
1350 BlockColors.find(
const_cast<BasicBlock *
>(BB))->second.size() != 1)
1354 while (isa<PHINode>(UI) && UI->
hasOneUser() &&
1358 UI = cast<Instruction>(UI->
user_back());
1365 FoldableInLoop =
true;
1378 if (
auto *CI = dyn_cast<CallInst>(&
I)) {
1385 for (
unsigned BundleIdx = 0, BundleEnd = CI->getNumOperandBundles();
1386 BundleIdx != BundleEnd; ++BundleIdx) {
1394 if (!BlockColors.empty()) {
1395 const ColorVector &CV = BlockColors.find(&ExitBlock)->second;
1396 assert(CV.
size() == 1 &&
"non-unique color for exit block!");
1399 if (EHPad->isEHPad())
1404 New->copyMetadata(*CI);
1410 if (!
I.getName().empty())
1411 New->setName(
I.getName() +
".le");
1421 if (
auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc))
1424 auto *MemUse = cast<MemoryUse>(NewMemAcc);
1437 for (
Use &
Op : New->operands())
1439 auto *OInst = cast<Instruction>(
Op.get());
1442 OInst->getName() +
".lcssa");
1455 I.eraseFromParent();
1464 I.moveBefore(*Dest->getParent(), Dest);
1479 "Expect only trivially replaceable PHI");
1481 auto [It, Inserted] = SunkCopies.
try_emplace(ExitBlock);
1500 if (isa<IndirectBrInst>(BBPred->getTerminator()))
1516 assert(ExitBlockSet.
count(ExitBB) &&
"Expect the PHI is in an exit block.");
1553 while (!PredBBs.
empty()) {
1556 "Expect all predecessors are in the loop");
1559 ExitBB, PredBB,
".split.loop.exit", &DTU, LI, MSSAU,
true);
1563 if (!BlockColors.empty())
1581 bool Changed =
false;
1588 auto *
User = cast<Instruction>(*UI);
1589 Use &U = UI.getUse();
1627 UI =
I.user_begin();
1631 if (VisitedUsers.
empty())
1636 <<
"sinking " <<
ore::NV(
"Inst", &
I);
1638 if (isa<LoadInst>(
I))
1640 else if (isa<CallInst>(
I))
1659 for (
auto *UI :
Users) {
1660 auto *
User = cast<Instruction>(UI);
1667 "The LCSSA PHI is not in an exit block!");
1671 PN, &
I, LI, SunkCopies, SafetyInfo, CurLoop, MSSAU);
1673 New->dropLocation();
1703 if ((
I.hasMetadataOtherThanDebugLoc() || isa<CallInst>(
I)) &&
1709 I.dropUBImplyingAttrsAndMetadata();
1711 I.dropUBImplyingAttrsAndMetadata({LLVMContext::MD_prof});
1714 if (isa<PHINode>(
I))
1722 I.updateLocationAfterHoist();
1724 if (isa<LoadInst>(
I))
1726 else if (isa<CallInst>(
I))
1739 if (AllowSpeculation &&
1743 bool GuaranteedToExecute =
1746 if (!GuaranteedToExecute) {
1747 auto *LI = dyn_cast<LoadInst>(&Inst);
1751 DEBUG_TYPE,
"LoadWithLoopInvariantAddressCondExecuted", LI)
1752 <<
"failed to hoist load with loop-invariant address "
1753 "because load is conditionally executed";
1757 return GuaranteedToExecute;
1771 bool UnorderedAtomic;
1774 bool CanInsertStoresInExitBlocks;
1788 I->getName() +
".lcssa");
1804 LoopInsertPts(LIP), MSSAInsertPts(MSSAIP), PredCache(
PIC), MSSAU(MSSAU),
1805 LI(li),
DL(
std::
move(dl)), Alignment(Alignment),
1806 UnorderedAtomic(UnorderedAtomic), AATags(AATags),
1807 SafetyInfo(SafetyInfo),
1808 CanInsertStoresInExitBlocks(CanInsertStoresInExitBlocks),
Uses(Insts) {}
1810 void insertStoresInLoopExitBlocks() {
1816 for (
unsigned i = 0, e = LoopExitBlocks.
size(); i != e; ++i) {
1818 Value *LiveInValue =
SSA.GetValueInMiddleOfBlock(ExitBlock);
1819 LiveInValue = maybeInsertLCSSAPHI(LiveInValue, ExitBlock);
1820 Value *
Ptr = maybeInsertLCSSAPHI(SomePtr, ExitBlock);
1823 if (UnorderedAtomic)
1834 NewID = cast_or_null<DIAssignID>(
1839 NewSI->
setMetadata(LLVMContext::MD_DIAssignID, NewID);
1847 if (!MSSAInsertPoint) {
1854 MSSAInsertPts[i] = NewMemAcc;
1855 MSSAU.
insertDef(cast<MemoryDef>(NewMemAcc),
true);
1860 void doExtraRewritesBeforeFinalDeletion()
override {
1861 if (CanInsertStoresInExitBlocks)
1862 insertStoresInLoopExitBlocks();
1865 void instructionDeleted(
Instruction *
I)
const override {
1871 if (isa<StoreInst>(
I))
1872 return CanInsertStoresInExitBlocks;
1877bool isNotCapturedBeforeOrInLoop(
const Value *V,
const Loop *L,
1884 V,
true,
L->getHeader()->getTerminator(), DT,
1890bool isNotVisibleOnUnwindInLoop(
const Value *Object,
const Loop *L,
1892 bool RequiresNoCaptureBeforeUnwind;
1896 return !RequiresNoCaptureBeforeUnwind ||
1897 isNotCapturedBeforeOrInLoop(Object, L, DT);
1905 isNotCapturedBeforeOrInLoop(Object, L, DT)) ||
1925 bool HasReadsOutsideSet) {
1927 assert(LI !=
nullptr && DT !=
nullptr && CurLoop !=
nullptr &&
1928 SafetyInfo !=
nullptr &&
1929 "Unexpected Input to promoteLoopAccessesToScalars");
1932 dbgs() <<
"Trying to promote set of must-aliased pointers:\n";
1933 for (
Value *
Ptr : PointerMustAliases)
1934 dbgs() <<
" " << *
Ptr <<
"\n";
1936 ++NumPromotionCandidates;
1938 Value *SomePtr = *PointerMustAliases.
begin();
1978 bool DereferenceableInPH =
false;
1979 bool StoreIsGuanteedToExecute =
false;
1980 bool LoadIsGuaranteedToExecute =
false;
1981 bool FoundLoadToPromote =
false;
1988 } StoreSafety = StoreSafetyUnknown;
1996 bool SawUnorderedAtomic =
false;
1997 bool SawNotAtomic =
false;
2004 if (HasReadsOutsideSet)
2005 StoreSafety = StoreUnsafe;
2014 if (!isNotVisibleOnUnwindInLoop(Object, CurLoop, DT))
2015 StoreSafety = StoreUnsafe;
2021 Type *AccessTy =
nullptr;
2022 for (
Value *ASIV : PointerMustAliases) {
2023 for (
Use &U : ASIV->uses()) {
2025 Instruction *UI = dyn_cast<Instruction>(U.getUser());
2031 if (
LoadInst *Load = dyn_cast<LoadInst>(UI)) {
2032 if (!Load->isUnordered())
2035 SawUnorderedAtomic |= Load->isAtomic();
2036 SawNotAtomic |= !Load->isAtomic();
2037 FoundLoadToPromote =
true;
2039 Align InstAlignment = Load->getAlign();
2041 if (!LoadIsGuaranteedToExecute)
2042 LoadIsGuaranteedToExecute =
2049 if (!DereferenceableInPH || (InstAlignment > Alignment))
2051 *Load, DT, TLI, CurLoop, SafetyInfo, ORE,
2053 DereferenceableInPH =
true;
2054 Alignment = std::max(Alignment, InstAlignment);
2056 }
else if (
const StoreInst *Store = dyn_cast<StoreInst>(UI)) {
2061 if (!Store->isUnordered())
2064 SawUnorderedAtomic |= Store->isAtomic();
2065 SawNotAtomic |= !Store->isAtomic();
2072 Align InstAlignment = Store->getAlign();
2073 bool GuaranteedToExecute =
2075 StoreIsGuanteedToExecute |= GuaranteedToExecute;
2076 if (GuaranteedToExecute) {
2077 DereferenceableInPH =
true;
2078 if (StoreSafety == StoreSafetyUnknown)
2079 StoreSafety = StoreSafe;
2080 Alignment = std::max(Alignment, InstAlignment);
2089 if (StoreSafety == StoreSafetyUnknown &&
2091 return DT->
dominates(Store->getParent(), Exit);
2093 StoreSafety = StoreSafe;
2097 if (!DereferenceableInPH) {
2099 Store->getPointerOperand(), Store->getValueOperand()->getType(),
2100 Store->getAlign(), MDL, Preheader->
getTerminator(), AC, DT, TLI);
2111 if (LoopUses.
empty()) {
2114 }
else if (AATags) {
2126 if (SawUnorderedAtomic && SawNotAtomic)
2136 if (!DereferenceableInPH) {
2137 LLVM_DEBUG(
dbgs() <<
"Not promoting: Not dereferenceable in preheader\n");
2145 if (StoreSafety == StoreSafetyUnknown) {
2147 bool ExplicitlyDereferenceableOnly;
2149 (!ExplicitlyDereferenceableOnly ||
2151 isThreadLocalObject(Object, CurLoop, DT,
TTI))
2152 StoreSafety = StoreSafe;
2157 if (StoreSafety != StoreSafe && !FoundLoadToPromote)
2162 if (StoreSafety == StoreSafe) {
2163 LLVM_DEBUG(
dbgs() <<
"LICM: Promoting load/store of the value: " << *SomePtr
2165 ++NumLoadStorePromoted;
2167 LLVM_DEBUG(
dbgs() <<
"LICM: Promoting load of the value: " << *SomePtr
2175 <<
"Moving accesses to memory location out of the loop";
2179 std::vector<DebugLoc> LoopUsesLocs;
2180 for (
auto U : LoopUses)
2181 LoopUsesLocs.push_back(U->getDebugLoc());
2187 LoopPromoter Promoter(SomePtr, LoopUses,
SSA, ExitBlocks, InsertPts,
2188 MSSAInsertPts,
PIC, MSSAU, *LI,
DL, Alignment,
2190 StoreIsGuanteedToExecute ? AATags :
AAMDNodes(),
2191 *SafetyInfo, StoreSafety == StoreSafe);
2196 if (FoundLoadToPromote || !StoreIsGuanteedToExecute) {
2200 if (SawUnorderedAtomic)
2204 if (AATags && LoadIsGuaranteedToExecute)
2209 MemoryUse *NewMemUse = cast<MemoryUse>(PreheaderLoadMemoryAccess);
2211 SSA.AddAvailableValue(Preheader, PreheaderLoad);
2220 Promoter.run(LoopUses);
2225 if (PreheaderLoad && PreheaderLoad->
use_empty())
2236 if (
const auto *MUD = dyn_cast<MemoryUseOrDef>(&
Access))
2237 Fn(MUD->getMemoryInst());
2247 auto IsPotentiallyPromotable = [L](
const Instruction *
I) {
2248 if (
const auto *SI = dyn_cast<StoreInst>(
I)) {
2249 const Value *PtrOp = SI->getPointerOperand();
2250 return !isa<ConstantData>(PtrOp) && L->isLoopInvariant(PtrOp);
2252 if (
const auto *LI = dyn_cast<LoadInst>(
I)) {
2253 const Value *PtrOp = LI->getPointerOperand();
2254 return !isa<ConstantData>(PtrOp) && L->isLoopInvariant(PtrOp);
2262 if (IsPotentiallyPromotable(
I)) {
2263 AttemptingPromotion.
insert(
I);
2271 if (!AS.isForwardingAliasSet() && AS.isMod() && AS.isMustAlias())
2283 ModRefInfo MR = Pair.getPointer()->aliasesUnknownInst(I, BatchAA);
2292 return !Pair.getPointer()->isRef();
2299 for (
auto [Set, HasReadsOutsideSet] : Sets) {
2301 for (
const auto &MemLoc : *Set)
2302 PointerMustAliases.
insert(
const_cast<Value *
>(MemLoc.Ptr));
2303 Result.emplace_back(std::move(PointerMustAliases), HasReadsOutsideSet);
2315 assert(isa<CallInst>(*
I) || isa<StoreInst>(*
I));
2318 if (Flags.tooManyMemoryAccesses())
2338 if (
const auto *MU = dyn_cast<MemoryUse>(&MA)) {
2347 if (!Flags.getIsSink() && !MSSA->
dominates(IMD, MU))
2349 }
else if (
const auto *MD = dyn_cast<MemoryDef>(&MA)) {
2350 if (
auto *LI = dyn_cast<LoadInst>(MD->getMemoryInst())) {
2352 assert(!LI->isUnordered() &&
"Expected unordered load");
2356 if (
auto *CI = dyn_cast<CallInst>(MD->getMemoryInst())) {
2360 if (
auto *SI = dyn_cast<StoreInst>(
I)) {
2365 auto *SCI = cast<CallInst>(
I);
2383 bool InvariantGroup) {
2385 if (!Flags.getIsSink()) {
2398 CurLoop->
contains(Source->getBlock()) &&
2399 !(InvariantGroup && Source->getBlock() == CurLoop->
getHeader() && isa<MemoryPhi>(Source));
2419 if (Flags.tooManyMemoryAccesses())
2434 if (
const auto *MD = dyn_cast<MemoryDef>(&MA))
2446 using namespace PatternMatch;
2447 Value *Cond1, *Cond2;
2463 if (L.isLoopInvariant(
LHS)) {
2467 if (L.isLoopInvariant(
LHS) || !L.isLoopInvariant(
RHS))
2474 Value *LHS1, *LHS2, *RHS1, *RHS2;
2475 if (!MatchICmpAgainstInvariant(Cond1, P1, LHS1, RHS1) ||
2476 !MatchICmpAgainstInvariant(Cond2, P2, LHS2, RHS2))
2479 if (!MatchingPred || LHS1 != LHS2)
2487 "Relational predicate is either less (or equal) or greater (or equal)!");
2489 ? (UseMin ? Intrinsic::smin : Intrinsic::smax)
2490 : (UseMin ? Intrinsic::umin : Intrinsic::umax);
2491 auto *Preheader = L.getLoopPreheader();
2492 assert(Preheader &&
"Loop is not in simplify form?");
2498 if (isa<SelectInst>(
I))
2501 id, RHS1, RHS2,
nullptr,
2504 (UseMin ?
"min" :
"max"));
2511 I.replaceAllUsesWith(NewCond);
2527 auto *
GEP = dyn_cast<GetElementPtrInst>(&
I);
2534 if (
GEP->hasAllConstantIndices())
2537 auto *Src = dyn_cast<GetElementPtrInst>(
GEP->getPointerOperand());
2538 if (!Src || !Src->hasOneUse() || !L.contains(Src))
2541 Value *SrcPtr = Src->getPointerOperand();
2542 auto LoopInvariant = [&](
Value *V) {
return L.isLoopInvariant(V); };
2543 if (!L.isLoopInvariant(SrcPtr) || !
all_of(
GEP->indices(), LoopInvariant))
2550 if (
all_of(Src->indices(), LoopInvariant))
2560 bool IsInBounds = Src->isInBounds() &&
GEP->isInBounds() &&
2564 BasicBlock *Preheader = L.getLoopPreheader();
2568 "invariant.gep", IsInBounds);
2570 Value *NewGEP = Builder.
CreateGEP(Src->getSourceElementType(), NewSrc,
2573 GEP->replaceAllUsesWith(NewGEP);
2586 assert(!L.isLoopInvariant(VariantLHS) &&
"Precondition.");
2587 assert(L.isLoopInvariant(InvariantRHS) &&
"Precondition.");
2592 using namespace PatternMatch;
2593 Value *VariantOp, *InvariantOp;
2603 if (L.isLoopInvariant(VariantOp))
2605 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2612 auto &
DL = L.getHeader()->getDataLayout();
2621 auto *Preheader = L.getLoopPreheader();
2622 assert(Preheader &&
"Loop is not in simplify form?");
2625 Builder.
CreateSub(InvariantRHS, InvariantOp,
"invariant.op",
2626 !IsSigned, IsSigned);
2631 Instruction &DeadI = cast<Instruction>(*VariantLHS);
2644 assert(!L.isLoopInvariant(VariantLHS) &&
"Precondition.");
2645 assert(L.isLoopInvariant(InvariantRHS) &&
"Precondition.");
2650 using namespace PatternMatch;
2651 Value *VariantOp, *InvariantOp;
2659 bool VariantSubtracted =
false;
2663 if (L.isLoopInvariant(VariantOp)) {
2665 VariantSubtracted =
true;
2668 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2676 auto &
DL = L.getHeader()->getDataLayout();
2678 if (VariantSubtracted && IsSigned) {
2683 }
else if (VariantSubtracted && !IsSigned) {
2688 }
else if (!VariantSubtracted && IsSigned) {
2699 auto *Preheader = L.getLoopPreheader();
2700 assert(Preheader &&
"Loop is not in simplify form?");
2704 ? Builder.
CreateSub(InvariantOp, InvariantRHS,
"invariant.op",
2705 !IsSigned, IsSigned)
2706 : Builder.
CreateAdd(InvariantOp, InvariantRHS,
"invariant.op",
2707 !IsSigned, IsSigned);
2712 Instruction &DeadI = cast<Instruction>(*VariantLHS);
2722 using namespace PatternMatch;
2729 if (L.isLoopInvariant(
LHS)) {
2740 if (
hoistAdd(Pred,
LHS,
RHS, cast<ICmpInst>(
I), L, SafetyInfo, MSSAU, AC, DT))
2743 if (
hoistSub(Pred,
LHS,
RHS, cast<ICmpInst>(
I), L, SafetyInfo, MSSAU, AC, DT))
2750 unsigned FPOpcode) {
2751 if (
I->getOpcode() == IntOpcode)
2753 if (
I->getOpcode() == FPOpcode &&
I->hasAllowReassoc() &&
2754 I->hasNoSignedZeros())
2770 Value *VariantOp =
I.getOperand(0);
2771 Value *InvariantOp =
I.getOperand(1);
2772 if (L.isLoopInvariant(VariantOp))
2774 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2776 Value *Factor = InvariantOp;
2782 if (
BinaryOperator *VariantBinOp = dyn_cast<BinaryOperator>(VariantOp))
2784 while (!Worklist.
empty()) {
2797 L.isLoopInvariant(BO))
2801 if (L.isLoopInvariant(U0))
2803 else if (L.isLoopInvariant(U1))
2807 unsigned Limit =
I.getType()->isIntOrIntVectorTy()
2810 if (Changes.
size() > Limit)
2813 if (Changes.
empty())
2817 if (
I.getType()->isIntOrIntVectorTy()) {
2818 for (
auto *
Add : Adds)
2819 Add->dropPoisonGeneratingFlags();
2823 auto *Preheader = L.getLoopPreheader();
2824 assert(Preheader &&
"Loop is not in simplify form?");
2826 for (
auto *U : Changes) {
2827 assert(L.isLoopInvariant(U->get()));
2828 auto *Ins = cast<BinaryOperator>(U->getUser());
2830 if (
I.getType()->isIntOrIntVectorTy()) {
2831 Mul = Builder.
CreateMul(U->get(), Factor,
"factor.op.mul");
2833 Ins->dropPoisonGeneratingFlags();
2838 unsigned OpIdx = U->getOperandNo();
2839 auto *
LHS =
OpIdx == 0 ?
Mul : Ins->getOperand(0);
2840 auto *
RHS =
OpIdx == 1 ?
Mul : Ins->getOperand(1);
2843 Ins->getName() +
".reass", Ins->getIterator());
2845 NewBO->copyIRFlags(Ins);
2846 if (VariantOp == Ins)
2848 Ins->replaceAllUsesWith(NewBO);
2852 I.replaceAllUsesWith(VariantOp);
2871 auto *BO = dyn_cast<BinaryOperator>(&
I);
2872 if (!BO || !BO->isAssociative())
2876 bool LVInRHS = L.isLoopInvariant(BO->getOperand(0));
2877 auto *BO0 = dyn_cast<BinaryOperator>(BO->getOperand(LVInRHS));
2878 if (!BO0 || BO0->getOpcode() != Opcode || !BO0->isAssociative() ||
2879 BO0->hasNUsesOrMore(BO0->getType()->isIntegerTy() ? 2 : 3))
2882 Value *LV = BO0->getOperand(0);
2883 Value *C1 = BO0->getOperand(1);
2884 Value *C2 = BO->getOperand(!LVInRHS);
2886 assert(BO->isCommutative() && BO0->isCommutative() &&
2887 "Associativity implies commutativity");
2888 if (L.isLoopInvariant(LV) && !L.isLoopInvariant(C1))
2890 if (L.isLoopInvariant(LV) || !L.isLoopInvariant(C1) || !L.isLoopInvariant(C2))
2893 auto *Preheader = L.getLoopPreheader();
2894 assert(Preheader &&
"Loop is not in simplify form?");
2897 auto *Inv = Builder.
CreateBinOp(Opcode, C1, C2,
"invariant.op");
2900 Opcode, LV, Inv, BO->
getName() +
".reass", BO->getIterator());
2903 if (Opcode == Instruction::FAdd || Opcode == Instruction::FMul) {
2905 FastMathFlags Intersect = BO->getFastMathFlags() & BO0->getFastMathFlags();
2906 if (
auto *
I = dyn_cast<Instruction>(Inv))
2907 I->setFastMathFlags(Intersect);
2908 NewBO->setFastMathFlags(Intersect);
2911 Flags.AllKnownNonNegative =
false;
2912 Flags.AllKnownNonZero =
false;
2913 Flags.mergeFlags(*BO);
2914 Flags.mergeFlags(*BO0);
2916 if (
auto *
I = dyn_cast<Instruction>(Inv))
2917 Flags.applyFlags(*
I);
2918 Flags.applyFlags(*NewBO);
2921 BO->replaceAllUsesWith(NewBO);
2926 if (BO0->use_empty()) {
2948 if (
hoistGEP(
I, L, SafetyInfo, MSSAU, AC, DT)) {
2961 bool IsInt =
I.getType()->isIntOrIntVectorTy();
2965 ++NumIntAssociationsHoisted;
2967 ++NumFPAssociationsHoisted;
2973 ++NumBOAssociationsHoisted;
2984 assert(CurLoop->
contains(BB) &&
"Only valid if BB is IN the loop");
unsigned const MachineRegisterInfo * MRI
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static msgpack::DocNode getNode(msgpack::DocNode DN, msgpack::Type Type, MCValue Val)
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
This file contains the declarations for the subclasses of Constant, which represent the different fla...
DXIL Forward Handle Accesses
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
iv Induction Variable Users
static bool isReassociableOp(Instruction *I, unsigned IntOpcode, unsigned FPOpcode)
static bool isNotUsedOrFoldableInLoop(const Instruction &I, const Loop *CurLoop, const LoopSafetyInfo *SafetyInfo, TargetTransformInfo *TTI, bool &FoldableInLoop, bool LoopNestMode)
Return true if the only users of this instruction are outside of the loop.
static bool hoistGEP(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Reassociate gep (gep ptr, idx1), idx2 to gep (gep ptr, idx2), idx1 if this allows hoisting the inner ...
static cl::opt< bool > SingleThread("licm-force-thread-model-single", cl::Hidden, cl::init(false), cl::desc("Force thread model single in LICM pass"))
cl::opt< bool > ProfcheckDisableMetadataFixes
static void splitPredecessorsOfLoopExit(PHINode *PN, DominatorTree *DT, LoopInfo *LI, const Loop *CurLoop, LoopSafetyInfo *SafetyInfo, MemorySSAUpdater *MSSAU)
static cl::opt< unsigned > FPAssociationUpperLimit("licm-max-num-fp-reassociations", cl::init(5U), cl::Hidden, cl::desc("Set upper limit for the number of transformations performed " "during a single round of hoisting the reassociated expressions."))
static bool isFoldableInLoop(const Instruction &I, const Loop *CurLoop, const TargetTransformInfo *TTI)
Return true if the instruction is foldable in the loop.
static bool hoistMinMax(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU)
Try to simplify things like (A < INV_1 AND icmp A < INV_2) into (A < min(INV_1, INV_2)),...
static void moveInstructionBefore(Instruction &I, BasicBlock::iterator Dest, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, ScalarEvolution *SE)
static Instruction * cloneInstructionInExitBlock(Instruction &I, BasicBlock &ExitBlock, PHINode &PN, const LoopInfo *LI, const LoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU)
static cl::opt< bool > ControlFlowHoisting("licm-control-flow-hoisting", cl::Hidden, cl::init(false), cl::desc("Enable control flow (and PHI) hoisting in LICM"))
static bool pointerInvalidatedByLoop(MemorySSA *MSSA, MemoryUse *MU, Loop *CurLoop, Instruction &I, SinkAndHoistLICMFlags &Flags, bool InvariantGroup)
static bool hoistAdd(ICmpInst::Predicate Pred, Value *VariantLHS, Value *InvariantRHS, ICmpInst &ICmp, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Try to turn things like "LV + C1 < C2" into "LV < C2 - C1".
static MemoryAccess * getClobberingMemoryAccess(MemorySSA &MSSA, BatchAAResults &BAA, SinkAndHoistLICMFlags &Flags, MemoryUseOrDef *MA)
static SmallVector< PointersAndHasReadsOutsideSet, 0 > collectPromotionCandidates(MemorySSA *MSSA, AliasAnalysis *AA, Loop *L)
static void hoist(Instruction &I, const DominatorTree *DT, const Loop *CurLoop, BasicBlock *Dest, ICFLoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU, ScalarEvolution *SE, OptimizationRemarkEmitter *ORE)
When an instruction is found to only use loop invariant operands that is safe to hoist,...
static bool canSplitPredecessors(PHINode *PN, LoopSafetyInfo *SafetyInfo)
static bool sink(Instruction &I, LoopInfo *LI, DominatorTree *DT, const Loop *CurLoop, ICFLoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU, OptimizationRemarkEmitter *ORE)
When an instruction is found to only be used outside of the loop, this function moves it to the exit ...
static bool hoistAddSub(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Reassociate and hoist add/sub expressions.
static bool hoistMulAddAssociation(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Try to reassociate expressions like ((A1 * B1) + (A2 * B2) + ...) * C where A1, A2,...
static cl::opt< uint32_t > MaxNumUsesTraversed("licm-max-num-uses-traversed", cl::Hidden, cl::init(8), cl::desc("Max num uses visited for identifying load " "invariance in loop using invariant start (default = 8)"))
static cl::opt< unsigned > IntAssociationUpperLimit("licm-max-num-int-reassociations", cl::init(5U), cl::Hidden, cl::desc("Set upper limit for the number of transformations performed " "during a single round of hoisting the reassociated expressions."))
static void foreachMemoryAccess(MemorySSA *MSSA, Loop *L, function_ref< void(Instruction *)> Fn)
static bool isLoadInvariantInLoop(LoadInst *LI, DominatorTree *DT, Loop *CurLoop)
static Instruction * sinkThroughTriviallyReplaceablePHI(PHINode *TPN, Instruction *I, LoopInfo *LI, SmallDenseMap< BasicBlock *, Instruction *, 32 > &SunkCopies, const LoopSafetyInfo *SafetyInfo, const Loop *CurLoop, MemorySSAUpdater &MSSAU)
static bool inSubLoop(BasicBlock *BB, Loop *CurLoop, LoopInfo *LI)
Little predicate that returns true if the specified basic block is in a subloop of the current one,...
static bool hoistSub(ICmpInst::Predicate Pred, Value *VariantLHS, Value *InvariantRHS, ICmpInst &ICmp, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Try to reassociate and hoist the following two patterns: LV - C1 < C2 --> LV < C1 + C2,...
static void eraseInstruction(Instruction &I, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU)
static bool isSafeToExecuteUnconditionally(Instruction &Inst, const DominatorTree *DT, const TargetLibraryInfo *TLI, const Loop *CurLoop, const LoopSafetyInfo *SafetyInfo, OptimizationRemarkEmitter *ORE, const Instruction *CtxI, AssumptionCache *AC, bool AllowSpeculation)
Only sink or hoist an instruction if it is not a trapping instruction, or if the instruction is known...
static bool hoistArithmetics(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Aggregates various functions for hoisting computations out of loop.
static bool noConflictingReadWrites(Instruction *I, MemorySSA *MSSA, AAResults *AA, Loop *CurLoop, SinkAndHoistLICMFlags &Flags)
static bool isTriviallyReplaceablePHI(const PHINode &PN, const Instruction &I)
Returns true if a PHINode is a trivially replaceable with an Instruction.
std::pair< SmallSetVector< Value *, 8 >, bool > PointersAndHasReadsOutsideSet
static cl::opt< bool > DisablePromotion("disable-licm-promotion", cl::Hidden, cl::init(false), cl::desc("Disable memory promotion in LICM pass"))
Memory promotion is enabled by default.
static bool hoistBOAssociation(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Reassociate associative binary expressions of the form.
static bool pointerInvalidatedByBlock(BasicBlock &BB, MemorySSA &MSSA, MemoryUse &MU)
This file defines the interface for the loop nest analysis.
Machine Loop Invariant Code Motion
This file exposes an interface to building/using memory SSA to walk memory instructions using a use/d...
Contains a collection of routines for determining if a given instruction is guaranteed to execute if ...
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
PassInstrumentationCallbacks PIC
#define INITIALIZE_PASS_DEPENDENCY(depName)
#define INITIALIZE_PASS_END(passName, arg, name, cfg, analysis)
#define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis)
This file provides a priority worklist.
Remove Loads Into Fake Uses
cl::opt< bool > ProfcheckDisableMetadataFixes("profcheck-disable-metadata-fixes", cl::Hidden, cl::init(false), cl::desc("Disable metadata propagation fixes discovered through Issue #147390"))
This file defines generic set operations that may be used on set's of different types,...
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
A private abstract base class describing the concept of an individual alias analysis implementation.
LLVM_ABI ModRefInfo getModRefInfoMask(const MemoryLocation &Loc, bool IgnoreLocals=false)
Returns a bitmask that should be unconditionally applied to the ModRef info of a memory location.
LLVM_ABI MemoryEffects getMemoryEffects(const CallBase *Call)
Return the behavior of the given call site.
LLVM_ABI void add(const MemoryLocation &Loc)
These methods are used to add different types of instructions to the alias sets.
A container for analyses that lazily runs them and caches their results.
Represent the analysis usage information of a pass.
AnalysisUsage & addRequired()
AnalysisUsage & addPreserved()
Add the specified Pass class to the set of analyses preserved by this pass.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
An immutable pass that tracks lazily created AssumptionCache objects.
A cache of @llvm.assume calls within a function.
LLVM Basic Block Representation.
LLVM_ABI void replaceSuccessorsPhiUsesWith(BasicBlock *Old, BasicBlock *New)
Update all phi nodes in this basic block's successors to refer to basic block New instead of basic bl...
iterator begin()
Instruction iterator methods.
LLVM_ABI const_iterator getFirstInsertionPt() const
Returns an iterator to the first instruction in this block that is suitable for inserting a non-PHI i...
LLVM_ABI InstListType::const_iterator getFirstNonPHIIt() const
Returns an iterator to the first instruction in this block that is not a PHINode instruction.
static BasicBlock * Create(LLVMContext &Context, const Twine &Name="", Function *Parent=nullptr, BasicBlock *InsertBefore=nullptr)
Creates a new BasicBlock.
LLVM_ABI const BasicBlock * getSingleSuccessor() const
Return the successor of this block if it has a single successor.
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this basic block belongs to.
InstListType::iterator iterator
Instruction iterators...
LLVM_ABI LLVMContext & getContext() const
Get the context in which this basic block lives.
void moveBefore(BasicBlock *MovePos)
Unlink this basic block from its current function and insert it into the function that MovePos lives ...
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction if the block is well formed or null if the block is not well forme...
LLVM_ABI bool canSplitPredecessors() const
This class is a wrapper over an AAResults, and it is intended to be used only when there are no IR ch...
ModRefInfo getModRefInfo(const Instruction *I, const std::optional< MemoryLocation > &OptLoc)
static LLVM_ABI BinaryOperator * Create(BinaryOps Op, Value *S1, Value *S2, const Twine &Name=Twine(), InsertPosition InsertBefore=nullptr)
Construct a binary instruction, given the opcode and the two operands.
Conditional or Unconditional Branch instruction.
bool isConditional() const
static BranchInst * Create(BasicBlock *IfTrue, InsertPosition InsertBefore=nullptr)
BasicBlock * getSuccessor(unsigned i) const
Value * getCondition() const
This class represents a function call, abstracting a target machine's calling convention.
static CallInst * Create(FunctionType *Ty, Value *F, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
void setPredicate(Predicate P)
Set the predicate for this instruction to the specified value.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Predicate getSwappedPredicate() const
For example, EQ->EQ, SLE->SGE, ULT->UGT, OEQ->OEQ, ULE->UGE, OLT->OGT, etc.
Predicate getInversePredicate() const
For example, EQ -> NE, UGT -> ULE, SLT -> SGE, OEQ -> UNE, UGT -> OLE, OLT -> UGE,...
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
static LLVM_ABI std::optional< CmpPredicate > getMatching(CmpPredicate A, CmpPredicate B)
Compares two CmpPredicates taking samesign into account and returns the canonicalized CmpPredicate if...
This is the shared class of boolean and integer constants.
int64_t getSExtValue() const
Return the constant as a 64-bit integer value after it has been sign extended as appropriate for the ...
This class represents an Operation in the Expression.
A parsed version of the target data layout string in and methods for querying it.
TypeSize getTypeStoreSize(Type *Ty) const
Returns the maximum number of bytes that may be overwritten by storing the specified type.
static LLVM_ABI DebugLoc getMergedLocations(ArrayRef< DebugLoc > Locs)
Try to combine the vector of locations passed as input in a single one.
static DebugLoc getDropped()
iterator find(const_arg_type_t< KeyT > Val)
std::pair< iterator, bool > try_emplace(KeyT &&Key, Ts &&...Args)
DomTreeNodeBase * getIDom() const
Analysis pass which computes a DominatorTree.
bool verify(VerificationLevel VL=VerificationLevel::Full) const
verify - checks if the tree is correct.
void changeImmediateDominator(DomTreeNodeBase< NodeT > *N, DomTreeNodeBase< NodeT > *NewIDom)
changeImmediateDominator - This method is used to update the dominator tree information when a node's...
DomTreeNodeBase< NodeT > * addNewBlock(NodeT *BB, NodeT *DomBB)
Add a new node to the dominator tree information.
DomTreeNodeBase< NodeT > * getNode(const NodeT *BB) const
getNode - return the (Post)DominatorTree node for the specified basic block.
bool properlyDominates(const DomTreeNodeBase< NodeT > *A, const DomTreeNodeBase< NodeT > *B) const
properlyDominates - Returns true iff A dominates B and A != B.
Legacy analysis pass which computes a DominatorTree.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
LLVM_ABI bool isReachableFromEntry(const Use &U) const
Provide an overload for a Use.
LLVM_ABI bool dominates(const BasicBlock *BB, const Use &U) const
Return true if the (end of the) basic block BB dominates the use U.
Convenience struct for specifying and reasoning about fast-math flags.
This implementation of LoopSafetyInfo use ImplicitControlFlowTracking to give precise answers on "may...
bool doesNotWriteMemoryBefore(const BasicBlock *BB, const Loop *CurLoop) const
Returns true if we could not execute a memory-modifying instruction before we enter BB under assumpti...
void removeInstruction(const Instruction *Inst)
Inform safety info that we are planning to remove the instruction Inst from its block.
bool isGuaranteedToExecute(const Instruction &Inst, const DominatorTree *DT, const Loop *CurLoop) const override
Returns true if the instruction in a loop is guaranteed to execute at least once (under the assumptio...
bool anyBlockMayThrow() const override
Returns true iff any block of the loop for which this info is contains an instruction that may throw ...
void computeLoopSafetyInfo(const Loop *CurLoop) override
Computes safety information for a loop checks loop body & header for the possibility of may throw exc...
void insertInstructionTo(const Instruction *Inst, const BasicBlock *BB)
Inform the safety info that we are planning to insert a new instruction Inst into the basic block BB.
This instruction compares its operands according to the predicate given to the constructor.
static bool isGE(Predicate P)
Return true if the predicate is SGE or UGE.
static bool isLT(Predicate P)
Return true if the predicate is SLT or ULT.
static bool isGT(Predicate P)
Return true if the predicate is SGT or UGT.
bool isRelational() const
Return true if the predicate is relational (not EQ or NE).
static bool isLE(Predicate P)
Return true if the predicate is SLE or ULE.
Value * CreateFreeze(Value *V, const Twine &Name="")
Value * CreateGEP(Type *Ty, Value *Ptr, ArrayRef< Value * > IdxList, const Twine &Name="", GEPNoWrapFlags NW=GEPNoWrapFlags::none())
LLVM_ABI Value * CreateBinaryIntrinsic(Intrinsic::ID ID, Value *LHS, Value *RHS, FMFSource FMFSource={}, const Twine &Name="")
Create a call to intrinsic ID with 2 operands which is mangled on the first type.
Value * CreateSub(Value *LHS, Value *RHS, const Twine &Name="", bool HasNUW=false, bool HasNSW=false)
Value * CreateAdd(Value *LHS, Value *RHS, const Twine &Name="", bool HasNUW=false, bool HasNSW=false)
Value * CreateBinOp(Instruction::BinaryOps Opc, Value *LHS, Value *RHS, const Twine &Name="", MDNode *FPMathTag=nullptr)
void SetInsertPoint(BasicBlock *TheBB)
This specifies that created instructions should be appended to the end of the specified block.
Value * CreateICmp(CmpInst::Predicate P, Value *LHS, Value *RHS, const Twine &Name="")
Value * CreateFMulFMF(Value *L, Value *R, FMFSource FMFSource, const Twine &Name="", MDNode *FPMD=nullptr)
Value * CreateMul(Value *LHS, Value *RHS, const Twine &Name="", bool HasNUW=false, bool HasNSW=false)
This provides a uniform API for creating instructions and inserting them into a basic block: either a...
LLVM_ABI void mergeDIAssignID(ArrayRef< const Instruction * > SourceInstructions)
Merge the DIAssignID metadata from this instruction and those attached to instructions in SourceInstr...
const DebugLoc & getDebugLoc() const
Return the debug location for this node as a DebugLoc.
LLVM_ABI void setAAMetadata(const AAMDNodes &N)
Sets the AA metadata on this instruction from the AAMDNodes structure.
LLVM_ABI void insertBefore(InstListType::iterator InsertPos)
Insert an unlinked instruction into a basic block immediately before the specified position.
LLVM_ABI InstListType::iterator eraseFromParent()
This method unlinks 'this' from the containing basic block and deletes it.
Instruction * user_back()
Specialize the methods defined in Value, as we know that an instruction can only be used by other ins...
MDNode * getMetadata(unsigned KindID) const
Get the metadata of given kind attached to this Instruction.
LLVM_ABI void setMetadata(unsigned KindID, MDNode *Node)
Set the metadata of the specified kind to the specified node.
LLVM_ABI AAMDNodes getAAMetadata() const
Returns the AA metadata for this instruction.
void setDebugLoc(DebugLoc Loc)
Set the debug location information for this instruction.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this instruction belongs to.
A wrapper class for inspecting calls to intrinsic functions.
void printPipeline(raw_ostream &OS, function_ref< StringRef(StringRef)> MapClassName2PassName)
PreservedAnalyses run(Loop &L, LoopAnalysisManager &AM, LoopStandardAnalysisResults &AR, LPMUpdater &U)
This is an important class for using LLVM in a threaded context.
PreservedAnalyses run(LoopNest &L, LoopAnalysisManager &AM, LoopStandardAnalysisResults &AR, LPMUpdater &U)
void printPipeline(raw_ostream &OS, function_ref< StringRef(StringRef)> MapClassName2PassName)
This class provides an interface for updating the loop pass manager based on mutations to the loop ne...
This is an alternative analysis pass to BlockFrequencyInfoWrapperPass.
static void getLazyBFIAnalysisUsage(AnalysisUsage &AU)
Helper for client passes to set up the analysis usage on behalf of this pass.
This is an alternative analysis pass to BranchProbabilityInfoWrapperPass.
An instruction for reading from memory.
void setAlignment(Align Align)
Value * getPointerOperand()
void setOrdering(AtomicOrdering Ordering)
Sets the ordering constraint of this load instruction.
Analysis pass that exposes the LoopInfo for a function.
bool contains(const LoopT *L) const
Return true if the specified loop is contained within in this loop.
BlockT * getHeader() const
void addBasicBlockToLoop(BlockT *NewBB, LoopInfoBase< BlockT, LoopT > &LI)
This method is used by other analyses to update loop information.
BlockT * getLoopPreheader() const
If there is a preheader for this loop, return it.
ArrayRef< BlockT * > getBlocks() const
Get a list of the basic blocks which make up this loop.
void getUniqueExitBlocks(SmallVectorImpl< BlockT * > &ExitBlocks) const
Return all unique successor blocks of this loop.
LoopT * getParentLoop() const
Return the parent loop if it exists or nullptr for top level loops.
Wrapper class to LoopBlocksDFS that provides a standard begin()/end() interface for the DFS reverse p...
void perform(const LoopInfo *LI)
Traverse the loop blocks and store the DFS result.
void verify(const DominatorTreeBase< BlockT, false > &DomTree) const
LoopT * getLoopFor(const BlockT *BB) const
Return the inner most loop that BB lives in.
The legacy pass manager's analysis pass to compute loop information.
LLVM_ABI bool wouldBeOutOfLoopUseRequiringLCSSA(const Value *V, const BasicBlock *ExitBB) const
This class represents a loop nest and can be used to query its properties.
Function * getParent() const
Return the function to which the loop-nest belongs.
Loop & getOutermostLoop() const
Return the outermost loop in the loop nest.
Captures loop safety information.
LLVM_ABI void copyColors(BasicBlock *New, BasicBlock *Old)
Copy colors of block Old into the block New.
LLVM_ABI const DenseMap< BasicBlock *, ColorVector > & getBlockColors() const
Returns block colors map that is used to update funclet operand bundles.
virtual bool isGuaranteedToExecute(const Instruction &Inst, const DominatorTree *DT, const Loop *CurLoop) const =0
Returns true if the instruction in a loop is guaranteed to execute at least once (under the assumptio...
Represents a single loop in the control flow graph.
bool isLoopInvariant(const Value *V, bool HasCoroSuspendInst=false) const
Return true if the specified value is loop invariant.
bool hasLoopInvariantOperands(const Instruction *I, bool HasCoroSuspendInst=false) const
Return true if all the operands of the specified instruction are loop invariant.
BasicBlock * getBlock() const
bool onlyWritesMemory() const
Whether this function only (at most) writes memory.
bool doesNotAccessMemory() const
Whether this function accesses no memory.
bool onlyReadsMemory() const
Whether this function only (at most) reads memory.
static LLVM_ABI MemoryLocation get(const LoadInst *LI)
Return a location with information about the memory reference by the given instruction.
An analysis that produces MemorySSA for a function.
MemorySSA * getMemorySSA() const
Get handle on MemorySSA.
LLVM_ABI void insertDef(MemoryDef *Def, bool RenameUses=false)
Insert a definition into the MemorySSA IR.
LLVM_ABI void insertUse(MemoryUse *Use, bool RenameUses=false)
LLVM_ABI MemoryAccess * createMemoryAccessInBB(Instruction *I, MemoryAccess *Definition, const BasicBlock *BB, MemorySSA::InsertionPlace Point, bool CreationMustSucceed=true)
Create a MemoryAccess in MemorySSA at a specified point in a block.
LLVM_ABI void removeMemoryAccess(MemoryAccess *, bool OptimizePhis=false)
Remove a MemoryAccess from MemorySSA, including updating all definitions and uses.
LLVM_ABI MemoryUseOrDef * createMemoryAccessAfter(Instruction *I, MemoryAccess *Definition, MemoryAccess *InsertPt)
Create a MemoryAccess in MemorySSA after an existing MemoryAccess.
LLVM_ABI void moveToPlace(MemoryUseOrDef *What, BasicBlock *BB, MemorySSA::InsertionPlace Where)
LLVM_ABI void wireOldPredecessorsToNewImmediatePredecessor(BasicBlock *Old, BasicBlock *New, ArrayRef< BasicBlock * > Preds, bool IdenticalEdgesWereMerged=true)
A new empty BasicBlock (New) now branches directly to Old.
MemoryAccess * getClobberingMemoryAccess(const Instruction *I, BatchAAResults &AA)
Given a memory Mod/Ref/ModRef'ing instruction, calling this will give you the nearest dominating Memo...
Legacy analysis pass which computes MemorySSA.
Encapsulates MemorySSA, including all data associated with memory accesses.
const AccessList * getBlockAccesses(const BasicBlock *BB) const
Return the list of MemoryAccess's for a given basic block.
LLVM_ABI MemorySSAWalker * getSkipSelfWalker()
LLVM_ABI bool dominates(const MemoryAccess *A, const MemoryAccess *B) const
Given two memory accesses in potentially different blocks, determine whether MemoryAccess A dominates...
LLVM_ABI void verifyMemorySSA(VerificationLevel=VerificationLevel::Fast) const
Verify that MemorySSA is self consistent (IE definitions dominate all uses, uses appear in the right ...
MemoryUseOrDef * getMemoryAccess(const Instruction *I) const
Given a memory Mod/Ref'ing instruction, get the MemorySSA access associated with it.
const DefsList * getBlockDefs(const BasicBlock *BB) const
Return the list of MemoryDef's and MemoryPhi's for a given basic block.
LLVM_ABI bool locallyDominates(const MemoryAccess *A, const MemoryAccess *B) const
Given two memory accesses in the same basic block, determine whether MemoryAccess A dominates MemoryA...
bool isLiveOnEntryDef(const MemoryAccess *MA) const
Return true if MA represents the live on entry value.
Class that has the common methods + fields of memory uses/defs.
MemoryAccess * getDefiningAccess() const
Get the access that produces the memory state used by this Use.
Represents read-only accesses to memory.
void addIncoming(Value *V, BasicBlock *BB)
Add an incoming value to the end of the PHI list.
op_range incoming_values()
void setIncomingBlock(unsigned i, BasicBlock *BB)
BasicBlock * getIncomingBlock(unsigned i) const
Return incoming basic block number i.
int getBasicBlockIndex(const BasicBlock *BB) const
Return the first index of the specified basic block in the value list for this PHI.
unsigned getNumIncomingValues() const
Return the number of incoming edges.
static PHINode * Create(Type *Ty, unsigned NumReservedValues, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructors - NumReservedValues is a hint for the number of incoming edges that this phi node will h...
static LLVM_ABI PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
Pass interface - Implemented by all 'passes'.
PointerIntPair - This class implements a pair of a pointer and small integer.
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
PredIteratorCache - This class is an extremely trivial cache for predecessor iterator queries.
size_t size(BasicBlock *BB)
ArrayRef< BasicBlock * > get(BasicBlock *BB)
A set of analyses that are preserved following a run of a transformation pass.
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
bool empty() const
Determine if the PriorityWorklist is empty or not.
bool insert(const T &X)
Insert a new element into the PriorityWorklist.
Helper class for SSA formation on a set of values defined in multiple blocks.
The main scalar evolution driver.
LLVM_ABI void forgetBlockAndLoopDispositions(Value *V=nullptr)
Called when the client has changed the disposition of values in a loop or block.
LLVM_ABI void forgetLoopDispositions()
Called when the client has changed the disposition of values in this loop.
bool remove(const value_type &X)
Remove an item from the set vector.
bool empty() const
Determine if the SetVector is empty or not.
iterator begin()
Get an iterator to the beginning of the SetVector.
bool insert(const value_type &X)
Insert a new element into the SetVector.
Flags controlling how much is checked when sinking or hoisting instructions.
LLVM_ABI SinkAndHoistLICMFlags(unsigned LicmMssaOptCap, unsigned LicmMssaNoAccForPromotionCap, bool IsSink, Loop &L, MemorySSA &MSSA)
unsigned LicmMssaNoAccForPromotionCap
A version of PriorityWorklist that selects small size optimized data structures for the vector and ma...
size_type count(ConstPtrType Ptr) const
count - Return 1 if the specified pointer is in the set, 0 otherwise.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
bool contains(ConstPtrType Ptr) const
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
A SetVector that performs no allocations if smaller than a certain size.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
reference emplace_back(ArgTypes &&... Args)
void reserve(size_type N)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
An instruction for storing to memory.
void setAlignment(Align Align)
void setOrdering(AtomicOrdering Ordering)
Sets the ordering constraint of this store instruction.
static unsigned getPointerOperandIndex()
StringRef - Represent a constant reference to a string, i.e.
Provides information about what library functions are available for the current target.
TinyPtrVector - This class is specialized for cases where there are normally 0 or 1 element in a vect...
The instances of the Type class are immutable: once they are created, they are never changed.
bool isIntegerTy() const
True if this is an instance of IntegerType.
A Use represents the edge between a Value definition and its users.
const Use & getOperandUse(unsigned i) const
void setOperand(unsigned i, Value *Val)
Value * getOperand(unsigned i) const
unsigned getNumOperands() const
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI bool hasOneUser() const
Return true if there is exactly one user of this value.
LLVM_ABI std::string getNameOrAsOperand() const
bool hasOneUse() const
Return true if there is exactly one use of this value.
LLVM_ABI void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
user_iterator_impl< User > user_iterator
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
LLVM_ABI void takeName(Value *V)
Transfer the name from V to this value.
constexpr ScalarTy getFixedValue() const
constexpr bool isScalable() const
Returns whether the quantity is scaled by a runtime quantity (vscale).
An efficient, type-erasing, non-owning reference to a callable.
const ParentTy * getParent() const
self_iterator getIterator()
This class implements an extremely fast bulk output stream that can only output to a stream.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ C
The default llvm calling convention, compatible with C.
OneUse_match< SubPat > m_OneUse(const SubPat &SP)
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWAdd(const LHS &L, const RHS &R)
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoSignedWrap > m_NSWSub(const LHS &L, const RHS &R)
bool match(Val *V, const Pattern &P)
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWSub(const LHS &L, const RHS &R)
class_match< Value > m_Value()
Match an arbitrary value and ignore it.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoSignedWrap > m_NSWAdd(const LHS &L, const RHS &R)
CmpClass_match< LHS, RHS, ICmpInst > m_ICmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
initializer< Ty > init(const Ty &Val)
DiagnosticInfoOptimizationBase::Argument NV
This is an optimization pass for GlobalISel generic memory operations.
@ NeverOverflows
Never overflows.
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI bool canSinkOrHoistInst(Instruction &I, AAResults *AA, DominatorTree *DT, Loop *CurLoop, MemorySSAUpdater &MSSAU, bool TargetExecutesOncePerLoop, SinkAndHoistLICMFlags &LICMFlags, OptimizationRemarkEmitter *ORE=nullptr)
Returns true if is legal to hoist or sink this instruction disregarding the possible introduction of ...
auto pred_end(const MachineBasicBlock *BB)
void set_intersect(S1Ty &S1, const S2Ty &S2)
set_intersect(A, B) - Compute A := A ^ B Identical to set_intersection, except that it works on set<>...
LLVM_ABI void salvageDebugInfo(const MachineRegisterInfo &MRI, MachineInstr &MI)
Assuming the instruction MI is going to be deleted, attempt to salvage debug users of MI by writing t...
auto successors(const MachineBasicBlock *BB)
LLVM_ABI bool isDereferenceableAndAlignedPointer(const Value *V, Type *Ty, Align Alignment, const DataLayout &DL, const Instruction *CtxI=nullptr, AssumptionCache *AC=nullptr, const DominatorTree *DT=nullptr, const TargetLibraryInfo *TLI=nullptr)
Returns true if V is always a dereferenceable pointer with alignment greater or equal than requested.
constexpr from_range_t from_range
LLVM_ABI bool formLCSSARecursively(Loop &L, const DominatorTree &DT, const LoopInfo *LI, ScalarEvolution *SE)
Put a loop nest into LCSSA form.
iterator_range< early_inc_iterator_impl< detail::IterOfRange< RangeT > > > make_early_inc_range(RangeT &&Range)
Make a range that does early increment to allow mutation of the underlying range without disrupting i...
auto pred_size(const MachineBasicBlock *BB)
LLVM_ABI bool isSafeToSpeculativelyExecute(const Instruction *I, const Instruction *CtxI=nullptr, AssumptionCache *AC=nullptr, const DominatorTree *DT=nullptr, const TargetLibraryInfo *TLI=nullptr, bool UseVariableInfo=true, bool IgnoreUBImplyingAttrs=true)
Return true if the instruction does not have any effects besides calculating the result and does not ...
LLVM_ABI bool hoistRegion(DomTreeNode *, AAResults *, LoopInfo *, DominatorTree *, AssumptionCache *, TargetLibraryInfo *, Loop *, MemorySSAUpdater &, ScalarEvolution *, ICFLoopSafetyInfo *, SinkAndHoistLICMFlags &, OptimizationRemarkEmitter *, bool, bool AllowSpeculation, bool HasCoroSuspendInst=false)
Walk the specified region of the CFG (defined by all blocks dominated by the specified block,...
LLVM_ABI bool PointerMayBeCapturedBefore(const Value *V, bool ReturnCaptures, const Instruction *I, const DominatorTree *DT, bool IncludeI=false, unsigned MaxUsesToExplore=0, const LoopInfo *LI=nullptr)
PointerMayBeCapturedBefore - Return true if this pointer value may be captured by the enclosing funct...
LLVM_ABI Pass * createLICMPass()
LLVM_ABI SmallVector< BasicBlock *, 16 > collectChildrenInLoop(DominatorTree *DT, DomTreeNode *N, const Loop *CurLoop)
Does a BFS from a given node to all of its children inside a given loop.
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI bool isInstructionTriviallyDead(Instruction *I, const TargetLibraryInfo *TLI=nullptr)
Return true if the result produced by the instruction is not used, and the instruction will return.
bool isGuard(const User *U)
Returns true iff U has semantics of a guard expressed in a form of call of llvm.experimental....
auto reverse(ContainerTy &&C)
LLVM_ABI OverflowResult computeOverflowForSignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
LLVM_ABI void initializeLegacyLICMPassPass(PassRegistry &)
bool isModSet(const ModRefInfo MRI)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
LLVM_TEMPLATE_ABI void appendLoopsToWorklist(RangeT &&, SmallPriorityWorklist< Loop *, 4 > &)
Utility that implements appending of loops onto a worklist given a range.
bool isModOrRefSet(const ModRefInfo MRI)
LLVM_ABI bool isNotVisibleOnUnwind(const Value *Object, bool &RequiresNoCaptureBeforeUnwind)
Return true if Object memory is not visible after an unwind, in the sense that program semantics cann...
LLVM_ABI void getLoopAnalysisUsage(AnalysisUsage &AU)
Helper to consistently add the set of standard passes to a loop pass's AnalysisUsage.
LLVM_ABI BasicBlock * SplitBlockPredecessors(BasicBlock *BB, ArrayRef< BasicBlock * > Preds, const char *Suffix, DominatorTree *DT, LoopInfo *LI=nullptr, MemorySSAUpdater *MSSAU=nullptr, bool PreserveLCSSA=false)
This method introduces at least one new basic block into the function and moves some of the predecess...
ModRefInfo
Flags indicating whether a memory access modifies or references memory.
LLVM_ABI bool VerifyMemorySSA
Enables verification of MemorySSA.
LLVM_ABI bool salvageKnowledge(Instruction *I, AssumptionCache *AC=nullptr, DominatorTree *DT=nullptr)
Calls BuildAssumeFromInst and if the resulting llvm.assume is valid insert if before I.
LLVM_ABI bool hasDisableLICMTransformsHint(const Loop *L)
Look for the loop attribute that disables the LICM transformation heuristics.
LLVM_ABI OverflowResult computeOverflowForSignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
@ Mul
Product of integers.
LLVM_ABI bool isIdentifiedFunctionLocal(const Value *V)
Return true if V is umabigously identified at the function-level.
LLVM_ABI bool isDereferenceablePointer(const Value *V, Type *Ty, const DataLayout &DL, const Instruction *CtxI=nullptr, AssumptionCache *AC=nullptr, const DominatorTree *DT=nullptr, const TargetLibraryInfo *TLI=nullptr)
Return true if this is always a dereferenceable pointer.
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI OverflowResult computeOverflowForUnsignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
auto pred_begin(const MachineBasicBlock *BB)
LLVM_ABI PreservedAnalyses getLoopPassPreservedAnalyses()
Returns the minimum set of Analyses that all loop passes must preserve.
auto find_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::find_if which take ranges instead of having to pass begin/end explicitly.
void erase_if(Container &C, UnaryPredicate P)
Provide a container algorithm similar to C++ Library Fundamentals v2's erase_if which is equivalent t...
auto predecessors(const MachineBasicBlock *BB)
Type * getLoadStoreType(const Value *I)
A helper function that returns the type of a load or store instruction.
LLVM_ABI bool sinkRegion(DomTreeNode *, AAResults *, LoopInfo *, DominatorTree *, TargetLibraryInfo *, TargetTransformInfo *, Loop *CurLoop, MemorySSAUpdater &, ICFLoopSafetyInfo *, SinkAndHoistLICMFlags &, OptimizationRemarkEmitter *, Loop *OutermostLoop=nullptr)
Walk the specified region of the CFG (defined by all blocks dominated by the specified block,...
LLVM_ABI OverflowResult computeOverflowForUnsignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
cl::opt< unsigned > SetLicmMssaNoAccForPromotionCap
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
bool capturesNothing(CaptureComponents CC)
LLVM_ABI bool isKnownNonNegative(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Returns true if the give value is known to be non-negative.
LLVM_ABI bool promoteLoopAccessesToScalars(const SmallSetVector< Value *, 8 > &, SmallVectorImpl< BasicBlock * > &, SmallVectorImpl< BasicBlock::iterator > &, SmallVectorImpl< MemoryAccess * > &, PredIteratorCache &, LoopInfo *, DominatorTree *, AssumptionCache *AC, const TargetLibraryInfo *, TargetTransformInfo *, Loop *, MemorySSAUpdater &, ICFLoopSafetyInfo *, OptimizationRemarkEmitter *, bool AllowSpeculation, bool HasReadsOutsideSet)
Try to promote memory values to scalars by sinking stores out of the loop and moving loads to before ...
cl::opt< unsigned > SetLicmMssaOptCap
LLVM_ABI bool sinkRegionForLoopNest(DomTreeNode *, AAResults *, LoopInfo *, DominatorTree *, TargetLibraryInfo *, TargetTransformInfo *, Loop *, MemorySSAUpdater &, ICFLoopSafetyInfo *, SinkAndHoistLICMFlags &, OptimizationRemarkEmitter *)
Call sinkRegion on loops contained within the specified loop in order from innermost to outermost.
LLVM_ABI bool isWritableObject(const Value *Object, bool &ExplicitlyDereferenceableOnly)
Return true if the Object is writable, in the sense that any location based on this pointer that can ...
LLVM_ABI void reportFatalUsageError(Error Err)
Report a fatal error that does not indicate a bug in LLVM.
Implement std::hash so that hash_code can be used in STL containers.
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
A collection of metadata nodes that might be associated with a memory access used by the alias-analys...
LLVM_ABI AAMDNodes merge(const AAMDNodes &Other) const
Given two sets of AAMDNodes applying to potentially different locations, determine the best AAMDNodes...
This struct is a compact representation of a valid (non-zero power of two) alignment.
unsigned MssaNoAccForPromotionCap
The adaptor from a function pass to a loop pass computes these analyses and makes them available to t...
TargetTransformInfo & TTI
A lightweight accessor for an operand bundle meant to be passed around by value.
uint32_t getTagID() const
Return the tag of this operand bundle as an integer.
A CRTP mix-in to automatically provide informational APIs needed for passes.