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."));
176 bool &FoldableInLoop,
bool LoopNestMode);
192 bool InvariantGroup);
214 std::pair<SmallSetVector<Value *, 8>,
bool>;
219struct LoopInvariantCodeMotion {
225 LoopInvariantCodeMotion(
unsigned LicmMssaOptCap,
226 unsigned LicmMssaNoAccForPromotionCap,
227 bool LicmAllowSpeculation)
228 : LicmMssaOptCap(LicmMssaOptCap),
229 LicmMssaNoAccForPromotionCap(LicmMssaNoAccForPromotionCap),
230 LicmAllowSpeculation(LicmAllowSpeculation) {}
233 unsigned LicmMssaOptCap;
234 unsigned LicmMssaNoAccForPromotionCap;
235 bool LicmAllowSpeculation;
238struct LegacyLICMPass :
public LoopPass {
243 bool LicmAllowSpeculation =
true)
244 :
LoopPass(
ID), LICM(LicmMssaOptCap, LicmMssaNoAccForPromotionCap,
245 LicmAllowSpeculation) {
254 <<
L->getHeader()->getNameOrAsOperand() <<
"\n");
258 auto *SE = getAnalysisIfAvailable<ScalarEvolutionWrapperPass>();
259 MemorySSA *MSSA = &getAnalysis<MemorySSAWrapperPass>().getMSSA();
264 return LICM.runOnLoop(
265 L, &getAnalysis<AAResultsWrapperPass>().getAAResults(),
266 &getAnalysis<LoopInfoWrapperPass>().getLoopInfo(),
267 &getAnalysis<DominatorTreeWrapperPass>().getDomTree(),
268 &getAnalysis<AssumptionCacheTracker>().getAssumptionCache(*
F),
269 &getAnalysis<TargetLibraryInfoWrapperPass>().getTLI(*
F),
270 &getAnalysis<TargetTransformInfoWrapperPass>().getTTI(*
F),
271 SE ? &SE->getSE() :
nullptr, MSSA, &ORE);
292 LoopInvariantCodeMotion LICM;
309 if (!LICM.runOnLoop(&L, &AR.
AA, &AR.
LI, &AR.
DT, &AR.
AC, &AR.
TLI, &AR.
TTI,
322 OS, MapClassName2PassName);
345 bool Changed = LICM.runOnLoop(&OutermostLoop, &AR.
AA, &AR.
LI, &AR.
DT, &AR.
AC,
363 OS, MapClassName2PassName);
370char LegacyLICMPass::ID = 0;
389 unsigned LicmMssaOptCap,
unsigned LicmMssaNoAccForPromotionCap,
bool IsSink,
391 : LicmMssaOptCap(LicmMssaOptCap),
392 LicmMssaNoAccForPromotionCap(LicmMssaNoAccForPromotionCap),
394 unsigned AccessCapCount = 0;
395 for (
auto *BB : L.getBlocks())
397 for (
const auto &MA : *Accesses) {
417 bool Changed =
false;
419 assert(L->isLCSSAForm(*DT) &&
"Loop is not in LCSSA form.");
437 return llvm::any_of(*BB, [](Instruction &I) {
438 IntrinsicInst *II = dyn_cast<IntrinsicInst>(&I);
439 return II && II->getIntrinsicID() == Intrinsic::coro_suspend;
463 if (
L->hasDedicatedExits())
467 TLI,
TTI, L, MSSAU, &SafetyInfo, Flags, ORE)
469 MSSAU, &SafetyInfo,
Flags, ORE);
470 Flags.setIsSink(
false);
473 MSSAU, SE, &SafetyInfo, Flags, ORE, LoopNestMode,
474 LicmAllowSpeculation);
484 !
Flags.tooManyMemoryAccesses() && !HasCoroSuspendInst) {
487 L->getUniqueExitBlocks(ExitBlocks);
491 return isa<CatchSwitchInst>(
Exit->getTerminator());
494 if (!HasCatchSwitch) {
500 InsertPts.
push_back(ExitBlock->getFirstInsertionPt());
508 bool Promoted =
false;
511 LocalPromoted =
false;
512 for (
auto [PointerMustAliases, HasReadsOutsideSet] :
515 PointerMustAliases, ExitBlocks, InsertPts, MSSAInsertPts,
PIC, LI,
516 DT, AC, TLI,
TTI, L, MSSAU, &SafetyInfo, ORE,
517 LicmAllowSpeculation, HasReadsOutsideSet);
519 Promoted |= LocalPromoted;
520 }
while (LocalPromoted);
538 assert(
L->isLCSSAForm(*DT) &&
"Loop not left in LCSSA form after LICM!");
539 assert((
L->isOutermost() ||
L->getParentLoop()->isLCSSAForm(*DT)) &&
540 "Parent loop not left in LCSSA form after LICM!");
563 assert(
N !=
nullptr && AA !=
nullptr && LI !=
nullptr && DT !=
nullptr &&
564 CurLoop !=
nullptr && SafetyInfo !=
nullptr &&
565 "Unexpected input to sinkRegion.");
573 bool Changed =
false;
599 bool FoldableInLoop =
false;
600 bool LoopNestMode = OutermostLoop !=
nullptr;
601 if (!
I.mayHaveSideEffects() &&
603 SafetyInfo,
TTI, FoldableInLoop,
606 if (
sink(
I, LI, DT, CurLoop, SafetyInfo, MSSAU, ORE)) {
607 if (!FoldableInLoop) {
630 bool Changed =
false;
634 while (!Worklist.
empty()) {
637 MSSAU, SafetyInfo, Flags, ORE, CurLoop);
650class ControlFlowHoister {
669 : LI(LI), DT(DT), CurLoop(CurLoop), MSSAU(MSSAU) {}
671 void registerPossiblyHoistableBranch(
BranchInst *BI) {
683 TrueDest == FalseDest)
695 if (TrueDestSucc.
count(FalseDest)) {
696 CommonSucc = FalseDest;
697 }
else if (FalseDestSucc.
count(TrueDest)) {
698 CommonSucc = TrueDest;
702 if (TrueDestSucc.
size() == 1)
703 CommonSucc = *TrueDestSucc.
begin();
707 else if (!TrueDestSucc.
empty()) {
711 assert(It !=
F->end() &&
"Could not find successor in function");
723 if (CommonSucc && DT->
dominates(BI, CommonSucc))
724 HoistableBranches[BI] = CommonSucc;
727 bool canHoistPHI(
PHINode *PN) {
736 PredecessorBlocks.
insert(PredBB);
744 for (
auto &Pair : HoistableBranches) {
745 if (Pair.second == BB) {
748 if (Pair.first->getSuccessor(0) == BB) {
749 PredecessorBlocks.
erase(Pair.first->getParent());
750 PredecessorBlocks.
erase(Pair.first->getSuccessor(1));
751 }
else if (Pair.first->getSuccessor(1) == BB) {
752 PredecessorBlocks.
erase(Pair.first->getParent());
753 PredecessorBlocks.
erase(Pair.first->getSuccessor(0));
755 PredecessorBlocks.
erase(Pair.first->getSuccessor(0));
756 PredecessorBlocks.
erase(Pair.first->getSuccessor(1));
762 return PredecessorBlocks.
empty();
769 if (HoistDestinationMap.
count(BB))
770 return HoistDestinationMap[BB];
773 auto HasBBAsSuccessor =
775 return BB != Pair.second && (Pair.first->getSuccessor(0) == BB ||
776 Pair.first->getSuccessor(1) == BB);
778 auto It =
llvm::find_if(HoistableBranches, HasBBAsSuccessor);
782 if (It == HoistableBranches.end()) {
785 <<
" as hoist destination for "
787 HoistDestinationMap[BB] = InitialPreheader;
788 return InitialPreheader;
791 assert(std::find_if(++It, HoistableBranches.end(), HasBBAsSuccessor) ==
792 HoistableBranches.end() &&
793 "BB is expected to be the target of at most one branch");
798 BasicBlock *CommonSucc = HoistableBranches[BI];
802 auto CreateHoistedBlock = [&](
BasicBlock *Orig) {
803 if (HoistDestinationMap.
count(Orig))
804 return HoistDestinationMap[Orig];
807 HoistDestinationMap[Orig] =
New;
813 <<
" as hoist destination for " << Orig->getName()
817 BasicBlock *HoistTrueDest = CreateHoistedBlock(TrueDest);
818 BasicBlock *HoistFalseDest = CreateHoistedBlock(FalseDest);
819 BasicBlock *HoistCommonSucc = CreateHoistedBlock(CommonSucc);
826 assert(TargetSucc &&
"Expected hoist target to have a single successor");
841 if (HoistTarget == InitialPreheader) {
852 for (
auto &Pair : HoistDestinationMap)
853 if (Pair.second == InitialPreheader && Pair.first != BI->
getParent())
854 Pair.second = HoistCommonSucc;
864 "Hoisting blocks should not have destroyed preheader");
865 return HoistDestinationMap[BB];
882 bool AllowSpeculation) {
884 assert(
N !=
nullptr && AA !=
nullptr && LI !=
nullptr && DT !=
nullptr &&
885 CurLoop !=
nullptr && SafetyInfo !=
nullptr &&
886 "Unexpected input to hoistRegion.");
888 ControlFlowHoister CFH(LI, DT, CurLoop, MSSAU);
899 bool Changed =
false;
904 if (!LoopNestMode &&
inSubLoop(BB, CurLoop, LI))
918 I, DT, TLI, CurLoop, SafetyInfo, ORE,
920 hoist(
I, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
929 if (
I.getOpcode() == Instruction::FDiv &&
I.hasAllowReciprocal() &&
931 auto Divisor =
I.getOperand(1);
932 auto One = llvm::ConstantFP::get(Divisor->getType(), 1.0);
933 auto ReciprocalDivisor = BinaryOperator::CreateFDiv(One, Divisor);
934 ReciprocalDivisor->setFastMathFlags(
I.getFastMathFlags());
936 ReciprocalDivisor->insertBefore(
I.getIterator());
937 ReciprocalDivisor->setDebugLoc(
I.getDebugLoc());
940 BinaryOperator::CreateFMul(
I.getOperand(0), ReciprocalDivisor);
941 Product->setFastMathFlags(
I.getFastMathFlags());
943 Product->insertAfter(
I.getIterator());
944 Product->setDebugLoc(
I.getDebugLoc());
945 I.replaceAllUsesWith(Product);
948 hoist(*ReciprocalDivisor, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB),
949 SafetyInfo, MSSAU, SE, ORE);
950 HoistedInstructions.
push_back(ReciprocalDivisor);
956 using namespace PatternMatch;
957 return I.use_empty() &&
958 match(&
I, m_Intrinsic<Intrinsic::invariant_start>());
960 auto MustExecuteWithoutWritesBefore = [&](
Instruction &
I) {
964 if ((IsInvariantStart(
I) ||
isGuard(&
I)) &&
966 MustExecuteWithoutWritesBefore(
I)) {
967 hoist(
I, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
974 if (
PHINode *PN = dyn_cast<PHINode>(&
I)) {
975 if (CFH.canHoistPHI(PN)) {
981 hoist(*PN, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
999 CFH.registerPossiblyHoistableBranch(BI);
1014 [&](
Use &U) { return DT->dominates(I, U); })) {
1020 "New hoist point expected to dominate old hoist point");
1024 << HoistPoint->
getParent()->getNameOrAsOperand()
1025 <<
": " << *
I <<
"\n");
1038#ifdef EXPENSIVE_CHECKS
1040 assert(DT->
verify(DominatorTree::VerificationLevel::Fast) &&
1041 "Dominator tree verification failed");
1073 if (isa<Constant>(
Addr))
1076 unsigned UsesVisited = 0;
1079 for (
auto *U :
Addr->users()) {
1086 if (!
II ||
II->getIntrinsicID() != Intrinsic::invariant_start ||
1089 ConstantInt *InvariantSize = cast<ConstantInt>(
II->getArgOperand(0));
1113 return (isa<LoadInst>(
I) || isa<StoreInst>(
I) || isa<CallInst>(
I) ||
1114 isa<FenceInst>(
I) || isa<CastInst>(
I) || isa<UnaryOperator>(
I) ||
1115 isa<BinaryOperator>(
I) || isa<SelectInst>(
I) ||
1116 isa<GetElementPtrInst>(
I) || isa<CmpInst>(
I) ||
1117 isa<InsertElementInst>(
I) || isa<ExtractElementInst>(
I) ||
1118 isa<ShuffleVectorInst>(
I) || isa<ExtractValueInst>(
I) ||
1119 isa<InsertValueInst>(
I) || isa<FreezeInst>(
I));
1123 for (
auto *BB :
L->getBlocks())
1132 for (
auto *BB :
L->getBlocks())
1135 for (
const auto &Acc : *Accs) {
1136 if (isa<MemoryPhi>(&Acc))
1138 const auto *MUD = cast<MemoryUseOrDef>(&Acc);
1139 if (MUD->getMemoryInst() !=
I || NotAPhi++ == 1)
1152 if (Flags.tooManyClobberingCalls())
1157 Flags.incrementClobberingCalls();
1163 bool TargetExecutesOncePerLoop,
1167 if (!isHoistableAndSinkableInst(
I))
1172 if (
LoadInst *LI = dyn_cast<LoadInst>(&
I)) {
1173 if (!LI->isUnordered())
1180 if (LI->hasMetadata(LLVMContext::MD_invariant_load))
1183 if (LI->isAtomic() && !TargetExecutesOncePerLoop)
1192 bool InvariantGroup = LI->hasMetadata(LLVMContext::MD_invariant_group);
1195 MSSA, MU, CurLoop,
I, Flags, InvariantGroup);
1201 DEBUG_TYPE,
"LoadWithLoopInvariantAddressInvalidated", LI)
1202 <<
"failed to move load with loop-invariant address "
1203 "because the loop may invalidate its value";
1207 }
else if (
CallInst *CI = dyn_cast<CallInst>(&
I)) {
1209 if (isa<DbgInfoIntrinsic>(
I))
1220 if (CI->isConvergent())
1228 if (CI->getFunction()->isPresplitCoroutine())
1231 using namespace PatternMatch;
1232 if (
match(CI, m_Intrinsic<Intrinsic::assume>()))
1248 if (
Op->getType()->isPointerTy() &&
1258 if (isReadOnly(MSSAU, CurLoop))
1266 }
else if (
auto *FI = dyn_cast<FenceInst>(&
I)) {
1269 return isOnlyMemoryAccess(FI, CurLoop, MSSAU);
1270 }
else if (
auto *SI = dyn_cast<StoreInst>(&
I)) {
1271 if (!SI->isUnordered())
1279 if (isOnlyMemoryAccess(SI, CurLoop, MSSAU))
1283 if (Flags.tooManyMemoryAccesses())
1291 CurLoop->
contains(Source->getBlock()))
1301 for (
const auto &MA : *Accesses)
1302 if (
const auto *MU = dyn_cast<MemoryUse>(&MA)) {
1312 if (!Flags.getIsSink() && !MSSA->
dominates(SIMD, MU))
1314 }
else if (
const auto *MD = dyn_cast<MemoryDef>(&MA)) {
1315 if (
auto *LI = dyn_cast<LoadInst>(MD->getMemoryInst())) {
1317 assert(!LI->isUnordered() &&
"Expected unordered load");
1321 if (
auto *CI = dyn_cast<CallInst>(MD->getMemoryInst())) {
1334 assert(!
I.mayReadOrWriteMemory() &&
"unhandled aliasing");
1357 if (
auto *
GEP = dyn_cast<GetElementPtrInst>(&
I)) {
1366 for (
const User *U :
GEP->users()) {
1370 (!isa<StoreInst>(UI) && !isa<LoadInst>(UI))))
1388 bool &FoldableInLoop,
bool LoopNestMode) {
1391 for (
const User *U :
I.users()) {
1393 if (
const PHINode *PN = dyn_cast<PHINode>(UI)) {
1401 if (isa<CallInst>(
I))
1402 if (!BlockColors.empty() &&
1403 BlockColors.find(
const_cast<BasicBlock *
>(BB))->second.size() != 1)
1407 while (isa<PHINode>(UI) && UI->
hasOneUser() &&
1411 UI = cast<Instruction>(UI->
user_back());
1418 FoldableInLoop =
true;
1431 if (
auto *CI = dyn_cast<CallInst>(&
I)) {
1438 for (
unsigned BundleIdx = 0, BundleEnd = CI->getNumOperandBundles();
1439 BundleIdx != BundleEnd; ++BundleIdx) {
1447 if (!BlockColors.empty()) {
1448 const ColorVector &CV = BlockColors.find(&ExitBlock)->second;
1449 assert(CV.
size() == 1 &&
"non-unique color for exit block!");
1452 if (EHPad->isEHPad())
1457 New->copyMetadata(*CI);
1463 if (!
I.getName().empty())
1464 New->setName(
I.getName() +
".le");
1474 if (
auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc))
1477 auto *MemUse = cast<MemoryUse>(NewMemAcc);
1490 for (
Use &
Op : New->operands())
1492 auto *OInst = cast<Instruction>(
Op.get());
1495 OInst->getName() +
".lcssa");
1508 I.eraseFromParent();
1517 I.moveBefore(*Dest->getParent(), Dest);
1532 "Expect only trivially replaceable PHI");
1535 auto It = SunkCopies.
find(ExitBlock);
1536 if (It != SunkCopies.
end())
1540 *
I, *ExitBlock, *TPN, LI, SafetyInfo, MSSAU);
1556 if (isa<IndirectBrInst>(BBPred->getTerminator()))
1573 assert(ExitBlockSet.
count(ExitBB) &&
"Expect the PHI is in an exit block.");
1610 while (!PredBBs.
empty()) {
1613 "Expect all predecessors are in the loop");
1616 ExitBB, PredBB,
".split.loop.exit", &DTU, LI, MSSAU,
true);
1620 if (!BlockColors.empty())
1638 bool Changed =
false;
1645 auto *
User = cast<Instruction>(*UI);
1646 Use &U = UI.getUse();
1684 UI =
I.user_begin();
1688 if (VisitedUsers.
empty())
1693 <<
"sinking " <<
ore::NV(
"Inst", &
I);
1695 if (isa<LoadInst>(
I))
1697 else if (isa<CallInst>(
I))
1717 for (
auto *UI :
Users) {
1718 auto *
User = cast<Instruction>(UI);
1725 "The LCSSA PHI is not in an exit block!");
1729 PN, &
I, LI, SunkCopies, SafetyInfo, CurLoop, MSSAU);
1731 New->dropLocation();
1761 if ((
I.hasMetadataOtherThanDebugLoc() || isa<CallInst>(
I)) &&
1766 I.dropUBImplyingAttrsAndMetadata();
1768 if (isa<PHINode>(
I))
1776 I.updateLocationAfterHoist();
1778 if (isa<LoadInst>(
I))
1780 else if (isa<CallInst>(
I))
1793 if (AllowSpeculation &&
1797 bool GuaranteedToExecute =
1800 if (!GuaranteedToExecute) {
1801 auto *LI = dyn_cast<LoadInst>(&Inst);
1805 DEBUG_TYPE,
"LoadWithLoopInvariantAddressCondExecuted", LI)
1806 <<
"failed to hoist load with loop-invariant address "
1807 "because load is conditionally executed";
1811 return GuaranteedToExecute;
1825 bool UnorderedAtomic;
1828 bool CanInsertStoresInExitBlocks;
1842 I->getName() +
".lcssa");
1858 LoopInsertPts(LIP), MSSAInsertPts(MSSAIP), PredCache(
PIC), MSSAU(MSSAU),
1859 LI(li),
DL(
std::
move(dl)), Alignment(Alignment),
1860 UnorderedAtomic(UnorderedAtomic), AATags(AATags),
1861 SafetyInfo(SafetyInfo),
1862 CanInsertStoresInExitBlocks(CanInsertStoresInExitBlocks),
Uses(Insts) {}
1864 void insertStoresInLoopExitBlocks() {
1870 for (
unsigned i = 0, e = LoopExitBlocks.
size(); i != e; ++i) {
1872 Value *LiveInValue =
SSA.GetValueInMiddleOfBlock(ExitBlock);
1873 LiveInValue = maybeInsertLCSSAPHI(LiveInValue, ExitBlock);
1874 Value *
Ptr = maybeInsertLCSSAPHI(SomePtr, ExitBlock);
1877 if (UnorderedAtomic)
1888 NewID = cast_or_null<DIAssignID>(
1893 NewSI->
setMetadata(LLVMContext::MD_DIAssignID, NewID);
1901 if (!MSSAInsertPoint) {
1908 MSSAInsertPts[i] = NewMemAcc;
1909 MSSAU.
insertDef(cast<MemoryDef>(NewMemAcc),
true);
1914 void doExtraRewritesBeforeFinalDeletion()
override {
1915 if (CanInsertStoresInExitBlocks)
1916 insertStoresInLoopExitBlocks();
1919 void instructionDeleted(
Instruction *
I)
const override {
1925 if (isa<StoreInst>(
I))
1926 return CanInsertStoresInExitBlocks;
1931bool isNotCapturedBeforeOrInLoop(
const Value *V,
const Loop *L,
1939 L->getHeader()->getTerminator(), DT);
1944bool isNotVisibleOnUnwindInLoop(
const Value *Object,
const Loop *L,
1946 bool RequiresNoCaptureBeforeUnwind;
1950 return !RequiresNoCaptureBeforeUnwind ||
1951 isNotCapturedBeforeOrInLoop(Object, L, DT);
1959 isNotCapturedBeforeOrInLoop(Object, L, DT)) ||
1979 bool HasReadsOutsideSet) {
1981 assert(LI !=
nullptr && DT !=
nullptr && CurLoop !=
nullptr &&
1982 SafetyInfo !=
nullptr &&
1983 "Unexpected Input to promoteLoopAccessesToScalars");
1986 dbgs() <<
"Trying to promote set of must-aliased pointers:\n";
1987 for (
Value *
Ptr : PointerMustAliases)
1988 dbgs() <<
" " << *
Ptr <<
"\n";
1990 ++NumPromotionCandidates;
1992 Value *SomePtr = *PointerMustAliases.
begin();
2032 bool DereferenceableInPH =
false;
2033 bool StoreIsGuanteedToExecute =
false;
2034 bool LoadIsGuaranteedToExecute =
false;
2035 bool FoundLoadToPromote =
false;
2042 } StoreSafety = StoreSafetyUnknown;
2050 bool SawUnorderedAtomic =
false;
2051 bool SawNotAtomic =
false;
2058 if (HasReadsOutsideSet)
2059 StoreSafety = StoreUnsafe;
2068 if (!isNotVisibleOnUnwindInLoop(Object, CurLoop, DT))
2069 StoreSafety = StoreUnsafe;
2075 Type *AccessTy =
nullptr;
2076 for (
Value *ASIV : PointerMustAliases) {
2077 for (
Use &U : ASIV->uses()) {
2079 Instruction *UI = dyn_cast<Instruction>(U.getUser());
2085 if (
LoadInst *Load = dyn_cast<LoadInst>(UI)) {
2086 if (!Load->isUnordered())
2089 SawUnorderedAtomic |= Load->isAtomic();
2090 SawNotAtomic |= !Load->isAtomic();
2091 FoundLoadToPromote =
true;
2093 Align InstAlignment = Load->getAlign();
2095 if (!LoadIsGuaranteedToExecute)
2096 LoadIsGuaranteedToExecute =
2103 if (!DereferenceableInPH || (InstAlignment > Alignment))
2105 *Load, DT, TLI, CurLoop, SafetyInfo, ORE,
2107 DereferenceableInPH =
true;
2108 Alignment = std::max(Alignment, InstAlignment);
2110 }
else if (
const StoreInst *Store = dyn_cast<StoreInst>(UI)) {
2115 if (!Store->isUnordered())
2118 SawUnorderedAtomic |= Store->isAtomic();
2119 SawNotAtomic |= !Store->isAtomic();
2126 Align InstAlignment = Store->getAlign();
2127 bool GuaranteedToExecute =
2129 StoreIsGuanteedToExecute |= GuaranteedToExecute;
2130 if (GuaranteedToExecute) {
2131 DereferenceableInPH =
true;
2132 if (StoreSafety == StoreSafetyUnknown)
2133 StoreSafety = StoreSafe;
2134 Alignment = std::max(Alignment, InstAlignment);
2143 if (StoreSafety == StoreSafetyUnknown &&
2145 return DT->
dominates(Store->getParent(), Exit);
2147 StoreSafety = StoreSafe;
2151 if (!DereferenceableInPH) {
2153 Store->getPointerOperand(), Store->getValueOperand()->getType(),
2154 Store->getAlign(), MDL, Preheader->
getTerminator(), AC, DT, TLI);
2165 if (LoopUses.
empty()) {
2168 }
else if (AATags) {
2180 if (SawUnorderedAtomic && SawNotAtomic)
2190 if (!DereferenceableInPH) {
2191 LLVM_DEBUG(
dbgs() <<
"Not promoting: Not dereferenceable in preheader\n");
2199 if (StoreSafety == StoreSafetyUnknown) {
2201 bool ExplicitlyDereferenceableOnly;
2203 (!ExplicitlyDereferenceableOnly ||
2205 isThreadLocalObject(Object, CurLoop, DT,
TTI))
2206 StoreSafety = StoreSafe;
2211 if (StoreSafety != StoreSafe && !FoundLoadToPromote)
2216 if (StoreSafety == StoreSafe) {
2217 LLVM_DEBUG(
dbgs() <<
"LICM: Promoting load/store of the value: " << *SomePtr
2219 ++NumLoadStorePromoted;
2221 LLVM_DEBUG(
dbgs() <<
"LICM: Promoting load of the value: " << *SomePtr
2229 <<
"Moving accesses to memory location out of the loop";
2233 std::vector<DILocation *> LoopUsesLocs;
2234 for (
auto *U : LoopUses)
2235 LoopUsesLocs.push_back(U->getDebugLoc().get());
2241 LoopPromoter Promoter(SomePtr, LoopUses,
SSA, ExitBlocks, InsertPts,
2242 MSSAInsertPts,
PIC, MSSAU, *LI,
DL, Alignment,
2244 StoreIsGuanteedToExecute ? AATags :
AAMDNodes(),
2245 *SafetyInfo, StoreSafety == StoreSafe);
2250 if (FoundLoadToPromote || !StoreIsGuanteedToExecute) {
2254 if (SawUnorderedAtomic)
2258 if (AATags && LoadIsGuaranteedToExecute)
2263 MemoryUse *NewMemUse = cast<MemoryUse>(PreheaderLoadMemoryAccess);
2265 SSA.AddAvailableValue(Preheader, PreheaderLoad);
2274 Promoter.run(LoopUses);
2279 if (PreheaderLoad && PreheaderLoad->
use_empty())
2289 for (
const auto &
Access : *Accesses)
2290 if (
const auto *MUD = dyn_cast<MemoryUseOrDef>(&
Access))
2291 Fn(MUD->getMemoryInst());
2301 auto IsPotentiallyPromotable = [L](
const Instruction *
I) {
2302 if (
const auto *SI = dyn_cast<StoreInst>(
I))
2303 return L->isLoopInvariant(SI->getPointerOperand());
2304 if (
const auto *LI = dyn_cast<LoadInst>(
I))
2305 return L->isLoopInvariant(LI->getPointerOperand());
2312 if (IsPotentiallyPromotable(
I)) {
2313 AttemptingPromotion.
insert(
I);
2321 if (!AS.isForwardingAliasSet() && AS.isMod() && AS.isMustAlias())
2333 ModRefInfo MR = Pair.getPointer()->aliasesUnknownInst(I, BatchAA);
2342 return !Pair.getPointer()->isRef();
2349 for (
auto [Set, HasReadsOutsideSet] : Sets) {
2351 for (
const auto &MemLoc : *Set)
2352 PointerMustAliases.
insert(
const_cast<Value *
>(MemLoc.Ptr));
2353 Result.emplace_back(std::move(PointerMustAliases), HasReadsOutsideSet);
2362 bool InvariantGroup) {
2364 if (!Flags.getIsSink()) {
2377 CurLoop->
contains(Source->getBlock()) &&
2378 !(InvariantGroup && Source->getBlock() == CurLoop->
getHeader() && isa<MemoryPhi>(Source));
2398 if (Flags.tooManyMemoryAccesses())
2412 for (
const auto &MA : *Accesses)
2413 if (
const auto *MD = dyn_cast<MemoryDef>(&MA))
2425 using namespace PatternMatch;
2426 Value *Cond1, *Cond2;
2442 if (L.isLoopInvariant(
LHS)) {
2446 if (L.isLoopInvariant(
LHS) || !L.isLoopInvariant(
RHS))
2453 Value *LHS1, *LHS2, *RHS1, *RHS2;
2454 if (!MatchICmpAgainstInvariant(Cond1, P1, LHS1, RHS1) ||
2455 !MatchICmpAgainstInvariant(Cond2, P2, LHS2, RHS2))
2458 if (!MatchingPred || LHS1 != LHS2)
2466 "Relational predicate is either less (or equal) or greater (or equal)!");
2468 ? (UseMin ? Intrinsic::smin : Intrinsic::smax)
2469 : (UseMin ? Intrinsic::umin : Intrinsic::umax);
2470 auto *Preheader = L.getLoopPreheader();
2471 assert(Preheader &&
"Loop is not in simplify form?");
2477 if (isa<SelectInst>(
I))
2480 id, RHS1, RHS2,
nullptr,
2483 (UseMin ?
"min" :
"max"));
2490 I.replaceAllUsesWith(NewCond);
2502 auto *
GEP = dyn_cast<GetElementPtrInst>(&
I);
2506 auto *Src = dyn_cast<GetElementPtrInst>(
GEP->getPointerOperand());
2507 if (!Src || !Src->hasOneUse() || !L.contains(Src))
2510 Value *SrcPtr = Src->getPointerOperand();
2511 auto LoopInvariant = [&](
Value *V) {
return L.isLoopInvariant(V); };
2512 if (!L.isLoopInvariant(SrcPtr) || !
all_of(
GEP->indices(), LoopInvariant))
2519 if (
all_of(Src->indices(), LoopInvariant))
2529 bool IsInBounds = Src->isInBounds() &&
GEP->isInBounds() &&
2533 BasicBlock *Preheader = L.getLoopPreheader();
2537 "invariant.gep", IsInBounds);
2539 Value *NewGEP = Builder.
CreateGEP(Src->getSourceElementType(), NewSrc,
2542 GEP->replaceAllUsesWith(NewGEP);
2554 assert(!L.isLoopInvariant(VariantLHS) &&
"Precondition.");
2555 assert(L.isLoopInvariant(InvariantRHS) &&
"Precondition.");
2560 using namespace PatternMatch;
2561 Value *VariantOp, *InvariantOp;
2571 if (L.isLoopInvariant(VariantOp))
2573 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2580 auto &
DL = L.getHeader()->getDataLayout();
2589 auto *Preheader = L.getLoopPreheader();
2590 assert(Preheader &&
"Loop is not in simplify form?");
2593 Builder.
CreateSub(InvariantRHS, InvariantOp,
"invariant.op",
2594 !IsSigned, IsSigned);
2609 assert(!L.isLoopInvariant(VariantLHS) &&
"Precondition.");
2610 assert(L.isLoopInvariant(InvariantRHS) &&
"Precondition.");
2615 using namespace PatternMatch;
2616 Value *VariantOp, *InvariantOp;
2624 bool VariantSubtracted =
false;
2628 if (L.isLoopInvariant(VariantOp)) {
2630 VariantSubtracted =
true;
2633 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2641 auto &
DL = L.getHeader()->getDataLayout();
2643 if (VariantSubtracted && IsSigned) {
2648 }
else if (VariantSubtracted && !IsSigned) {
2653 }
else if (!VariantSubtracted && IsSigned) {
2664 auto *Preheader = L.getLoopPreheader();
2665 assert(Preheader &&
"Loop is not in simplify form?");
2669 ? Builder.
CreateSub(InvariantOp, InvariantRHS,
"invariant.op",
2670 !IsSigned, IsSigned)
2671 : Builder.
CreateAdd(InvariantOp, InvariantRHS,
"invariant.op",
2672 !IsSigned, IsSigned);
2684 using namespace PatternMatch;
2691 if (L.isLoopInvariant(
LHS)) {
2702 if (
hoistAdd(Pred,
LHS,
RHS, cast<ICmpInst>(
I), L, SafetyInfo, MSSAU, AC, DT))
2705 if (
hoistSub(Pred,
LHS,
RHS, cast<ICmpInst>(
I), L, SafetyInfo, MSSAU, AC, DT))
2712 unsigned FPOpcode) {
2713 if (
I->getOpcode() == IntOpcode)
2715 if (
I->getOpcode() == FPOpcode &&
I->hasAllowReassoc() &&
2716 I->hasNoSignedZeros())
2732 Value *VariantOp =
I.getOperand(0);
2733 Value *InvariantOp =
I.getOperand(1);
2734 if (L.isLoopInvariant(VariantOp))
2736 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2738 Value *Factor = InvariantOp;
2744 if (
BinaryOperator *VariantBinOp = dyn_cast<BinaryOperator>(VariantOp))
2746 while (!Worklist.
empty()) {
2759 L.isLoopInvariant(BO))
2763 if (L.isLoopInvariant(U0))
2765 else if (L.isLoopInvariant(U1))
2769 unsigned Limit =
I.getType()->isIntOrIntVectorTy()
2772 if (Changes.
size() > Limit)
2775 if (Changes.
empty())
2779 if (
I.getType()->isIntOrIntVectorTy()) {
2780 for (
auto *
Add : Adds)
2781 Add->dropPoisonGeneratingFlags();
2785 auto *Preheader = L.getLoopPreheader();
2786 assert(Preheader &&
"Loop is not in simplify form?");
2788 for (
auto *U : Changes) {
2789 assert(L.isLoopInvariant(U->get()));
2790 auto *Ins = cast<BinaryOperator>(U->getUser());
2792 if (
I.getType()->isIntOrIntVectorTy()) {
2793 Mul = Builder.
CreateMul(U->get(), Factor,
"factor.op.mul");
2795 Ins->dropPoisonGeneratingFlags();
2800 unsigned OpIdx = U->getOperandNo();
2801 auto *
LHS = OpIdx == 0 ?
Mul : Ins->getOperand(0);
2802 auto *
RHS = OpIdx == 1 ?
Mul : Ins->getOperand(1);
2805 Ins->getName() +
".reass", Ins->getIterator());
2806 NewBO->copyIRFlags(Ins);
2807 if (VariantOp == Ins)
2809 Ins->replaceAllUsesWith(NewBO);
2813 I.replaceAllUsesWith(VariantOp);
2832 auto *BO = dyn_cast<BinaryOperator>(&
I);
2833 if (!BO || !BO->isAssociative())
2837 bool LVInRHS = L.isLoopInvariant(BO->getOperand(0));
2838 auto *BO0 = dyn_cast<BinaryOperator>(BO->getOperand(LVInRHS));
2839 if (!BO0 || BO0->getOpcode() != Opcode || !BO0->isAssociative() ||
2840 BO0->hasNUsesOrMore(3))
2843 Value *LV = BO0->getOperand(0);
2844 Value *C1 = BO0->getOperand(1);
2845 Value *C2 = BO->getOperand(!LVInRHS);
2847 assert(BO->isCommutative() && BO0->isCommutative() &&
2848 "Associativity implies commutativity");
2849 if (L.isLoopInvariant(LV) && !L.isLoopInvariant(C1))
2851 if (L.isLoopInvariant(LV) || !L.isLoopInvariant(C1) || !L.isLoopInvariant(C2))
2854 auto *Preheader = L.getLoopPreheader();
2855 assert(Preheader &&
"Loop is not in simplify form?");
2858 auto *Inv = Builder.
CreateBinOp(Opcode, C1, C2,
"invariant.op");
2861 Opcode, LV, Inv, BO->
getName() +
".reass", BO->getIterator());
2864 if (Opcode == Instruction::Add && BO->hasNoUnsignedWrap() &&
2865 BO0->hasNoUnsignedWrap()) {
2867 if (
auto *
I = dyn_cast<Instruction>(Inv))
2868 I->setHasNoUnsignedWrap(
true);
2869 NewBO->setHasNoUnsignedWrap(
true);
2870 }
else if (Opcode == Instruction::FAdd || Opcode == Instruction::FMul) {
2872 FastMathFlags Intersect = BO->getFastMathFlags() & BO0->getFastMathFlags();
2873 if (
auto *
I = dyn_cast<Instruction>(Inv))
2874 I->setFastMathFlags(Intersect);
2875 NewBO->setFastMathFlags(Intersect);
2878 BO->replaceAllUsesWith(NewBO);
2883 if (BO0->use_empty())
2903 if (
hoistGEP(
I, L, SafetyInfo, MSSAU, AC, DT)) {
2916 bool IsInt =
I.getType()->isIntOrIntVectorTy();
2920 ++NumIntAssociationsHoisted;
2922 ++NumFPAssociationsHoisted;
2928 ++NumBOAssociationsHoisted;
2939 assert(CurLoop->
contains(BB) &&
"Only valid if BB is IN the loop");
unsigned const MachineRegisterInfo * MRI
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...
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"))
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)"))
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 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 ...
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
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
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)
ModRefInfo getModRefInfoMask(const MemoryLocation &Loc, bool IgnoreLocals=false)
Returns a bitmask that should be unconditionally applied to the ModRef info of a memory location.
MemoryEffects getMemoryEffects(const CallBase *Call)
Return the behavior of the given call site.
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.
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.
const_iterator getFirstInsertionPt() const
Returns an iterator to the first instruction in this block that is suitable for inserting a non-PHI i...
InstListType::const_iterator getFirstNonPHIIt() const
Iterator returning form of getFirstNonPHI.
static BasicBlock * Create(LLVMContext &Context, const Twine &Name="", Function *Parent=nullptr, BasicBlock *InsertBefore=nullptr)
Creates a new BasicBlock.
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.
const DataLayout & getDataLayout() const
Get the data layout of the module this basic block belongs to.
InstListType::iterator iterator
Instruction iterators...
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...
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 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 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 ...
static DILocation * getMergedLocations(ArrayRef< DILocation * > Locs)
Try to combine the vector of locations passed as input in a single one.
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.
iterator find(const_arg_type_t< KeyT > Val)
size_type count(const_arg_type_t< KeyT > Val) const
Return 1 if the specified key is in the map, 0 otherwise.
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.
bool isReachableFromEntry(const Use &U) const
Provide an overload for a Use.
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())
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...
void mergeDIAssignID(ArrayRef< const Instruction * > SourceInstructions)
Merge the DIAssignID metadata from this instruction and those attached to instructions in SourceInstr...
void insertBefore(Instruction *InsertPos)
Insert an unlinked instruction into a basic block immediately before the specified instruction.
void setAAMetadata(const AAMDNodes &N)
Sets the AA metadata on this instruction from the AAMDNodes structure.
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.
void setMetadata(unsigned KindID, MDNode *Node)
Set the metadata of the specified kind to the specified node.
AAMDNodes getAAMetadata() const
Returns the AA metadata for this instruction.
void setDebugLoc(DebugLoc Loc)
Set the debug location information for this instruction.
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.
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.
void copyColors(BasicBlock *New, BasicBlock *Old)
Copy colors of block Old into the block New.
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 hasLoopInvariantOperands(const Instruction *I) const
Return true if all the operands of the specified instruction are loop invariant.
bool isLoopInvariant(const Value *V) const
Return true if the specified value is loop invariant.
BasicBlock * getBlock() const
bool doesNotAccessMemory() const
Whether this function accesses no memory.
bool onlyAccessesArgPointees() const
Whether this function only (at most) accesses argument memory.
bool onlyReadsMemory() const
Whether this function only (at most) reads memory.
static 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.
void insertDef(MemoryDef *Def, bool RenameUses=false)
Insert a definition into the MemorySSA IR.
void insertUse(MemoryUse *Use, bool RenameUses=false)
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.
void removeMemoryAccess(MemoryAccess *, bool OptimizePhis=false)
Remove a MemoryAccess from MemorySSA, including updating all definitions and uses.
MemoryUseOrDef * createMemoryAccessAfter(Instruction *I, MemoryAccess *Definition, MemoryAccess *InsertPt)
Create a MemoryAccess in MemorySSA after an existing MemoryAccess.
void moveToPlace(MemoryUseOrDef *What, BasicBlock *BB, MemorySSA::InsertionPlace Where)
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.
MemorySSAWalker * getSkipSelfWalker()
bool dominates(const MemoryAccess *A, const MemoryAccess *B) const
Given two memory accesses in potentially different blocks, determine whether MemoryAccess A dominates...
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.
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 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 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.
void forgetBlockAndLoopDispositions(Value *V=nullptr)
Called when the client has changed the disposition of values in a loop or block.
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.
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...
bool erase(PtrType Ptr)
Remove pointer from the set.
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.
bool hasOneUser() const
Return true if there is exactly one user of this value.
std::string getNameOrAsOperand() const
bool hasOneUse() const
Return true if there is exactly one use of this value.
void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
user_iterator_impl< User > user_iterator
StringRef getName() const
Return a constant reference to the value's name.
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.
@ C
The default llvm calling convention, compatible with C.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
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)
OneUse_match< T > m_OneUse(const T &SubPattern)
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.
void ReplaceInstWithInst(BasicBlock *BB, BasicBlock::iterator &BI, Instruction *I)
Replace the instruction specified by BI with the instruction specified by I.
@ 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.
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<>...
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...
void initializeLegacyLICMPassPass(PassRegistry &)
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.
bool formLCSSARecursively(Loop &L, const DominatorTree &DT, const LoopInfo *LI, ScalarEvolution *SE)
Put a loop nest into LCSSA form.
bool PointerMayBeCapturedBefore(const Value *V, bool ReturnCaptures, bool StoreCaptures, 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...
const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=6)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
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)
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 hoistRegion(DomTreeNode *, AAResults *, LoopInfo *, DominatorTree *, AssumptionCache *, TargetLibraryInfo *, Loop *, MemorySSAUpdater &, ScalarEvolution *, ICFLoopSafetyInfo *, SinkAndHoistLICMFlags &, OptimizationRemarkEmitter *, bool, bool AllowSpeculation)
Walk the specified region of the CFG (defined by all blocks dominated by the specified block,...
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
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)
OverflowResult computeOverflowForSignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
bool isModSet(const ModRefInfo MRI)
raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
void report_fatal_error(Error Err, bool gen_crash_diag=true)
Report a serious error, calling any installed error handler.
bool isModOrRefSet(const ModRefInfo MRI)
bool isSafeToSpeculativelyExecute(const Instruction *I, const Instruction *CtxI=nullptr, AssumptionCache *AC=nullptr, const DominatorTree *DT=nullptr, const TargetLibraryInfo *TLI=nullptr, bool UseVariableInfo=true)
Return true if the instruction does not have any effects besides calculating the result and does not ...
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...
void getLoopAnalysisUsage(AnalysisUsage &AU)
Helper to consistently add the set of standard passes to a loop pass's AnalysisUsage.
RNSuccIterator< NodeRef, BlockT, RegionT > succ_begin(NodeRef Node)
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.
bool VerifyMemorySSA
Enables verification of MemorySSA.
RNSuccIterator< NodeRef, BlockT, RegionT > succ_end(NodeRef Node)
bool salvageKnowledge(Instruction *I, AssumptionCache *AC=nullptr, DominatorTree *DT=nullptr)
Calls BuildAssumeFromInst and if the resulting llvm.assume is valid insert if before I.
bool hasDisableLICMTransformsHint(const Loop *L)
Look for the loop attribute that disables the LICM transformation heuristics.
OverflowResult computeOverflowForSignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
@ Mul
Product of integers.
void appendLoopsToWorklist(RangeT &&, SmallPriorityWorklist< Loop *, 4 > &)
Utility that implements appending of loops onto a worklist given a range.
bool isIdentifiedFunctionLocal(const Value *V)
Return true if V is umabigously identified at the function-level.
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.
OverflowResult computeOverflowForUnsignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
auto pred_begin(const MachineBasicBlock *BB)
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.
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,...
OverflowResult computeOverflowForUnsignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
cl::opt< unsigned > SetLicmMssaNoAccForPromotionCap
bool isKnownNonNegative(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Returns true if the give value is known to be non-negative.
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
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.
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 ...
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...
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.