| /freebsd/contrib/llvm-project/llvm/lib/Transforms/Scalar/ |
| H A D | LoopInterchange.cpp | 654 BasicBlock *OuterLoopLatch = OuterLoop->getLoopLatch(); in tightlyNested() 735 BasicBlock *InnerLoopLatch = InnerLoop->getLoopLatch(); in isLoopStructureUnderstood() 895 if (!L->getLoopLatch() || !L->getLoopPredecessor()) in findInductionAndReductions() 915 Value *V = followLCSSA(PHI.getIncomingValueForBlock(L->getLoopLatch())); in findInductionAndReductions() 936 BasicBlock *InnerLoopLatch = InnerLoop->getLoopLatch(); in currentLimitations() 941 OuterLoop->getExitingBlock() != OuterLoop->getLoopLatch() || in currentLimitations() 943 !isa<BranchInst>(OuterLoop->getLoopLatch()->getTerminator())) { in currentLimitations() 1054 if (!IncomingI || IncomingI->getParent() != OuterLoop->getLoopLatch()) in areOuterLoopExitPHIsSupported() 1067 if (OuterLoop->getLoopLatch()->getUniquePredecessor() == nullptr) in areOuterLoopExitPHIsSupported() 1088 if (OuterLoop->getLoopLatch()->getUniquePredecessor() != nullptr) in areInnerLoopLatchPHIsSupported() [all …]
|
| H A D | LoopBoundSplit.cpp | 75 Cond.NonPHIAddRecValue = PN->getIncomingValueForBlock(L.getLoopLatch()); in analyzeICmp() 247 if (L.getLoopLatch() == BB) in findSplitCandidate() 362 (L.getExitingBlock() == L.getLoopLatch()) ? true : false; in splitLoopBound() 372 isExitingLatch ? PN.getIncomingValueForBlock(L.getLoopLatch()) : &PN, in splitLoopBound() 387 PN.getIncomingValueForBlock(L.getLoopLatch())) in splitLoopBound()
|
| H A D | IndVarSimplify.cpp | 455 if (!L->getLoopLatch() || in rewriteFirstIterationLoopExitValues() 456 !DT->dominates(IncomingBB, L->getLoopLatch())) in rewriteFirstIterationLoopExitValues() 711 assert(L->getLoopLatch() && "Must be in simplified form"); in needsLFTR() 748 int Idx = Phi->getBasicBlockIndex(L->getLoopLatch()); in needsLFTR() 805 assert(L->getLoopLatch()); in isLoopCounter() 814 int LatchIdx = Phi->getBasicBlockIndex(L->getLoopLatch()); in isLoopCounter() 837 BasicBlock *LatchBlock = L->getLoopLatch(); in FindLoopCounter() 945 assert(L->getLoopLatch() && "Loop no longer in simplified form?"); in linearFunctionTestReplace() 948 cast<Instruction>(IndVar->getIncomingValueForBlock(L->getLoopLatch())); in linearFunctionTestReplace() 957 if (ExitingBB == L->getLoopLatch()) { in linearFunctionTestReplace() [all …]
|
| H A D | LoopSimplifyCFG.cpp | 293 DeleteCurrentLoop = !IsEdgeLive(L.getLoopLatch(), L.getHeader()); in analyze() 302 BlocksInLoopAfterFolding.insert(L.getLoopLatch()); in analyze() 548 assert(L.getLoopLatch() && "Should be single latch!"); in run() 671 if (!L.getLoopLatch()) in constantFoldTerminators()
|
| H A D | LoopFlatten.cpp | 408 BasicBlock *Latch = L->getLoopLatch(); in findLoopComponents() 502 InnerPHI.getIncomingValueForBlock(FI.InnerLoop->getLoopLatch()); in checkPHIs() 518 OuterPHI->getIncomingValueForBlock(FI.OuterLoop->getLoopLatch())); in checkPHIs() 772 FI.InnerInductionPHI->removeIncomingValue(FI.InnerLoop->getLoopLatch()); in DoFlattenLoopPair() 777 PHI->removeIncomingValue(FI.InnerLoop->getLoopLatch()); in DoFlattenLoopPair()
|
| H A D | LoopTermFold.cpp | 69 BasicBlock *LoopLatch = L->getLoopLatch(); in canFoldTermCondOfLoop() 246 BasicBlock *LoopLatch = L->getLoopLatch(); in RunTermFold()
|
| H A D | LoopUnrollAndJamPass.cpp | 365 BasicBlock *Latch = L->getLoopLatch(); in tryToUnrollAndJamLoop() 366 BasicBlock *SubLoopLatch = SubLoop->getLoopLatch(); in tryToUnrollAndJamLoop()
|
| H A D | LoopPredication.cpp | 810 BasicBlock *LoopLatch = L->getLoopLatch(); in parseLoopLatchICmp() 890 auto *LatchBlock = L->getLoopLatch(); in isLoopProfitableToPredicate() 1014 assert(DT.dominates(ExitingBB, L->getLoopLatch()) && in getMinAnalyzeableBackedgeTakenCount() 1055 auto *Latch = L->getLoopLatch(); in predicateLoopExits()
|
| H A D | LoopDeletion.cpp | 223 BasicBlock *Latch = L->getLoopLatch(); in canProveExitOnFirstIteration() 404 if (!L->getLoopLatch()) in breakBackedgeIfNotTaken()
|
| H A D | LoopVersioningLICM.cpp | 197 if (CurLoop->getExitingBlock() != CurLoop->getLoopLatch()) { in legalLoopStructure()
|
| /freebsd/contrib/llvm-project/llvm/lib/Analysis/ |
| H A D | LoopNestAnalysis.cpp | 54 const BasicBlock *Latch = OuterLoop.getLoopLatch(); in getOuterLoopLatchCmp() 162 const BasicBlock *OuterLoopLatch = OuterLoop.getLoopLatch(); in analyzeLoopNestForPerfectNest() 226 const BasicBlock *OuterLoopLatch = OuterLoop.getLoopLatch(); in getInterveningInstructions() 327 const BasicBlock *OuterLoopLatch = OuterLoop.getLoopLatch(); in checkLoopsStructure() 329 const BasicBlock *InnerLoopLatch = InnerLoop.getLoopLatch(); in checkLoopsStructure()
|
| H A D | LoopInfo.cpp | 176 if (BasicBlock *Latch = getLoopLatch()) in getLatchCmpInst() 234 BasicBlock *Latch = L.getLoopLatch(); in getCanonicalPredicate() 313 BasicBlock *Latch = getLoopLatch(); in getInductionVariable() 373 assert(Preheader && getLoopLatch() && in getLoopGuardBranch() 483 return getLoopPreheader() && getLoopLatch() && hasDedicatedExits(); in isLoopSimplifyForm()
|
| H A D | IVUsers.cpp | 103 BasicBlock *LatchBlock = L->getLoopLatch(); in IVUseShouldUsePostIncValue()
|
| /freebsd/contrib/llvm-project/llvm/lib/Transforms/Utils/ |
| H A D | LoopRotationUtils.cpp | 239 BasicBlock *Latch = L->getLoopLatch(); in canRotateDeoptimizingLatchExit() 424 BasicBlock *OrigLatch = L->getLoopLatch(); in rotateLoop() 856 SplitLatchEdge |= L->getLoopLatch() == ExitPred; in rotateLoop() 882 assert(L->getLoopLatch() && "Invalid loop latch after loop rotation"); in rotateLoop() 992 BasicBlock *Latch = L->getLoopLatch(); in simplifyLoopLatch() 1043 assert((!MadeChange || L->isLoopExiting(L->getLoopLatch())) && in processLoop()
|
| H A D | LoopPeel.cpp | 229 Value *Input = Phi->getIncomingValueForBlock(L.getLoopLatch()); in calculate() 301 BasicBlock *Latch = L.getLoopLatch(); in peelToTurnInvariantLoadsDerefencebale() 342 BasicBlock *Latch = L.getLoopLatch(); in canPeelLastIteration() 569 if (L.getLoopLatch() == BB) in countToEliminateCompares() 583 BasicBlock *Latch = L->getLoopLatch(); in violatesLegacyMultiExitLoopCheck() 843 BasicBlock *Latch = L->getLoopLatch(); in cloneLoopBlocks() 1046 BasicBlock *Latch = L->getLoopLatch(); in peelLoop() 1227 cast<ICmpInst>(L->getLoopLatch()->getTerminator()->getOperand(0)); in peelLoop()
|
| H A D | LoopUnrollRuntime.cpp | 100 BasicBlock *Latch = L->getLoopLatch(); in ConnectProlog() 216 BasicBlock *Latch = L->getLoopLatch(); in ConnectEpilog() 347 BasicBlock *Latch = L->getLoopLatch(); in CloneLoopBlocks() 596 BasicBlock *Latch = L->getLoopLatch(); in UnrollRuntimeLoopRemainder() 976 BasicBlock *RemainderLatch = remainderLoop->getLoopLatch(); in UnrollRuntimeLoopRemainder()
|
| H A D | LoopUnrollAndJam.cpp | 73 BasicBlock *SubLoopLatch = SubLoop->getLoopLatch(); in partitionLoopBlocks() 294 BasicBlock *LatchBlock = L->getLoopLatch(); in UnrollAndJamLoop() 302 SubLoop->getLoopLatch()->getTerminator()->getSuccessor(0)); in UnrollAndJamLoop() 966 BasicBlock *Latch = L->getLoopLatch(); in isSafeToUnrollAndJam()
|
| H A D | LoopConstrainer.cpp | 118 SE.getExitCount(&L, L.getLoopLatch(), ScalarEvolution::SymbolicMaximum); in getNarrowestLatchMaxTakenCountEstimate() 133 BasicBlock *Latch = L.getLoopLatch(); in parseLoopStructure() 485 cast<BasicBlock>(GetClonedValue(OriginalLoop.getLoopLatch())); in cloneLoop()
|
| H A D | LoopSimplify.cpp | 556 BasicBlock *LoopLatch = L->getLoopLatch(); in simplifyOneLoop() 875 if (!L->getLoopPreheader() || !L->getLoopLatch()) {
|
| /freebsd/contrib/llvm-project/llvm/lib/CodeGen/ |
| H A D | MachineLoopInfo.cpp | 123 if (MachineBasicBlock *Latch = getLoopLatch()) { in findLoopControlBlock() 157 MachineBasicBlock *HB = L->getHeader(), *LB = L->getLoopLatch(); in findLoopPreheader()
|
| /freebsd/contrib/llvm-project/llvm/lib/Target/ARM/ |
| H A D | MVETPAndVPTOptimisationsPass.cpp | 114 MachineBasicBlock *Latch = ML->getLoopLatch(); in findLoopComponents() 397 if (LoopPhi->getOperand(2).getMBB() == ML->getLoopLatch()) { in MergeLoopEnd() 494 (Phi->getOperand(2).getMBB() != ML->getLoopLatch() && in ConvertTailPredLoop() 495 Phi->getOperand(4).getMBB() != ML->getLoopLatch())) { in ConvertTailPredLoop() 499 CountReg = Phi->getOperand(2).getMBB() == ML->getLoopLatch() in ConvertTailPredLoop()
|
| /freebsd/contrib/llvm-project/llvm/lib/Transforms/Vectorize/ |
| H A D | LoopVectorizationLegality.cpp | 340 assert(Lp->getLoopLatch() && "Expected loop with a single latch."); in isUniformLoop() 355 BasicBlock *Latch = Lp->getLoopLatch(); in isUniformLoop() 727 AllowedExit.insert(Phi->getIncomingValueForBlock(TheLoop->getLoopLatch())); in addInductionPhi() 1399 BasicBlock *Latch = TheLoop->getLoopLatch(); in blockNeedsPredication() 1647 BasicBlock *LatchBB = TheLoop->getLoopLatch(); in isVectorizableEarlyExitLoop() 1918 if (TheLoop->getExitingBlock() != TheLoop->getLoopLatch()) { in canFoldTailByMasking()
|
| H A D | EVLIndVarSimplify.cpp | 109 BasicBlock *LatchBlock = L.getLoopLatch(); in run()
|
| /freebsd/contrib/llvm-project/llvm/include/llvm/Support/ |
| H A D | GenericLoopInfoImpl.h | 151 const BlockT *Latch = getLoopLatch(); in getUniqueNonLatchExitBlocks() 164 BlockT *Latch = getLoopLatch(); in getUniqueLatchExitBlock() 256 BlockT *LoopBase<BlockT, LoopT>::getLoopLatch() const { in getLoopLatch() function
|
| /freebsd/contrib/llvm-project/llvm/lib/Target/Hexagon/ |
| H A D | HexagonHardwareLoops.cpp | 404 MachineBasicBlock *Latch = L->getLoopLatch(); in findInductionRegister() 602 MachineBasicBlock *Latch = L->getLoopLatch(); in getLoopTripCount() 1261 if (ExitingBlock != L->getLoopLatch()) { in convertToHardwareLoop() 1630 MachineBasicBlock *Latch = L->getLoopLatch(); in fixupInductionVariable() 1876 MachineBasicBlock *Latch = L->getLoopLatch(); in createPreheaderForLoop()
|