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 addStringLoopAttribute("llvm.loop.unroll.disable", {"llvm.loop.unroll."});
561}
562
564 if (findOptionMDForLoop(this, "llvm.loop.mustprogress"))
565 return;
566 addStringLoopAttribute("llvm.loop.mustprogress");
567}
568
570 ArrayRef<StringRef> RemovePrefixes) const {
571 LLVMContext &Context = getHeader()->getContext();
572 MDNode *AttrMD = MDNode::get(Context, MDString::get(Context, Name));
573 MDNode *LoopID = getLoopID();
574 MDNode *NewLoopID =
575 makePostTransformationMetadata(Context, LoopID, RemovePrefixes, {AttrMD});
576 setLoopID(NewLoopID);
577}
578
580 ArrayRef<StringRef> RemovePrefixes) const {
581 LLVMContext &Context = getHeader()->getContext();
582 MDNode *AttrMD = MDNode::get(
583 Context,
584 {MDString::get(Context, Name),
585 ConstantAsMetadata::get(ConstantInt::get(Context, APInt(32, Value)))});
586 MDNode *LoopID = getLoopID();
587 MDNode *NewLoopID =
588 makePostTransformationMetadata(Context, LoopID, RemovePrefixes, {AttrMD});
589 setLoopID(NewLoopID);
590}
591
593 MDNode *DesiredLoopIdMetadata = getLoopID();
594
595 if (!DesiredLoopIdMetadata)
596 return false;
597
598 MDNode *ParallelAccesses =
599 findOptionMDForLoop(this, "llvm.loop.parallel_accesses");
601 ParallelAccessGroups; // For scalable 'contains' check.
602 if (ParallelAccesses) {
603 for (const MDOperand &MD : drop_begin(ParallelAccesses->operands())) {
604 MDNode *AccGroup = cast<MDNode>(MD.get());
605 assert(isValidAsAccessGroup(AccGroup) &&
606 "List item must be an access group");
607 ParallelAccessGroups.insert(AccGroup);
608 }
609 }
610
611 // The loop branch contains the parallel loop metadata. In order to ensure
612 // that any parallel-loop-unaware optimization pass hasn't added loop-carried
613 // dependencies (thus converted the loop back to a sequential loop), check
614 // that all the memory instructions in the loop belong to an access group that
615 // is parallel to this loop.
616 for (BasicBlock *BB : this->blocks()) {
617 for (Instruction &I : *BB) {
618 if (!I.mayReadOrWriteMemory())
619 continue;
620
621 if (MDNode *AccessGroup = I.getMetadata(LLVMContext::MD_access_group)) {
622 auto ContainsAccessGroup = [&ParallelAccessGroups](MDNode *AG) -> bool {
623 if (AG->getNumOperands() == 0) {
624 assert(isValidAsAccessGroup(AG) && "Item must be an access group");
625 return ParallelAccessGroups.count(AG);
626 }
627
628 for (const MDOperand &AccessListItem : AG->operands()) {
629 MDNode *AccGroup = cast<MDNode>(AccessListItem.get());
630 assert(isValidAsAccessGroup(AccGroup) &&
631 "List item must be an access group");
632 if (ParallelAccessGroups.count(AccGroup))
633 return true;
634 }
635 return false;
636 };
637
638 if (ContainsAccessGroup(AccessGroup))
639 continue;
640 }
641
642 // The memory instruction can refer to the loop identifier metadata
643 // directly or indirectly through another list metadata (in case of
644 // nested parallel loops). The loop identifier metadata refers to
645 // itself so we can check both cases with the same routine.
646 MDNode *LoopIdMD =
647 I.getMetadata(LLVMContext::MD_mem_parallel_loop_access);
648
649 if (!LoopIdMD)
650 return false;
651
652 if (!llvm::is_contained(LoopIdMD->operands(), DesiredLoopIdMetadata))
653 return false;
654 }
655 }
656 return true;
657}
658
660
662 // If we have a debug location in the loop ID, then use it.
663 if (MDNode *LoopID = getLoopID()) {
664 DebugLoc Start;
665 // We use the first DebugLoc in the header as the start location of the loop
666 // and if there is a second DebugLoc in the header we use it as end location
667 // of the loop.
668 for (const MDOperand &MDO : llvm::drop_begin(LoopID->operands())) {
669 if (DILocation *L = dyn_cast<DILocation>(MDO)) {
670 if (!Start)
671 Start = DebugLoc(L);
672 else
673 return LocRange(Start, DebugLoc(L));
674 }
675 }
676
677 if (Start)
678 return LocRange(Start);
679 }
680
681 // Try the pre-header first.
682 if (BasicBlock *PHeadBB = getLoopPreheader())
683 if (DebugLoc DL = PHeadBB->getTerminator()->getDebugLoc())
684 return LocRange(DL);
685
686 // If we have no pre-header or there are no instructions with debug
687 // info in it, try the header.
688 if (BasicBlock *HeadBB = getHeader())
689 return LocRange(HeadBB->getTerminator()->getDebugLoc());
690
691 return LocRange();
692}
693
694std::string Loop::getLocStr() const {
695 std::string Result;
696 raw_string_ostream OS(Result);
697 if (const DebugLoc LoopDbgLoc = getStartLoc())
698 LoopDbgLoc.print(OS);
699 else
700 // Just print the module name.
702 return Result;
703}
704
705#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
707
709 print(dbgs(), /*Verbose=*/true);
710}
711#endif
712
713//===----------------------------------------------------------------------===//
714// UnloopUpdater implementation
715//
716
717namespace {
718/// Find the new parent loop for all blocks within the "unloop" whose last
719/// backedges has just been removed.
720class UnloopUpdater {
721 Loop &Unloop;
722 LoopInfo *LI;
723
724 LoopBlocksDFS DFS;
725
726 // Map unloop's immediate subloops to their nearest reachable parents. Nested
727 // loops within these subloops will not change parents. However, an immediate
728 // subloop's new parent will be the nearest loop reachable from either its own
729 // exits *or* any of its nested loop's exits.
730 DenseMap<Loop *, Loop *> SubloopParents;
731
732 // Flag the presence of an irreducible backedge whose destination is a block
733 // directly contained by the original unloop.
734 bool FoundIB = false;
735
736public:
737 UnloopUpdater(Loop *UL, LoopInfo *LInfo) : Unloop(*UL), LI(LInfo), DFS(UL) {}
738
739 void updateBlockParents();
740
741 void removeBlocksFromAncestors();
742
743 void updateSubloopParents();
744
745protected:
746 Loop *getNearestLoop(BasicBlock *BB, Loop *BBLoop);
747};
748} // end anonymous namespace
749
750/// Update the parent loop for all blocks that are directly contained within the
751/// original "unloop".
752void UnloopUpdater::updateBlockParents() {
753 if (Unloop.getNumBlocks()) {
754 // Perform a post order CFG traversal of all blocks within this loop,
755 // propagating the nearest loop from successors to predecessors.
756 LoopBlocksTraversal Traversal(DFS, LI);
757 for (BasicBlock *POI : Traversal) {
758
759 Loop *L = LI->getLoopFor(POI);
760 Loop *NL = getNearestLoop(POI, L);
761
762 if (NL != L) {
763 // For reducible loops, NL is now an ancestor of Unloop.
764 assert((NL != &Unloop && (!NL || NL->contains(&Unloop))) &&
765 "uninitialized successor");
766 LI->changeLoopFor(POI, NL);
767 } else {
768 // Or the current block is part of a subloop, in which case its parent
769 // is unchanged.
770 assert((FoundIB || Unloop.contains(L)) && "uninitialized successor");
771 }
772 }
773 }
774 // Each irreducible loop within the unloop induces a round of iteration using
775 // the DFS result cached by Traversal.
776 bool Changed = FoundIB;
777 for (unsigned NIters = 0; Changed; ++NIters) {
778 assert(NIters < Unloop.getNumBlocks() && "runaway iterative algorithm");
779 (void)NIters;
780
781 // Iterate over the postorder list of blocks, propagating the nearest loop
782 // from successors to predecessors as before.
783 Changed = false;
784 for (LoopBlocksDFS::POIterator POI = DFS.beginPostorder(),
785 POE = DFS.endPostorder();
786 POI != POE; ++POI) {
787
788 Loop *L = LI->getLoopFor(*POI);
789 Loop *NL = getNearestLoop(*POI, L);
790 if (NL != L) {
791 assert(NL != &Unloop && (!NL || NL->contains(&Unloop)) &&
792 "uninitialized successor");
793 LI->changeLoopFor(*POI, NL);
794 Changed = true;
795 }
796 }
797 }
798}
799
800/// Remove unloop's blocks from all ancestors below their new parents.
801void UnloopUpdater::removeBlocksFromAncestors() {
802 // Remove all unloop's blocks (including those in nested subloops) from
803 // ancestors below the new parent loop.
804 for (BasicBlock *BB : Unloop.blocks()) {
805 Loop *OuterParent = LI->getLoopFor(BB);
806 if (Unloop.contains(OuterParent)) {
807 while (OuterParent->getParentLoop() != &Unloop)
808 OuterParent = OuterParent->getParentLoop();
809 OuterParent = SubloopParents[OuterParent];
810 }
811 // Remove blocks from former Ancestors except Unloop itself which will be
812 // deleted.
813 for (Loop *OldParent = Unloop.getParentLoop(); OldParent != OuterParent;
814 OldParent = OldParent->getParentLoop()) {
815 assert(OldParent && "new loop is not an ancestor of the original");
816 OldParent->removeBlockFromLoop(BB);
817 }
818 }
819}
820
821/// Update the parent loop for all subloops directly nested within unloop.
822void UnloopUpdater::updateSubloopParents() {
823 while (!Unloop.isInnermost()) {
824 Loop *Subloop = *std::prev(Unloop.end());
825 Unloop.removeChildLoop(std::prev(Unloop.end()));
826
827 assert(SubloopParents.count(Subloop) && "DFS failed to visit subloop");
828 if (Loop *Parent = SubloopParents[Subloop])
829 Parent->addChildLoop(Subloop);
830 else
831 LI->addTopLevelLoop(Subloop);
832 }
833}
834
835/// Return the nearest parent loop among this block's successors. If a successor
836/// is a subloop header, consider its parent to be the nearest parent of the
837/// subloop's exits.
838///
839/// For subloop blocks, simply update SubloopParents and return NULL.
840Loop *UnloopUpdater::getNearestLoop(BasicBlock *BB, Loop *BBLoop) {
841
842 // Initially for blocks directly contained by Unloop, NearLoop == Unloop and
843 // is considered uninitialized.
844 Loop *NearLoop = BBLoop;
845
846 Loop *Subloop = nullptr;
847 if (NearLoop != &Unloop && Unloop.contains(NearLoop)) {
848 Subloop = NearLoop;
849 // Find the subloop ancestor that is directly contained within Unloop.
850 while (Subloop->getParentLoop() != &Unloop) {
851 Subloop = Subloop->getParentLoop();
852 assert(Subloop && "subloop is not an ancestor of the original loop");
853 }
854 // Get the current nearest parent of the Subloop exits, initially Unloop.
855 NearLoop = SubloopParents.insert({Subloop, &Unloop}).first->second;
856 }
857
858 if (succ_empty(BB)) {
859 assert(!Subloop && "subloop blocks must have a successor");
860 NearLoop = nullptr; // unloop blocks may now exit the function.
861 }
862 for (BasicBlock *Succ : successors(BB)) {
863 if (Succ == BB)
864 continue; // self loops are uninteresting
865
866 Loop *L = LI->getLoopFor(Succ);
867 if (L == &Unloop) {
868 // This successor has not been processed. This path must lead to an
869 // irreducible backedge.
870 assert((FoundIB || !DFS.hasPostorder(Succ)) && "should have seen IB");
871 FoundIB = true;
872 }
873 if (L != &Unloop && Unloop.contains(L)) {
874 // Successor is in a subloop.
875 if (Subloop)
876 continue; // Branching within subloops. Ignore it.
877
878 // BB branches from the original into a subloop header.
879 assert(L->getParentLoop() == &Unloop && "cannot skip into nested loops");
880
881 // Get the current nearest parent of the Subloop's exits.
882 L = SubloopParents[L];
883 // L could be Unloop if the only exit was an irreducible backedge.
884 }
885 if (L == &Unloop) {
886 continue;
887 }
888 // Handle critical edges from Unloop into a sibling loop.
889 if (L && !L->contains(&Unloop)) {
890 L = L->getParentLoop();
891 }
892 // Remember the nearest parent loop among successors or subloop exits.
893 if (NearLoop == &Unloop || !NearLoop || NearLoop->contains(L))
894 NearLoop = L;
895 }
896 if (Subloop) {
897 SubloopParents[Subloop] = NearLoop;
898 return BBLoop;
899 }
900 return NearLoop;
901}
902
903LoopInfo::LoopInfo(const DomTreeBase<BasicBlock> &DomTree) { analyze(DomTree); }
904
906 FunctionAnalysisManager::Invalidator &) {
907 // Check whether the analysis, all analyses on functions, or the function's
908 // CFG have been preserved.
909 auto PAC = PA.getChecker<LoopAnalysis>();
910 return !(PAC.preserved() || PAC.preservedSet<AllAnalysesOn<Function>>() ||
911 PAC.preservedSet<CFGAnalyses>());
912}
913
914void LoopInfo::erase(Loop *Unloop) {
915 assert(!Unloop->isInvalid() && "Loop has already been erased!");
916
917 llvm::scope_exit InvalidateOnExit([&]() { destroy(Unloop); });
918
919 // First handle the special case of no parent loop to simplify the algorithm.
920 if (Unloop->isOutermost()) {
921 // Since BBLoop had no parent, Unloop blocks are no longer in a loop.
922 for (BasicBlock *BB : Unloop->blocks()) {
923 // Don't reparent blocks in subloops.
924 if (getLoopFor(BB) != Unloop)
925 continue;
926
927 // Blocks no longer have a parent but are still referenced by Unloop until
928 // the Unloop object is deleted.
929 changeLoopFor(BB, nullptr);
930 }
931
932 // Remove the loop from the top-level LoopInfo object.
933 for (iterator I = begin();; ++I) {
934 assert(I != end() && "Couldn't find loop");
935 if (*I == Unloop) {
936 removeLoop(I);
937 break;
938 }
939 }
940
941 // Move all of the subloops to the top-level.
942 while (!Unloop->isInnermost())
943 addTopLevelLoop(Unloop->removeChildLoop(std::prev(Unloop->end())));
944
945 return;
946 }
947
948 // Update the parent loop for all blocks within the loop. Blocks within
949 // subloops will not change parents.
950 UnloopUpdater Updater(Unloop, this);
951 Updater.updateBlockParents();
952
953 // Remove blocks from former ancestor loops.
954 Updater.removeBlocksFromAncestors();
955
956 // Add direct subloops as children in their new parent loop.
957 Updater.updateSubloopParents();
958
959 // Remove unloop from its parent loop.
960 Loop *ParentLoop = Unloop->getParentLoop();
961 for (Loop::iterator I = ParentLoop->begin();; ++I) {
962 assert(I != ParentLoop->end() && "Couldn't find loop");
963 if (*I == Unloop) {
964 ParentLoop->removeChildLoop(I);
965 break;
966 }
967 }
968}
969
971 const Value *V, const BasicBlock *ExitBB) const {
972 if (V->getType()->isTokenTy())
973 // We can't form PHIs of token type, so the definition of LCSSA excludes
974 // values of that type.
975 return false;
976
978 if (!I)
979 return false;
980 const Loop *L = getLoopFor(I->getParent());
981 if (!L)
982 return false;
983 if (L->contains(ExitBB))
984 // Could be an exit bb of a subloop and contained in defining loop
985 return false;
986
987 // We found a (new) out-of-loop use location, for a value defined in-loop.
988 // (Note that because of LCSSA, we don't have to account for values defined
989 // in sibling loops. Such values will have LCSSA phis of their own in the
990 // common parent loop.)
991 return true;
992}
993
994AnalysisKey LoopAnalysis::Key;
995
997 // FIXME: Currently we create a LoopInfo from scratch for every function.
998 // This may prove to be too wasteful due to deallocating and re-allocating
999 // memory each time for the underlying map and vector datastructures. At some
1000 // point it may prove worthwhile to use a freelist and recycle LoopInfo
1001 // objects. I don't want to add that kind of complexity until the scope of
1002 // the problem is better understood.
1003 LoopInfo LI;
1005 return LI;
1006}
1007
1010 auto &LI = AM.getResult<LoopAnalysis>(F);
1011 OS << "Loop info for function '" << F.getName() << "':\n";
1012 LI.print(OS);
1013 return PreservedAnalyses::all();
1014}
1015
1017 const std::string &Banner) {
1018 if (forcePrintModuleIR()) {
1019 // handling -print-module-scope
1020 OS << Banner << " (loop: ";
1021 L.getHeader()->printAsOperand(OS, false);
1022 OS << ")\n";
1023
1024 // printing whole module
1025 OS << *L.getHeader()->getModule();
1026 return;
1027 }
1028
1029 if (forcePrintFuncIR()) {
1030 // handling -print-loop-func-scope.
1031 // -print-module-scope overrides this.
1032 OS << Banner << " (loop: ";
1033 L.getHeader()->printAsOperand(OS, false);
1034 OS << ")\n";
1035
1036 // printing whole function.
1037 OS << *L.getHeader()->getParent();
1038 return;
1039 }
1040
1041 OS << Banner;
1042
1043 auto *PreHeader = L.getLoopPreheader();
1044 if (PreHeader) {
1045 OS << "\n; Preheader:";
1046 PreHeader->print(OS);
1047 OS << "\n; Loop:";
1048 }
1049
1050 for (auto *Block : L.blocks())
1051 if (Block)
1052 Block->print(OS);
1053 else
1054 OS << "Printing <null> block";
1055
1057 L.getExitBlocks(ExitBlocks);
1058 if (!ExitBlocks.empty()) {
1059 OS << "\n; Exit blocks";
1060 for (auto *Block : ExitBlocks)
1061 if (Block)
1062 Block->print(OS);
1063 else
1064 OS << "Printing <null> block";
1065 }
1066}
1067
1069 // No loop metadata node, no loop properties.
1070 if (!LoopID)
1071 return nullptr;
1072
1073 // First operand should refer to the metadata node itself, for legacy reasons.
1074 assert(LoopID->getNumOperands() > 0 && "requires at least one operand");
1075 assert(LoopID->getOperand(0) == LoopID && "invalid loop id");
1076
1077 // Iterate over the metdata node operands and look for MDString metadata.
1078 for (const MDOperand &MDO : llvm::drop_begin(LoopID->operands())) {
1079 MDNode *MD = dyn_cast<MDNode>(MDO);
1080 if (!MD || MD->getNumOperands() < 1)
1081 continue;
1083 if (!S)
1084 continue;
1085 // Return the operand node if MDString holds expected metadata.
1086 if (Name == S->getString())
1087 return MD;
1088 }
1089
1090 // Loop property not found.
1091 return nullptr;
1092}
1093
1095 return findOptionMDForLoopID(TheLoop->getLoopID(), Name);
1096}
1097
1098/// Find string metadata for loop
1099///
1100/// If it has a value (e.g. {"llvm.distribute", 1} return the value as an
1101/// operand or null otherwise. If the string metadata is not found return
1102/// Optional's not-a-value.
1103std::optional<const MDOperand *>
1105 MDNode *MD = findOptionMDForLoop(TheLoop, Name);
1106 if (!MD)
1107 return std::nullopt;
1108 switch (MD->getNumOperands()) {
1109 case 1:
1110 return nullptr;
1111 case 2:
1112 return &MD->getOperand(1);
1113 default:
1114 llvm_unreachable("loop metadata has 0 or 1 operand");
1115 }
1116}
1117
1118std::optional<bool> llvm::getOptionalBoolLoopAttribute(const Loop *TheLoop,
1119 StringRef Name) {
1120 MDNode *MD = findOptionMDForLoop(TheLoop, Name);
1121 if (!MD)
1122 return std::nullopt;
1123 switch (MD->getNumOperands()) {
1124 case 1:
1125 // When the value is absent it is interpreted as 'attribute set'.
1126 return true;
1127 case 2:
1128 if (ConstantInt *IntMD =
1130 return IntMD->getZExtValue();
1131 return true;
1132 }
1133 llvm_unreachable("unexpected number of options");
1134}
1135
1137 return getOptionalBoolLoopAttribute(TheLoop, Name).value_or(false);
1138}
1139
1140std::optional<int> llvm::getOptionalIntLoopAttribute(const Loop *TheLoop,
1141 StringRef Name) {
1142 const MDOperand *AttrMD =
1143 findStringMetadataForLoop(TheLoop, Name).value_or(nullptr);
1144 if (!AttrMD)
1145 return std::nullopt;
1146
1147 ConstantInt *IntMD = mdconst::extract_or_null<ConstantInt>(AttrMD->get());
1148 if (!IntMD)
1149 return std::nullopt;
1150
1151 return IntMD->getSExtValue();
1152}
1153
1155 int Default) {
1156 return getOptionalIntLoopAttribute(TheLoop, Name).value_or(Default);
1157}
1158
1160 BasicBlock *H = TheLoop->getHeader();
1161 for (Instruction &II : *H) {
1162 if (auto *CB = dyn_cast<CallBase>(&II)) {
1163 if (!CB->isConvergent())
1164 continue;
1165 // This is the heart if it uses a token defined outside the loop. The
1166 // verifier has already checked that only the loop intrinsic can use such
1167 // a token.
1168 if (auto *Token = CB->getConvergenceControlToken()) {
1169 auto *TokenDef = cast<Instruction>(Token);
1170 if (!TheLoop->contains(TokenDef->getParent()))
1171 return CB;
1172 }
1173 return nullptr;
1174 }
1175 }
1176 return nullptr;
1177}
1178
1179bool llvm::isFinite(const Loop *L) {
1180 return L->getHeader()->getParent()->willReturn();
1181}
1182
1183static const char *LLVMLoopMustProgress = "llvm.loop.mustprogress";
1184
1188
1190 return L->getHeader()->getParent()->mustProgress() || hasMustProgress(L);
1191}
1192
1194 return Node->getNumOperands() == 0 && Node->isDistinct();
1195}
1196
1198 MDNode *OrigLoopID,
1199 ArrayRef<StringRef> RemovePrefixes,
1200 ArrayRef<MDNode *> AddAttrs) {
1201 // First remove any existing loop metadata related to this transformation.
1203
1204 // Reserve first location for self reference to the LoopID metadata node.
1205 MDs.push_back(nullptr);
1206
1207 // Remove metadata for the transformation that has been applied or that became
1208 // outdated.
1209 if (OrigLoopID) {
1210 for (const MDOperand &MDO : llvm::drop_begin(OrigLoopID->operands())) {
1211 bool IsVectorMetadata = false;
1212 Metadata *Op = MDO;
1213 if (MDNode *MD = dyn_cast<MDNode>(Op)) {
1214 const MDString *S = dyn_cast<MDString>(MD->getOperand(0));
1215 if (S)
1216 IsVectorMetadata =
1217 llvm::any_of(RemovePrefixes, [S](StringRef Prefix) -> bool {
1218 return S->getString().starts_with(Prefix);
1219 });
1220 }
1221 if (!IsVectorMetadata)
1222 MDs.push_back(Op);
1223 }
1224 }
1225
1226 // Add metadata to avoid reapplying a transformation, such as
1227 // llvm.loop.unroll.disable and llvm.loop.isvectorized.
1228 MDs.append(AddAttrs.begin(), AddAttrs.end());
1229
1230 MDNode *NewLoopID = MDNode::getDistinct(Context, MDs);
1231 // Replace the temporary node with a self-reference.
1232 NewLoopID->replaceOperandWith(0, NewLoopID);
1233 return NewLoopID;
1234}
1235
1236//===----------------------------------------------------------------------===//
1237// LoopInfo implementation
1238//
1239
1241
1243INITIALIZE_PASS_BEGIN(LoopInfoWrapperPass, "loops", "Natural Loop Information",
1244 true, true)
1246INITIALIZE_PASS_END(LoopInfoWrapperPass, "loops", "Natural Loop Information",
1248
1250 releaseMemory();
1252 return false;
1253}
1254
1256 // LoopInfoWrapperPass is a FunctionPass, but verifying every loop in the
1257 // function each time verifyAnalysis is called is very expensive. The
1258 // -verify-loop-info option can enable this. In order to perform some
1259 // checking by default, LoopPass has been taught to call verifyLoop manually
1260 // during loop pass sequences.
1261 if (VerifyLoopInfo) {
1262 auto &DT = getAnalysis<DominatorTreeWrapperPass>().getDomTree();
1263 LI.verify(DT);
1264 }
1265}
1266
1271
1273 LI.print(OS);
1274}
1275
1283
1284//===----------------------------------------------------------------------===//
1285// LoopBlocksDFS implementation
1286//
1287
1288/// Traverse the loop blocks and store the DFS result.
1289/// Useful for clients that just want the final DFS result and don't need to
1290/// visit blocks during the initial traversal.
1292 LoopBlocksTraversal Traversal(*this, LI);
1293 for ([[maybe_unused]] BasicBlock *BB : Traversal)
1294 ;
1295}
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.
Class for arbitrary precision integers.
Definition APInt.h:78
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; assumes that the block is well-formed.
Definition BasicBlock.h:237
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
static ConstantAsMetadata * get(Constant *C)
Definition Metadata.h:537
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:589
LLVM_ABI LoopInfo run(Function &F, FunctionAnalysisManager &AM)
Definition LoopInfo.cpp:996
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.
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:616
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:632
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:970
LLVM_ABI bool invalidate(Function &F, const PreservedAnalyses &PA, FunctionAnalysisManager::Invalidator &)
Handle invalidation explicitly.
Definition LoopInfo.cpp:905
LLVM_ABI void erase(Loop *L)
Update LoopInfo after removing the last backedge from a loop.
Definition LoopInfo.cpp:914
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:694
void dumpVerbose() const
Definition LoopInfo.cpp:708
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:592
DebugLoc getStartLoc() const
Return the debug location of the start of this loop.
Definition LoopInfo.cpp:659
void dump() const
Definition LoopInfo.cpp:706
LocRange getLocRange() const
Return the source code span of the loop.
Definition LoopInfo.cpp:661
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
LLVM_ABI void addIntLoopAttribute(StringRef Name, unsigned Value, ArrayRef< StringRef > RemovePrefixes={}) const
Add an integer metadata attribute to this loop's loop-ID node.
Definition LoopInfo.cpp:579
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:563
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
LLVM_ABI void addStringLoopAttribute(StringRef Name, ArrayRef< StringRef > RemovePrefixes={}) const
Add a string-only metadata attribute to this loop's loop-ID node.
Definition LoopInfo.cpp:569
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:426
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.
auto drop_begin(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the first N elements excluded.
Definition STLExtras.h:315
cl::opt< bool > ProfcheckDisableMetadataFixes
Definition LoopInfo.cpp:60
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:1738
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:1745
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:1946
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
@ Default
The result value is 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
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