LLVM 23.0.0git
LoopInfo.cpp
Go to the documentation of this file.
1//===- LoopInfo.cpp - Natural Loop Calculator -----------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file defines the LoopInfo class that is used to identify natural loops
10// and determine the loop depth of various nodes of the CFG. Note that the
11// loops identified may actually be several natural loops that share the same
12// header node... not just a single natural loop.
13//
14//===----------------------------------------------------------------------===//
15
17#include "llvm/ADT/ScopeExit.h"
26#include "llvm/Config/llvm-config.h"
27#include "llvm/IR/CFG.h"
28#include "llvm/IR/Constants.h"
29#include "llvm/IR/DebugLoc.h"
30#include "llvm/IR/Dominators.h"
32#include "llvm/IR/LLVMContext.h"
33#include "llvm/IR/Metadata.h"
34#include "llvm/IR/Module.h"
35#include "llvm/IR/PassManager.h"
36#include "llvm/IR/PrintPasses.h"
43using namespace llvm;
44
45// Explicitly instantiate methods in LoopInfoImpl.h for IR-level Loops.
48
49// Always verify loopinfo if expensive checking is enabled.
50#ifdef EXPENSIVE_CHECKS
51bool llvm::VerifyLoopInfo = true;
52#else
54#endif
57 cl::Hidden, cl::desc("Verify loop info (time consuming)"));
58
59namespace llvm {
61} // end namespace llvm
62
63//===----------------------------------------------------------------------===//
64// Loop implementation
65//
66
67bool Loop::isLoopInvariant(const Value *V) const {
68 if (const Instruction *I = dyn_cast<Instruction>(V))
69 return !contains(I);
70 return true; // All non-instructions are loop invariant
71}
72
74 return all_of(I->operands(), [&](Value *V) { return isLoopInvariant(V); });
75}
76
78 MemorySSAUpdater *MSSAU,
79 ScalarEvolution *SE) const {
81 return makeLoopInvariant(I, Changed, InsertPt, MSSAU, SE);
82 return true; // All non-instructions are loop-invariant.
83}
84
86 Instruction *InsertPt, MemorySSAUpdater *MSSAU,
87 ScalarEvolution *SE) const {
88 BasicBlock *OriginalParent = I->getParent();
89 // Test if the value is already loop-invariant.
90 if (isLoopInvariant(I))
91 return true;
93 return false;
94 if (I->mayReadFromMemory())
95 return false;
96 // EH block instructions are immobile.
97 if (I->isEHPad())
98 return false;
99 // Determine the insertion point, unless one was given.
100 if (!InsertPt) {
101 BasicBlock *Preheader = getLoopPreheader();
102 // Without a preheader, hoisting is not feasible.
103 if (!Preheader)
104 return false;
105 InsertPt = Preheader->getTerminator();
106 }
107 // Don't hoist instructions with loop-variant operands.
108 for (Value *Operand : I->operands())
109 if (!makeLoopInvariant(Operand, Changed, InsertPt, MSSAU, SE))
110 return false;
111
112 // Hoist.
113 I->moveBefore(InsertPt->getIterator());
114 if (MSSAU)
115 if (auto *MUD = MSSAU->getMemorySSA()->getMemoryAccess(I))
116 MSSAU->moveToPlace(MUD, InsertPt->getParent(),
118
119 // We want to preserve profile metadata if possible. However, we need to
120 // ensure that profile metadata would remain the same outside of the loop.
121 // Given at this point we know the conditional is loop-invariant, we just
122 // need to worry about other control flow in the loop conditioned on values
123 // that are potentially not independent of the condition of the instruction
124 // we are interested in hoisting. Given this is not knowable in the general
125 // case, we only hoist from a loop header (which covers a reasonable number
126 // of cases) where we are guaranteed to not run into problems.
127 SmallVector<unsigned, 1> ProfileMetadataToPreserve;
129 if (OriginalParent == getHeader())
130 ProfileMetadataToPreserve.push_back(LLVMContext::MD_prof);
131
132 // There is possibility of hoisting this instruction above some arbitrary
133 // condition. Any metadata defined on it can be control dependent on this
134 // condition. Conservatively strip it here so that we don't give any wrong
135 // information to the optimizer.
136 I->dropUnknownNonDebugMetadata(ProfileMetadataToPreserve);
137
138 if (ProfileMetadataToPreserve.empty() && isa<SelectInst>(I))
140
141 if (SE)
143
144 Changed = true;
145 return true;
146}
147
149 BasicBlock *&Backedge) const {
151
152 Incoming = nullptr;
153 Backedge = nullptr;
155 assert(PI != pred_end(H) && "Loop must have at least one backedge!");
156 Backedge = *PI++;
157 if (PI == pred_end(H))
158 return false; // dead loop
159 Incoming = *PI++;
160 if (PI != pred_end(H))
161 return false; // multiple backedges?
162
163 if (contains(Incoming)) {
164 if (contains(Backedge))
165 return false;
166 std::swap(Incoming, Backedge);
167 } else if (!contains(Backedge))
168 return false;
169
170 assert(Incoming && Backedge && "expected non-null incoming and backedges");
171 return true;
172}
173
176
177 BasicBlock *Incoming = nullptr, *Backedge = nullptr;
178 if (!getIncomingAndBackEdge(Incoming, Backedge))
179 return nullptr;
180
181 // Loop over all of the PHI nodes, looking for a canonical indvar.
182 for (BasicBlock::iterator I = H->begin(); isa<PHINode>(I); ++I) {
183 PHINode *PN = cast<PHINode>(I);
184 if (ConstantInt *CI =
186 if (CI->isZero())
187 if (Instruction *Inc =
189 if (Inc->getOpcode() == Instruction::Add && Inc->getOperand(0) == PN)
190 if (ConstantInt *CI = dyn_cast<ConstantInt>(Inc->getOperand(1)))
191 if (CI->isOne())
192 return PN;
193 }
194 return nullptr;
195}
196
197/// Get the latch condition instruction.
199 if (BasicBlock *Latch = getLoopLatch())
200 if (CondBrInst *BI = dyn_cast_or_null<CondBrInst>(Latch->getTerminator()))
201 return dyn_cast<ICmpInst>(BI->getCondition());
202
203 return nullptr;
204}
205
206/// Return the final value of the loop induction variable if found.
207static Value *findFinalIVValue(const Loop &L, const PHINode &IndVar,
208 const Instruction &StepInst) {
209 ICmpInst *LatchCmpInst = L.getLatchCmpInst();
210 if (!LatchCmpInst)
211 return nullptr;
212
213 Value *Op0 = LatchCmpInst->getOperand(0);
214 Value *Op1 = LatchCmpInst->getOperand(1);
215 if (Op0 == &IndVar || Op0 == &StepInst)
216 return Op1;
217
218 if (Op1 == &IndVar || Op1 == &StepInst)
219 return Op0;
220
221 return nullptr;
222}
223
224std::optional<Loop::LoopBounds>
226 ScalarEvolution &SE) {
227 InductionDescriptor IndDesc;
228 if (!InductionDescriptor::isInductionPHI(&IndVar, &L, &SE, IndDesc))
229 return std::nullopt;
230
231 Value *InitialIVValue = IndDesc.getStartValue();
232 Instruction *StepInst = IndDesc.getInductionBinOp();
233 if (!InitialIVValue || !StepInst)
234 return std::nullopt;
235
236 const SCEV *Step = IndDesc.getStep();
237 Value *StepInstOp1 = StepInst->getOperand(1);
238 Value *StepInstOp0 = StepInst->getOperand(0);
239 Value *StepValue = nullptr;
240 if (SE.getSCEV(StepInstOp1) == Step)
241 StepValue = StepInstOp1;
242 else if (SE.getSCEV(StepInstOp0) == Step)
243 StepValue = StepInstOp0;
244
245 Value *FinalIVValue = findFinalIVValue(L, IndVar, *StepInst);
246 if (!FinalIVValue)
247 return std::nullopt;
248
249 return LoopBounds(L, *InitialIVValue, *StepInst, StepValue, *FinalIVValue,
250 SE);
251}
252
254
256 BasicBlock *Latch = L.getLoopLatch();
257 assert(Latch && "Expecting valid latch");
258
260
261 ICmpInst *LatchCmpInst = dyn_cast<ICmpInst>(BI->getCondition());
262 assert(LatchCmpInst &&
263 "Expecting the latch compare instruction to be a CmpInst");
264
265 // Need to inverse the predicate when first successor is not the loop
266 // header
267 ICmpInst::Predicate Pred = (BI->getSuccessor(0) == L.getHeader())
268 ? LatchCmpInst->getPredicate()
269 : LatchCmpInst->getInversePredicate();
270
271 if (LatchCmpInst->getOperand(0) == &getFinalIVValue())
273
274 // Need to flip strictness of the predicate when the latch compare instruction
275 // is not using StepInst
276 if (LatchCmpInst->getOperand(0) == &getStepInst() ||
277 LatchCmpInst->getOperand(1) == &getStepInst())
278 return Pred;
279
280 // Cannot flip strictness of NE and EQ
281 if (Pred != ICmpInst::ICMP_NE && Pred != ICmpInst::ICMP_EQ)
283
285 if (D == Direction::Increasing)
286 return ICmpInst::ICMP_SLT;
287
288 if (D == Direction::Decreasing)
289 return ICmpInst::ICMP_SGT;
290
291 // If cannot determine the direction, then unable to find the canonical
292 // predicate
294}
295
297 if (const SCEVAddRecExpr *StepAddRecExpr =
299 if (const SCEV *StepRecur = StepAddRecExpr->getStepRecurrence(SE)) {
300 if (SE.isKnownPositive(StepRecur))
301 return Direction::Increasing;
302 if (SE.isKnownNegative(StepRecur))
303 return Direction::Decreasing;
304 }
305
306 return Direction::Unknown;
307}
308
309std::optional<Loop::LoopBounds> Loop::getBounds(ScalarEvolution &SE) const {
310 if (PHINode *IndVar = getInductionVariable(SE))
311 return LoopBounds::getBounds(*this, *IndVar, SE);
312
313 return std::nullopt;
314}
315
317 if (!isLoopSimplifyForm())
318 return nullptr;
319
320 BasicBlock *Header = getHeader();
321 assert(Header && "Expected a valid loop header");
323 if (!CmpInst)
324 return nullptr;
325
326 Value *LatchCmpOp0 = CmpInst->getOperand(0);
327 Value *LatchCmpOp1 = CmpInst->getOperand(1);
328
329 for (PHINode &IndVar : Header->phis()) {
330 InductionDescriptor IndDesc;
331 if (!InductionDescriptor::isInductionPHI(&IndVar, this, &SE, IndDesc))
332 continue;
333
334 BasicBlock *Latch = getLoopLatch();
335 Value *StepInst = IndVar.getIncomingValueForBlock(Latch);
336
337 // case 1:
338 // IndVar = phi[{InitialValue, preheader}, {StepInst, latch}]
339 // StepInst = IndVar + step
340 // cmp = StepInst < FinalValue
341 if (StepInst == LatchCmpOp0 || StepInst == LatchCmpOp1)
342 return &IndVar;
343
344 // case 2:
345 // IndVar = phi[{InitialValue, preheader}, {StepInst, latch}]
346 // StepInst = IndVar + step
347 // cmp = IndVar < FinalValue
348 if (&IndVar == LatchCmpOp0 || &IndVar == LatchCmpOp1)
349 return &IndVar;
350 }
351
352 return nullptr;
353}
354
356 InductionDescriptor &IndDesc) const {
357 if (PHINode *IndVar = getInductionVariable(SE))
358 return InductionDescriptor::isInductionPHI(IndVar, this, &SE, IndDesc);
359
360 return false;
361}
362
364 ScalarEvolution &SE) const {
365 // Located in the loop header
366 BasicBlock *Header = getHeader();
367 if (AuxIndVar.getParent() != Header)
368 return false;
369
370 // No uses outside of the loop
371 for (User *U : AuxIndVar.users())
372 if (const Instruction *I = dyn_cast<Instruction>(U))
373 if (!contains(I))
374 return false;
375
376 InductionDescriptor IndDesc;
377 if (!InductionDescriptor::isInductionPHI(&AuxIndVar, this, &SE, IndDesc))
378 return false;
379
380 // The step instruction opcode should be add or sub.
381 if (IndDesc.getInductionOpcode() != Instruction::Add &&
382 IndDesc.getInductionOpcode() != Instruction::Sub)
383 return false;
384
385 // Incremented by a loop invariant step for each loop iteration
386 return SE.isLoopInvariant(IndDesc.getStep(), this);
387}
388
390 if (!isLoopSimplifyForm())
391 return nullptr;
392
393 BasicBlock *Preheader = getLoopPreheader();
394 assert(Preheader && getLoopLatch() &&
395 "Expecting a loop with valid preheader and latch");
396
397 // Loop should be in rotate form.
398 if (!isRotatedForm())
399 return nullptr;
400
401 // Disallow loops with more than one unique exit block, as we do not verify
402 // that GuardOtherSucc post dominates all exit blocks.
403 BasicBlock *ExitFromLatch = getUniqueExitBlock();
404 if (!ExitFromLatch)
405 return nullptr;
406
407 BasicBlock *GuardBB = Preheader->getUniquePredecessor();
408 if (!GuardBB)
409 return nullptr;
410
411 assert(GuardBB->getTerminator() && "Expecting valid guard terminator");
412
413 CondBrInst *GuardBI = dyn_cast<CondBrInst>(GuardBB->getTerminator());
414 if (!GuardBI)
415 return nullptr;
416
417 BasicBlock *GuardOtherSucc = (GuardBI->getSuccessor(0) == Preheader)
418 ? GuardBI->getSuccessor(1)
419 : GuardBI->getSuccessor(0);
420
421 // Check if ExitFromLatch (or any BasicBlock which is an empty unique
422 // successor of ExitFromLatch) is equal to GuardOtherSucc. If
423 // skipEmptyBlockUntil returns GuardOtherSucc, then the guard branch for the
424 // loop is GuardBI (return GuardBI), otherwise return nullptr.
425 if (&LoopNest::skipEmptyBlockUntil(ExitFromLatch, GuardOtherSucc,
426 /*CheckUniquePred=*/true) ==
427 GuardOtherSucc)
428 return GuardBI;
429 else
430 return nullptr;
431}
432
434 InductionDescriptor IndDesc;
435 if (!getInductionDescriptor(SE, IndDesc))
436 return false;
437
439 if (!Init || !Init->isZero())
440 return false;
441
442 if (IndDesc.getInductionOpcode() != Instruction::Add)
443 return false;
444
445 ConstantInt *Step = IndDesc.getConstIntStepValue();
446 if (!Step || !Step->isOne())
447 return false;
448
449 return true;
450}
451
452// Check that 'BB' doesn't have any uses outside of the 'L'
453static bool isBlockInLCSSAForm(const Loop &L, const BasicBlock &BB,
454 const DominatorTree &DT, bool IgnoreTokens) {
455 for (const Instruction &I : BB) {
456 // Tokens can't be used in PHI nodes and live-out tokens prevent loop
457 // optimizations, so for the purposes of considered LCSSA form, we
458 // can ignore them.
459 if (IgnoreTokens && I.getType()->isTokenTy())
460 continue;
461
462 for (const Use &U : I.uses()) {
463 const Instruction *UI = cast<Instruction>(U.getUser());
464 const BasicBlock *UserBB = UI->getParent();
465
466 // For practical purposes, we consider that the use in a PHI
467 // occurs in the respective predecessor block. For more info,
468 // see the `phi` doc in LangRef and the LCSSA doc.
469 if (const PHINode *P = dyn_cast<PHINode>(UI))
470 UserBB = P->getIncomingBlock(U);
471
472 // Check the current block, as a fast-path, before checking whether
473 // the use is anywhere in the loop. Most values are used in the same
474 // block they are defined in. Also, blocks not reachable from the
475 // entry are special; uses in them don't need to go through PHIs.
476 if (UserBB != &BB && !L.contains(UserBB) &&
477 DT.isReachableFromEntry(UserBB))
478 return false;
479 }
480 }
481 return true;
482}
483
484bool Loop::isLCSSAForm(const DominatorTree &DT, bool IgnoreTokens) const {
485 // For each block we check that it doesn't have any uses outside of this loop.
486 return all_of(this->blocks(), [&](const BasicBlock *BB) {
487 return isBlockInLCSSAForm(*this, *BB, DT, IgnoreTokens);
488 });
489}
490
492 bool IgnoreTokens) const {
493 // For each block we check that it doesn't have any uses outside of its
494 // innermost loop. This process will transitively guarantee that the current
495 // loop and all of the nested loops are in LCSSA form.
496 return all_of(this->blocks(), [&](const BasicBlock *BB) {
497 return isBlockInLCSSAForm(*LI.getLoopFor(BB), *BB, DT, IgnoreTokens);
498 });
499}
500
502 // Normal-form loops have a preheader, a single backedge, and all of their
503 // exits have all their predecessors inside the loop.
505}
506
507// Routines that reform the loop CFG and split edges often fail on indirectbr.
509 // Return false if any loop blocks contain indirectbrs, or there are any calls
510 // to noduplicate functions.
511 for (BasicBlock *BB : this->blocks()) {
512 if (isa<IndirectBrInst>(BB->getTerminator()))
513 return false;
514
515 for (Instruction &I : *BB)
516 if (auto *CB = dyn_cast<CallBase>(&I))
517 if (CB->cannotDuplicate())
518 return false;
519 }
520 return true;
521}
522
524 MDNode *LoopID = nullptr;
525
526 // Go through the latch blocks and check the terminator for the metadata.
527 SmallVector<BasicBlock *, 4> LatchesBlocks;
528 getLoopLatches(LatchesBlocks);
529 for (BasicBlock *BB : LatchesBlocks) {
530 Instruction *TI = BB->getTerminator();
531 MDNode *MD = TI->getMetadata(LLVMContext::MD_loop);
532
533 if (!MD)
534 return nullptr;
535
536 if (!LoopID)
537 LoopID = MD;
538 else if (MD != LoopID)
539 return nullptr;
540 }
541 if (!LoopID || LoopID->getNumOperands() == 0 ||
542 LoopID->getOperand(0) != LoopID)
543 return nullptr;
544 return LoopID;
545}
546
547void Loop::setLoopID(MDNode *LoopID) const {
548 assert((!LoopID || LoopID->getNumOperands() > 0) &&
549 "Loop ID needs at least one operand");
550 assert((!LoopID || LoopID->getOperand(0) == LoopID) &&
551 "Loop ID should refer to itself");
552
554 getLoopLatches(LoopLatches);
555 for (BasicBlock *BB : LoopLatches)
556 BB->getTerminator()->setMetadata(LLVMContext::MD_loop, LoopID);
557}
558
560 LLVMContext &Context = getHeader()->getContext();
561
562 MDNode *DisableUnrollMD =
563 MDNode::get(Context, MDString::get(Context, "llvm.loop.unroll.disable"));
564 MDNode *LoopID = getLoopID();
566 Context, LoopID, {"llvm.loop.unroll."}, {DisableUnrollMD});
567 setLoopID(NewLoopID);
568}
569
571 LLVMContext &Context = getHeader()->getContext();
572
573 MDNode *MustProgress = findOptionMDForLoop(this, "llvm.loop.mustprogress");
574
575 if (MustProgress)
576 return;
577
578 MDNode *MustProgressMD =
579 MDNode::get(Context, MDString::get(Context, "llvm.loop.mustprogress"));
580 MDNode *LoopID = getLoopID();
581 MDNode *NewLoopID =
582 makePostTransformationMetadata(Context, LoopID, {}, {MustProgressMD});
583 setLoopID(NewLoopID);
584}
585
587 MDNode *DesiredLoopIdMetadata = getLoopID();
588
589 if (!DesiredLoopIdMetadata)
590 return false;
591
592 MDNode *ParallelAccesses =
593 findOptionMDForLoop(this, "llvm.loop.parallel_accesses");
595 ParallelAccessGroups; // For scalable 'contains' check.
596 if (ParallelAccesses) {
597 for (const MDOperand &MD : drop_begin(ParallelAccesses->operands())) {
598 MDNode *AccGroup = cast<MDNode>(MD.get());
599 assert(isValidAsAccessGroup(AccGroup) &&
600 "List item must be an access group");
601 ParallelAccessGroups.insert(AccGroup);
602 }
603 }
604
605 // The loop branch contains the parallel loop metadata. In order to ensure
606 // that any parallel-loop-unaware optimization pass hasn't added loop-carried
607 // dependencies (thus converted the loop back to a sequential loop), check
608 // that all the memory instructions in the loop belong to an access group that
609 // is parallel to this loop.
610 for (BasicBlock *BB : this->blocks()) {
611 for (Instruction &I : *BB) {
612 if (!I.mayReadOrWriteMemory())
613 continue;
614
615 if (MDNode *AccessGroup = I.getMetadata(LLVMContext::MD_access_group)) {
616 auto ContainsAccessGroup = [&ParallelAccessGroups](MDNode *AG) -> bool {
617 if (AG->getNumOperands() == 0) {
618 assert(isValidAsAccessGroup(AG) && "Item must be an access group");
619 return ParallelAccessGroups.count(AG);
620 }
621
622 for (const MDOperand &AccessListItem : AG->operands()) {
623 MDNode *AccGroup = cast<MDNode>(AccessListItem.get());
624 assert(isValidAsAccessGroup(AccGroup) &&
625 "List item must be an access group");
626 if (ParallelAccessGroups.count(AccGroup))
627 return true;
628 }
629 return false;
630 };
631
632 if (ContainsAccessGroup(AccessGroup))
633 continue;
634 }
635
636 // The memory instruction can refer to the loop identifier metadata
637 // directly or indirectly through another list metadata (in case of
638 // nested parallel loops). The loop identifier metadata refers to
639 // itself so we can check both cases with the same routine.
640 MDNode *LoopIdMD =
641 I.getMetadata(LLVMContext::MD_mem_parallel_loop_access);
642
643 if (!LoopIdMD)
644 return false;
645
646 if (!llvm::is_contained(LoopIdMD->operands(), DesiredLoopIdMetadata))
647 return false;
648 }
649 }
650 return true;
651}
652
654
656 // If we have a debug location in the loop ID, then use it.
657 if (MDNode *LoopID = getLoopID()) {
658 DebugLoc Start;
659 // We use the first DebugLoc in the header as the start location of the loop
660 // and if there is a second DebugLoc in the header we use it as end location
661 // of the loop.
662 for (const MDOperand &MDO : llvm::drop_begin(LoopID->operands())) {
663 if (DILocation *L = dyn_cast<DILocation>(MDO)) {
664 if (!Start)
665 Start = DebugLoc(L);
666 else
667 return LocRange(Start, DebugLoc(L));
668 }
669 }
670
671 if (Start)
672 return LocRange(Start);
673 }
674
675 // Try the pre-header first.
676 if (BasicBlock *PHeadBB = getLoopPreheader())
677 if (DebugLoc DL = PHeadBB->getTerminator()->getDebugLoc())
678 return LocRange(DL);
679
680 // If we have no pre-header or there are no instructions with debug
681 // info in it, try the header.
682 if (BasicBlock *HeadBB = getHeader())
683 return LocRange(HeadBB->getTerminator()->getDebugLoc());
684
685 return LocRange();
686}
687
688std::string Loop::getLocStr() const {
689 std::string Result;
690 raw_string_ostream OS(Result);
691 if (const DebugLoc LoopDbgLoc = getStartLoc())
692 LoopDbgLoc.print(OS);
693 else
694 // Just print the module name.
696 return Result;
697}
698
699#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
701
703 print(dbgs(), /*Verbose=*/true);
704}
705#endif
706
707//===----------------------------------------------------------------------===//
708// UnloopUpdater implementation
709//
710
711namespace {
712/// Find the new parent loop for all blocks within the "unloop" whose last
713/// backedges has just been removed.
714class UnloopUpdater {
715 Loop &Unloop;
716 LoopInfo *LI;
717
718 LoopBlocksDFS DFS;
719
720 // Map unloop's immediate subloops to their nearest reachable parents. Nested
721 // loops within these subloops will not change parents. However, an immediate
722 // subloop's new parent will be the nearest loop reachable from either its own
723 // exits *or* any of its nested loop's exits.
724 DenseMap<Loop *, Loop *> SubloopParents;
725
726 // Flag the presence of an irreducible backedge whose destination is a block
727 // directly contained by the original unloop.
728 bool FoundIB = false;
729
730public:
731 UnloopUpdater(Loop *UL, LoopInfo *LInfo) : Unloop(*UL), LI(LInfo), DFS(UL) {}
732
733 void updateBlockParents();
734
735 void removeBlocksFromAncestors();
736
737 void updateSubloopParents();
738
739protected:
740 Loop *getNearestLoop(BasicBlock *BB, Loop *BBLoop);
741};
742} // end anonymous namespace
743
744/// Update the parent loop for all blocks that are directly contained within the
745/// original "unloop".
746void UnloopUpdater::updateBlockParents() {
747 if (Unloop.getNumBlocks()) {
748 // Perform a post order CFG traversal of all blocks within this loop,
749 // propagating the nearest loop from successors to predecessors.
750 LoopBlocksTraversal Traversal(DFS, LI);
751 for (BasicBlock *POI : Traversal) {
752
753 Loop *L = LI->getLoopFor(POI);
754 Loop *NL = getNearestLoop(POI, L);
755
756 if (NL != L) {
757 // For reducible loops, NL is now an ancestor of Unloop.
758 assert((NL != &Unloop && (!NL || NL->contains(&Unloop))) &&
759 "uninitialized successor");
760 LI->changeLoopFor(POI, NL);
761 } else {
762 // Or the current block is part of a subloop, in which case its parent
763 // is unchanged.
764 assert((FoundIB || Unloop.contains(L)) && "uninitialized successor");
765 }
766 }
767 }
768 // Each irreducible loop within the unloop induces a round of iteration using
769 // the DFS result cached by Traversal.
770 bool Changed = FoundIB;
771 for (unsigned NIters = 0; Changed; ++NIters) {
772 assert(NIters < Unloop.getNumBlocks() && "runaway iterative algorithm");
773 (void)NIters;
774
775 // Iterate over the postorder list of blocks, propagating the nearest loop
776 // from successors to predecessors as before.
777 Changed = false;
778 for (LoopBlocksDFS::POIterator POI = DFS.beginPostorder(),
779 POE = DFS.endPostorder();
780 POI != POE; ++POI) {
781
782 Loop *L = LI->getLoopFor(*POI);
783 Loop *NL = getNearestLoop(*POI, L);
784 if (NL != L) {
785 assert(NL != &Unloop && (!NL || NL->contains(&Unloop)) &&
786 "uninitialized successor");
787 LI->changeLoopFor(*POI, NL);
788 Changed = true;
789 }
790 }
791 }
792}
793
794/// Remove unloop's blocks from all ancestors below their new parents.
795void UnloopUpdater::removeBlocksFromAncestors() {
796 // Remove all unloop's blocks (including those in nested subloops) from
797 // ancestors below the new parent loop.
798 for (BasicBlock *BB : Unloop.blocks()) {
799 Loop *OuterParent = LI->getLoopFor(BB);
800 if (Unloop.contains(OuterParent)) {
801 while (OuterParent->getParentLoop() != &Unloop)
802 OuterParent = OuterParent->getParentLoop();
803 OuterParent = SubloopParents[OuterParent];
804 }
805 // Remove blocks from former Ancestors except Unloop itself which will be
806 // deleted.
807 for (Loop *OldParent = Unloop.getParentLoop(); OldParent != OuterParent;
808 OldParent = OldParent->getParentLoop()) {
809 assert(OldParent && "new loop is not an ancestor of the original");
810 OldParent->removeBlockFromLoop(BB);
811 }
812 }
813}
814
815/// Update the parent loop for all subloops directly nested within unloop.
816void UnloopUpdater::updateSubloopParents() {
817 while (!Unloop.isInnermost()) {
818 Loop *Subloop = *std::prev(Unloop.end());
819 Unloop.removeChildLoop(std::prev(Unloop.end()));
820
821 assert(SubloopParents.count(Subloop) && "DFS failed to visit subloop");
822 if (Loop *Parent = SubloopParents[Subloop])
823 Parent->addChildLoop(Subloop);
824 else
825 LI->addTopLevelLoop(Subloop);
826 }
827}
828
829/// Return the nearest parent loop among this block's successors. If a successor
830/// is a subloop header, consider its parent to be the nearest parent of the
831/// subloop's exits.
832///
833/// For subloop blocks, simply update SubloopParents and return NULL.
834Loop *UnloopUpdater::getNearestLoop(BasicBlock *BB, Loop *BBLoop) {
835
836 // Initially for blocks directly contained by Unloop, NearLoop == Unloop and
837 // is considered uninitialized.
838 Loop *NearLoop = BBLoop;
839
840 Loop *Subloop = nullptr;
841 if (NearLoop != &Unloop && Unloop.contains(NearLoop)) {
842 Subloop = NearLoop;
843 // Find the subloop ancestor that is directly contained within Unloop.
844 while (Subloop->getParentLoop() != &Unloop) {
845 Subloop = Subloop->getParentLoop();
846 assert(Subloop && "subloop is not an ancestor of the original loop");
847 }
848 // Get the current nearest parent of the Subloop exits, initially Unloop.
849 NearLoop = SubloopParents.insert({Subloop, &Unloop}).first->second;
850 }
851
852 if (succ_empty(BB)) {
853 assert(!Subloop && "subloop blocks must have a successor");
854 NearLoop = nullptr; // unloop blocks may now exit the function.
855 }
856 for (BasicBlock *Succ : successors(BB)) {
857 if (Succ == BB)
858 continue; // self loops are uninteresting
859
860 Loop *L = LI->getLoopFor(Succ);
861 if (L == &Unloop) {
862 // This successor has not been processed. This path must lead to an
863 // irreducible backedge.
864 assert((FoundIB || !DFS.hasPostorder(Succ)) && "should have seen IB");
865 FoundIB = true;
866 }
867 if (L != &Unloop && Unloop.contains(L)) {
868 // Successor is in a subloop.
869 if (Subloop)
870 continue; // Branching within subloops. Ignore it.
871
872 // BB branches from the original into a subloop header.
873 assert(L->getParentLoop() == &Unloop && "cannot skip into nested loops");
874
875 // Get the current nearest parent of the Subloop's exits.
876 L = SubloopParents[L];
877 // L could be Unloop if the only exit was an irreducible backedge.
878 }
879 if (L == &Unloop) {
880 continue;
881 }
882 // Handle critical edges from Unloop into a sibling loop.
883 if (L && !L->contains(&Unloop)) {
884 L = L->getParentLoop();
885 }
886 // Remember the nearest parent loop among successors or subloop exits.
887 if (NearLoop == &Unloop || !NearLoop || NearLoop->contains(L))
888 NearLoop = L;
889 }
890 if (Subloop) {
891 SubloopParents[Subloop] = NearLoop;
892 return BBLoop;
893 }
894 return NearLoop;
895}
896
897LoopInfo::LoopInfo(const DomTreeBase<BasicBlock> &DomTree) { analyze(DomTree); }
898
900 FunctionAnalysisManager::Invalidator &) {
901 // Check whether the analysis, all analyses on functions, or the function's
902 // CFG have been preserved.
903 auto PAC = PA.getChecker<LoopAnalysis>();
904 return !(PAC.preserved() || PAC.preservedSet<AllAnalysesOn<Function>>() ||
905 PAC.preservedSet<CFGAnalyses>());
906}
907
908void LoopInfo::erase(Loop *Unloop) {
909 assert(!Unloop->isInvalid() && "Loop has already been erased!");
910
911 llvm::scope_exit InvalidateOnExit([&]() { destroy(Unloop); });
912
913 // First handle the special case of no parent loop to simplify the algorithm.
914 if (Unloop->isOutermost()) {
915 // Since BBLoop had no parent, Unloop blocks are no longer in a loop.
916 for (BasicBlock *BB : Unloop->blocks()) {
917 // Don't reparent blocks in subloops.
918 if (getLoopFor(BB) != Unloop)
919 continue;
920
921 // Blocks no longer have a parent but are still referenced by Unloop until
922 // the Unloop object is deleted.
923 changeLoopFor(BB, nullptr);
924 }
925
926 // Remove the loop from the top-level LoopInfo object.
927 for (iterator I = begin();; ++I) {
928 assert(I != end() && "Couldn't find loop");
929 if (*I == Unloop) {
930 removeLoop(I);
931 break;
932 }
933 }
934
935 // Move all of the subloops to the top-level.
936 while (!Unloop->isInnermost())
937 addTopLevelLoop(Unloop->removeChildLoop(std::prev(Unloop->end())));
938
939 return;
940 }
941
942 // Update the parent loop for all blocks within the loop. Blocks within
943 // subloops will not change parents.
944 UnloopUpdater Updater(Unloop, this);
945 Updater.updateBlockParents();
946
947 // Remove blocks from former ancestor loops.
948 Updater.removeBlocksFromAncestors();
949
950 // Add direct subloops as children in their new parent loop.
951 Updater.updateSubloopParents();
952
953 // Remove unloop from its parent loop.
954 Loop *ParentLoop = Unloop->getParentLoop();
955 for (Loop::iterator I = ParentLoop->begin();; ++I) {
956 assert(I != ParentLoop->end() && "Couldn't find loop");
957 if (*I == Unloop) {
958 ParentLoop->removeChildLoop(I);
959 break;
960 }
961 }
962}
963
965 const Value *V, const BasicBlock *ExitBB) const {
966 if (V->getType()->isTokenTy())
967 // We can't form PHIs of token type, so the definition of LCSSA excludes
968 // values of that type.
969 return false;
970
972 if (!I)
973 return false;
974 const Loop *L = getLoopFor(I->getParent());
975 if (!L)
976 return false;
977 if (L->contains(ExitBB))
978 // Could be an exit bb of a subloop and contained in defining loop
979 return false;
980
981 // We found a (new) out-of-loop use location, for a value defined in-loop.
982 // (Note that because of LCSSA, we don't have to account for values defined
983 // in sibling loops. Such values will have LCSSA phis of their own in the
984 // common parent loop.)
985 return true;
986}
987
988AnalysisKey LoopAnalysis::Key;
989
991 // FIXME: Currently we create a LoopInfo from scratch for every function.
992 // This may prove to be too wasteful due to deallocating and re-allocating
993 // memory each time for the underlying map and vector datastructures. At some
994 // point it may prove worthwhile to use a freelist and recycle LoopInfo
995 // objects. I don't want to add that kind of complexity until the scope of
996 // the problem is better understood.
997 LoopInfo LI;
999 return LI;
1000}
1001
1004 auto &LI = AM.getResult<LoopAnalysis>(F);
1005 OS << "Loop info for function '" << F.getName() << "':\n";
1006 LI.print(OS);
1007 return PreservedAnalyses::all();
1008}
1009
1011 const std::string &Banner) {
1012 if (forcePrintModuleIR()) {
1013 // handling -print-module-scope
1014 OS << Banner << " (loop: ";
1015 L.getHeader()->printAsOperand(OS, false);
1016 OS << ")\n";
1017
1018 // printing whole module
1019 OS << *L.getHeader()->getModule();
1020 return;
1021 }
1022
1023 if (forcePrintFuncIR()) {
1024 // handling -print-loop-func-scope.
1025 // -print-module-scope overrides this.
1026 OS << Banner << " (loop: ";
1027 L.getHeader()->printAsOperand(OS, false);
1028 OS << ")\n";
1029
1030 // printing whole function.
1031 OS << *L.getHeader()->getParent();
1032 return;
1033 }
1034
1035 OS << Banner;
1036
1037 auto *PreHeader = L.getLoopPreheader();
1038 if (PreHeader) {
1039 OS << "\n; Preheader:";
1040 PreHeader->print(OS);
1041 OS << "\n; Loop:";
1042 }
1043
1044 for (auto *Block : L.blocks())
1045 if (Block)
1046 Block->print(OS);
1047 else
1048 OS << "Printing <null> block";
1049
1051 L.getExitBlocks(ExitBlocks);
1052 if (!ExitBlocks.empty()) {
1053 OS << "\n; Exit blocks";
1054 for (auto *Block : ExitBlocks)
1055 if (Block)
1056 Block->print(OS);
1057 else
1058 OS << "Printing <null> block";
1059 }
1060}
1061
1063 // No loop metadata node, no loop properties.
1064 if (!LoopID)
1065 return nullptr;
1066
1067 // First operand should refer to the metadata node itself, for legacy reasons.
1068 assert(LoopID->getNumOperands() > 0 && "requires at least one operand");
1069 assert(LoopID->getOperand(0) == LoopID && "invalid loop id");
1070
1071 // Iterate over the metdata node operands and look for MDString metadata.
1072 for (const MDOperand &MDO : llvm::drop_begin(LoopID->operands())) {
1073 MDNode *MD = dyn_cast<MDNode>(MDO);
1074 if (!MD || MD->getNumOperands() < 1)
1075 continue;
1077 if (!S)
1078 continue;
1079 // Return the operand node if MDString holds expected metadata.
1080 if (Name == S->getString())
1081 return MD;
1082 }
1083
1084 // Loop property not found.
1085 return nullptr;
1086}
1087
1089 return findOptionMDForLoopID(TheLoop->getLoopID(), Name);
1090}
1091
1092/// Find string metadata for loop
1093///
1094/// If it has a value (e.g. {"llvm.distribute", 1} return the value as an
1095/// operand or null otherwise. If the string metadata is not found return
1096/// Optional's not-a-value.
1097std::optional<const MDOperand *>
1099 MDNode *MD = findOptionMDForLoop(TheLoop, Name);
1100 if (!MD)
1101 return std::nullopt;
1102 switch (MD->getNumOperands()) {
1103 case 1:
1104 return nullptr;
1105 case 2:
1106 return &MD->getOperand(1);
1107 default:
1108 llvm_unreachable("loop metadata has 0 or 1 operand");
1109 }
1110}
1111
1112std::optional<bool> llvm::getOptionalBoolLoopAttribute(const Loop *TheLoop,
1113 StringRef Name) {
1114 MDNode *MD = findOptionMDForLoop(TheLoop, Name);
1115 if (!MD)
1116 return std::nullopt;
1117 switch (MD->getNumOperands()) {
1118 case 1:
1119 // When the value is absent it is interpreted as 'attribute set'.
1120 return true;
1121 case 2:
1122 if (ConstantInt *IntMD =
1124 return IntMD->getZExtValue();
1125 return true;
1126 }
1127 llvm_unreachable("unexpected number of options");
1128}
1129
1131 return getOptionalBoolLoopAttribute(TheLoop, Name).value_or(false);
1132}
1133
1134std::optional<int> llvm::getOptionalIntLoopAttribute(const Loop *TheLoop,
1135 StringRef Name) {
1136 const MDOperand *AttrMD =
1137 findStringMetadataForLoop(TheLoop, Name).value_or(nullptr);
1138 if (!AttrMD)
1139 return std::nullopt;
1140
1141 ConstantInt *IntMD = mdconst::extract_or_null<ConstantInt>(AttrMD->get());
1142 if (!IntMD)
1143 return std::nullopt;
1144
1145 return IntMD->getSExtValue();
1146}
1147
1149 int Default) {
1150 return getOptionalIntLoopAttribute(TheLoop, Name).value_or(Default);
1151}
1152
1154 BasicBlock *H = TheLoop->getHeader();
1155 for (Instruction &II : *H) {
1156 if (auto *CB = dyn_cast<CallBase>(&II)) {
1157 if (!CB->isConvergent())
1158 continue;
1159 // This is the heart if it uses a token defined outside the loop. The
1160 // verifier has already checked that only the loop intrinsic can use such
1161 // a token.
1162 if (auto *Token = CB->getConvergenceControlToken()) {
1163 auto *TokenDef = cast<Instruction>(Token);
1164 if (!TheLoop->contains(TokenDef->getParent()))
1165 return CB;
1166 }
1167 return nullptr;
1168 }
1169 }
1170 return nullptr;
1171}
1172
1173bool llvm::isFinite(const Loop *L) {
1174 return L->getHeader()->getParent()->willReturn();
1175}
1176
1177static const char *LLVMLoopMustProgress = "llvm.loop.mustprogress";
1178
1182
1184 return L->getHeader()->getParent()->mustProgress() || hasMustProgress(L);
1185}
1186
1188 return Node->getNumOperands() == 0 && Node->isDistinct();
1189}
1190
1192 MDNode *OrigLoopID,
1193 ArrayRef<StringRef> RemovePrefixes,
1194 ArrayRef<MDNode *> AddAttrs) {
1195 // First remove any existing loop metadata related to this transformation.
1197
1198 // Reserve first location for self reference to the LoopID metadata node.
1199 MDs.push_back(nullptr);
1200
1201 // Remove metadata for the transformation that has been applied or that became
1202 // outdated.
1203 if (OrigLoopID) {
1204 for (const MDOperand &MDO : llvm::drop_begin(OrigLoopID->operands())) {
1205 bool IsVectorMetadata = false;
1206 Metadata *Op = MDO;
1207 if (MDNode *MD = dyn_cast<MDNode>(Op)) {
1208 const MDString *S = dyn_cast<MDString>(MD->getOperand(0));
1209 if (S)
1210 IsVectorMetadata =
1211 llvm::any_of(RemovePrefixes, [S](StringRef Prefix) -> bool {
1212 return S->getString().starts_with(Prefix);
1213 });
1214 }
1215 if (!IsVectorMetadata)
1216 MDs.push_back(Op);
1217 }
1218 }
1219
1220 // Add metadata to avoid reapplying a transformation, such as
1221 // llvm.loop.unroll.disable and llvm.loop.isvectorized.
1222 MDs.append(AddAttrs.begin(), AddAttrs.end());
1223
1224 MDNode *NewLoopID = MDNode::getDistinct(Context, MDs);
1225 // Replace the temporary node with a self-reference.
1226 NewLoopID->replaceOperandWith(0, NewLoopID);
1227 return NewLoopID;
1228}
1229
1230//===----------------------------------------------------------------------===//
1231// LoopInfo implementation
1232//
1233
1235
1237INITIALIZE_PASS_BEGIN(LoopInfoWrapperPass, "loops", "Natural Loop Information",
1238 true, true)
1240INITIALIZE_PASS_END(LoopInfoWrapperPass, "loops", "Natural Loop Information",
1242
1244 releaseMemory();
1246 return false;
1247}
1248
1250 // LoopInfoWrapperPass is a FunctionPass, but verifying every loop in the
1251 // function each time verifyAnalysis is called is very expensive. The
1252 // -verify-loop-info option can enable this. In order to perform some
1253 // checking by default, LoopPass has been taught to call verifyLoop manually
1254 // during loop pass sequences.
1255 if (VerifyLoopInfo) {
1256 auto &DT = getAnalysis<DominatorTreeWrapperPass>().getDomTree();
1257 LI.verify(DT);
1258 }
1259}
1260
1265
1267 LI.print(OS);
1268}
1269
1277
1278//===----------------------------------------------------------------------===//
1279// LoopBlocksDFS implementation
1280//
1281
1282/// Traverse the loop blocks and store the DFS result.
1283/// Useful for clients that just want the final DFS result and don't need to
1284/// visit blocks during the initial traversal.
1286 LoopBlocksTraversal Traversal(*this, LI);
1287 for (LoopBlocksTraversal::POTIterator POI = Traversal.begin(),
1288 POE = Traversal.end();
1289 POI != POE; ++POI)
1290 ;
1291}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
Definition Compiler.h:661
#define LLVM_EXPORT_TEMPLATE
Definition Compiler.h:215
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...
Module.h This file contains the declarations for the Module class.
This header defines various interfaces for pass management in LLVM.
static bool isBlockInLCSSAForm(const Loop &L, const BasicBlock &BB, const DominatorTree &DT, bool IgnoreTokens)
Definition LoopInfo.cpp:453
static const char * LLVMLoopMustProgress
static Value * findFinalIVValue(const Loop &L, const PHINode &IndVar, const Instruction &StepInst)
Return the final value of the loop induction variable if found.
Definition LoopInfo.cpp:207
Loop::LoopBounds::Direction Direction
Definition LoopInfo.cpp:253
static cl::opt< bool, true > VerifyLoopInfoX("verify-loop-info", cl::location(VerifyLoopInfo), cl::Hidden, cl::desc("Verify loop info (time consuming)"))
This file defines the interface for the loop nest analysis.
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
#define H(x, y, z)
Definition MD5.cpp:56
This file exposes an interface to building/using memory SSA to walk memory instructions using a use/d...
This file contains the declarations for metadata subclasses.
uint64_t IntrinsicInst * II
#define P(N)
#define INITIALIZE_PASS_DEPENDENCY(depName)
Definition PassSupport.h:42
#define INITIALIZE_PASS_END(passName, arg, name, cfg, analysis)
Definition PassSupport.h:44
#define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis)
Definition PassSupport.h:39
This file contains the declarations for profiling metadata utility functions.
static DominatorTree getDomTree(Function &F)
This file defines the make_scope_exit function, which executes user-defined cleanup logic at scope ex...
This file defines the SmallPtrSet class.
This templated class represents "all analyses that operate over <aparticular IR unit>" (e....
Definition Analysis.h:50
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Represent the analysis usage information of a pass.
void setPreservesAll()
Set by analyses that do not transform their input at all.
AnalysisUsage & addRequiredTransitive()
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
iterator end() const
Definition ArrayRef.h:131
iterator begin() const
Definition ArrayRef.h:130
LLVM Basic Block Representation.
Definition BasicBlock.h:62
const Function * getParent() const
Return the enclosing method, or null if none.
Definition BasicBlock.h:213
LLVM_ABI const BasicBlock * getUniquePredecessor() const
Return the predecessor of this block if it has a unique predecessor block.
InstListType::iterator iterator
Instruction iterators...
Definition BasicBlock.h:170
LLVM_ABI LLVMContext & getContext() const
Get the context in which this basic block 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...
Definition BasicBlock.h:233
Represents analyses that only rely on functions' control flow.
Definition Analysis.h:73
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
This class is the base class for the comparison instructions.
Definition InstrTypes.h:664
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Definition InstrTypes.h:676
@ ICMP_SLT
signed less than
Definition InstrTypes.h:705
@ ICMP_SGT
signed greater than
Definition InstrTypes.h:703
@ ICMP_NE
not equal
Definition InstrTypes.h:698
Predicate getSwappedPredicate() const
For example, EQ->EQ, SLE->SGE, ULT->UGT, OEQ->OEQ, ULE->UGE, OLT->OGT, etc.
Definition InstrTypes.h:827
Predicate getInversePredicate() const
For example, EQ -> NE, UGT -> ULE, SLT -> SGE, OEQ -> UNE, UGT -> OLE, OLT -> UGE,...
Definition InstrTypes.h:789
Predicate getPredicate() const
Return the predicate for this instruction.
Definition InstrTypes.h:765
Predicate getFlippedStrictnessPredicate() const
For predicate of kind "is X or equal to 0" returns the predicate "is X".
Definition InstrTypes.h:893
Conditional Branch instruction.
Value * getCondition() const
BasicBlock * getSuccessor(unsigned i) const
This is the shared class of boolean and integer constants.
Definition Constants.h:87
bool isOne() const
This is just a convenience method to make client code smaller for a common case.
Definition Constants.h:225
int64_t getSExtValue() const
Return the constant as a 64-bit integer value after it has been sign extended as appropriate for the ...
Definition Constants.h:174
A debug info location.
Definition DebugLoc.h:123
Analysis pass which computes a DominatorTree.
Definition Dominators.h:278
Legacy analysis pass which computes a DominatorTree.
Definition Dominators.h:316
void print(raw_ostream &OS, const Module *M=nullptr) const override
print - Print out the internal state of the pass.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Definition Dominators.h:159
LLVM_ABI bool isReachableFromEntry(const Use &U) const
Provide an overload for a Use.
FunctionPass(char &pid)
Definition Pass.h:316
Module * getParent()
Get the module that this global value is contained inside of...
This instruction compares its operands according to the predicate given to the constructor.
A struct for saving information about induction variables.
BinaryOperator * getInductionBinOp() const
const SCEV * getStep() const
static LLVM_ABI bool isInductionPHI(PHINode *Phi, const Loop *L, ScalarEvolution *SE, InductionDescriptor &D, const SCEV *Expr=nullptr, SmallVectorImpl< Instruction * > *CastsToIgnore=nullptr)
Returns true if Phi is an induction in the loop L.
Instruction::BinaryOps getInductionOpcode() const
Returns binary opcode of the induction operator.
Value * getStartValue() const
LLVM_ABI ConstantInt * getConstIntStepValue() const
MDNode * getMetadata(unsigned KindID) const
Get the metadata of given kind attached to this Instruction.
This is an important class for using LLVM in a threaded context.
Definition LLVMContext.h:68
Analysis pass that exposes the LoopInfo for a function.
Definition LoopInfo.h:569
LLVM_ABI LoopInfo run(Function &F, FunctionAnalysisManager &AM)
Definition LoopInfo.cpp:990
Instances of this class are used to represent loops that are detected in the flow graph.
bool contains(const Loop *L) const
typename std::vector< Loop * >::const_iterator iterator
bool isOutermost() const
Return true if the loop does not have a parent (natural) loop.
bool isInnermost() const
Return true if the loop does not contain any (natural) loops.
void getLoopLatches(SmallVectorImpl< BasicBlock * > &LoopLatches) const
void print(raw_ostream &OS, bool Verbose=false, bool PrintNested=true, unsigned Depth=0) const
iterator_range< block_iterator > blocks() const
bool isInvalid() const
Return true if this loop is no longer valid.
LoopT * getParentLoop() const
Return the parent loop if it exists or nullptr for top level loops.
LoopT * removeChildLoop(iterator I)
This removes the specified child from being a subloop of this loop.
Store the result of a depth first search within basic blocks contained by a single loop.
friend class LoopBlocksTraversal
std::vector< BasicBlock * >::const_iterator POIterator
Postorder list iterators.
void perform(const LoopInfo *LI)
Traverse the loop blocks and store the DFS result.
po_iterator< BasicBlock *, LoopBlocksTraversal, true > POTIterator
Graph traversal iterator.
POTIterator begin()
Postorder traversal over the graph.
This class builds and contains all of the top-level loop structures in the specified function.
void verify(const DominatorTreeBase< BlockT, false > &DomTree) const
void analyze(const DominatorTreeBase< BlockT, false > &DomTree)
Create the loop forest using a stable algorithm.
typename std::vector< Loop * >::const_iterator iterator
LoopT * getLoopFor(const BlockT *BB) const
Return the inner most loop that BB lives in.
void changeLoopFor(const BasicBlock *BB, Loop *L)
The legacy pass manager's analysis pass to compute loop information.
Definition LoopInfo.h:596
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
void releaseMemory() override
releaseMemory() - This member can be implemented by a pass if it wants to be able to release its memo...
Definition LoopInfo.h:612
bool runOnFunction(Function &F) override
Calculate the natural loop information for a given function.
void verifyAnalysis() const override
verifyAnalysis() - This member can be implemented by a analysis pass to check state of analysis infor...
void print(raw_ostream &O, const Module *M=nullptr) const override
print - Print out the internal state of the pass.
LoopInfo()=default
LLVM_ABI bool wouldBeOutOfLoopUseRequiringLCSSA(const Value *V, const BasicBlock *ExitBB) const
Definition LoopInfo.cpp:964
LLVM_ABI bool invalidate(Function &F, const PreservedAnalyses &PA, FunctionAnalysisManager::Invalidator &)
Handle invalidation explicitly.
Definition LoopInfo.cpp:899
LLVM_ABI void erase(Loop *L)
Update LoopInfo after removing the last backedge from a loop.
Definition LoopInfo.cpp:908
static const BasicBlock & skipEmptyBlockUntil(const BasicBlock *From, const BasicBlock *End, bool CheckUniquePred=false)
Recursivelly traverse all empty 'single successor' basic blocks of From (if there are any).
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
A range representing the start and end location of a loop.
Definition LoopInfo.h:43
const DebugLoc & getStart() const
Definition LoopInfo.h:53
Represents a single loop in the control flow graph.
Definition LoopInfo.h:40
bool isCanonical(ScalarEvolution &SE) const
Return true if the loop induction variable starts at zero and increments by one each time through the...
Definition LoopInfo.cpp:433
bool isLCSSAForm(const DominatorTree &DT, bool IgnoreTokens=true) const
Return true if the Loop is in LCSSA form.
Definition LoopInfo.cpp:484
std::optional< LoopBounds > getBounds(ScalarEvolution &SE) const
Return the struct LoopBounds collected if all struct members are found, else std::nullopt.
Definition LoopInfo.cpp:309
bool isSafeToClone() const
Return true if the loop body is safe to clone in practice.
Definition LoopInfo.cpp:508
std::string getLocStr() const
Return a string containing the debug location of the loop (file name + line number if present,...
Definition LoopInfo.cpp:688
void dumpVerbose() const
Definition LoopInfo.cpp:702
bool hasLoopInvariantOperands(const Instruction *I) const
Return true if all the operands of the specified instruction are loop invariant.
Definition LoopInfo.cpp:73
bool isAnnotatedParallel() const
Returns true if the loop is annotated parallel.
Definition LoopInfo.cpp:586
DebugLoc getStartLoc() const
Return the debug location of the start of this loop.
Definition LoopInfo.cpp:653
void dump() const
Definition LoopInfo.cpp:700
LocRange getLocRange() const
Return the source code span of the loop.
Definition LoopInfo.cpp:655
bool isLoopInvariant(const Value *V) const
Return true if the specified value is loop invariant.
Definition LoopInfo.cpp:67
ICmpInst * getLatchCmpInst() const
Get the latch condition instruction.
Definition LoopInfo.cpp:198
bool getInductionDescriptor(ScalarEvolution &SE, InductionDescriptor &IndDesc) const
Get the loop induction descriptor for the loop induction variable.
Definition LoopInfo.cpp:355
CondBrInst * getLoopGuardBranch() const
Return the loop guard branch, if it exists.
Definition LoopInfo.cpp:389
bool isRotatedForm() const
Return true if the loop is in rotated form.
Definition LoopInfo.h:303
void setLoopMustProgress()
Add llvm.loop.mustprogress to this loop's loop id metadata.
Definition LoopInfo.cpp:570
PHINode * getInductionVariable(ScalarEvolution &SE) const
Return the loop induction variable if found, else return nullptr.
Definition LoopInfo.cpp:316
bool isLoopSimplifyForm() const
Return true if the Loop is in the form that the LoopSimplify form transforms loops to,...
Definition LoopInfo.cpp:501
bool isRecursivelyLCSSAForm(const DominatorTree &DT, const LoopInfo &LI, bool IgnoreTokens=true) const
Return true if this Loop and all inner subloops are in LCSSA form.
Definition LoopInfo.cpp:491
void setLoopID(MDNode *LoopID) const
Set the llvm.loop loop id metadata for this loop.
Definition LoopInfo.cpp:547
void setLoopAlreadyUnrolled()
Add llvm.loop.unroll.disable to this loop's loop id metadata.
Definition LoopInfo.cpp:559
bool makeLoopInvariant(Value *V, bool &Changed, Instruction *InsertPt=nullptr, MemorySSAUpdater *MSSAU=nullptr, ScalarEvolution *SE=nullptr) const
If the given value is an instruction inside of the loop and it can be hoisted, do so to make it trivi...
Definition LoopInfo.cpp:77
PHINode * getCanonicalInductionVariable() const
Check to see if the loop has a canonical induction variable: an integer recurrence that starts at 0 a...
Definition LoopInfo.cpp:174
bool getIncomingAndBackEdge(BasicBlock *&Incoming, BasicBlock *&Backedge) const
Obtain the unique incoming and back edge.
Definition LoopInfo.cpp:148
MDNode * getLoopID() const
Return the llvm.loop loop id metadata node for this loop if it is present.
Definition LoopInfo.cpp:523
bool isAuxiliaryInductionVariable(PHINode &AuxIndVar, ScalarEvolution &SE) const
Return true if the given PHINode AuxIndVar is.
Definition LoopInfo.cpp:363
Metadata node.
Definition Metadata.h:1080
LLVM_ABI void replaceOperandWith(unsigned I, Metadata *New)
Replace a specific operand.
static MDTuple * getDistinct(LLVMContext &Context, ArrayRef< Metadata * > MDs)
Definition Metadata.h:1580
const MDOperand & getOperand(unsigned I) const
Definition Metadata.h:1444
ArrayRef< MDOperand > operands() const
Definition Metadata.h:1442
static MDTuple * get(LLVMContext &Context, ArrayRef< Metadata * > MDs)
Definition Metadata.h:1572
unsigned getNumOperands() const
Return number of MDNode operands.
Definition Metadata.h:1450
Tracking metadata reference owned by Metadata.
Definition Metadata.h:902
Metadata * get() const
Definition Metadata.h:931
A single uniqued string.
Definition Metadata.h:722
LLVM_ABI StringRef getString() const
Definition Metadata.cpp:632
static LLVM_ABI MDString * get(LLVMContext &Context, StringRef Str)
Definition Metadata.cpp:614
MemorySSA * getMemorySSA() const
Get handle on MemorySSA.
LLVM_ABI void moveToPlace(MemoryUseOrDef *What, BasicBlock *BB, MemorySSA::InsertionPlace Where)
MemoryUseOrDef * getMemoryAccess(const Instruction *I) const
Given a memory Mod/Ref'ing instruction, get the MemorySSA access associated with it.
Definition MemorySSA.h:720
Root of the metadata hierarchy.
Definition Metadata.h:64
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
const std::string & getModuleIdentifier() const
Get the module identifier which is, essentially, the name of the module.
Definition Module.h:252
Value * getIncomingValueForBlock(const BasicBlock *BB) const
AnalysisType & getAnalysis() const
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information ...
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
Definition Analysis.h:118
PreservedAnalysisChecker getChecker() const
Build a checker for this PreservedAnalyses and the specified analysis type.
Definition Analysis.h:275
This node represents a polynomial recurrence on the trip count of the specified loop.
This class represents an analyzed expression in the program.
The main scalar evolution driver.
LLVM_ABI bool isLoopInvariant(const SCEV *S, const Loop *L)
Return true if the value of the given SCEV is unchanging in the specified loop.
LLVM_ABI void forgetBlockAndLoopDispositions(Value *V=nullptr)
Called when the client has changed the disposition of values in a loop or block.
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.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
void append(ItTy in_start, ItTy in_end)
Add the specified range to the end of the SmallVector.
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
bool starts_with(StringRef Prefix) const
Check if this string starts with the given Prefix.
Definition StringRef.h:258
A Use represents the edge between a Value definition and its users.
Definition Use.h:35
Value * getOperand(unsigned i) const
Definition User.h:207
LLVM Value Representation.
Definition Value.h:75
iterator_range< user_iterator > users()
Definition Value.h:427
const ParentTy * getParent() const
Definition ilist_node.h:34
self_iterator getIterator()
Definition ilist_node.h:123
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
A raw_ostream that writes to an std::string.
Changed
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
LocationClass< Ty > location(Ty &L)
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > extract_or_null(Y &&MD)
Extract a Value from Metadata, allowing null.
Definition Metadata.h:683
This is an optimization pass for GlobalISel generic memory operations.
Definition Types.h:26
auto drop_begin(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the first N elements excluded.
Definition STLExtras.h:316
cl::opt< bool > ProfcheckDisableMetadataFixes
Definition Metadata.cpp:64
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1739
LLVM_ABI bool getBooleanLoopAttribute(const Loop *TheLoop, StringRef Name)
Returns true if Name is applied to TheLoop and enabled.
bool succ_empty(const Instruction *I)
Definition CFG.h:153
bool forcePrintModuleIR()
LLVM_ABI std::optional< bool > getOptionalBoolLoopAttribute(const Loop *TheLoop, StringRef Name)
LLVM_ABI int getIntLoopAttribute(const Loop *TheLoop, StringRef Name, int Default=0)
Find named metadata for a loop with an integer value.
auto pred_end(const MachineBasicBlock *BB)
LLVM_ABI void setExplicitlyUnknownBranchWeightsIfProfiled(Instruction &I, StringRef PassName, const Function *F=nullptr)
Like setExplicitlyUnknownBranchWeights(...), but only sets unknown branch weights in the new instruct...
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
LLVM_ABI std::optional< const MDOperand * > findStringMetadataForLoop(const Loop *TheLoop, StringRef Name)
Find string metadata for loop.
auto successors(const MachineBasicBlock *BB)
LLVM_ABI MDNode * findOptionMDForLoop(const Loop *TheLoop, StringRef Name)
Find string metadata for a loop.
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 hasMustProgress(const Loop *L)
Look for the loop attribute that requires progress within the loop.
auto dyn_cast_or_null(const Y &Val)
Definition Casting.h:753
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1746
LLVM_ABI bool isMustProgress(const Loop *L)
Return true if this loop can be assumed to make progress.
LLVM_ABI CallBase * getLoopConvergenceHeart(const Loop *TheLoop)
Find the convergence heart of the loop.
LLVM_ABI bool isFinite(const Loop *L)
Return true if this loop can be assumed to run for a finite number of iterations.
DominatorTreeBase< T, false > DomTreeBase
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:207
LLVM_ABI bool VerifyLoopInfo
Enable verification of loop info.
Definition LoopInfo.cpp:53
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
Definition Casting.h:547
LLVM_ABI std::optional< int > getOptionalIntLoopAttribute(const Loop *TheLoop, StringRef Name)
Find named metadata for a loop with an integer value.
LLVM_ABI bool isValidAsAccessGroup(MDNode *AccGroup)
Return whether an MDNode might represent an access group.
LLVM_ABI void printLoop(const Loop &L, raw_ostream &OS, const std::string &Banner="")
Function to print a loop's contents as LLVM's text IR assembly.
DWARFExpression::Operation Op
PredIterator< BasicBlock, Value::user_iterator > pred_iterator
Definition CFG.h:105
auto pred_begin(const MachineBasicBlock *BB)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
LLVM_ABI llvm::MDNode * makePostTransformationMetadata(llvm::LLVMContext &Context, MDNode *OrigLoopID, llvm::ArrayRef< llvm::StringRef > RemovePrefixes, llvm::ArrayRef< llvm::MDNode * > AddAttrs)
Create a new LoopID after the loop has been transformed.
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
Definition STLExtras.h:1947
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
@ Default
The result values are uniform if and only if all operands are uniform.
Definition Uniformity.h:20
LLVM_ABI MDNode * findOptionMDForLoopID(MDNode *LoopID, StringRef Name)
Find and return the loop attribute node for the attribute Name in LoopID.
bool forcePrintFuncIR()
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
Definition BitVector.h:872
A special type used by analysis passes to provide an address that identifies that particular analysis...
Definition Analysis.h:29
Incoming for lane mask phi as machine instruction, incoming register Reg and incoming block Block are...
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
static LLVM_ABI std::optional< Loop::LoopBounds > getBounds(const Loop &L, PHINode &IndVar, ScalarEvolution &SE)
Return the LoopBounds object if.
Definition LoopInfo.cpp:225
Direction
An enum for the direction of the loop.
Definition LoopInfo.h:216
Value & getFinalIVValue() const
Get the final value of the loop induction variable.
Definition LoopInfo.h:175
Instruction & getStepInst() const
Get the instruction that updates the loop induction variable.
Definition LoopInfo.h:168
LLVM_ABI ICmpInst::Predicate getCanonicalPredicate() const
Return the canonical predicate for the latch compare instruction, if able to be calcuated.
Definition LoopInfo.cpp:255
LLVM_ABI Direction getDirection() const
Get the direction of the loop.
Definition LoopInfo.cpp:296