LLVM 23.0.0git
LICM.cpp
Go to the documentation of this file.
1//===-- LICM.cpp - Loop Invariant Code Motion Pass ------------------------===//
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 pass performs loop invariant code motion, attempting to remove as much
10// code from the body of a loop as possible. It does this by either hoisting
11// code into the preheader block, or by sinking code to the exit blocks if it is
12// safe. This pass also promotes must-aliased memory locations in the loop to
13// live in registers, thus hoisting and sinking "invariant" loads and stores.
14//
15// Hoisting operations out of loops is a canonicalization transform. It
16// enables and simplifies subsequent optimizations in the middle-end.
17// Rematerialization of hoisted instructions to reduce register pressure is the
18// responsibility of the back-end, which has more accurate information about
19// register pressure and also handles other optimizations than LICM that
20// increase live-ranges.
21//
22// This pass uses alias analysis for two purposes:
23//
24// 1. Moving loop invariant loads and calls out of loops. If we can determine
25// that a load or call inside of a loop never aliases anything stored to,
26// we can hoist it or sink it like any other instruction.
27// 2. Scalar Promotion of Memory - If there is a store instruction inside of
28// the loop, we try to move the store to happen AFTER the loop instead of
29// inside of the loop. This can only happen if a few conditions are true:
30// A. The pointer stored through is loop invariant
31// B. There are no stores or loads in the loop which _may_ alias the
32// pointer. There are no calls in the loop which mod/ref the pointer.
33// If these conditions are true, we can promote the loads and stores in the
34// loop of the pointer to use a temporary alloca'd variable. We then use
35// the SSAUpdater to construct the appropriate SSA form for the value.
36//
37//===----------------------------------------------------------------------===//
38
42#include "llvm/ADT/Statistic.h"
50#include "llvm/Analysis/Loads.h"
63#include "llvm/IR/CFG.h"
64#include "llvm/IR/Constants.h"
65#include "llvm/IR/DataLayout.h"
68#include "llvm/IR/Dominators.h"
69#include "llvm/IR/IRBuilder.h"
72#include "llvm/IR/LLVMContext.h"
73#include "llvm/IR/Metadata.h"
78#include "llvm/Support/Debug.h"
86#include <algorithm>
87#include <utility>
88using namespace llvm;
89
90namespace llvm {
91class LPMUpdater;
92} // namespace llvm
93
94#define DEBUG_TYPE "licm"
95
96STATISTIC(NumCreatedBlocks, "Number of blocks created");
97STATISTIC(NumClonedBranches, "Number of branches cloned");
98STATISTIC(NumSunk, "Number of instructions sunk out of loop");
99STATISTIC(NumHoisted, "Number of instructions hoisted out of loop");
100STATISTIC(NumMovedLoads, "Number of load insts hoisted or sunk");
101STATISTIC(NumMovedCalls, "Number of call insts hoisted or sunk");
102STATISTIC(NumPromotionCandidates, "Number of promotion candidates");
103STATISTIC(NumLoadPromoted, "Number of load-only promotions");
104STATISTIC(NumLoadStorePromoted, "Number of load and store promotions");
105STATISTIC(NumMinMaxHoisted,
106 "Number of min/max expressions hoisted out of the loop");
107STATISTIC(NumGEPsHoisted,
108 "Number of geps reassociated and hoisted out of the loop");
109STATISTIC(NumAddSubHoisted, "Number of add/subtract expressions reassociated "
110 "and hoisted out of the loop");
111STATISTIC(NumFPAssociationsHoisted, "Number of invariant FP expressions "
112 "reassociated and hoisted out of the loop");
113STATISTIC(NumIntAssociationsHoisted,
114 "Number of invariant int expressions "
115 "reassociated and hoisted out of the loop");
116STATISTIC(NumBOAssociationsHoisted, "Number of invariant BinaryOp expressions "
117 "reassociated and hoisted out of the loop");
118
119/// Memory promotion is enabled by default.
120static cl::opt<bool>
121 DisablePromotion("disable-licm-promotion", cl::Hidden, cl::init(false),
122 cl::desc("Disable memory promotion in LICM pass"));
123
125 "licm-control-flow-hoisting", cl::Hidden, cl::init(false),
126 cl::desc("Enable control flow (and PHI) hoisting in LICM"));
127
128static cl::opt<bool>
129 SingleThread("licm-force-thread-model-single", cl::Hidden, cl::init(false),
130 cl::desc("Force thread model single in LICM pass"));
131
133 "licm-max-num-uses-traversed", cl::Hidden, cl::init(8),
134 cl::desc("Max num uses visited for identifying load "
135 "invariance in loop using invariant start (default = 8)"));
136
138 "licm-max-num-fp-reassociations", cl::init(5U), cl::Hidden,
139 cl::desc(
140 "Set upper limit for the number of transformations performed "
141 "during a single round of hoisting the reassociated expressions."));
142
144 "licm-max-num-int-reassociations", cl::init(5U), cl::Hidden,
145 cl::desc(
146 "Set upper limit for the number of transformations performed "
147 "during a single round of hoisting the reassociated expressions."));
148
149// Experimental option to allow imprecision in LICM in pathological cases, in
150// exchange for faster compile. This is to be removed if MemorySSA starts to
151// address the same issue. LICM calls MemorySSAWalker's
152// getClobberingMemoryAccess, up to the value of the Cap, getting perfect
153// accuracy. Afterwards, LICM will call into MemorySSA's getDefiningAccess,
154// which may not be precise, since optimizeUses is capped. The result is
155// correct, but we may not get as "far up" as possible to get which access is
156// clobbering the one queried.
158 "licm-mssa-optimization-cap", cl::init(100), cl::Hidden,
159 cl::desc("Enable imprecision in LICM in pathological cases, in exchange "
160 "for faster compile. Caps the MemorySSA clobbering calls."));
161
162// Experimentally, memory promotion carries less importance than sinking and
163// hoisting. Limit when we do promotion when using MemorySSA, in order to save
164// compile time.
166 "licm-mssa-max-acc-promotion", cl::init(250), cl::Hidden,
167 cl::desc("[LICM & MemorySSA] When MSSA in LICM is disabled, this has no "
168 "effect. When MSSA in LICM is enabled, then this is the maximum "
169 "number of accesses allowed to be present in a loop in order to "
170 "enable memory promotion."));
171
172namespace llvm {
174} // end namespace llvm
175
176static bool inSubLoop(BasicBlock *BB, Loop *CurLoop, LoopInfo *LI);
177static bool isNotUsedOrFoldableInLoop(const Instruction &I, const Loop *CurLoop,
178 const LoopSafetyInfo *SafetyInfo,
180 bool &FoldableInLoop, bool LoopNestMode);
181static void hoist(Instruction &I, const DominatorTree *DT, const Loop *CurLoop,
182 BasicBlock *Dest, ICFLoopSafetyInfo *SafetyInfo,
185static bool sink(Instruction &I, LoopInfo *LI, DominatorTree *DT,
186 const Loop *CurLoop, ICFLoopSafetyInfo *SafetyInfo,
189 Instruction &Inst, const DominatorTree *DT, const TargetLibraryInfo *TLI,
190 const Loop *CurLoop, const LoopSafetyInfo *SafetyInfo,
191 OptimizationRemarkEmitter *ORE, const Instruction *CtxI,
192 AssumptionCache *AC, bool AllowSpeculation);
194 AAResults *AA, Loop *CurLoop,
195 SinkAndHoistLICMFlags &Flags);
196static bool pointerInvalidatedByLoop(MemorySSA *MSSA, MemoryUse *MU,
197 Loop *CurLoop, Instruction &I,
199 bool InvariantGroup);
200static bool pointerInvalidatedByBlock(BasicBlock &BB, MemorySSA &MSSA,
201 MemoryUse &MU);
202/// Aggregates various functions for hoisting computations out of loop.
203static bool hoistArithmetics(Instruction &I, Loop &L,
204 ICFLoopSafetyInfo &SafetyInfo,
206 DominatorTree *DT);
207static bool
209 BasicBlock *HoistDest, ICFLoopSafetyInfo *SafetyInfo,
212 SmallVectorImpl<Instruction *> &HoistedInstructions);
214 Instruction &I, BasicBlock &ExitBlock, PHINode &PN, const LoopInfo *LI,
215 const LoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU);
216
217static void eraseInstruction(Instruction &I, ICFLoopSafetyInfo &SafetyInfo,
218 MemorySSAUpdater &MSSAU);
219
221 ICFLoopSafetyInfo &SafetyInfo,
223
224static void foreachMemoryAccess(MemorySSA *MSSA, Loop *L,
225 function_ref<void(Instruction *)> Fn);
227 std::pair<SmallSetVector<Value *, 8>, bool>;
230
231namespace {
232struct LoopInvariantCodeMotion {
233 bool runOnLoop(Loop *L, AAResults *AA, LoopInfo *LI, DominatorTree *DT,
236 OptimizationRemarkEmitter *ORE, bool LoopNestMode = false);
237
238 LoopInvariantCodeMotion(unsigned LicmMssaOptCap,
239 unsigned LicmMssaNoAccForPromotionCap,
240 bool LicmAllowSpeculation)
241 : LicmMssaOptCap(LicmMssaOptCap),
242 LicmMssaNoAccForPromotionCap(LicmMssaNoAccForPromotionCap),
243 LicmAllowSpeculation(LicmAllowSpeculation) {}
244
245private:
246 unsigned LicmMssaOptCap;
247 unsigned LicmMssaNoAccForPromotionCap;
248 bool LicmAllowSpeculation;
249};
250
251struct LegacyLICMPass : public LoopPass {
252 static char ID; // Pass identification, replacement for typeid
253 LegacyLICMPass(
254 unsigned LicmMssaOptCap = SetLicmMssaOptCap,
255 unsigned LicmMssaNoAccForPromotionCap = SetLicmMssaNoAccForPromotionCap,
256 bool LicmAllowSpeculation = true)
257 : LoopPass(ID), LICM(LicmMssaOptCap, LicmMssaNoAccForPromotionCap,
258 LicmAllowSpeculation) {
260 }
261
262 bool runOnLoop(Loop *L, LPPassManager &LPM) override {
263 if (skipLoop(L))
264 return false;
265
266 LLVM_DEBUG(dbgs() << "Perform LICM on Loop with header at block "
267 << L->getHeader()->getNameOrAsOperand() << "\n");
268
269 Function *F = L->getHeader()->getParent();
270
271 auto *SE = getAnalysisIfAvailable<ScalarEvolutionWrapperPass>();
272 MemorySSA *MSSA = &getAnalysis<MemorySSAWrapperPass>().getMSSA();
273 // For the old PM, we can't use OptimizationRemarkEmitter as an analysis
274 // pass. Function analyses need to be preserved across loop transformations
275 // but ORE cannot be preserved (see comment before the pass definition).
276 OptimizationRemarkEmitter ORE(L->getHeader()->getParent());
277 return LICM.runOnLoop(
278 L, &getAnalysis<AAResultsWrapperPass>().getAAResults(),
279 &getAnalysis<LoopInfoWrapperPass>().getLoopInfo(),
280 &getAnalysis<DominatorTreeWrapperPass>().getDomTree(),
281 &getAnalysis<AssumptionCacheTracker>().getAssumptionCache(*F),
282 &getAnalysis<TargetLibraryInfoWrapperPass>().getTLI(*F),
283 &getAnalysis<TargetTransformInfoWrapperPass>().getTTI(*F),
284 SE ? &SE->getSE() : nullptr, MSSA, &ORE);
285 }
286
287 /// This transformation requires natural loop information & requires that
288 /// loop preheaders be inserted into the CFG...
289 ///
290 void getAnalysisUsage(AnalysisUsage &AU) const override {
291 AU.addPreserved<DominatorTreeWrapperPass>();
292 AU.addPreserved<LoopInfoWrapperPass>();
293 AU.addRequired<TargetLibraryInfoWrapperPass>();
294 AU.addRequired<MemorySSAWrapperPass>();
295 AU.addPreserved<MemorySSAWrapperPass>();
296 AU.addRequired<TargetTransformInfoWrapperPass>();
297 AU.addRequired<AssumptionCacheTracker>();
300 AU.addPreserved<LazyBlockFrequencyInfoPass>();
301 AU.addPreserved<LazyBranchProbabilityInfoPass>();
302 }
303
304private:
305 LoopInvariantCodeMotion LICM;
306};
307} // namespace
308
311 if (!AR.MSSA)
312 reportFatalUsageError("LICM requires MemorySSA (loop-mssa)");
313
314 // For the new PM, we also can't use OptimizationRemarkEmitter as an analysis
315 // pass. Function analyses need to be preserved across loop transformations
316 // but ORE cannot be preserved (see comment before the pass definition).
317 OptimizationRemarkEmitter ORE(L.getHeader()->getParent());
318
319 LoopInvariantCodeMotion LICM(Opts.MssaOptCap, Opts.MssaNoAccForPromotionCap,
320 Opts.AllowSpeculation);
321 if (!LICM.runOnLoop(&L, &AR.AA, &AR.LI, &AR.DT, &AR.AC, &AR.TLI, &AR.TTI,
322 &AR.SE, AR.MSSA, &ORE))
323 return PreservedAnalyses::all();
324
326 PA.preserve<MemorySSAAnalysis>();
327
328 return PA;
329}
330
332 raw_ostream &OS, function_ref<StringRef(StringRef)> MapClassName2PassName) {
333 static_cast<PassInfoMixin<LICMPass> *>(this)->printPipeline(
334 OS, MapClassName2PassName);
335
336 OS << '<';
337 OS << (Opts.AllowSpeculation ? "" : "no-") << "allowspeculation";
338 OS << '>';
339}
340
343 LPMUpdater &) {
344 if (!AR.MSSA)
345 reportFatalUsageError("LNICM requires MemorySSA (loop-mssa)");
346
347 // For the new PM, we also can't use OptimizationRemarkEmitter as an analysis
348 // pass. Function analyses need to be preserved across loop transformations
349 // but ORE cannot be preserved (see comment before the pass definition).
351
352 LoopInvariantCodeMotion LICM(Opts.MssaOptCap, Opts.MssaNoAccForPromotionCap,
353 Opts.AllowSpeculation);
354
355 Loop &OutermostLoop = LN.getOutermostLoop();
356 bool Changed = LICM.runOnLoop(&OutermostLoop, &AR.AA, &AR.LI, &AR.DT, &AR.AC,
357 &AR.TLI, &AR.TTI, &AR.SE, AR.MSSA, &ORE, true);
358
359 if (!Changed)
360 return PreservedAnalyses::all();
361
363
364 PA.preserve<DominatorTreeAnalysis>();
365 PA.preserve<LoopAnalysis>();
366 PA.preserve<MemorySSAAnalysis>();
367
368 return PA;
369}
370
372 raw_ostream &OS, function_ref<StringRef(StringRef)> MapClassName2PassName) {
373 static_cast<PassInfoMixin<LNICMPass> *>(this)->printPipeline(
374 OS, MapClassName2PassName);
375
376 OS << '<';
377 OS << (Opts.AllowSpeculation ? "" : "no-") << "allowspeculation";
378 OS << '>';
379}
380
381char LegacyLICMPass::ID = 0;
382INITIALIZE_PASS_BEGIN(LegacyLICMPass, "licm", "Loop Invariant Code Motion",
383 false, false)
389INITIALIZE_PASS_END(LegacyLICMPass, "licm", "Loop Invariant Code Motion", false,
390 false)
391
392Pass *llvm::createLICMPass() { return new LegacyLICMPass(); }
393
398
400 unsigned LicmMssaOptCap, unsigned LicmMssaNoAccForPromotionCap, bool IsSink,
401 Loop &L, MemorySSA &MSSA)
404 IsSink(IsSink) {
405 unsigned AccessCapCount = 0;
406 for (auto *BB : L.getBlocks())
407 if (const auto *Accesses = MSSA.getBlockAccesses(BB))
408 for (const auto &MA : *Accesses) {
409 (void)MA;
410 ++AccessCapCount;
411 if (AccessCapCount > LicmMssaNoAccForPromotionCap) {
412 NoOfMemAccTooLarge = true;
413 return;
414 }
415 }
416}
417
418/// Hoist expressions out of the specified loop. Note, alias info for inner
419/// loop is not preserved so it is not a good idea to run LICM multiple
420/// times on one loop.
421bool LoopInvariantCodeMotion::runOnLoop(Loop *L, AAResults *AA, LoopInfo *LI,
425 ScalarEvolution *SE, MemorySSA *MSSA,
427 bool LoopNestMode) {
428 bool Changed = false;
429
430 assert(L->isLCSSAForm(*DT) && "Loop is not in LCSSA form.");
431
432 // If this loop has metadata indicating that LICM is not to be performed then
433 // just exit.
435 return false;
436 }
437
438 // Don't sink stores from loops with coroutine suspend instructions.
439 // LICM would sink instructions into the default destination of
440 // the coroutine switch. The default destination of the switch is to
441 // handle the case where the coroutine is suspended, by which point the
442 // coroutine frame may have been destroyed. No instruction can be sunk there.
443 // FIXME: This would unfortunately hurt the performance of coroutines, however
444 // there is currently no general solution for this. Similar issues could also
445 // potentially happen in other passes where instructions are being moved
446 // across that edge.
447 bool HasCoroSuspendInst = llvm::any_of(L->getBlocks(), [](BasicBlock *BB) {
448 using namespace PatternMatch;
449 return any_of(make_pointer_range(*BB),
450 match_fn(m_Intrinsic<Intrinsic::coro_suspend>()));
451 });
452
453 MemorySSAUpdater MSSAU(MSSA);
454 SinkAndHoistLICMFlags Flags(LicmMssaOptCap, LicmMssaNoAccForPromotionCap,
455 /*IsSink=*/true, *L, *MSSA);
456
457 // Get the preheader block to move instructions into...
458 BasicBlock *Preheader = L->getLoopPreheader();
459
460 // Compute loop safety information.
461 ICFLoopSafetyInfo SafetyInfo;
462 SafetyInfo.computeLoopSafetyInfo(L);
463
464 // We want to visit all of the instructions in this loop... that are not parts
465 // of our subloops (they have already had their invariants hoisted out of
466 // their loop, into this loop, so there is no need to process the BODIES of
467 // the subloops).
468 //
469 // Traverse the body of the loop in depth first order on the dominator tree so
470 // that we are guaranteed to see definitions before we see uses. This allows
471 // us to sink instructions in one pass, without iteration. After sinking
472 // instructions, we perform another pass to hoist them out of the loop.
473 if (L->hasDedicatedExits())
474 Changed |=
475 LoopNestMode
476 ? sinkRegionForLoopNest(DT->getNode(L->getHeader()), AA, LI, DT,
477 TLI, TTI, L, MSSAU, &SafetyInfo, Flags, ORE)
478 : sinkRegion(DT->getNode(L->getHeader()), AA, LI, DT, TLI, TTI, L,
479 MSSAU, &SafetyInfo, Flags, ORE);
480 Flags.setIsSink(false);
481 if (Preheader)
482 Changed |= hoistRegion(DT->getNode(L->getHeader()), AA, LI, DT, AC, TLI, L,
483 MSSAU, SE, &SafetyInfo, Flags, ORE, LoopNestMode,
484 LicmAllowSpeculation);
485
486 // Now that all loop invariants have been removed from the loop, promote any
487 // memory references to scalars that we can.
488 // Don't sink stores from loops without dedicated block exits. Exits
489 // containing indirect branches are not transformed by loop simplify,
490 // make sure we catch that. An additional load may be generated in the
491 // preheader for SSA updater, so also avoid sinking when no preheader
492 // is available.
493 if (!DisablePromotion && Preheader && L->hasDedicatedExits() &&
494 !Flags.tooManyMemoryAccesses() && !HasCoroSuspendInst) {
495 // Figure out the loop exits and their insertion points
496 SmallVector<BasicBlock *, 8> ExitBlocks;
497 L->getUniqueExitBlocks(ExitBlocks);
498
499 // We can't insert into a catchswitch.
500 bool HasCatchSwitch = llvm::any_of(ExitBlocks, [](BasicBlock *Exit) {
501 return isa<CatchSwitchInst>(Exit->getTerminator());
502 });
503
504 if (!HasCatchSwitch) {
506 SmallVector<MemoryAccess *, 8> MSSAInsertPts;
507 InsertPts.reserve(ExitBlocks.size());
508 MSSAInsertPts.reserve(ExitBlocks.size());
509 for (BasicBlock *ExitBlock : ExitBlocks) {
510 InsertPts.push_back(ExitBlock->getFirstInsertionPt());
511 MSSAInsertPts.push_back(nullptr);
512 }
513
515
516 // Promoting one set of accesses may make the pointers for another set
517 // loop invariant, so run this in a loop.
518 bool Promoted = false;
519 bool LocalPromoted;
520 do {
521 LocalPromoted = false;
522 for (auto [PointerMustAliases, HasReadsOutsideSet] :
523 collectPromotionCandidates(MSSA, AA, L)) {
524 LocalPromoted |= promoteLoopAccessesToScalars(
525 PointerMustAliases, ExitBlocks, InsertPts, MSSAInsertPts, PIC, LI,
526 DT, AC, TLI, TTI, L, MSSAU, &SafetyInfo, ORE,
527 LicmAllowSpeculation, HasReadsOutsideSet);
528 }
529 Promoted |= LocalPromoted;
530 } while (LocalPromoted);
531
532 // Once we have promoted values across the loop body we have to
533 // recursively reform LCSSA as any nested loop may now have values defined
534 // within the loop used in the outer loop.
535 // FIXME: This is really heavy handed. It would be a bit better to use an
536 // SSAUpdater strategy during promotion that was LCSSA aware and reformed
537 // it as it went.
538 if (Promoted)
539 formLCSSARecursively(*L, *DT, LI, SE);
540
541 Changed |= Promoted;
542 }
543 }
544
545 // Check that neither this loop nor its parent have had LCSSA broken. LICM is
546 // specifically moving instructions across the loop boundary and so it is
547 // especially in need of basic functional correctness checking here.
548 assert(L->isLCSSAForm(*DT) && "Loop not left in LCSSA form after LICM!");
549 assert((L->isOutermost() || L->getParentLoop()->isLCSSAForm(*DT)) &&
550 "Parent loop not left in LCSSA form after LICM!");
551
552 if (VerifyMemorySSA)
553 MSSA->verifyMemorySSA();
554
555 if (Changed && SE)
557 return Changed;
558}
559
560/// Walk the specified region of the CFG (defined by all blocks dominated by
561/// the specified block, and that are in the current loop) in reverse depth
562/// first order w.r.t the DominatorTree. This allows us to visit uses before
563/// definitions, allowing us to sink a loop body in one pass without iteration.
564///
567 TargetTransformInfo *TTI, Loop *CurLoop,
568 MemorySSAUpdater &MSSAU, ICFLoopSafetyInfo *SafetyInfo,
570 OptimizationRemarkEmitter *ORE, Loop *OutermostLoop) {
571
572 // Verify inputs.
573 assert(N != nullptr && AA != nullptr && LI != nullptr && DT != nullptr &&
574 CurLoop != nullptr && SafetyInfo != nullptr &&
575 "Unexpected input to sinkRegion.");
576
577 // We want to visit children before parents. We will enqueue all the parents
578 // before their children in the worklist and process the worklist in reverse
579 // order.
581 collectChildrenInLoop(DT, N, CurLoop);
582
583 bool Changed = false;
584 for (BasicBlock *BB : reverse(Worklist)) {
585 // subloop (which would already have been processed).
586 if (inSubLoop(BB, CurLoop, LI))
587 continue;
588
589 for (BasicBlock::iterator II = BB->end(); II != BB->begin();) {
590 Instruction &I = *--II;
591
592 // The instruction is not used in the loop if it is dead. In this case,
593 // we just delete it instead of sinking it.
594 if (isInstructionTriviallyDead(&I, TLI)) {
595 LLVM_DEBUG(dbgs() << "LICM deleting dead inst: " << I << '\n');
598 ++II;
599 eraseInstruction(I, *SafetyInfo, MSSAU);
600 Changed = true;
601 continue;
602 }
603
604 // Check to see if we can sink this instruction to the exit blocks
605 // of the loop. We can do this if the all users of the instruction are
606 // outside of the loop. In this case, it doesn't even matter if the
607 // operands of the instruction are loop invariant.
608 //
609 bool FoldableInLoop = false;
610 bool LoopNestMode = OutermostLoop != nullptr;
611 if (!I.mayHaveSideEffects() &&
612 isNotUsedOrFoldableInLoop(I, LoopNestMode ? OutermostLoop : CurLoop,
613 SafetyInfo, TTI, FoldableInLoop,
614 LoopNestMode) &&
615 canSinkOrHoistInst(I, AA, DT, CurLoop, MSSAU, true, Flags, ORE)) {
616 if (sink(I, LI, DT, CurLoop, SafetyInfo, MSSAU, ORE)) {
617 if (!FoldableInLoop) {
618 ++II;
620 eraseInstruction(I, *SafetyInfo, MSSAU);
621 }
622 Changed = true;
623 }
624 }
625 }
626 }
627 if (VerifyMemorySSA)
628 MSSAU.getMemorySSA()->verifyMemorySSA();
629 return Changed;
630}
631
634 TargetTransformInfo *TTI, Loop *CurLoop,
635 MemorySSAUpdater &MSSAU,
636 ICFLoopSafetyInfo *SafetyInfo,
639
640 bool Changed = false;
642 Worklist.insert(CurLoop);
643 appendLoopsToWorklist(*CurLoop, Worklist);
644 while (!Worklist.empty()) {
645 Loop *L = Worklist.pop_back_val();
646 Changed |= sinkRegion(DT->getNode(L->getHeader()), AA, LI, DT, TLI, TTI, L,
647 MSSAU, SafetyInfo, Flags, ORE, CurLoop);
648 }
649 return Changed;
650}
651
652namespace {
653// This is a helper class for hoistRegion to make it able to hoist control flow
654// in order to be able to hoist phis. The way this works is that we initially
655// start hoisting to the loop preheader, and when we see a loop invariant branch
656// we make note of this. When we then come to hoist an instruction that's
657// conditional on such a branch we duplicate the branch and the relevant control
658// flow, then hoist the instruction into the block corresponding to its original
659// block in the duplicated control flow.
660class ControlFlowHoister {
661private:
662 // Information about the loop we are hoisting from
663 LoopInfo *LI;
664 DominatorTree *DT;
665 Loop *CurLoop;
666 MemorySSAUpdater &MSSAU;
667
668 // A map of blocks in the loop to the block their instructions will be hoisted
669 // to.
670 DenseMap<BasicBlock *, BasicBlock *> HoistDestinationMap;
671
672 // The branches that we can hoist, mapped to the block that marks a
673 // convergence point of their control flow.
674 DenseMap<CondBrInst *, BasicBlock *> HoistableBranches;
675
676public:
677 ControlFlowHoister(LoopInfo *LI, DominatorTree *DT, Loop *CurLoop,
678 MemorySSAUpdater &MSSAU)
679 : LI(LI), DT(DT), CurLoop(CurLoop), MSSAU(MSSAU) {}
680
681 void registerPossiblyHoistableBranch(CondBrInst *BI) {
682 // We can only hoist conditional branches with loop invariant operands.
683 if (!ControlFlowHoisting || !CurLoop->hasLoopInvariantOperands(BI))
684 return;
685
686 // The branch destinations need to be in the loop, and we don't gain
687 // anything by duplicating conditional branches with duplicate successors,
688 // as it's essentially the same as an unconditional branch.
689 BasicBlock *TrueDest = BI->getSuccessor(0);
690 BasicBlock *FalseDest = BI->getSuccessor(1);
691 if (!CurLoop->contains(TrueDest) || !CurLoop->contains(FalseDest) ||
692 TrueDest == FalseDest)
693 return;
694
695 // We can hoist BI if one branch destination is the successor of the other,
696 // or both have common successor which we check by seeing if the
697 // intersection of their successors is non-empty.
698 // TODO: This could be expanded to allowing branches where both ends
699 // eventually converge to a single block.
700 SmallPtrSet<BasicBlock *, 4> TrueDestSucc(llvm::from_range,
701 successors(TrueDest));
702 SmallPtrSet<BasicBlock *, 4> FalseDestSucc(llvm::from_range,
703 successors(FalseDest));
704 BasicBlock *CommonSucc = nullptr;
705 if (TrueDestSucc.count(FalseDest)) {
706 CommonSucc = FalseDest;
707 } else if (FalseDestSucc.count(TrueDest)) {
708 CommonSucc = TrueDest;
709 } else {
710 set_intersect(TrueDestSucc, FalseDestSucc);
711 // If there's one common successor use that.
712 if (TrueDestSucc.size() == 1)
713 CommonSucc = *TrueDestSucc.begin();
714 // If there's more than one pick whichever appears first in the block list
715 // (we can't use the value returned by TrueDestSucc.begin() as it's
716 // unpredicatable which element gets returned).
717 else if (!TrueDestSucc.empty()) {
718 Function *F = TrueDest->getParent();
719 auto IsSucc = [&](BasicBlock &BB) { return TrueDestSucc.count(&BB); };
720 auto It = llvm::find_if(*F, IsSucc);
721 assert(It != F->end() && "Could not find successor in function");
722 CommonSucc = &*It;
723 }
724 }
725 // The common successor has to be dominated by the branch, as otherwise
726 // there will be some other path to the successor that will not be
727 // controlled by this branch so any phi we hoist would be controlled by the
728 // wrong condition. This also takes care of avoiding hoisting of loop back
729 // edges.
730 // TODO: In some cases this could be relaxed if the successor is dominated
731 // by another block that's been hoisted and we can guarantee that the
732 // control flow has been replicated exactly.
733 if (CommonSucc && DT->dominates(BI, CommonSucc))
734 HoistableBranches[BI] = CommonSucc;
735 }
736
737 bool canHoistPHI(PHINode *PN) {
738 // The phi must have loop invariant operands.
739 if (!ControlFlowHoisting || !CurLoop->hasLoopInvariantOperands(PN))
740 return false;
741 // We can hoist phis if the block they are in is the target of hoistable
742 // branches which cover all of the predecessors of the block.
743 BasicBlock *BB = PN->getParent();
744 SmallPtrSet<BasicBlock *, 8> PredecessorBlocks(llvm::from_range,
745 predecessors(BB));
746 // If we have less predecessor blocks than predecessors then the phi will
747 // have more than one incoming value for the same block which we can't
748 // handle.
749 // TODO: This could be handled be erasing some of the duplicate incoming
750 // values.
751 if (PredecessorBlocks.size() != pred_size(BB))
752 return false;
753 for (auto &Pair : HoistableBranches) {
754 if (Pair.second == BB) {
755 // Which blocks are predecessors via this branch depends on if the
756 // branch is triangle-like or diamond-like.
757 if (Pair.first->getSuccessor(0) == BB) {
758 PredecessorBlocks.erase(Pair.first->getParent());
759 PredecessorBlocks.erase(Pair.first->getSuccessor(1));
760 } else if (Pair.first->getSuccessor(1) == BB) {
761 PredecessorBlocks.erase(Pair.first->getParent());
762 PredecessorBlocks.erase(Pair.first->getSuccessor(0));
763 } else {
764 PredecessorBlocks.erase(Pair.first->getSuccessor(0));
765 PredecessorBlocks.erase(Pair.first->getSuccessor(1));
766 }
767 }
768 }
769 // PredecessorBlocks will now be empty if for every predecessor of BB we
770 // found a hoistable branch source.
771 return PredecessorBlocks.empty();
772 }
773
774 BasicBlock *getOrCreateHoistedBlock(BasicBlock *BB) {
776 return CurLoop->getLoopPreheader();
777 // If BB has already been hoisted, return that
778 if (auto It = HoistDestinationMap.find(BB); It != HoistDestinationMap.end())
779 return It->second;
780
781 // Check if this block is conditional based on a pending branch
782 auto HasBBAsSuccessor =
783 [&](DenseMap<CondBrInst *, BasicBlock *>::value_type &Pair) {
784 return BB != Pair.second && (Pair.first->getSuccessor(0) == BB ||
785 Pair.first->getSuccessor(1) == BB);
786 };
787 auto It = llvm::find_if(HoistableBranches, HasBBAsSuccessor);
788
789 // If not involved in a pending branch, hoist to preheader
790 BasicBlock *InitialPreheader = CurLoop->getLoopPreheader();
791 if (It == HoistableBranches.end()) {
792 LLVM_DEBUG(dbgs() << "LICM using "
793 << InitialPreheader->getNameOrAsOperand()
794 << " as hoist destination for "
795 << BB->getNameOrAsOperand() << "\n");
796 HoistDestinationMap[BB] = InitialPreheader;
797 return InitialPreheader;
798 }
799 CondBrInst *BI = It->first;
800 assert(std::none_of(std::next(It), HoistableBranches.end(),
801 HasBBAsSuccessor) &&
802 "BB is expected to be the target of at most one branch");
803
804 LLVMContext &C = BB->getContext();
805 BasicBlock *TrueDest = BI->getSuccessor(0);
806 BasicBlock *FalseDest = BI->getSuccessor(1);
807 BasicBlock *CommonSucc = HoistableBranches[BI];
808 BasicBlock *HoistTarget = getOrCreateHoistedBlock(BI->getParent());
809
810 // Create hoisted versions of blocks that currently don't have them
811 auto CreateHoistedBlock = [&](BasicBlock *Orig) {
812 auto [It, Inserted] = HoistDestinationMap.try_emplace(Orig);
813 if (!Inserted)
814 return It->second;
815 BasicBlock *New =
816 BasicBlock::Create(C, Orig->getName() + ".licm", Orig->getParent());
817 It->second = New;
818 DT->addNewBlock(New, HoistTarget);
819 if (CurLoop->getParentLoop())
820 CurLoop->getParentLoop()->addBasicBlockToLoop(New, *LI);
821 ++NumCreatedBlocks;
822 LLVM_DEBUG(dbgs() << "LICM created " << New->getName()
823 << " as hoist destination for " << Orig->getName()
824 << "\n");
825 return New;
826 };
827 BasicBlock *HoistTrueDest = CreateHoistedBlock(TrueDest);
828 BasicBlock *HoistFalseDest = CreateHoistedBlock(FalseDest);
829 BasicBlock *HoistCommonSucc = CreateHoistedBlock(CommonSucc);
830
831 // Link up these blocks with branches.
832 if (!HoistCommonSucc->hasTerminator()) {
833 // The new common successor we've generated will branch to whatever that
834 // hoist target branched to.
835 BasicBlock *TargetSucc = HoistTarget->getSingleSuccessor();
836 assert(TargetSucc && "Expected hoist target to have a single successor");
837 HoistCommonSucc->moveBefore(TargetSucc);
838 UncondBrInst::Create(TargetSucc, HoistCommonSucc);
839 }
840 if (!HoistTrueDest->hasTerminator()) {
841 HoistTrueDest->moveBefore(HoistCommonSucc);
842 UncondBrInst::Create(HoistCommonSucc, HoistTrueDest);
843 }
844 if (!HoistFalseDest->hasTerminator()) {
845 HoistFalseDest->moveBefore(HoistCommonSucc);
846 UncondBrInst::Create(HoistCommonSucc, HoistFalseDest);
847 }
848
849 // If BI is being cloned to what was originally the preheader then
850 // HoistCommonSucc will now be the new preheader.
851 if (HoistTarget == InitialPreheader) {
852 // Phis in the loop header now need to use the new preheader.
853 InitialPreheader->replaceSuccessorsPhiUsesWith(HoistCommonSucc);
855 HoistTarget->getSingleSuccessor(), HoistCommonSucc, {HoistTarget});
856 // The new preheader dominates the loop header.
857 DomTreeNode *PreheaderNode = DT->getNode(HoistCommonSucc);
858 DomTreeNode *HeaderNode = DT->getNode(CurLoop->getHeader());
859 DT->changeImmediateDominator(HeaderNode, PreheaderNode);
860 // The preheader hoist destination is now the new preheader, with the
861 // exception of the hoist destination of this branch.
862 for (auto &Pair : HoistDestinationMap)
863 if (Pair.second == InitialPreheader && Pair.first != BI->getParent())
864 Pair.second = HoistCommonSucc;
865 }
866
867 // Now finally clone BI.
868 auto *NewBI =
869 CondBrInst::Create(BI->getCondition(), HoistTrueDest, HoistFalseDest,
870 HoistTarget->getTerminator()->getIterator());
871 HoistTarget->getTerminator()->eraseFromParent();
872 // md_prof should also come from the original branch - since the
873 // condition was hoisted, the branch probabilities shouldn't change.
875 NewBI->copyMetadata(*BI, {LLVMContext::MD_prof});
876 // FIXME: Issue #152767: debug info should also be the same as the
877 // original branch, **if** the user explicitly indicated that.
878 NewBI->setDebugLoc(HoistTarget->getTerminator()->getDebugLoc());
879
880 ++NumClonedBranches;
881
882 assert(CurLoop->getLoopPreheader() &&
883 "Hoisting blocks should not have destroyed preheader");
884 return HoistDestinationMap[BB];
885 }
886};
887} // namespace
888
889/// Walk the specified region of the CFG (defined by all blocks dominated by
890/// the specified block, and that are in the current loop) in depth first
891/// order w.r.t the DominatorTree. This allows us to visit definitions before
892/// uses, allowing us to hoist a loop body in one pass without iteration.
893///
896 TargetLibraryInfo *TLI, Loop *CurLoop,
898 ICFLoopSafetyInfo *SafetyInfo,
900 OptimizationRemarkEmitter *ORE, bool LoopNestMode,
901 bool AllowSpeculation) {
902 // Verify inputs.
903 assert(N != nullptr && AA != nullptr && LI != nullptr && DT != nullptr &&
904 CurLoop != nullptr && SafetyInfo != nullptr &&
905 "Unexpected input to hoistRegion.");
906
907 ControlFlowHoister CFH(LI, DT, CurLoop, MSSAU);
908
909 // Keep track of instructions that have been hoisted, as they may need to be
910 // re-hoisted if they end up not dominating all of their uses.
911 SmallVector<Instruction *, 16> HoistedInstructions;
912
913 // For PHI hoisting to work we need to hoist blocks before their successors.
914 // We can do this by iterating through the blocks in the loop in reverse
915 // post-order.
916 LoopBlocksRPO Worklist(CurLoop);
917 Worklist.perform(LI);
918 bool Changed = false;
919 BasicBlock *Preheader = CurLoop->getLoopPreheader();
920 for (BasicBlock *BB : Worklist) {
921 // Only need to process the contents of this block if it is not part of a
922 // subloop (which would already have been processed).
923 if (!LoopNestMode && inSubLoop(BB, CurLoop, LI))
924 continue;
925
927 // Try hoisting the instruction out to the preheader. We can only do
928 // this if all of the operands of the instruction are loop invariant and
929 // if it is safe to hoist the instruction.
930 // TODO: It may be safe to hoist if we are hoisting to a conditional block
931 // and we have accurately duplicated the control flow from the loop header
932 // to that block.
933 if (CurLoop->hasLoopInvariantOperands(&I) &&
934 canSinkOrHoistInst(I, AA, DT, CurLoop, MSSAU, true, Flags, ORE) &&
935 isSafeToExecuteUnconditionally(I, DT, TLI, CurLoop, SafetyInfo, ORE,
936 Preheader->getTerminator(), AC,
937 AllowSpeculation)) {
938 hoist(I, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
939 MSSAU, SE, ORE);
940 HoistedInstructions.push_back(&I);
941 Changed = true;
942 continue;
943 }
944
945 if (auto *Ins = dyn_cast<InsertElementInst>(&I))
946 if (hoistInsertPastInsert(Ins, CurLoop, DT,
947 CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
948 MSSAU, SE, ORE, HoistedInstructions)) {
949 Changed = true;
950 continue;
951 }
952
953 // Attempt to remove floating point division out of the loop by
954 // converting it to a reciprocal multiplication.
955 if (I.getOpcode() == Instruction::FDiv && I.hasAllowReciprocal() &&
956 CurLoop->isLoopInvariant(I.getOperand(1))) {
957 auto Divisor = I.getOperand(1);
958 auto One = llvm::ConstantFP::get(Divisor->getType(), 1.0);
959 auto ReciprocalDivisor = BinaryOperator::CreateFDiv(One, Divisor);
960 ReciprocalDivisor->setFastMathFlags(I.getFastMathFlags());
961 SafetyInfo->insertInstructionTo(ReciprocalDivisor, I.getParent());
962 ReciprocalDivisor->insertBefore(I.getIterator());
963 ReciprocalDivisor->setDebugLoc(I.getDebugLoc());
964
965 auto Product =
966 BinaryOperator::CreateFMul(I.getOperand(0), ReciprocalDivisor);
967 Product->setFastMathFlags(I.getFastMathFlags());
968 SafetyInfo->insertInstructionTo(Product, I.getParent());
969 Product->insertAfter(I.getIterator());
970 Product->setDebugLoc(I.getDebugLoc());
971 I.replaceAllUsesWith(Product);
972 eraseInstruction(I, *SafetyInfo, MSSAU);
973
974 hoist(*ReciprocalDivisor, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB),
975 SafetyInfo, MSSAU, SE, ORE);
976 HoistedInstructions.push_back(ReciprocalDivisor);
977 Changed = true;
978 continue;
979 }
980
981 auto IsInvariantStart = [&](Instruction &I) {
982 using namespace PatternMatch;
983 return I.use_empty() &&
985 };
986 auto MustExecuteWithoutWritesBefore = [&](Instruction &I) {
987 return SafetyInfo->isGuaranteedToExecute(I, DT, CurLoop) &&
988 SafetyInfo->doesNotWriteMemoryBefore(I, CurLoop);
989 };
990 if ((IsInvariantStart(I) || isGuard(&I)) &&
991 CurLoop->hasLoopInvariantOperands(&I) &&
992 MustExecuteWithoutWritesBefore(I)) {
993 hoist(I, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
994 MSSAU, SE, ORE);
995 HoistedInstructions.push_back(&I);
996 Changed = true;
997 continue;
998 }
999
1000 if (PHINode *PN = dyn_cast<PHINode>(&I)) {
1001 if (CFH.canHoistPHI(PN)) {
1002 // Redirect incoming blocks first to ensure that we create hoisted
1003 // versions of those blocks before we hoist the phi.
1004 for (unsigned int i = 0; i < PN->getNumIncomingValues(); ++i)
1005 PN->setIncomingBlock(
1006 i, CFH.getOrCreateHoistedBlock(PN->getIncomingBlock(i)));
1007 hoist(*PN, DT, CurLoop, CFH.getOrCreateHoistedBlock(BB), SafetyInfo,
1008 MSSAU, SE, ORE);
1009 assert(DT->dominates(PN, BB) && "Conditional PHIs not expected");
1010 Changed = true;
1011 continue;
1012 }
1013 }
1014
1015 // Try to reassociate instructions so that part of computations can be
1016 // done out of loop.
1017 if (hoistArithmetics(I, *CurLoop, *SafetyInfo, MSSAU, AC, DT)) {
1018 Changed = true;
1019 continue;
1020 }
1021
1022 // Remember possibly hoistable branches so we can actually hoist them
1023 // later if needed.
1024 if (CondBrInst *BI = dyn_cast<CondBrInst>(&I))
1025 CFH.registerPossiblyHoistableBranch(BI);
1026 }
1027 }
1028
1029 // If we hoisted instructions to a conditional block they may not dominate
1030 // their uses that weren't hoisted (such as phis where some operands are not
1031 // loop invariant). If so make them unconditional by moving them to their
1032 // immediate dominator. We iterate through the instructions in reverse order
1033 // which ensures that when we rehoist an instruction we rehoist its operands,
1034 // and also keep track of where in the block we are rehoisting to make sure
1035 // that we rehoist instructions before the instructions that use them.
1036 Instruction *HoistPoint = nullptr;
1037 if (ControlFlowHoisting) {
1038 for (Instruction *I : reverse(HoistedInstructions)) {
1039 if (!llvm::all_of(I->uses(),
1040 [&](Use &U) { return DT->dominates(I, U); })) {
1041 BasicBlock *Dominator =
1042 DT->getNode(I->getParent())->getIDom()->getBlock();
1043 if (!HoistPoint || !DT->dominates(HoistPoint->getParent(), Dominator)) {
1044 if (HoistPoint)
1045 assert(DT->dominates(Dominator, HoistPoint->getParent()) &&
1046 "New hoist point expected to dominate old hoist point");
1047 HoistPoint = Dominator->getTerminator();
1048 }
1049 LLVM_DEBUG(dbgs() << "LICM rehoisting to "
1050 << HoistPoint->getParent()->getNameOrAsOperand()
1051 << ": " << *I << "\n");
1052 moveInstructionBefore(*I, HoistPoint->getIterator(), *SafetyInfo, MSSAU,
1053 SE);
1054 HoistPoint = I;
1055 Changed = true;
1056 }
1057 }
1058 }
1059 if (VerifyMemorySSA)
1060 MSSAU.getMemorySSA()->verifyMemorySSA();
1061
1062 // Now that we've finished hoisting make sure that LI and DT are still
1063 // valid.
1064#ifdef EXPENSIVE_CHECKS
1065 if (Changed) {
1066 assert(DT->verify(DominatorTree::VerificationLevel::Fast) &&
1067 "Dominator tree verification failed");
1068 LI->verify(*DT);
1069 }
1070#endif
1071
1072 return Changed;
1073}
1074
1075static std::optional<uint64_t>
1077 // Must have constant insertion lane.
1078 auto *InsertedIdxCI = dyn_cast<ConstantInt>(Ins->getOperand(2));
1079 if (!InsertedIdxCI)
1080 return std::nullopt;
1081 auto *VecTy = cast<VectorType>(Ins->getType());
1082
1083 // Avoid hoisting past out of bounds inserts.
1084 if (InsertedIdxCI->isNegative() ||
1085 InsertedIdxCI->getValue().uge(
1086 VecTy->getElementCount().getKnownMinValue()))
1087 return std::nullopt;
1088 return InsertedIdxCI->getValue().getLimitedValue();
1089}
1090
1091static bool
1093 BasicBlock *HoistDest, ICFLoopSafetyInfo *SafetyInfo,
1096 SmallVectorImpl<Instruction *> &HoistedInstructions) {
1097 // Canonicalize:
1098 // %inner = insertelement %base, %variant, C1
1099 // %outer = insertelement %inner, %invariant, C2
1100 // into:
1101 // %outer = insertelement %base, %invariant, C2
1102 // %inner = insertelement %outer, %variant, C1
1103 // so we can hoist %outer
1104
1105 // The instruction we are hoisting must have invariant insertion data
1106 Value *InsertedElt = Ins->getOperand(1);
1107 if (!CurLoop->isLoopInvariant(InsertedElt))
1108 return false;
1109
1110 std::optional<uint64_t> HoistIdx = getConstantInsertionIndex(Ins);
1111 if (!HoistIdx)
1112 return false;
1113
1114 InsertElementInst *Inner = Ins;
1115 while (!CurLoop->isLoopInvariant(Inner->getOperand(0))) {
1116 // If the inner value isn't invariant, check to see if it is another insert
1117 // All instructions in the chain must be in the same basic block
1118 auto *InnerIns = dyn_cast<InsertElementInst>(Inner->getOperand(0));
1119 if (!InnerIns || InnerIns->getParent() != Ins->getParent())
1120 return false;
1121
1122 // Make sure not hoisting past insertions into the same lane
1123 std::optional<uint64_t> InsertIdx = getConstantInsertionIndex(InnerIns);
1124 if (!InsertIdx || *InsertIdx == *HoistIdx)
1125 return false;
1126
1127 // Instruction being hoisted past must only have one use
1128 if (!InnerIns->hasOneUse())
1129 return false;
1130
1131 Inner = InnerIns;
1132 }
1133
1134 // Base case of `insertelement <4 x i8> %invar0, i8 %invar1, i32 2` handled in
1135 // base LICM logic
1136 if (Inner == Ins)
1137 return false;
1138
1139 Ins->replaceAllUsesWith(Ins->getOperand(0));
1140 Ins->moveBefore(Inner->getIterator());
1141 Ins->setOperand(0, Inner->getOperand(0));
1142 Inner->setOperand(0, Ins);
1143 hoist(*Ins, DT, CurLoop, HoistDest, SafetyInfo, MSSAU, SE, ORE);
1144 HoistedInstructions.push_back(Ins);
1145 return true;
1146}
1147
1148// Return true if LI is invariant within scope of the loop. LI is invariant if
1149// CurLoop is dominated by an invariant.start representing the same memory
1150// location and size as the memory location LI loads from, and also the
1151// invariant.start has no uses.
1153 Loop *CurLoop) {
1154 Value *Addr = LI->getPointerOperand();
1155 const DataLayout &DL = LI->getDataLayout();
1156 const TypeSize LocSizeInBits = DL.getTypeSizeInBits(LI->getType());
1157
1158 // It is not currently possible for clang to generate an invariant.start
1159 // intrinsic with scalable vector types because we don't support thread local
1160 // sizeless types and we don't permit sizeless types in structs or classes.
1161 // Furthermore, even if support is added for this in future the intrinsic
1162 // itself is defined to have a size of -1 for variable sized objects. This
1163 // makes it impossible to verify if the intrinsic envelops our region of
1164 // interest. For example, both <vscale x 32 x i8> and <vscale x 16 x i8>
1165 // types would have a -1 parameter, but the former is clearly double the size
1166 // of the latter.
1167 if (LocSizeInBits.isScalable())
1168 return false;
1169
1170 // If we've ended up at a global/constant, bail. We shouldn't be looking at
1171 // uselists for non-local Values in a loop pass.
1172 if (isa<Constant>(Addr))
1173 return false;
1174
1175 unsigned UsesVisited = 0;
1176 // Traverse all uses of the load operand value, to see if invariant.start is
1177 // one of the uses, and whether it dominates the load instruction.
1178 for (auto *U : Addr->users()) {
1179 // Avoid traversing for Load operand with high number of users.
1180 if (++UsesVisited > MaxNumUsesTraversed)
1181 return false;
1183 // If there are escaping uses of invariant.start instruction, the load maybe
1184 // non-invariant.
1185 if (!II || II->getIntrinsicID() != Intrinsic::invariant_start ||
1186 !II->use_empty())
1187 continue;
1188 ConstantInt *InvariantSize = cast<ConstantInt>(II->getArgOperand(0));
1189 // The intrinsic supports having a -1 argument for variable sized objects
1190 // so we should check for that here.
1191 if (InvariantSize->isNegative())
1192 continue;
1193 uint64_t InvariantSizeInBits = InvariantSize->getSExtValue() * 8;
1194 // Confirm the invariant.start location size contains the load operand size
1195 // in bits. Also, the invariant.start should dominate the load, and we
1196 // should not hoist the load out of a loop that contains this dominating
1197 // invariant.start.
1198 if (LocSizeInBits.getFixedValue() <= InvariantSizeInBits &&
1199 DT->properlyDominates(II->getParent(), CurLoop->getHeader()))
1200 return true;
1201 }
1202
1203 return false;
1204}
1205
1206/// Return true if-and-only-if we know how to (mechanically) both hoist and
1207/// sink a given instruction out of a loop. Does not address legality
1208/// concerns such as aliasing or speculation safety.
1219
1220/// Return true if I is the only Instruction with a MemoryAccess in L.
1221static bool isOnlyMemoryAccess(const Instruction *I, const Loop *L,
1222 const MemorySSAUpdater &MSSAU) {
1223 for (auto *BB : L->getBlocks())
1224 if (auto *Accs = MSSAU.getMemorySSA()->getBlockAccesses(BB)) {
1225 int NotAPhi = 0;
1226 for (const auto &Acc : *Accs) {
1227 if (isa<MemoryPhi>(&Acc))
1228 continue;
1229 const auto *MUD = cast<MemoryUseOrDef>(&Acc);
1230 if (MUD->getMemoryInst() != I || NotAPhi++ == 1)
1231 return false;
1232 }
1233 }
1234 return true;
1235}
1236
1238 BatchAAResults &BAA,
1239 SinkAndHoistLICMFlags &Flags,
1240 MemoryUseOrDef *MA) {
1241 // See declaration of SetLicmMssaOptCap for usage details.
1242 if (Flags.tooManyClobberingCalls())
1243 return MA->getDefiningAccess();
1244
1245 MemoryAccess *Source =
1247 Flags.incrementClobberingCalls();
1248 return Source;
1249}
1250
1252 Loop *CurLoop, MemorySSA &MSSA,
1253 bool TargetExecutesOncePerLoop,
1254 SinkAndHoistLICMFlags &Flags,
1256 if (!LI.isUnordered())
1257 return false; // Don't sink/hoist volatile or ordered atomic loads!
1258
1259 // Loads from constant memory are always safe to move, even if they end up
1260 // in the same alias set as something that ends up being modified.
1261 if (!isModSet(AA->getModRefInfoMask(LI.getOperand(0))))
1262 return true;
1263 if (LI.hasMetadata(LLVMContext::MD_invariant_load))
1264 return true;
1265
1266 if (LI.isAtomic() && !TargetExecutesOncePerLoop)
1267 return false; // Don't risk duplicating unordered loads
1268
1269 // This checks for an invariant.start dominating the load.
1270 if (isLoadInvariantInLoop(&LI, DT, CurLoop))
1271 return true;
1272
1273 auto *MU = cast<MemoryUse>(MSSA.getMemoryAccess(&LI));
1274
1275 bool InvariantGroup = LI.hasMetadata(LLVMContext::MD_invariant_group);
1276
1277 bool Invalidated =
1278 pointerInvalidatedByLoop(&MSSA, MU, CurLoop, LI, Flags, InvariantGroup);
1279 // Check loop-invariant address because this may also be a sinkable load
1280 // whose address is not necessarily loop-invariant.
1281 if (ORE && Invalidated && CurLoop->isLoopInvariant(LI.getPointerOperand()))
1282 ORE->emit([&]() {
1284 DEBUG_TYPE, "LoadWithLoopInvariantAddressInvalidated", &LI)
1285 << "failed to move load with loop-invariant address "
1286 "because the loop may invalidate its value";
1287 });
1288
1289 return !Invalidated;
1290}
1291
1293 Loop *CurLoop, MemorySSAUpdater &MSSAU,
1294 bool TargetExecutesOncePerLoop,
1295 SinkAndHoistLICMFlags &Flags,
1297 // If we don't understand the instruction, bail early.
1299 return false;
1300
1301 MemorySSA *MSSA = MSSAU.getMemorySSA();
1302 // Loads have extra constraints we have to verify before we can hoist them.
1303 if (LoadInst *LI = dyn_cast<LoadInst>(&I)) {
1304 return canHoistLoad(*LI, AA, DT, CurLoop, *MSSA, TargetExecutesOncePerLoop,
1305 Flags, ORE);
1306 } else if (CallInst *CI = dyn_cast<CallInst>(&I)) {
1307 // Don't sink calls which can throw.
1308 if (CI->mayThrow())
1309 return false;
1310
1311 // Convergent attribute has been used on operations that involve
1312 // inter-thread communication which results are implicitly affected by the
1313 // enclosing control flows. It is not safe to hoist or sink such operations
1314 // across control flow.
1315 if (CI->isConvergent())
1316 return false;
1317
1318 // FIXME: Current LLVM IR semantics don't work well with coroutines and
1319 // thread local globals. We currently treat getting the address of a thread
1320 // local global as not accessing memory, even though it may not be a
1321 // constant throughout a function with coroutines. Remove this check after
1322 // we better model semantics of thread local globals.
1323 if (CI->getFunction()->isPresplitCoroutine())
1324 return false;
1325
1326 using namespace PatternMatch;
1328 // Assumes don't actually alias anything or throw
1329 return true;
1330
1331 // Handle simple cases by querying alias analysis.
1332 MemoryEffects Behavior = AA->getMemoryEffects(CI);
1333
1334 if (Behavior.doesNotAccessMemory())
1335 return true;
1336 if (Behavior.onlyReadsMemory()) {
1337 // Might have stale MemoryDef for call that was later inferred to be
1338 // read-only.
1339 auto *MU = dyn_cast<MemoryUse>(MSSA->getMemoryAccess(CI));
1340 if (!MU)
1341 return false;
1342
1343 // If we can prove there are no writes to the memory read by the call, we
1344 // can hoist or sink.
1346 MSSA, MU, CurLoop, I, Flags, /*InvariantGroup=*/false);
1347 }
1348
1349 if (Behavior.onlyWritesMemory()) {
1350 // can hoist or sink if there are no conflicting read/writes to the
1351 // memory location written to by the call.
1352 return noConflictingReadWrites(CI, MSSA, AA, CurLoop, Flags);
1353 }
1354
1355 return false;
1356 } else if (auto *FI = dyn_cast<FenceInst>(&I)) {
1357 // Fences alias (most) everything to provide ordering. For the moment,
1358 // just give up if there are any other memory operations in the loop.
1359 return isOnlyMemoryAccess(FI, CurLoop, MSSAU);
1360 } else if (auto *SI = dyn_cast<StoreInst>(&I)) {
1361 if (!SI->isUnordered())
1362 return false; // Don't sink/hoist volatile or ordered atomic store!
1363
1364 // We can only hoist a store that we can prove writes a value which is not
1365 // read or overwritten within the loop. For those cases, we fallback to
1366 // load store promotion instead. TODO: We can extend this to cases where
1367 // there is exactly one write to the location and that write dominates an
1368 // arbitrary number of reads in the loop.
1369 if (isOnlyMemoryAccess(SI, CurLoop, MSSAU))
1370 return true;
1371 return noConflictingReadWrites(SI, MSSA, AA, CurLoop, Flags);
1372 }
1373
1374 assert(!I.mayReadOrWriteMemory() && "unhandled aliasing");
1375
1376 // We've established mechanical ability and aliasing, it's up to the caller
1377 // to check fault safety
1378 return true;
1379}
1380
1381/// Returns true if a PHINode is a trivially replaceable with an
1382/// Instruction.
1383/// This is true when all incoming values are that instruction.
1384/// This pattern occurs most often with LCSSA PHI nodes.
1385///
1386static bool isTriviallyReplaceablePHI(const PHINode &PN, const Instruction &I) {
1387 for (const Value *IncValue : PN.incoming_values())
1388 if (IncValue != &I)
1389 return false;
1390
1391 return true;
1392}
1393
1394/// Return true if the instruction is foldable in the loop.
1395static bool isFoldableInLoop(const Instruction &I, const Loop *CurLoop,
1396 const TargetTransformInfo *TTI) {
1397 if (auto *GEP = dyn_cast<GetElementPtrInst>(&I)) {
1398 InstructionCost CostI =
1399 TTI->getInstructionCost(&I, TargetTransformInfo::TCK_SizeAndLatency);
1400 if (CostI != TargetTransformInfo::TCC_Free)
1401 return false;
1402 // For a GEP, we cannot simply use getInstructionCost because currently
1403 // it optimistically assumes that a GEP will fold into addressing mode
1404 // regardless of its users.
1405 const BasicBlock *BB = GEP->getParent();
1406 for (const User *U : GEP->users()) {
1407 const Instruction *UI = cast<Instruction>(U);
1408 if (CurLoop->contains(UI) &&
1409 (BB != UI->getParent() ||
1410 (!isa<StoreInst>(UI) && !isa<LoadInst>(UI))))
1411 return false;
1412 }
1413 return true;
1414 }
1415
1416 return false;
1417}
1418
1419/// Return true if the only users of this instruction are outside of
1420/// the loop. If this is true, we can sink the instruction to the exit
1421/// blocks of the loop.
1422///
1423/// We also return true if the instruction could be folded away in lowering.
1424/// (e.g., a GEP can be folded into a load as an addressing mode in the loop).
1425static bool isNotUsedOrFoldableInLoop(const Instruction &I, const Loop *CurLoop,
1426 const LoopSafetyInfo *SafetyInfo,
1428 bool &FoldableInLoop, bool LoopNestMode) {
1429 const auto &BlockColors = SafetyInfo->getBlockColors();
1430 bool IsFoldable = isFoldableInLoop(I, CurLoop, TTI);
1431 for (const User *U : I.users()) {
1432 const Instruction *UI = cast<Instruction>(U);
1433 if (const PHINode *PN = dyn_cast<PHINode>(UI)) {
1434 const BasicBlock *BB = PN->getParent();
1435 // We cannot sink uses in catchswitches.
1437 return false;
1438
1439 // We need to sink a callsite to a unique funclet. Avoid sinking if the
1440 // phi use is too muddled.
1441 if (isa<CallInst>(I))
1442 if (!BlockColors.empty() &&
1443 BlockColors.find(const_cast<BasicBlock *>(BB))->second.size() != 1)
1444 return false;
1445
1446 if (LoopNestMode) {
1447 while (isa<PHINode>(UI) && UI->hasOneUser() &&
1448 UI->getNumOperands() == 1) {
1449 if (!CurLoop->contains(UI))
1450 break;
1451 UI = cast<Instruction>(UI->user_back());
1452 }
1453 }
1454 }
1455
1456 if (CurLoop->contains(UI)) {
1457 if (IsFoldable) {
1458 FoldableInLoop = true;
1459 continue;
1460 }
1461 return false;
1462 }
1463 }
1464 return true;
1465}
1466
1468 Instruction &I, BasicBlock &ExitBlock, PHINode &PN, const LoopInfo *LI,
1469 const LoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU) {
1470 Instruction *New;
1471 if (auto *CI = dyn_cast<CallInst>(&I)) {
1472 const auto &BlockColors = SafetyInfo->getBlockColors();
1473
1474 // Sinking call-sites need to be handled differently from other
1475 // instructions. The cloned call-site needs a funclet bundle operand
1476 // appropriate for its location in the CFG.
1478 for (unsigned BundleIdx = 0, BundleEnd = CI->getNumOperandBundles();
1479 BundleIdx != BundleEnd; ++BundleIdx) {
1480 OperandBundleUse Bundle = CI->getOperandBundleAt(BundleIdx);
1481 if (Bundle.getTagID() == LLVMContext::OB_funclet)
1482 continue;
1483
1484 OpBundles.emplace_back(Bundle);
1485 }
1486
1487 if (!BlockColors.empty()) {
1488 const ColorVector &CV = BlockColors.find(&ExitBlock)->second;
1489 assert(CV.size() == 1 && "non-unique color for exit block!");
1490 BasicBlock *BBColor = CV.front();
1491 BasicBlock::iterator EHPad = BBColor->getFirstNonPHIIt();
1492 if (EHPad->isEHPad())
1493 OpBundles.emplace_back("funclet", &*EHPad);
1494 }
1495
1496 New = CallInst::Create(CI, OpBundles);
1497 New->copyMetadata(*CI);
1498 } else {
1499 New = I.clone();
1500 }
1501
1502 New->insertInto(&ExitBlock, ExitBlock.getFirstInsertionPt());
1503 if (!I.getName().empty())
1504 New->setName(I.getName() + ".le");
1505
1506 if (MSSAU.getMemorySSA()->getMemoryAccess(&I)) {
1507 // Create a new MemoryAccess and let MemorySSA set its defining access.
1508 // After running some passes, MemorySSA might be outdated, and the
1509 // instruction `I` may have become a non-memory touching instruction.
1510 MemoryAccess *NewMemAcc = MSSAU.createMemoryAccessInBB(
1511 New, nullptr, New->getParent(), MemorySSA::Beginning,
1512 /*CreationMustSucceed=*/false);
1513 if (NewMemAcc) {
1514 if (auto *MemDef = dyn_cast<MemoryDef>(NewMemAcc))
1515 MSSAU.insertDef(MemDef, /*RenameUses=*/true);
1516 else {
1517 auto *MemUse = cast<MemoryUse>(NewMemAcc);
1518 MSSAU.insertUse(MemUse, /*RenameUses=*/true);
1519 }
1520 }
1521 }
1522
1523 // Build LCSSA PHI nodes for any in-loop operands (if legal). Note that
1524 // this is particularly cheap because we can rip off the PHI node that we're
1525 // replacing for the number and blocks of the predecessors.
1526 // OPT: If this shows up in a profile, we can instead finish sinking all
1527 // invariant instructions, and then walk their operands to re-establish
1528 // LCSSA. That will eliminate creating PHI nodes just to nuke them when
1529 // sinking bottom-up.
1530 for (Use &Op : New->operands())
1531 if (LI->wouldBeOutOfLoopUseRequiringLCSSA(Op.get(), PN.getParent())) {
1532 auto *OInst = cast<Instruction>(Op.get());
1533 PHINode *OpPN =
1534 PHINode::Create(OInst->getType(), PN.getNumIncomingValues(),
1535 OInst->getName() + ".lcssa");
1536 OpPN->insertBefore(ExitBlock.begin());
1537 for (unsigned i = 0, e = PN.getNumIncomingValues(); i != e; ++i)
1538 OpPN->addIncoming(OInst, PN.getIncomingBlock(i));
1539 Op = OpPN;
1540 }
1541 return New;
1542}
1543
1545 MemorySSAUpdater &MSSAU) {
1546 MSSAU.removeMemoryAccess(&I);
1547 SafetyInfo.removeInstruction(&I);
1548 I.eraseFromParent();
1549}
1550
1552 ICFLoopSafetyInfo &SafetyInfo,
1553 MemorySSAUpdater &MSSAU,
1554 ScalarEvolution *SE) {
1555 SafetyInfo.removeInstruction(&I);
1556 SafetyInfo.insertInstructionTo(&I, Dest->getParent());
1557 I.moveBefore(*Dest->getParent(), Dest);
1559 MSSAU.getMemorySSA()->getMemoryAccess(&I)))
1560 MSSAU.moveToPlace(OldMemAcc, Dest->getParent(),
1562 if (SE)
1564}
1565
1567 PHINode *TPN, Instruction *I, LoopInfo *LI,
1569 const LoopSafetyInfo *SafetyInfo, const Loop *CurLoop,
1570 MemorySSAUpdater &MSSAU) {
1572 "Expect only trivially replaceable PHI");
1573 BasicBlock *ExitBlock = TPN->getParent();
1574 auto [It, Inserted] = SunkCopies.try_emplace(ExitBlock);
1575 if (Inserted)
1576 It->second = cloneInstructionInExitBlock(*I, *ExitBlock, *TPN, LI,
1577 SafetyInfo, MSSAU);
1578 return It->second;
1579}
1580
1581static bool canSplitPredecessors(PHINode *PN, LoopSafetyInfo *SafetyInfo) {
1582 BasicBlock *BB = PN->getParent();
1583 if (!BB->canSplitPredecessors())
1584 return false;
1585 // It's not impossible to split EHPad blocks, but if BlockColors already exist
1586 // it require updating BlockColors for all offspring blocks accordingly. By
1587 // skipping such corner case, we can make updating BlockColors after splitting
1588 // predecessor fairly simple.
1589 if (!SafetyInfo->getBlockColors().empty() &&
1590 BB->getFirstNonPHIIt()->isEHPad())
1591 return false;
1592 for (BasicBlock *BBPred : predecessors(BB)) {
1593 if (isa<IndirectBrInst>(BBPred->getTerminator()))
1594 return false;
1595 }
1596 return true;
1597}
1598
1600 LoopInfo *LI, const Loop *CurLoop,
1601 LoopSafetyInfo *SafetyInfo,
1602 MemorySSAUpdater *MSSAU) {
1603#ifndef NDEBUG
1605 CurLoop->getUniqueExitBlocks(ExitBlocks);
1606 SmallPtrSet<BasicBlock *, 32> ExitBlockSet(llvm::from_range, ExitBlocks);
1607#endif
1608 BasicBlock *ExitBB = PN->getParent();
1609 assert(ExitBlockSet.count(ExitBB) && "Expect the PHI is in an exit block.");
1610
1611 // Split predecessors of the loop exit to make instructions in the loop are
1612 // exposed to exit blocks through trivially replaceable PHIs while keeping the
1613 // loop in the canonical form where each predecessor of each exit block should
1614 // be contained within the loop. For example, this will convert the loop below
1615 // from
1616 //
1617 // LB1:
1618 // %v1 =
1619 // br %LE, %LB2
1620 // LB2:
1621 // %v2 =
1622 // br %LE, %LB1
1623 // LE:
1624 // %p = phi [%v1, %LB1], [%v2, %LB2] <-- non-trivially replaceable
1625 //
1626 // to
1627 //
1628 // LB1:
1629 // %v1 =
1630 // br %LE.split, %LB2
1631 // LB2:
1632 // %v2 =
1633 // br %LE.split2, %LB1
1634 // LE.split:
1635 // %p1 = phi [%v1, %LB1] <-- trivially replaceable
1636 // br %LE
1637 // LE.split2:
1638 // %p2 = phi [%v2, %LB2] <-- trivially replaceable
1639 // br %LE
1640 // LE:
1641 // %p = phi [%p1, %LE.split], [%p2, %LE.split2]
1642 //
1643 const auto &BlockColors = SafetyInfo->getBlockColors();
1644 SmallSetVector<BasicBlock *, 8> PredBBs(pred_begin(ExitBB), pred_end(ExitBB));
1645 DomTreeUpdater DTU(DT, DomTreeUpdater::UpdateStrategy::Lazy);
1646 while (!PredBBs.empty()) {
1647 BasicBlock *PredBB = *PredBBs.begin();
1648 assert(CurLoop->contains(PredBB) &&
1649 "Expect all predecessors are in the loop");
1650 if (PN->getBasicBlockIndex(PredBB) >= 0) {
1652 ExitBB, PredBB, ".split.loop.exit", &DTU, LI, MSSAU, true);
1653 // Since we do not allow splitting EH-block with BlockColors in
1654 // canSplitPredecessors(), we can simply assign predecessor's color to
1655 // the new block.
1656 if (!BlockColors.empty())
1657 // Grab a reference to the ColorVector to be inserted before getting the
1658 // reference to the vector we are copying because inserting the new
1659 // element in BlockColors might cause the map to be reallocated.
1660 SafetyInfo->copyColors(NewPred, PredBB);
1661 }
1662 PredBBs.remove(PredBB);
1663 }
1664}
1665
1666/// When an instruction is found to only be used outside of the loop, this
1667/// function moves it to the exit blocks and patches up SSA form as needed.
1668/// This method is guaranteed to remove the original instruction from its
1669/// position, and may either delete it or move it to outside of the loop.
1670///
1671static bool sink(Instruction &I, LoopInfo *LI, DominatorTree *DT,
1672 const Loop *CurLoop, ICFLoopSafetyInfo *SafetyInfo,
1674 bool Changed = false;
1675 LLVM_DEBUG(dbgs() << "LICM sinking instruction: " << I << "\n");
1676
1677 // Iterate over users to be ready for actual sinking. Replace users via
1678 // unreachable blocks with undef and make all user PHIs trivially replaceable.
1679 SmallPtrSet<Instruction *, 8> VisitedUsers;
1680 for (Value::user_iterator UI = I.user_begin(), UE = I.user_end(); UI != UE;) {
1681 auto *User = cast<Instruction>(*UI);
1682 Use &U = UI.getUse();
1683 ++UI;
1684
1685 if (VisitedUsers.count(User) || CurLoop->contains(User))
1686 continue;
1687
1688 if (!DT->isReachableFromEntry(User->getParent())) {
1689 U = PoisonValue::get(I.getType());
1690 Changed = true;
1691 continue;
1692 }
1693
1694 // The user must be a PHI node.
1695 PHINode *PN = cast<PHINode>(User);
1696
1697 // Surprisingly, instructions can be used outside of loops without any
1698 // exits. This can only happen in PHI nodes if the incoming block is
1699 // unreachable.
1700 BasicBlock *BB = PN->getIncomingBlock(U);
1701 if (!DT->isReachableFromEntry(BB)) {
1702 U = PoisonValue::get(I.getType());
1703 Changed = true;
1704 continue;
1705 }
1706
1707 VisitedUsers.insert(PN);
1708 if (isTriviallyReplaceablePHI(*PN, I))
1709 continue;
1710
1711 if (!canSplitPredecessors(PN, SafetyInfo))
1712 return Changed;
1713
1714 // Split predecessors of the PHI so that we can make users trivially
1715 // replaceable.
1716 splitPredecessorsOfLoopExit(PN, DT, LI, CurLoop, SafetyInfo, &MSSAU);
1717
1718 // Should rebuild the iterators, as they may be invalidated by
1719 // splitPredecessorsOfLoopExit().
1720 UI = I.user_begin();
1721 UE = I.user_end();
1722 }
1723
1724 if (VisitedUsers.empty())
1725 return Changed;
1726
1727 ORE->emit([&]() {
1728 return OptimizationRemark(DEBUG_TYPE, "InstSunk", &I)
1729 << "sinking " << ore::NV("Inst", &I);
1730 });
1731 if (isa<LoadInst>(I))
1732 ++NumMovedLoads;
1733 else if (isa<CallInst>(I))
1734 ++NumMovedCalls;
1735 ++NumSunk;
1736
1737#ifndef NDEBUG
1739 CurLoop->getUniqueExitBlocks(ExitBlocks);
1740 SmallPtrSet<BasicBlock *, 32> ExitBlockSet(llvm::from_range, ExitBlocks);
1741#endif
1742
1743 // Clones of this instruction. Don't create more than one per exit block!
1745
1746 // If this instruction is only used outside of the loop, then all users are
1747 // PHI nodes in exit blocks due to LCSSA form. Just RAUW them with clones of
1748 // the instruction.
1749 // First check if I is worth sinking for all uses. Sink only when it is worth
1750 // across all uses.
1751 SmallSetVector<User*, 8> Users(I.user_begin(), I.user_end());
1752 for (auto *UI : Users) {
1753 auto *User = cast<Instruction>(UI);
1754
1755 if (CurLoop->contains(User))
1756 continue;
1757
1758 PHINode *PN = cast<PHINode>(User);
1759 assert(ExitBlockSet.count(PN->getParent()) &&
1760 "The LCSSA PHI is not in an exit block!");
1761
1762 // The PHI must be trivially replaceable.
1764 PN, &I, LI, SunkCopies, SafetyInfo, CurLoop, MSSAU);
1765 // As we sink the instruction out of the BB, drop its debug location.
1766 New->dropLocation();
1767 PN->replaceAllUsesWith(New);
1768 eraseInstruction(*PN, *SafetyInfo, MSSAU);
1769 Changed = true;
1770 }
1771 return Changed;
1772}
1773
1774/// When an instruction is found to only use loop invariant operands that
1775/// is safe to hoist, this instruction is called to do the dirty work.
1776///
1777static void hoist(Instruction &I, const DominatorTree *DT, const Loop *CurLoop,
1778 BasicBlock *Dest, ICFLoopSafetyInfo *SafetyInfo,
1781 LLVM_DEBUG(dbgs() << "LICM hoisting to " << Dest->getNameOrAsOperand() << ": "
1782 << I << "\n");
1783 ORE->emit([&]() {
1784 return OptimizationRemark(DEBUG_TYPE, "Hoisted", &I) << "hoisting "
1785 << ore::NV("Inst", &I);
1786 });
1787
1788 // Metadata can be dependent on conditions we are hoisting above.
1789 // Conservatively strip all metadata on the instruction unless we were
1790 // guaranteed to execute I if we entered the loop, in which case the metadata
1791 // is valid in the loop preheader.
1792 // Similarly, If I is a call and it is not guaranteed to execute in the loop,
1793 // then moving to the preheader means we should strip attributes on the call
1794 // that can cause UB since we may be hoisting above conditions that allowed
1795 // inferring those attributes. They may not be valid at the preheader.
1796 if ((I.hasMetadataOtherThanDebugLoc() || isa<CallInst>(I)) &&
1797 // The check on hasMetadataOtherThanDebugLoc is to prevent us from burning
1798 // time in isGuaranteedToExecute if we don't actually have anything to
1799 // drop. It is a compile time optimization, not required for correctness.
1800 !SafetyInfo->isGuaranteedToExecute(I, DT, CurLoop)) {
1801 I.dropUBImplyingAttrsAndMetadata();
1802 }
1803
1804 if (isa<PHINode>(I))
1805 // Move the new node to the end of the phi list in the destination block.
1806 moveInstructionBefore(I, Dest->getFirstNonPHIIt(), *SafetyInfo, MSSAU, SE);
1807 else
1808 // Move the new node to the destination block, before its terminator.
1809 moveInstructionBefore(I, Dest->getTerminator()->getIterator(), *SafetyInfo,
1810 MSSAU, SE);
1811
1812 I.updateLocationAfterHoist();
1813
1814 if (isa<LoadInst>(I))
1815 ++NumMovedLoads;
1816 else if (isa<CallInst>(I))
1817 ++NumMovedCalls;
1818 ++NumHoisted;
1819}
1820
1821/// Only sink or hoist an instruction if it is not a trapping instruction,
1822/// or if the instruction is known not to trap when moved to the preheader.
1823/// or if it is a trapping instruction and is guaranteed to execute.
1825 Instruction &Inst, const DominatorTree *DT, const TargetLibraryInfo *TLI,
1826 const Loop *CurLoop, const LoopSafetyInfo *SafetyInfo,
1827 OptimizationRemarkEmitter *ORE, const Instruction *CtxI,
1828 AssumptionCache *AC, bool AllowSpeculation) {
1829 if (AllowSpeculation &&
1830 isSafeToSpeculativelyExecute(&Inst, CtxI, AC, DT, TLI))
1831 return true;
1832
1833 bool GuaranteedToExecute =
1834 SafetyInfo->isGuaranteedToExecute(Inst, DT, CurLoop);
1835
1836 if (!GuaranteedToExecute) {
1837 auto *LI = dyn_cast<LoadInst>(&Inst);
1838 if (LI && CurLoop->isLoopInvariant(LI->getPointerOperand()))
1839 ORE->emit([&]() {
1841 DEBUG_TYPE, "LoadWithLoopInvariantAddressCondExecuted", LI)
1842 << "failed to hoist load with loop-invariant address "
1843 "because load is conditionally executed";
1844 });
1845 }
1846
1847 return GuaranteedToExecute;
1848}
1849
1850namespace {
1851class LoopPromoter : public LoadAndStorePromoter {
1852 Value *SomePtr; // Designated pointer to store to.
1853 SmallVectorImpl<BasicBlock *> &LoopExitBlocks;
1854 SmallVectorImpl<BasicBlock::iterator> &LoopInsertPts;
1855 SmallVectorImpl<MemoryAccess *> &MSSAInsertPts;
1856 PredIteratorCache &PredCache;
1857 MemorySSAUpdater &MSSAU;
1858 LoopInfo &LI;
1859 DebugLoc DL;
1860 Align Alignment;
1861 bool UnorderedAtomic;
1862 AAMDNodes AATags;
1863 ICFLoopSafetyInfo &SafetyInfo;
1864 bool CanInsertStoresInExitBlocks;
1866
1867 // We're about to add a use of V in a loop exit block. Insert an LCSSA phi
1868 // (if legal) if doing so would add an out-of-loop use to an instruction
1869 // defined in-loop.
1870 Value *maybeInsertLCSSAPHI(Value *V, BasicBlock *BB) const {
1871 if (!LI.wouldBeOutOfLoopUseRequiringLCSSA(V, BB))
1872 return V;
1873
1875 // We need to create an LCSSA PHI node for the incoming value and
1876 // store that.
1877 PHINode *PN = PHINode::Create(I->getType(), PredCache.size(BB),
1878 I->getName() + ".lcssa");
1879 PN->insertBefore(BB->begin());
1880 for (BasicBlock *Pred : PredCache.get(BB))
1881 PN->addIncoming(I, Pred);
1882 return PN;
1883 }
1884
1885public:
1886 LoopPromoter(Value *SP, ArrayRef<const Instruction *> Insts, SSAUpdater &S,
1887 SmallVectorImpl<BasicBlock *> &LEB,
1888 SmallVectorImpl<BasicBlock::iterator> &LIP,
1889 SmallVectorImpl<MemoryAccess *> &MSSAIP, PredIteratorCache &PIC,
1890 MemorySSAUpdater &MSSAU, LoopInfo &li, DebugLoc dl,
1891 Align Alignment, bool UnorderedAtomic, const AAMDNodes &AATags,
1892 ICFLoopSafetyInfo &SafetyInfo, bool CanInsertStoresInExitBlocks)
1893 : LoadAndStorePromoter(Insts, S), SomePtr(SP), LoopExitBlocks(LEB),
1894 LoopInsertPts(LIP), MSSAInsertPts(MSSAIP), PredCache(PIC), MSSAU(MSSAU),
1895 LI(li), DL(std::move(dl)), Alignment(Alignment),
1896 UnorderedAtomic(UnorderedAtomic), AATags(AATags),
1897 SafetyInfo(SafetyInfo),
1898 CanInsertStoresInExitBlocks(CanInsertStoresInExitBlocks), Uses(Insts) {}
1899
1900 void insertStoresInLoopExitBlocks() {
1901 // Insert stores after in the loop exit blocks. Each exit block gets a
1902 // store of the live-out values that feed them. Since we've already told
1903 // the SSA updater about the defs in the loop and the preheader
1904 // definition, it is all set and we can start using it.
1905 DIAssignID *NewID = nullptr;
1906 for (unsigned i = 0, e = LoopExitBlocks.size(); i != e; ++i) {
1907 BasicBlock *ExitBlock = LoopExitBlocks[i];
1908 Value *LiveInValue = SSA.GetValueInMiddleOfBlock(ExitBlock);
1909 LiveInValue = maybeInsertLCSSAPHI(LiveInValue, ExitBlock);
1910 Value *Ptr = maybeInsertLCSSAPHI(SomePtr, ExitBlock);
1911 BasicBlock::iterator InsertPos = LoopInsertPts[i];
1912 StoreInst *NewSI = new StoreInst(LiveInValue, Ptr, InsertPos);
1913 if (UnorderedAtomic)
1914 NewSI->setOrdering(AtomicOrdering::Unordered);
1915 NewSI->setAlignment(Alignment);
1916 NewSI->setDebugLoc(DL);
1917 // Attach DIAssignID metadata to the new store, generating it on the
1918 // first loop iteration.
1919 if (i == 0) {
1920 // NewSI will have its DIAssignID set here if there are any stores in
1921 // Uses with a DIAssignID attachment. This merged ID will then be
1922 // attached to the other inserted stores (in the branch below).
1923 NewSI->mergeDIAssignID(Uses);
1925 NewSI->getMetadata(LLVMContext::MD_DIAssignID));
1926 } else {
1927 // Attach the DIAssignID (or nullptr) merged from Uses in the branch
1928 // above.
1929 NewSI->setMetadata(LLVMContext::MD_DIAssignID, NewID);
1930 }
1931
1932 if (AATags)
1933 NewSI->setAAMetadata(AATags);
1934
1935 MemoryAccess *MSSAInsertPoint = MSSAInsertPts[i];
1936 MemoryAccess *NewMemAcc;
1937 if (!MSSAInsertPoint) {
1938 NewMemAcc = MSSAU.createMemoryAccessInBB(
1939 NewSI, nullptr, NewSI->getParent(), MemorySSA::Beginning);
1940 } else {
1941 NewMemAcc =
1942 MSSAU.createMemoryAccessAfter(NewSI, nullptr, MSSAInsertPoint);
1943 }
1944 MSSAInsertPts[i] = NewMemAcc;
1945 MSSAU.insertDef(cast<MemoryDef>(NewMemAcc), true);
1946 // FIXME: true for safety, false may still be correct.
1947 }
1948 }
1949
1950 void doExtraRewritesBeforeFinalDeletion() override {
1951 if (CanInsertStoresInExitBlocks)
1952 insertStoresInLoopExitBlocks();
1953 }
1954
1955 void instructionDeleted(Instruction *I) const override {
1956 SafetyInfo.removeInstruction(I);
1957 MSSAU.removeMemoryAccess(I);
1958 }
1959
1960 bool shouldDelete(Instruction *I) const override {
1961 if (isa<StoreInst>(I))
1962 return CanInsertStoresInExitBlocks;
1963 return true;
1964 }
1965};
1966
1967bool isNotCapturedBeforeOrInLoop(const Value *V, const Loop *L,
1968 DominatorTree *DT) {
1969 // We can perform the captured-before check against any instruction in the
1970 // loop header, as the loop header is reachable from any instruction inside
1971 // the loop.
1972 // TODO: ReturnCaptures=true shouldn't be necessary here.
1974 V, /*ReturnCaptures=*/true, L->getHeader()->getTerminator(), DT,
1975 /*IncludeI=*/false, CaptureComponents::Provenance));
1976}
1977
1978/// Return true if we can prove that a caller cannot inspect the object if an
1979/// unwind occurs inside the loop.
1980bool isNotVisibleOnUnwindInLoop(const Value *Object, const Loop *L,
1981 DominatorTree *DT) {
1982 bool RequiresNoCaptureBeforeUnwind;
1983 if (!isNotVisibleOnUnwind(Object, RequiresNoCaptureBeforeUnwind))
1984 return false;
1985
1986 return !RequiresNoCaptureBeforeUnwind ||
1987 isNotCapturedBeforeOrInLoop(Object, L, DT);
1988}
1989
1990bool isThreadLocalObject(const Value *Object, const Loop *L, DominatorTree *DT,
1992 // The object must be function-local to start with, and then not captured
1993 // before/in the loop.
1994 return (isIdentifiedFunctionLocal(Object) &&
1995 isNotCapturedBeforeOrInLoop(Object, L, DT)) ||
1996 (TTI->isSingleThreaded() || SingleThread);
1997}
1998
1999} // namespace
2000
2001/// Try to promote memory values to scalars by sinking stores out of the
2002/// loop and moving loads to before the loop. We do this by looping over
2003/// the stores in the loop, looking for stores to Must pointers which are
2004/// loop invariant.
2005///
2007 const SmallSetVector<Value *, 8> &PointerMustAliases,
2012 const TargetLibraryInfo *TLI, TargetTransformInfo *TTI, Loop *CurLoop,
2013 MemorySSAUpdater &MSSAU, ICFLoopSafetyInfo *SafetyInfo,
2014 OptimizationRemarkEmitter *ORE, bool AllowSpeculation,
2015 bool HasReadsOutsideSet) {
2016 // Verify inputs.
2017 assert(LI != nullptr && DT != nullptr && CurLoop != nullptr &&
2018 SafetyInfo != nullptr &&
2019 "Unexpected Input to promoteLoopAccessesToScalars");
2020
2021 LLVM_DEBUG({
2022 dbgs() << "Trying to promote set of must-aliased pointers:\n";
2023 for (Value *Ptr : PointerMustAliases)
2024 dbgs() << " " << *Ptr << "\n";
2025 });
2026 ++NumPromotionCandidates;
2027
2028 Value *SomePtr = *PointerMustAliases.begin();
2029 BasicBlock *Preheader = CurLoop->getLoopPreheader();
2030
2031 // It is not safe to promote a load/store from the loop if the load/store is
2032 // conditional. For example, turning:
2033 //
2034 // for () { if (c) *P += 1; }
2035 //
2036 // into:
2037 //
2038 // tmp = *P; for () { if (c) tmp +=1; } *P = tmp;
2039 //
2040 // is not safe, because *P may only be valid to access if 'c' is true.
2041 //
2042 // The safety property divides into two parts:
2043 // p1) The memory may not be dereferenceable on entry to the loop. In this
2044 // case, we can't insert the required load in the preheader.
2045 // p2) The memory model does not allow us to insert a store along any dynamic
2046 // path which did not originally have one.
2047 //
2048 // If at least one store is guaranteed to execute, both properties are
2049 // satisfied, and promotion is legal.
2050 //
2051 // This, however, is not a necessary condition. Even if no store/load is
2052 // guaranteed to execute, we can still establish these properties.
2053 // We can establish (p1) by proving that hoisting the load into the preheader
2054 // is safe (i.e. proving dereferenceability on all paths through the loop). We
2055 // can use any access within the alias set to prove dereferenceability,
2056 // since they're all must alias.
2057 //
2058 // There are two ways establish (p2):
2059 // a) Prove the location is thread-local. In this case the memory model
2060 // requirement does not apply, and stores are safe to insert.
2061 // b) Prove a store dominates every exit block. In this case, if an exit
2062 // blocks is reached, the original dynamic path would have taken us through
2063 // the store, so inserting a store into the exit block is safe. Note that this
2064 // is different from the store being guaranteed to execute. For instance,
2065 // if an exception is thrown on the first iteration of the loop, the original
2066 // store is never executed, but the exit blocks are not executed either.
2067
2068 bool DereferenceableInPH = false;
2069 bool StoreIsGuaranteedToExecute = false;
2070 bool LoadIsGuaranteedToExecute = false;
2071 bool FoundLoadToPromote = false;
2072
2073 // Goes from Unknown to either Safe or Unsafe, but can't switch between them.
2074 enum {
2075 StoreSafe,
2076 StoreUnsafe,
2077 StoreSafetyUnknown,
2078 } StoreSafety = StoreSafetyUnknown;
2079
2081
2082 // We start with an alignment of one and try to find instructions that allow
2083 // us to prove better alignment.
2084 Align Alignment;
2085 // Keep track of which types of access we see
2086 bool SawUnorderedAtomic = false;
2087 bool SawNotAtomic = false;
2088 AAMDNodes AATags;
2089
2090 const DataLayout &MDL = Preheader->getDataLayout();
2091
2092 // If there are reads outside the promoted set, then promoting stores is
2093 // definitely not safe.
2094 if (HasReadsOutsideSet)
2095 StoreSafety = StoreUnsafe;
2096
2097 if (StoreSafety == StoreSafetyUnknown && SafetyInfo->anyBlockMayThrow()) {
2098 // If a loop can throw, we have to insert a store along each unwind edge.
2099 // That said, we can't actually make the unwind edge explicit. Therefore,
2100 // we have to prove that the store is dead along the unwind edge. We do
2101 // this by proving that the caller can't have a reference to the object
2102 // after return and thus can't possibly load from the object.
2103 Value *Object = getUnderlyingObject(SomePtr);
2104 if (!isNotVisibleOnUnwindInLoop(Object, CurLoop, DT))
2105 StoreSafety = StoreUnsafe;
2106 }
2107
2108 // Check that all accesses to pointers in the alias set use the same type.
2109 // We cannot (yet) promote a memory location that is loaded and stored in
2110 // different sizes. While we are at it, collect alignment and AA info.
2111 Type *AccessTy = nullptr;
2112 for (Value *ASIV : PointerMustAliases) {
2113 for (Use &U : ASIV->uses()) {
2114 // Ignore instructions that are outside the loop.
2115 Instruction *UI = dyn_cast<Instruction>(U.getUser());
2116 if (!UI || !CurLoop->contains(UI))
2117 continue;
2118
2119 // If there is an non-load/store instruction in the loop, we can't promote
2120 // it.
2121 if (LoadInst *Load = dyn_cast<LoadInst>(UI)) {
2122 if (!Load->isUnordered())
2123 return false;
2124
2125 SawUnorderedAtomic |= Load->isAtomic();
2126 SawNotAtomic |= !Load->isAtomic();
2127 FoundLoadToPromote = true;
2128
2129 Align InstAlignment = Load->getAlign();
2130
2131 if (!LoadIsGuaranteedToExecute)
2132 LoadIsGuaranteedToExecute =
2133 SafetyInfo->isGuaranteedToExecute(*UI, DT, CurLoop);
2134
2135 // Note that proving a load safe to speculate requires proving
2136 // sufficient alignment at the target location. Proving it guaranteed
2137 // to execute does as well. Thus we can increase our guaranteed
2138 // alignment as well.
2139 if (!DereferenceableInPH || (InstAlignment > Alignment))
2141 *Load, DT, TLI, CurLoop, SafetyInfo, ORE,
2142 Preheader->getTerminator(), AC, AllowSpeculation)) {
2143 DereferenceableInPH = true;
2144 Alignment = std::max(Alignment, InstAlignment);
2145 }
2146 } else if (const StoreInst *Store = dyn_cast<StoreInst>(UI)) {
2147 // Stores *of* the pointer are not interesting, only stores *to* the
2148 // pointer.
2149 if (U.getOperandNo() != StoreInst::getPointerOperandIndex())
2150 continue;
2151 if (!Store->isUnordered())
2152 return false;
2153
2154 SawUnorderedAtomic |= Store->isAtomic();
2155 SawNotAtomic |= !Store->isAtomic();
2156
2157 // If the store is guaranteed to execute, both properties are satisfied.
2158 // We may want to check if a store is guaranteed to execute even if we
2159 // already know that promotion is safe, since it may have higher
2160 // alignment than any other guaranteed stores, in which case we can
2161 // raise the alignment on the promoted store.
2162 Align InstAlignment = Store->getAlign();
2163 bool GuaranteedToExecute =
2164 SafetyInfo->isGuaranteedToExecute(*UI, DT, CurLoop);
2165 StoreIsGuaranteedToExecute |= GuaranteedToExecute;
2166 if (GuaranteedToExecute) {
2167 DereferenceableInPH = true;
2168 if (StoreSafety == StoreSafetyUnknown)
2169 StoreSafety = StoreSafe;
2170 Alignment = std::max(Alignment, InstAlignment);
2171 }
2172
2173 // If a store dominates all exit blocks, it is safe to sink.
2174 // As explained above, if an exit block was executed, a dominating
2175 // store must have been executed at least once, so we are not
2176 // introducing stores on paths that did not have them.
2177 // Note that this only looks at explicit exit blocks. If we ever
2178 // start sinking stores into unwind edges (see above), this will break.
2179 if (StoreSafety == StoreSafetyUnknown &&
2180 llvm::all_of(ExitBlocks, [&](BasicBlock *Exit) {
2181 return DT->dominates(Store->getParent(), Exit);
2182 }))
2183 StoreSafety = StoreSafe;
2184
2185 // If the store is not guaranteed to execute, we may still get
2186 // deref info through it.
2187 if (!DereferenceableInPH) {
2188 DereferenceableInPH = isDereferenceableAndAlignedPointer(
2189 Store->getPointerOperand(), Store->getValueOperand()->getType(),
2190 Store->getAlign(),
2191 SimplifyQuery(MDL, TLI, DT, AC, Preheader->getTerminator()));
2192 }
2193 } else
2194 continue; // Not a load or store.
2195
2196 if (!AccessTy)
2197 AccessTy = getLoadStoreType(UI);
2198 else if (AccessTy != getLoadStoreType(UI))
2199 return false;
2200
2201 // Merge the AA tags.
2202 if (LoopUses.empty()) {
2203 // On the first load/store, just take its AA tags.
2204 AATags = UI->getAAMetadata();
2205 } else if (AATags) {
2206 AATags = AATags.merge(UI->getAAMetadata());
2207 }
2208
2209 LoopUses.push_back(UI);
2210 }
2211 }
2212
2213 // If we found both an unordered atomic instruction and a non-atomic memory
2214 // access, bail. We can't blindly promote non-atomic to atomic since we
2215 // might not be able to lower the result. We can't downgrade since that
2216 // would violate memory model. Also, align 0 is an error for atomics.
2217 if (SawUnorderedAtomic && SawNotAtomic)
2218 return false;
2219
2220 // If we're inserting an atomic load in the preheader, we must be able to
2221 // lower it. We're only guaranteed to be able to lower naturally aligned
2222 // atomics.
2223 if (SawUnorderedAtomic && Alignment < MDL.getTypeStoreSize(AccessTy))
2224 return false;
2225
2226 // If we couldn't prove we can hoist the load, bail.
2227 if (!DereferenceableInPH) {
2228 LLVM_DEBUG(dbgs() << "Not promoting: Not dereferenceable in preheader\n");
2229 return false;
2230 }
2231
2232 // We know we can hoist the load, but don't have a guaranteed store.
2233 // Check whether the location is writable and thread-local. If it is, then we
2234 // can insert stores along paths which originally didn't have them without
2235 // violating the memory model.
2236 if (StoreSafety == StoreSafetyUnknown) {
2237 Value *Object = getUnderlyingObject(SomePtr);
2238 bool ExplicitlyDereferenceableOnly;
2239 // The dereferenceability query here is only required to satisfy the
2240 // writable contract, actual dereferenceability has already been proven
2241 // above. As such, we can ignore frees.
2242 if (isWritableObject(Object, ExplicitlyDereferenceableOnly) &&
2243 (!ExplicitlyDereferenceableOnly ||
2244 isDereferenceablePointer(SomePtr, AccessTy, MDL,
2245 /*IgnoreFree=*/true)) &&
2246 isThreadLocalObject(Object, CurLoop, DT, TTI))
2247 StoreSafety = StoreSafe;
2248 }
2249
2250 // If we've still failed to prove we can sink the store, hoist the load
2251 // only, if possible.
2252 if (StoreSafety != StoreSafe && !FoundLoadToPromote)
2253 // If we cannot hoist the load either, give up.
2254 return false;
2255
2256 // Lets do the promotion!
2257 if (StoreSafety == StoreSafe) {
2258 LLVM_DEBUG(dbgs() << "LICM: Promoting load/store of the value: " << *SomePtr
2259 << '\n');
2260 ++NumLoadStorePromoted;
2261 } else {
2262 LLVM_DEBUG(dbgs() << "LICM: Promoting load of the value: " << *SomePtr
2263 << '\n');
2264 ++NumLoadPromoted;
2265 }
2266
2267 ORE->emit([&]() {
2268 return OptimizationRemark(DEBUG_TYPE, "PromoteLoopAccessesToScalar",
2269 LoopUses[0])
2270 << "Moving accesses to memory location out of the loop";
2271 });
2272
2273 // Look at all the loop uses, and try to merge their locations.
2274 std::vector<DebugLoc> LoopUsesLocs;
2275 for (auto U : LoopUses)
2276 LoopUsesLocs.push_back(U->getDebugLoc());
2277 auto DL = DebugLoc::getMergedLocations(LoopUsesLocs);
2278
2279 // We use the SSAUpdater interface to insert phi nodes as required.
2281 SSAUpdater SSA(&NewPHIs);
2282 LoopPromoter Promoter(SomePtr, LoopUses, SSA, ExitBlocks, InsertPts,
2283 MSSAInsertPts, PIC, MSSAU, *LI, DL, Alignment,
2284 SawUnorderedAtomic,
2285 StoreIsGuaranteedToExecute ? AATags : AAMDNodes(),
2286 *SafetyInfo, StoreSafety == StoreSafe);
2287
2288 // Set up the preheader to have a definition of the value. It is the live-out
2289 // value from the preheader that uses in the loop will use.
2290 LoadInst *PreheaderLoad = nullptr;
2291 if (FoundLoadToPromote || !StoreIsGuaranteedToExecute) {
2292 PreheaderLoad =
2293 new LoadInst(AccessTy, SomePtr, SomePtr->getName() + ".promoted",
2294 Preheader->getTerminator()->getIterator());
2295 if (SawUnorderedAtomic)
2296 PreheaderLoad->setOrdering(AtomicOrdering::Unordered);
2297 PreheaderLoad->setAlignment(Alignment);
2298 PreheaderLoad->setDebugLoc(DebugLoc::getDropped());
2299 if (AATags && LoadIsGuaranteedToExecute)
2300 PreheaderLoad->setAAMetadata(AATags);
2301
2302 MemoryAccess *PreheaderLoadMemoryAccess = MSSAU.createMemoryAccessInBB(
2303 PreheaderLoad, nullptr, PreheaderLoad->getParent(), MemorySSA::End);
2304 MemoryUse *NewMemUse = cast<MemoryUse>(PreheaderLoadMemoryAccess);
2305 MSSAU.insertUse(NewMemUse, /*RenameUses=*/true);
2306 SSA.AddAvailableValue(Preheader, PreheaderLoad);
2307 } else {
2308 SSA.AddAvailableValue(Preheader, PoisonValue::get(AccessTy));
2309 }
2310
2311 if (VerifyMemorySSA)
2312 MSSAU.getMemorySSA()->verifyMemorySSA();
2313 // Rewrite all the loads in the loop and remember all the definitions from
2314 // stores in the loop.
2315 Promoter.run(LoopUses);
2316
2317 if (VerifyMemorySSA)
2318 MSSAU.getMemorySSA()->verifyMemorySSA();
2319 // If the SSAUpdater didn't use the load in the preheader, just zap it now.
2320 if (PreheaderLoad && PreheaderLoad->use_empty())
2321 eraseInstruction(*PreheaderLoad, *SafetyInfo, MSSAU);
2322
2323 return true;
2324}
2325
2326static void foreachMemoryAccess(MemorySSA *MSSA, Loop *L,
2327 function_ref<void(Instruction *)> Fn) {
2328 for (const BasicBlock *BB : L->blocks())
2329 if (const auto *Accesses = MSSA->getBlockAccesses(BB))
2330 for (const auto &Access : *Accesses)
2331 if (const auto *MUD = dyn_cast<MemoryUseOrDef>(&Access))
2332 Fn(MUD->getMemoryInst());
2333}
2334
2335// The bool indicates whether there might be reads outside the set, in which
2336// case only loads may be promoted.
2339 BatchAAResults BatchAA(*AA);
2340 AliasSetTracker AST(BatchAA);
2341
2342 auto IsPotentiallyPromotable = [L](const Instruction *I) {
2343 if (const auto *SI = dyn_cast<StoreInst>(I)) {
2344 const Value *PtrOp = SI->getPointerOperand();
2345 return !isa<ConstantData>(PtrOp) && L->isLoopInvariant(PtrOp);
2346 }
2347 if (const auto *LI = dyn_cast<LoadInst>(I)) {
2348 const Value *PtrOp = LI->getPointerOperand();
2349 return !isa<ConstantData>(PtrOp) && L->isLoopInvariant(PtrOp);
2350 }
2351 return false;
2352 };
2353
2354 // Populate AST with potentially promotable accesses.
2355 SmallPtrSet<Value *, 16> AttemptingPromotion;
2356 foreachMemoryAccess(MSSA, L, [&](Instruction *I) {
2357 if (IsPotentiallyPromotable(I)) {
2358 AttemptingPromotion.insert(I);
2359 AST.add(I);
2360 }
2361 });
2362
2363 // We're only interested in must-alias sets that contain a mod.
2365 for (AliasSet &AS : AST)
2366 if (!AS.isForwardingAliasSet() && AS.isMod() && AS.isMustAlias())
2367 Sets.push_back({&AS, false});
2368
2369 if (Sets.empty())
2370 return {}; // Nothing to promote...
2371
2372 // Discard any sets for which there is an aliasing non-promotable access.
2373 foreachMemoryAccess(MSSA, L, [&](Instruction *I) {
2374 if (AttemptingPromotion.contains(I))
2375 return;
2376
2378 ModRefInfo MR = Pair.getPointer()->aliasesUnknownInst(I, BatchAA);
2379 // Cannot promote if there are writes outside the set.
2380 if (isModSet(MR))
2381 return true;
2382 if (isRefSet(MR)) {
2383 // Remember reads outside the set.
2384 Pair.setInt(true);
2385 // If this is a mod-only set and there are reads outside the set,
2386 // we will not be able to promote, so bail out early.
2387 return !Pair.getPointer()->isRef();
2388 }
2389 return false;
2390 });
2391 });
2392
2394 for (auto [Set, HasReadsOutsideSet] : Sets) {
2395 SmallSetVector<Value *, 8> PointerMustAliases;
2396 for (const auto &MemLoc : *Set)
2397 PointerMustAliases.insert(const_cast<Value *>(MemLoc.Ptr));
2398 Result.emplace_back(std::move(PointerMustAliases), HasReadsOutsideSet);
2399 }
2400
2401 return Result;
2402}
2403
2404// For a given store instruction or writeonly call instruction, this function
2405// checks that there are no read or writes that conflict with the memory
2406// access in the instruction
2408 AAResults *AA, Loop *CurLoop,
2409 SinkAndHoistLICMFlags &Flags) {
2411 // If there are more accesses than the Promotion cap, then give up as we're
2412 // not walking a list that long.
2413 if (Flags.tooManyMemoryAccesses())
2414 return false;
2415
2416 auto *IMD = MSSA->getMemoryAccess(I);
2417 BatchAAResults BAA(*AA);
2418 auto *Source = getClobberingMemoryAccess(*MSSA, BAA, Flags, IMD);
2419 // Make sure there are no clobbers inside the loop.
2420 if (!MSSA->isLiveOnEntryDef(Source) && CurLoop->contains(Source->getBlock()))
2421 return false;
2422
2423 // If there are interfering Uses don't move this store.
2424 // TODO: Cache set of Uses on the first walk in runOnLoop, update when
2425 // moving accesses. Can also extend to dominating uses.
2426 for (auto *BB : CurLoop->getBlocks()) {
2427 auto *Accesses = MSSA->getBlockAccesses(BB);
2428 if (!Accesses)
2429 continue;
2430 for (const auto &MA : *Accesses) {
2431 // Accesses are ordered. If we find one that I dominates we can stop.
2432 if (!Flags.getIsSink() && MSSA->dominates(IMD, &MA))
2433 break;
2434
2435 if (const auto *MemUseOrDef = dyn_cast<MemoryUseOrDef>(&MA)) {
2436 // Skip unrelated accesses.
2437 if (isNoModRef(BAA.getModRefInfo(MemUseOrDef->getMemoryInst(), I)))
2438 continue;
2439
2440 return false;
2441 }
2442 }
2443 }
2444 return true;
2445}
2446
2448 Loop *CurLoop, Instruction &I,
2449 SinkAndHoistLICMFlags &Flags,
2450 bool InvariantGroup) {
2451 // For hoisting, use the walker to determine safety
2452 if (!Flags.getIsSink()) {
2453 // If hoisting an invariant group, we only need to check that there
2454 // is no store to the loaded pointer between the start of the loop,
2455 // and the load (since all values must be the same).
2456
2457 // This can be checked in two conditions:
2458 // 1) if the memoryaccess is outside the loop
2459 // 2) the earliest access is at the loop header,
2460 // if the memory loaded is the phi node
2461
2462 BatchAAResults BAA(MSSA->getAA());
2463 MemoryAccess *Source = getClobberingMemoryAccess(*MSSA, BAA, Flags, MU);
2464 return !MSSA->isLiveOnEntryDef(Source) &&
2465 CurLoop->contains(Source->getBlock()) &&
2466 !(InvariantGroup && Source->getBlock() == CurLoop->getHeader() && isa<MemoryPhi>(Source));
2467 }
2468
2469 // For sinking, we'd need to check all Defs below this use. The getClobbering
2470 // call will look on the backedge of the loop, but will check aliasing with
2471 // the instructions on the previous iteration.
2472 // For example:
2473 // for (i ... )
2474 // load a[i] ( Use (LoE)
2475 // store a[i] ( 1 = Def (2), with 2 = Phi for the loop.
2476 // i++;
2477 // The load sees no clobbering inside the loop, as the backedge alias check
2478 // does phi translation, and will check aliasing against store a[i-1].
2479 // However sinking the load outside the loop, below the store is incorrect.
2480
2481 // For now, only sink if there are no Defs in the loop, and the existing ones
2482 // precede the use and are in the same block.
2483 // FIXME: Increase precision: Safe to sink if Use post dominates the Def;
2484 // needs PostDominatorTreeAnalysis.
2485 // FIXME: More precise: no Defs that alias this Use.
2486 if (Flags.tooManyMemoryAccesses())
2487 return true;
2488 for (auto *BB : CurLoop->getBlocks())
2489 if (pointerInvalidatedByBlock(*BB, *MSSA, *MU))
2490 return true;
2491 // When sinking, the source block may not be part of the loop so check it.
2492 if (!CurLoop->contains(&I))
2493 return pointerInvalidatedByBlock(*I.getParent(), *MSSA, *MU);
2494
2495 return false;
2496}
2497
2499 if (const auto *Accesses = MSSA.getBlockDefs(&BB))
2500 for (const auto &MA : *Accesses)
2501 if (const auto *MD = dyn_cast<MemoryDef>(&MA))
2502 if (MU.getBlock() != MD->getBlock() || !MSSA.locallyDominates(MD, &MU))
2503 return true;
2504 return false;
2505}
2506
2507/// Try to simplify things like (A < INV_1 AND icmp A < INV_2) into (A <
2508/// min(INV_1, INV_2)), if INV_1 and INV_2 are both loop invariants and their
2509/// minimun can be computed outside of loop, and X is not a loop-invariant.
2510static bool hoistMinMax(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo,
2511 MemorySSAUpdater &MSSAU) {
2512 bool Inverse = false;
2513 using namespace PatternMatch;
2514 Value *Cond1, *Cond2;
2515 if (match(&I, m_LogicalOr(m_Value(Cond1), m_Value(Cond2)))) {
2516 Inverse = true;
2517 } else if (match(&I, m_LogicalAnd(m_Value(Cond1), m_Value(Cond2)))) {
2518 // Do nothing
2519 } else
2520 return false;
2521
2522 auto MatchICmpAgainstInvariant = [&](Value *C, CmpPredicate &P, Value *&LHS,
2523 Value *&RHS) {
2524 if (!match(C, m_OneUse(m_ICmp(P, m_Value(LHS), m_Value(RHS)))))
2525 return false;
2526 if (!LHS->getType()->isIntegerTy())
2527 return false;
2529 return false;
2530 if (L.isLoopInvariant(LHS)) {
2531 std::swap(LHS, RHS);
2533 }
2534 if (L.isLoopInvariant(LHS) || !L.isLoopInvariant(RHS))
2535 return false;
2536 if (Inverse)
2538 return true;
2539 };
2540 CmpPredicate P1, P2;
2541 Value *LHS1, *LHS2, *RHS1, *RHS2;
2542 if (!MatchICmpAgainstInvariant(Cond1, P1, LHS1, RHS1) ||
2543 !MatchICmpAgainstInvariant(Cond2, P2, LHS2, RHS2))
2544 return false;
2545 auto MatchingPred = CmpPredicate::getMatching(P1, P2);
2546 if (!MatchingPred || LHS1 != LHS2)
2547 return false;
2548
2549 // Everything is fine, we can do the transform.
2550 bool UseMin = ICmpInst::isLT(*MatchingPred) || ICmpInst::isLE(*MatchingPred);
2551 assert(
2552 (UseMin || ICmpInst::isGT(*MatchingPred) ||
2553 ICmpInst::isGE(*MatchingPred)) &&
2554 "Relational predicate is either less (or equal) or greater (or equal)!");
2555 Intrinsic::ID id = ICmpInst::isSigned(*MatchingPred)
2556 ? (UseMin ? Intrinsic::smin : Intrinsic::smax)
2557 : (UseMin ? Intrinsic::umin : Intrinsic::umax);
2558 auto *Preheader = L.getLoopPreheader();
2559 assert(Preheader && "Loop is not in simplify form?");
2560 IRBuilder<> Builder(Preheader->getTerminator());
2561 // We are about to create a new guaranteed use for RHS2 which might not exist
2562 // before (if it was a non-taken input of logical and/or instruction). If it
2563 // was poison, we need to freeze it. Note that no new use for LHS and RHS1 are
2564 // introduced, so they don't need this.
2565 if (isa<SelectInst>(I))
2566 RHS2 = Builder.CreateFreeze(RHS2, RHS2->getName() + ".fr");
2567 Value *NewRHS = Builder.CreateBinaryIntrinsic(
2568 id, RHS1, RHS2, nullptr,
2569 StringRef("invariant.") +
2570 (ICmpInst::isSigned(*MatchingPred) ? "s" : "u") +
2571 (UseMin ? "min" : "max"));
2572 Builder.SetInsertPoint(&I);
2573 ICmpInst::Predicate P = *MatchingPred;
2574 if (Inverse)
2576 Value *NewCond = Builder.CreateICmp(P, LHS1, NewRHS);
2577 NewCond->takeName(&I);
2578 I.replaceAllUsesWith(NewCond);
2579 eraseInstruction(I, SafetyInfo, MSSAU);
2580 Instruction &CondI1 = *cast<Instruction>(Cond1);
2581 Instruction &CondI2 = *cast<Instruction>(Cond2);
2582 salvageDebugInfo(CondI1);
2583 salvageDebugInfo(CondI2);
2584 eraseInstruction(CondI1, SafetyInfo, MSSAU);
2585 eraseInstruction(CondI2, SafetyInfo, MSSAU);
2586 return true;
2587}
2588
2589/// Reassociate gep (gep ptr, idx1), idx2 to gep (gep ptr, idx2), idx1 if
2590/// this allows hoisting the inner GEP.
2591static bool hoistGEP(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo,
2593 DominatorTree *DT) {
2595 if (!GEP)
2596 return false;
2597
2598 // Do not try to hoist a constant GEP out of the loop via reassociation.
2599 // Constant GEPs can often be folded into addressing modes, and reassociating
2600 // them may inhibit CSE of a common base.
2601 if (GEP->hasAllConstantIndices())
2602 return false;
2603
2604 auto *Src = dyn_cast<GetElementPtrInst>(GEP->getPointerOperand());
2605 if (!Src || !Src->hasOneUse() || !L.contains(Src))
2606 return false;
2607
2608 Value *SrcPtr = Src->getPointerOperand();
2609 auto LoopInvariant = [&](Value *V) { return L.isLoopInvariant(V); };
2610 if (!L.isLoopInvariant(SrcPtr) || !all_of(GEP->indices(), LoopInvariant))
2611 return false;
2612
2613 // This can only happen if !AllowSpeculation, otherwise this would already be
2614 // handled.
2615 // FIXME: Should we respect AllowSpeculation in these reassociation folds?
2616 // The flag exists to prevent metadata dropping, which is not relevant here.
2617 if (all_of(Src->indices(), LoopInvariant))
2618 return false;
2619
2620 // The swapped GEPs are inbounds if both original GEPs are inbounds
2621 // and the sign of the offsets is the same. For simplicity, only
2622 // handle both offsets being non-negative.
2623 const DataLayout &DL = GEP->getDataLayout();
2624 auto NonNegative = [&](Value *V) {
2625 return isKnownNonNegative(V, SimplifyQuery(DL, DT, AC, GEP));
2626 };
2627 bool IsInBounds = Src->isInBounds() && GEP->isInBounds() &&
2628 all_of(Src->indices(), NonNegative) &&
2629 all_of(GEP->indices(), NonNegative);
2630
2631 BasicBlock *Preheader = L.getLoopPreheader();
2632 IRBuilder<> Builder(Preheader->getTerminator());
2633 Value *NewSrc = Builder.CreateGEP(GEP->getSourceElementType(), SrcPtr,
2634 SmallVector<Value *>(GEP->indices()),
2635 "invariant.gep", IsInBounds);
2636 Builder.SetInsertPoint(GEP);
2637 Value *NewGEP = Builder.CreateGEP(Src->getSourceElementType(), NewSrc,
2638 SmallVector<Value *>(Src->indices()), "gep",
2639 IsInBounds);
2640 GEP->replaceAllUsesWith(NewGEP);
2641 eraseInstruction(*GEP, SafetyInfo, MSSAU);
2642 salvageDebugInfo(*Src);
2643 eraseInstruction(*Src, SafetyInfo, MSSAU);
2644 return true;
2645}
2646
2647/// Try to turn things like "LV + C1 < C2" into "LV < C2 - C1". Here
2648/// C1 and C2 are loop invariants and LV is a loop-variant.
2649static bool hoistAdd(ICmpInst::Predicate Pred, Value *VariantLHS,
2650 Value *InvariantRHS, ICmpInst &ICmp, Loop &L,
2651 ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU,
2652 AssumptionCache *AC, DominatorTree *DT) {
2653 assert(!L.isLoopInvariant(VariantLHS) && "Precondition.");
2654 assert(L.isLoopInvariant(InvariantRHS) && "Precondition.");
2655
2656 bool IsSigned = ICmpInst::isSigned(Pred);
2657
2658 // Try to represent VariantLHS as sum of invariant and variant operands.
2659 using namespace PatternMatch;
2660 Value *VariantOp, *InvariantOp;
2661 if (IsSigned && !match(VariantLHS, m_NSWAddLike(m_Value(VariantOp),
2662 m_Value(InvariantOp))))
2663 return false;
2664 if (!IsSigned && !match(VariantLHS, m_NUWAddLike(m_Value(VariantOp),
2665 m_Value(InvariantOp))))
2666 return false;
2667
2668 // LHS itself is a loop-variant, try to represent it in the form:
2669 // "VariantOp + InvariantOp". If it is possible, then we can reassociate.
2670 if (L.isLoopInvariant(VariantOp))
2671 std::swap(VariantOp, InvariantOp);
2672 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2673 return false;
2674
2675 // In order to turn "LV + C1 < C2" into "LV < C2 - C1", we need to be able to
2676 // freely move values from left side of inequality to right side (just as in
2677 // normal linear arithmetics). Overflows make things much more complicated, so
2678 // we want to avoid this.
2679 auto &DL = L.getHeader()->getDataLayout();
2680 SimplifyQuery SQ(DL, DT, AC, &ICmp);
2681 if (IsSigned && computeOverflowForSignedSub(InvariantRHS, InvariantOp, SQ) !=
2683 return false;
2684 if (!IsSigned &&
2685 computeOverflowForUnsignedSub(InvariantRHS, InvariantOp, SQ) !=
2687 return false;
2688 auto *Preheader = L.getLoopPreheader();
2689 assert(Preheader && "Loop is not in simplify form?");
2690 IRBuilder<> Builder(Preheader->getTerminator());
2691 Value *NewCmpOp =
2692 Builder.CreateSub(InvariantRHS, InvariantOp, "invariant.op",
2693 /*HasNUW*/ !IsSigned, /*HasNSW*/ IsSigned);
2694 ICmp.setPredicate(Pred);
2695 ICmp.setOperand(0, VariantOp);
2696 ICmp.setOperand(1, NewCmpOp);
2697 // The new LHS is a different value, so a samesign (or any other
2698 // poison-generating) flag asserted about the old operands may no longer hold.
2700
2701 Instruction &DeadI = cast<Instruction>(*VariantLHS);
2702 salvageDebugInfo(DeadI);
2703 eraseInstruction(DeadI, SafetyInfo, MSSAU);
2704 return true;
2705}
2706
2707/// Try to reassociate and hoist the following two patterns:
2708/// LV - C1 < C2 --> LV < C1 + C2,
2709/// C1 - LV < C2 --> LV > C1 - C2.
2710static bool hoistSub(ICmpInst::Predicate Pred, Value *VariantLHS,
2711 Value *InvariantRHS, ICmpInst &ICmp, Loop &L,
2712 ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU,
2713 AssumptionCache *AC, DominatorTree *DT) {
2714 assert(!L.isLoopInvariant(VariantLHS) && "Precondition.");
2715 assert(L.isLoopInvariant(InvariantRHS) && "Precondition.");
2716
2717 bool IsSigned = ICmpInst::isSigned(Pred);
2718
2719 // Try to represent VariantLHS as sum of invariant and variant operands.
2720 using namespace PatternMatch;
2721 Value *VariantOp, *InvariantOp;
2722 if (IsSigned &&
2723 !match(VariantLHS, m_NSWSub(m_Value(VariantOp), m_Value(InvariantOp))))
2724 return false;
2725 if (!IsSigned &&
2726 !match(VariantLHS, m_NUWSub(m_Value(VariantOp), m_Value(InvariantOp))))
2727 return false;
2728
2729 bool VariantSubtracted = false;
2730 // LHS itself is a loop-variant, try to represent it in the form:
2731 // "VariantOp + InvariantOp". If it is possible, then we can reassociate. If
2732 // the variant operand goes with minus, we use a slightly different scheme.
2733 if (L.isLoopInvariant(VariantOp)) {
2734 std::swap(VariantOp, InvariantOp);
2735 VariantSubtracted = true;
2736 Pred = ICmpInst::getSwappedPredicate(Pred);
2737 }
2738 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2739 return false;
2740
2741 // In order to turn "LV - C1 < C2" into "LV < C2 + C1", we need to be able to
2742 // freely move values from left side of inequality to right side (just as in
2743 // normal linear arithmetics). Overflows make things much more complicated, so
2744 // we want to avoid this. Likewise, for "C1 - LV < C2" we need to prove that
2745 // "C1 - C2" does not overflow.
2746 auto &DL = L.getHeader()->getDataLayout();
2747 SimplifyQuery SQ(DL, DT, AC, &ICmp);
2748 if (VariantSubtracted && IsSigned) {
2749 // C1 - LV < C2 --> LV > C1 - C2
2750 if (computeOverflowForSignedSub(InvariantOp, InvariantRHS, SQ) !=
2752 return false;
2753 } else if (VariantSubtracted && !IsSigned) {
2754 // C1 - LV < C2 --> LV > C1 - C2
2755 if (computeOverflowForUnsignedSub(InvariantOp, InvariantRHS, SQ) !=
2757 return false;
2758 } else if (!VariantSubtracted && IsSigned) {
2759 // LV - C1 < C2 --> LV < C1 + C2
2760 if (computeOverflowForSignedAdd(InvariantOp, InvariantRHS, SQ) !=
2762 return false;
2763 } else { // !VariantSubtracted && !IsSigned
2764 // LV - C1 < C2 --> LV < C1 + C2
2765 if (computeOverflowForUnsignedAdd(InvariantOp, InvariantRHS, SQ) !=
2767 return false;
2768 }
2769 auto *Preheader = L.getLoopPreheader();
2770 assert(Preheader && "Loop is not in simplify form?");
2771 IRBuilder<> Builder(Preheader->getTerminator());
2772 Value *NewCmpOp =
2773 VariantSubtracted
2774 ? Builder.CreateSub(InvariantOp, InvariantRHS, "invariant.op",
2775 /*HasNUW*/ !IsSigned, /*HasNSW*/ IsSigned)
2776 : Builder.CreateAdd(InvariantOp, InvariantRHS, "invariant.op",
2777 /*HasNUW*/ !IsSigned, /*HasNSW*/ IsSigned);
2778 ICmp.setPredicate(Pred);
2779 ICmp.setOperand(0, VariantOp);
2780 ICmp.setOperand(1, NewCmpOp);
2781 // The new LHS is a different value, so a samesign (or any other
2782 // poison-generating) flag asserted about the old operands may no longer hold.
2784
2785 Instruction &DeadI = cast<Instruction>(*VariantLHS);
2786 salvageDebugInfo(DeadI);
2787 eraseInstruction(DeadI, SafetyInfo, MSSAU);
2788 return true;
2789}
2790
2791/// Reassociate and hoist add/sub expressions.
2792static bool hoistAddSub(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo,
2794 DominatorTree *DT) {
2795 using namespace PatternMatch;
2796 CmpPredicate Pred;
2797 Value *LHS, *RHS;
2798 if (!match(&I, m_ICmp(Pred, m_Value(LHS), m_Value(RHS))))
2799 return false;
2800
2801 // Put variant operand to LHS position.
2802 if (L.isLoopInvariant(LHS)) {
2803 std::swap(LHS, RHS);
2804 Pred = ICmpInst::getSwappedPredicate(Pred);
2805 }
2806 // We want to delete the initial operation after reassociation, so only do it
2807 // if it has no other uses.
2808 if (L.isLoopInvariant(LHS) || !L.isLoopInvariant(RHS) || !LHS->hasOneUse())
2809 return false;
2810
2811 // TODO: We could go with smarter context, taking common dominator of all I's
2812 // users instead of I itself.
2813 if (hoistAdd(Pred, LHS, RHS, cast<ICmpInst>(I), L, SafetyInfo, MSSAU, AC, DT))
2814 return true;
2815
2816 if (hoistSub(Pred, LHS, RHS, cast<ICmpInst>(I), L, SafetyInfo, MSSAU, AC, DT))
2817 return true;
2818
2819 return false;
2820}
2821
2822static bool isReassociableOp(Instruction *I, unsigned IntOpcode,
2823 unsigned FPOpcode) {
2824 if (I->getOpcode() == IntOpcode)
2825 return true;
2826 if (I->getOpcode() == FPOpcode && I->hasAllowReassoc() &&
2827 I->hasNoSignedZeros())
2828 return true;
2829 return false;
2830}
2831
2832/// Try to reassociate expressions like ((A1 * B1) + (A2 * B2) + ...) * C where
2833/// A1, A2, ... and C are loop invariants into expressions like
2834/// ((A1 * C * B1) + (A2 * C * B2) + ...) and hoist the (A1 * C), (A2 * C), ...
2835/// invariant expressions. This functions returns true only if any hoisting has
2836/// actually occurred.
2838 ICFLoopSafetyInfo &SafetyInfo,
2840 DominatorTree *DT) {
2841 if (!isReassociableOp(&I, Instruction::Mul, Instruction::FMul))
2842 return false;
2843 Value *VariantOp = I.getOperand(0);
2844 Value *InvariantOp = I.getOperand(1);
2845 if (L.isLoopInvariant(VariantOp))
2846 std::swap(VariantOp, InvariantOp);
2847 if (L.isLoopInvariant(VariantOp) || !L.isLoopInvariant(InvariantOp))
2848 return false;
2849 Value *Factor = InvariantOp;
2850
2851 // First, we need to make sure we should do the transformation.
2852 SmallVector<Use *> Changes;
2855 if (BinaryOperator *VariantBinOp = dyn_cast<BinaryOperator>(VariantOp))
2856 Worklist.push_back(VariantBinOp);
2857 while (!Worklist.empty()) {
2858 BinaryOperator *BO = Worklist.pop_back_val();
2859 if (!BO->hasOneUse())
2860 return false;
2861 if (isReassociableOp(BO, Instruction::Add, Instruction::FAdd) &&
2864 Worklist.push_back(cast<BinaryOperator>(BO->getOperand(0)));
2865 Worklist.push_back(cast<BinaryOperator>(BO->getOperand(1)));
2866 Adds.push_back(BO);
2867 continue;
2868 }
2869 if (!isReassociableOp(BO, Instruction::Mul, Instruction::FMul) ||
2870 L.isLoopInvariant(BO))
2871 return false;
2872 Use &U0 = BO->getOperandUse(0);
2873 Use &U1 = BO->getOperandUse(1);
2874 if (L.isLoopInvariant(U0))
2875 Changes.push_back(&U0);
2876 else if (L.isLoopInvariant(U1))
2877 Changes.push_back(&U1);
2878 else
2879 return false;
2880 unsigned Limit = I.getType()->isIntOrIntVectorTy()
2883 if (Changes.size() > Limit)
2884 return false;
2885 }
2886 if (Changes.empty())
2887 return false;
2888
2889 // Drop the poison flags for any adds we looked through.
2890 if (I.getType()->isIntOrIntVectorTy()) {
2891 for (auto *Add : Adds)
2892 Add->dropPoisonGeneratingFlags();
2893 }
2894
2895 // We know we should do it so let's do the transformation.
2896 auto *Preheader = L.getLoopPreheader();
2897 assert(Preheader && "Loop is not in simplify form?");
2898 IRBuilder<> Builder(Preheader->getTerminator());
2899 for (auto *U : Changes) {
2900 assert(L.isLoopInvariant(U->get()));
2901 auto *Ins = cast<BinaryOperator>(U->getUser());
2902 Value *Mul;
2903 if (I.getType()->isIntOrIntVectorTy()) {
2904 Mul = Builder.CreateMul(U->get(), Factor, "factor.op.mul");
2905 // Drop the poison flags on the original multiply.
2906 Ins->dropPoisonGeneratingFlags();
2907 } else
2908 Mul = Builder.CreateFMulFMF(U->get(), Factor, Ins, "factor.op.fmul");
2909
2910 // Rewrite the reassociable instruction.
2911 unsigned OpIdx = U->getOperandNo();
2912 auto *LHS = OpIdx == 0 ? Mul : Ins->getOperand(0);
2913 auto *RHS = OpIdx == 1 ? Mul : Ins->getOperand(1);
2914 auto *NewBO =
2915 BinaryOperator::Create(Ins->getOpcode(), LHS, RHS,
2916 Ins->getName() + ".reass", Ins->getIterator());
2917 NewBO->setDebugLoc(DebugLoc::getDropped());
2918 NewBO->copyIRFlags(Ins);
2919 if (VariantOp == Ins)
2920 VariantOp = NewBO;
2921 Ins->replaceAllUsesWith(NewBO);
2922 eraseInstruction(*Ins, SafetyInfo, MSSAU);
2923 }
2924
2925 I.replaceAllUsesWith(VariantOp);
2926 eraseInstruction(I, SafetyInfo, MSSAU);
2927 return true;
2928}
2929
2930/// Reassociate associative binary expressions of the form
2931///
2932/// 1. "(LV op C1) op C2" ==> "LV op (C1 op C2)"
2933/// 2. "(C1 op LV) op C2" ==> "LV op (C1 op C2)"
2934/// 3. "C2 op (C1 op LV)" ==> "LV op (C1 op C2)"
2935/// 4. "C2 op (LV op C1)" ==> "LV op (C1 op C2)"
2936///
2937/// where op is an associative BinOp, LV is a loop variant, and C1 and C2 are
2938/// loop invariants that we want to hoist, noting that associativity implies
2939/// commutativity.
2941 ICFLoopSafetyInfo &SafetyInfo,
2943 DominatorTree *DT) {
2944 auto *BO = dyn_cast<BinaryOperator>(&I);
2945 if (!BO || !BO->isAssociative())
2946 return false;
2947
2948 Instruction::BinaryOps Opcode = BO->getOpcode();
2949 bool LVInRHS = L.isLoopInvariant(BO->getOperand(0));
2950 auto *BO0 = dyn_cast<BinaryOperator>(BO->getOperand(LVInRHS));
2951 if (!BO0 || BO0->getOpcode() != Opcode || !BO0->isAssociative() ||
2952 BO0->hasNUsesOrMore(BO0->getType()->isIntegerTy() ? 2 : 3))
2953 return false;
2954
2955 Value *LV = BO0->getOperand(0);
2956 Value *C1 = BO0->getOperand(1);
2957 Value *C2 = BO->getOperand(!LVInRHS);
2958
2959 assert(BO->isCommutative() && BO0->isCommutative() &&
2960 "Associativity implies commutativity");
2961 if (L.isLoopInvariant(LV) && !L.isLoopInvariant(C1))
2962 std::swap(LV, C1);
2963 if (L.isLoopInvariant(LV) || !L.isLoopInvariant(C1) || !L.isLoopInvariant(C2))
2964 return false;
2965
2966 auto *Preheader = L.getLoopPreheader();
2967 assert(Preheader && "Loop is not in simplify form?");
2968
2969 IRBuilder<> Builder(Preheader->getTerminator());
2970 auto *Inv = Builder.CreateBinOp(Opcode, C1, C2, "invariant.op");
2971
2972 auto *NewBO = BinaryOperator::Create(
2973 Opcode, LV, Inv, BO->getName() + ".reass", BO->getIterator());
2974 NewBO->setDebugLoc(DebugLoc::getDropped());
2975
2976 if (Opcode == Instruction::FAdd || Opcode == Instruction::FMul) {
2977 // Intersect FMF flags for FADD and FMUL.
2978 FastMathFlags Intersect = BO->getFastMathFlags() & BO0->getFastMathFlags();
2979 if (auto *I = dyn_cast<Instruction>(Inv))
2980 I->setFastMathFlags(Intersect);
2981 NewBO->setFastMathFlags(Intersect);
2982 } else {
2983 OverflowTracking Flags;
2984 Flags.AllKnownNonNegative = false;
2985 Flags.AllKnownNonZero = false;
2986 Flags.mergeFlags(*BO);
2987 Flags.mergeFlags(*BO0);
2988 // If `Inv` was not constant-folded, a new Instruction has been created.
2989 if (auto *I = dyn_cast<Instruction>(Inv))
2990 Flags.applyFlags(*I);
2991 Flags.applyFlags(*NewBO);
2992 }
2993
2994 BO->replaceAllUsesWith(NewBO);
2995 eraseInstruction(*BO, SafetyInfo, MSSAU);
2996
2997 // (LV op C1) might not be erased if it has more uses than the one we just
2998 // replaced.
2999 if (BO0->use_empty()) {
3000 salvageDebugInfo(*BO0);
3001 eraseInstruction(*BO0, SafetyInfo, MSSAU);
3002 }
3003
3004 return true;
3005}
3006
3007/// Reassociate add/sub expressions of the form:
3008///
3009/// 1. "(LV + C1) - C2" ==> "LV + (C1 - C2)"
3010/// 2. "(LV - C1) - C2" ==> "LV - (C1 + C2)"
3011/// 3. "(LV - C1) + C2" ==> "LV + (C2 - C1)"
3012///
3013/// where LV is a loop variant, and C1 and C2 are loop invariants.
3014/// Sub is not associative, but these algebraic identities allow hoisting
3015/// invariant computations out of the loop.
3017 ICFLoopSafetyInfo &SafetyInfo,
3019 DominatorTree *DT) {
3020 using namespace PatternMatch;
3021
3022 Instruction *BO;
3023 Value *LV, *C1, *C2;
3024 Instruction::BinaryOps InvOp, ResultOp;
3025
3026 // Try to match one of three reassociation patterns involving sub.
3027 //
3028 // 1. (LV + C1) - C2 ==> LV + (C1 - C2)
3029 // 2. (LV - C1) - C2 ==> LV - (C1 + C2)
3030 // 3. (LV - C1) + C2 ==> LV + (C2 - C1)
3031 // ^ ^
3032 // \ \___ InvOp
3033 // \
3034 // \____ ResultOp
3035 //
3036 if (match(&I,
3038 m_Value(C2)))) {
3039 // Case 1.
3040 //
3041 // Depending on which of the addition is invariant, we might need to swap
3042 // the arguments
3043 if (L.isLoopInvariant(LV) && !L.isLoopInvariant(C1))
3044 std::swap(LV, C1);
3045 InvOp = Instruction::Sub;
3046 ResultOp = Instruction::Add;
3047 } else if (match(&I, m_Sub(m_OneUse(m_Instruction(
3048 BO, m_Sub(m_Value(LV), m_Value(C1)))),
3049 m_Value(C2)))) {
3050 // Case 2.
3051 InvOp = Instruction::Add;
3052 ResultOp = Instruction::Sub;
3053 } else if (match(&I, m_c_Add(m_OneUse(m_Instruction(
3054 BO, m_Sub(m_Value(LV), m_Value(C1)))),
3055 m_Value(C2)))) {
3056 // Case 3.
3057 //
3058 // We use (C2 - C1) as the invariant as opposed to case 1, but instead of
3059 // adding a special case in invariant creation, we can just swap the
3060 // operands here.
3061 std::swap(C1, C2);
3062 InvOp = Instruction::Sub;
3063 ResultOp = Instruction::Add;
3064 } else {
3065 return false;
3066 }
3067
3068 if (L.isLoopInvariant(LV) || !L.isLoopInvariant(C1) || !L.isLoopInvariant(C2))
3069 return false;
3070
3071 auto *Preheader = L.getLoopPreheader();
3072 assert(Preheader && "Loop is not in simplify form?");
3073
3074 IRBuilder<> Builder(Preheader->getTerminator());
3075 auto *Inv = Builder.CreateBinOp(InvOp, C1, C2, "invariant.op");
3076
3077 auto *NewBO = BinaryOperator::Create(ResultOp, LV, Inv,
3078 I.getName() + ".reass", I.getIterator());
3079 NewBO->setDebugLoc(DebugLoc::getDropped());
3080
3081 // No overflow flags are set on the new instructions -- reassociation
3082 // involving sub does not preserve nsw/nuw in general.
3083
3084 I.replaceAllUsesWith(NewBO);
3085 eraseInstruction(I, SafetyInfo, MSSAU);
3086
3087 salvageDebugInfo(*BO);
3088 eraseInstruction(*BO, SafetyInfo, MSSAU);
3089
3090 return true;
3091}
3092
3094 ICFLoopSafetyInfo &SafetyInfo,
3096 DominatorTree *DT) {
3097 // Optimize complex patterns, such as (x < INV1 && x < INV2), turning them
3098 // into (x < min(INV1, INV2)), and hoisting the invariant part of this
3099 // expression out of the loop.
3100 if (hoistMinMax(I, L, SafetyInfo, MSSAU)) {
3101 ++NumHoisted;
3102 ++NumMinMaxHoisted;
3103 return true;
3104 }
3105
3106 // Try to hoist GEPs by reassociation.
3107 if (hoistGEP(I, L, SafetyInfo, MSSAU, AC, DT)) {
3108 ++NumHoisted;
3109 ++NumGEPsHoisted;
3110 return true;
3111 }
3112
3113 // Try to hoist add/sub's by reassociation.
3114 if (hoistAddSub(I, L, SafetyInfo, MSSAU, AC, DT)) {
3115 ++NumHoisted;
3116 ++NumAddSubHoisted;
3117 return true;
3118 }
3119
3120 bool IsInt = I.getType()->isIntOrIntVectorTy();
3121 if (hoistMulAddAssociation(I, L, SafetyInfo, MSSAU, AC, DT)) {
3122 ++NumHoisted;
3123 if (IsInt)
3124 ++NumIntAssociationsHoisted;
3125 else
3126 ++NumFPAssociationsHoisted;
3127 return true;
3128 }
3129
3130 if (hoistBOAssociation(I, L, SafetyInfo, MSSAU, AC, DT)) {
3131 ++NumHoisted;
3132 ++NumBOAssociationsHoisted;
3133 return true;
3134 }
3135
3136 if (hoistSubAddAssociation(I, L, SafetyInfo, MSSAU, AC, DT)) {
3137 ++NumHoisted;
3138 ++NumBOAssociationsHoisted;
3139 return true;
3140 }
3141
3142 return false;
3143}
3144
3145/// Little predicate that returns true if the specified basic block is in
3146/// a subloop of the current one, not the current one itself.
3147///
3148static bool inSubLoop(BasicBlock *BB, Loop *CurLoop, LoopInfo *LI) {
3149 assert(CurLoop->contains(BB) && "Only valid if BB is IN the loop");
3150 return LI->getLoopFor(BB) != CurLoop;
3151}
for(const MachineOperand &MO :llvm::drop_begin(OldMI.operands(), Desc.getNumOperands()))
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static msgpack::DocNode getNode(msgpack::DocNode DN, msgpack::Type Type, MCValue Val)
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
This file contains the declarations for the subclasses of Constant, which represent the different fla...
DXIL Forward Handle Accesses
DXIL Resource Access
early cse Early CSE w MemorySSA
#define DEBUG_TYPE
Hexagon Common GEP
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
iv Induction Variable Users
Definition IVUsers.cpp:48
static bool isReassociableOp(Instruction *I, unsigned IntOpcode, unsigned FPOpcode)
Definition LICM.cpp:2822
static bool isNotUsedOrFoldableInLoop(const Instruction &I, const Loop *CurLoop, const LoopSafetyInfo *SafetyInfo, TargetTransformInfo *TTI, bool &FoldableInLoop, bool LoopNestMode)
Return true if the only users of this instruction are outside of the loop.
Definition LICM.cpp:1425
static bool hoistGEP(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Reassociate gep (gep ptr, idx1), idx2 to gep (gep ptr, idx2), idx1 if this allows hoisting the inner ...
Definition LICM.cpp:2591
static cl::opt< bool > SingleThread("licm-force-thread-model-single", cl::Hidden, cl::init(false), cl::desc("Force thread model single in LICM pass"))
static void splitPredecessorsOfLoopExit(PHINode *PN, DominatorTree *DT, LoopInfo *LI, const Loop *CurLoop, LoopSafetyInfo *SafetyInfo, MemorySSAUpdater *MSSAU)
Definition LICM.cpp:1599
static bool hoistInsertPastInsert(InsertElementInst *Ins, Loop *CurLoop, DominatorTree *DT, BasicBlock *HoistDest, ICFLoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU, ScalarEvolution *SE, OptimizationRemarkEmitter *ORE, SmallVectorImpl< Instruction * > &HoistedInstructions)
Definition LICM.cpp:1092
static cl::opt< unsigned > FPAssociationUpperLimit("licm-max-num-fp-reassociations", cl::init(5U), cl::Hidden, cl::desc("Set upper limit for the number of transformations performed " "during a single round of hoisting the reassociated expressions."))
static bool isFoldableInLoop(const Instruction &I, const Loop *CurLoop, const TargetTransformInfo *TTI)
Return true if the instruction is foldable in the loop.
Definition LICM.cpp:1395
static bool hoistMinMax(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU)
Try to simplify things like (A < INV_1 AND icmp A < INV_2) into (A < min(INV_1, INV_2)),...
Definition LICM.cpp:2510
static void moveInstructionBefore(Instruction &I, BasicBlock::iterator Dest, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, ScalarEvolution *SE)
Definition LICM.cpp:1551
static Instruction * cloneInstructionInExitBlock(Instruction &I, BasicBlock &ExitBlock, PHINode &PN, const LoopInfo *LI, const LoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU)
Definition LICM.cpp:1467
static cl::opt< bool > ControlFlowHoisting("licm-control-flow-hoisting", cl::Hidden, cl::init(false), cl::desc("Enable control flow (and PHI) hoisting in LICM"))
static bool pointerInvalidatedByLoop(MemorySSA *MSSA, MemoryUse *MU, Loop *CurLoop, Instruction &I, SinkAndHoistLICMFlags &Flags, bool InvariantGroup)
Definition LICM.cpp:2447
static bool hoistSubAddAssociation(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Reassociate add/sub expressions of the form:
Definition LICM.cpp:3016
static bool hoistAdd(ICmpInst::Predicate Pred, Value *VariantLHS, Value *InvariantRHS, ICmpInst &ICmp, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Try to turn things like "LV + C1 < C2" into "LV < C2 - C1".
Definition LICM.cpp:2649
static MemoryAccess * getClobberingMemoryAccess(MemorySSA &MSSA, BatchAAResults &BAA, SinkAndHoistLICMFlags &Flags, MemoryUseOrDef *MA)
Definition LICM.cpp:1237
static SmallVector< PointersAndHasReadsOutsideSet, 0 > collectPromotionCandidates(MemorySSA *MSSA, AliasAnalysis *AA, Loop *L)
Definition LICM.cpp:2338
static void hoist(Instruction &I, const DominatorTree *DT, const Loop *CurLoop, BasicBlock *Dest, ICFLoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU, ScalarEvolution *SE, OptimizationRemarkEmitter *ORE)
When an instruction is found to only use loop invariant operands that is safe to hoist,...
Definition LICM.cpp:1777
static bool canSplitPredecessors(PHINode *PN, LoopSafetyInfo *SafetyInfo)
Definition LICM.cpp:1581
static bool sink(Instruction &I, LoopInfo *LI, DominatorTree *DT, const Loop *CurLoop, ICFLoopSafetyInfo *SafetyInfo, MemorySSAUpdater &MSSAU, OptimizationRemarkEmitter *ORE)
When an instruction is found to only be used outside of the loop, this function moves it to the exit ...
Definition LICM.cpp:1671
static bool hoistAddSub(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Reassociate and hoist add/sub expressions.
Definition LICM.cpp:2792
static bool hoistMulAddAssociation(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Try to reassociate expressions like ((A1 * B1) + (A2 * B2) + ...) * C where A1, A2,...
Definition LICM.cpp:2837
static cl::opt< uint32_t > MaxNumUsesTraversed("licm-max-num-uses-traversed", cl::Hidden, cl::init(8), cl::desc("Max num uses visited for identifying load " "invariance in loop using invariant start (default = 8)"))
static bool isOnlyMemoryAccess(const Instruction *I, const Loop *L, const MemorySSAUpdater &MSSAU)
Return true if I is the only Instruction with a MemoryAccess in L.
Definition LICM.cpp:1221
static cl::opt< unsigned > IntAssociationUpperLimit("licm-max-num-int-reassociations", cl::init(5U), cl::Hidden, cl::desc("Set upper limit for the number of transformations performed " "during a single round of hoisting the reassociated expressions."))
static void foreachMemoryAccess(MemorySSA *MSSA, Loop *L, function_ref< void(Instruction *)> Fn)
Definition LICM.cpp:2326
static bool isLoadInvariantInLoop(LoadInst *LI, DominatorTree *DT, Loop *CurLoop)
Definition LICM.cpp:1152
static bool isHoistableAndSinkableInst(Instruction &I)
Return true if-and-only-if we know how to (mechanically) both hoist and sink a given instruction out ...
Definition LICM.cpp:1209
static Instruction * sinkThroughTriviallyReplaceablePHI(PHINode *TPN, Instruction *I, LoopInfo *LI, SmallDenseMap< BasicBlock *, Instruction *, 32 > &SunkCopies, const LoopSafetyInfo *SafetyInfo, const Loop *CurLoop, MemorySSAUpdater &MSSAU)
Definition LICM.cpp:1566
static bool inSubLoop(BasicBlock *BB, Loop *CurLoop, LoopInfo *LI)
Little predicate that returns true if the specified basic block is in a subloop of the current one,...
Definition LICM.cpp:3148
static bool hoistSub(ICmpInst::Predicate Pred, Value *VariantLHS, Value *InvariantRHS, ICmpInst &ICmp, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Try to reassociate and hoist the following two patterns: LV - C1 < C2 --> LV < C1 + C2,...
Definition LICM.cpp:2710
static void eraseInstruction(Instruction &I, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU)
Definition LICM.cpp:1544
static bool isSafeToExecuteUnconditionally(Instruction &Inst, const DominatorTree *DT, const TargetLibraryInfo *TLI, const Loop *CurLoop, const LoopSafetyInfo *SafetyInfo, OptimizationRemarkEmitter *ORE, const Instruction *CtxI, AssumptionCache *AC, bool AllowSpeculation)
Only sink or hoist an instruction if it is not a trapping instruction, or if the instruction is known...
Definition LICM.cpp:1824
static bool hoistArithmetics(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Aggregates various functions for hoisting computations out of loop.
Definition LICM.cpp:3093
static bool noConflictingReadWrites(Instruction *I, MemorySSA *MSSA, AAResults *AA, Loop *CurLoop, SinkAndHoistLICMFlags &Flags)
Definition LICM.cpp:2407
static bool isTriviallyReplaceablePHI(const PHINode &PN, const Instruction &I)
Returns true if a PHINode is a trivially replaceable with an Instruction.
Definition LICM.cpp:1386
std::pair< SmallSetVector< Value *, 8 >, bool > PointersAndHasReadsOutsideSet
Definition LICM.cpp:226
static cl::opt< bool > DisablePromotion("disable-licm-promotion", cl::Hidden, cl::init(false), cl::desc("Disable memory promotion in LICM pass"))
Memory promotion is enabled by default.
static std::optional< uint64_t > getConstantInsertionIndex(InsertElementInst *Ins)
Definition LICM.cpp:1076
static bool hoistBOAssociation(Instruction &I, Loop &L, ICFLoopSafetyInfo &SafetyInfo, MemorySSAUpdater &MSSAU, AssumptionCache *AC, DominatorTree *DT)
Reassociate associative binary expressions of the form.
Definition LICM.cpp:2940
static bool pointerInvalidatedByBlock(BasicBlock &BB, MemorySSA &MSSA, MemoryUse &MU)
Definition LICM.cpp:2498
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
Memory SSA
Definition MemorySSA.cpp:72
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.
Contains a collection of routines for determining if a given instruction is guaranteed to execute if ...
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
#define P(N)
if(PassOpts->AAPipeline)
PassInstrumentationCallbacks PIC
#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 provides a priority worklist.
static DominatorTree getDomTree(Function &F)
Remove Loads Into Fake Uses
This file defines generic set operations that may be used on set's of different types,...
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
Definition Statistic.h:171
#define LLVM_DEBUG(...)
Definition Debug.h:119
This pass exposes codegen information to IR-level passes.
static cl::opt< bool > DisablePromotion("disable-type-promotion", cl::Hidden, cl::init(false), cl::desc("Disable type promotion pass"))
Value * RHS
Value * LHS
BinaryOperator * Mul
LLVM_ABI void add(const MemoryLocation &Loc)
These methods are used to add different types of instructions to the alias sets.
AnalysisUsage & addRequired()
AnalysisUsage & addPreserved()
Add the specified Pass class to the set of analyses preserved by this pass.
A cache of @llvm.assume calls within a function.
LLVM Basic Block Representation.
Definition BasicBlock.h:62
LLVM_ABI void replaceSuccessorsPhiUsesWith(BasicBlock *Old, BasicBlock *New)
Update all phi nodes in this basic block's successors to refer to basic block New instead of basic bl...
iterator begin()
Instruction iterator methods.
Definition BasicBlock.h:461
LLVM_ABI const_iterator getFirstInsertionPt() const
Returns an iterator to the first instruction in this block that is suitable for inserting a non-PHI i...
const Function * getParent() const
Return the enclosing method, or null if none.
Definition BasicBlock.h:213
bool hasTerminator() const LLVM_READONLY
Returns whether the block has a terminator.
Definition BasicBlock.h:232
LLVM_ABI InstListType::const_iterator getFirstNonPHIIt() const
Returns an iterator to the first instruction in this block that is not a PHINode instruction.
static BasicBlock * Create(LLVMContext &Context, const Twine &Name="", Function *Parent=nullptr, BasicBlock *InsertBefore=nullptr)
Creates a new BasicBlock.
Definition BasicBlock.h:206
LLVM_ABI const BasicBlock * getSingleSuccessor() const
Return the successor of this block if it has a single successor.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this basic block belongs to.
InstListType::iterator iterator
Instruction iterators...
Definition BasicBlock.h:170
LLVM_ABI LLVMContext & getContext() const
Get the context in which this basic block lives.
void moveBefore(BasicBlock *MovePos)
Unlink this basic block from its current function and insert it into the function that MovePos lives ...
Definition BasicBlock.h:388
LLVM_ABI bool canSplitPredecessors() const
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction; assumes that the block is well-formed.
Definition BasicBlock.h:237
This class is a wrapper over an AAResults, and it is intended to be used only when there are no IR ch...
ModRefInfo getModRefInfo(const Instruction *I, const std::optional< MemoryLocation > &OptLoc)
static LLVM_ABI BinaryOperator * Create(BinaryOps Op, Value *S1, Value *S2, const Twine &Name=Twine(), InsertPosition InsertBefore=nullptr)
Construct a binary instruction, given the opcode and the two operands.
This class represents a function call, abstracting a target machine's calling convention.
static CallInst * Create(FunctionType *Ty, Value *F, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
void setPredicate(Predicate P)
Set the predicate for this instruction to the specified value.
Definition InstrTypes.h:831
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Definition InstrTypes.h:740
bool isSigned() const
Definition InstrTypes.h:993
Predicate getSwappedPredicate() const
For example, EQ->EQ, SLE->SGE, ULT->UGT, OEQ->OEQ, ULE->UGE, OLT->OGT, etc.
Definition InstrTypes.h:890
Predicate getInversePredicate() const
For example, EQ -> NE, UGT -> ULE, SLT -> SGE, OEQ -> UNE, UGT -> OLE, OLT -> UGE,...
Definition InstrTypes.h:852
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
static LLVM_ABI std::optional< CmpPredicate > getMatching(CmpPredicate A, CmpPredicate B)
Compares two CmpPredicates taking samesign into account and returns the canonicalized CmpPredicate if...
Conditional Branch instruction.
static CondBrInst * Create(Value *Cond, BasicBlock *IfTrue, BasicBlock *IfFalse, InsertPosition InsertBefore=nullptr)
Value * getCondition() const
BasicBlock * getSuccessor(unsigned i) const
This is the shared class of boolean and integer constants.
Definition Constants.h:87
bool isNegative() const
Definition Constants.h:214
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 parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:64
TypeSize getTypeStoreSize(Type *Ty) const
Returns the maximum number of bytes that may be overwritten by storing the specified type.
Definition DataLayout.h:579
static LLVM_ABI DebugLoc getMergedLocations(ArrayRef< DebugLoc > Locs)
Try to combine the vector of locations passed as input in a single one.
Definition DebugLoc.cpp:156
static DebugLoc getDropped()
Definition DebugLoc.h:153
iterator find(const_arg_type_t< KeyT > Val)
Definition DenseMap.h:225
std::pair< iterator, bool > try_emplace(KeyT &&Key, Ts &&...Args)
Definition DenseMap.h:301
iterator end()
Definition DenseMap.h:143
DomTreeNodeBase * getIDom() const
NodeT * getBlock() const
Analysis pass which computes a DominatorTree.
Definition Dominators.h:270
bool verify(VerificationLevel VL=VerificationLevel::Full) const
verify - checks if the tree is correct.
void changeImmediateDominator(DomTreeNodeBase< NodeT > *N, DomTreeNodeBase< NodeT > *NewIDom)
changeImmediateDominator - This method is used to update the dominator tree information when a node's...
DomTreeNodeBase< NodeT > * addNewBlock(NodeT *BB, NodeT *DomBB)
Add a new node to the dominator tree information.
DomTreeNodeBase< NodeT > * getNode(const NodeT *BB) const
getNode - return the (Post)DominatorTree node for the specified basic block.
bool properlyDominates(const DomTreeNodeBase< NodeT > *A, const DomTreeNodeBase< NodeT > *B) const
properlyDominates - Returns true iff A dominates B and A != B.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Definition Dominators.h:151
LLVM_ABI bool isReachableFromEntry(const Use &U) const
Provide an overload for a Use.
LLVM_ABI bool dominates(const BasicBlock *BB, const Use &U) const
Return true if the (end of the) basic block BB dominates the use U.
Convenience struct for specifying and reasoning about fast-math flags.
Definition FMF.h:23
This implementation of LoopSafetyInfo use ImplicitControlFlowTracking to give precise answers on "may...
bool doesNotWriteMemoryBefore(const BasicBlock *BB, const Loop *CurLoop) const
Returns true if we could not execute a memory-modifying instruction before we enter BB under assumpti...
void removeInstruction(const Instruction *Inst)
Inform safety info that we are planning to remove the instruction Inst from its block.
bool isGuaranteedToExecute(const Instruction &Inst, const DominatorTree *DT, const Loop *CurLoop) const override
Returns true if the instruction in a loop is guaranteed to execute at least once (under the assumptio...
bool anyBlockMayThrow() const override
Returns true iff any block of the loop for which this info is contains an instruction that may throw ...
void computeLoopSafetyInfo(const Loop *CurLoop) override
Computes safety information for a loop checks loop body & header for the possibility of may throw exc...
void insertInstructionTo(const Instruction *Inst, const BasicBlock *BB)
Inform the safety info that we are planning to insert a new instruction Inst into the basic block BB.
This instruction compares its operands according to the predicate given to the constructor.
static bool isGE(Predicate P)
Return true if the predicate is SGE or UGE.
static bool isLT(Predicate P)
Return true if the predicate is SLT or ULT.
static bool isGT(Predicate P)
Return true if the predicate is SGT or UGT.
bool isRelational() const
Return true if the predicate is relational (not EQ or NE).
static bool isLE(Predicate P)
Return true if the predicate is SLE or ULE.
This provides a uniform API for creating instructions and inserting them into a basic block: either a...
Definition IRBuilder.h:2868
This instruction inserts a single (scalar) element into a VectorType value.
VectorType * getType() const
Overload to return most specific vector type.
LLVM_ABI void mergeDIAssignID(ArrayRef< const Instruction * > SourceInstructions)
Merge the DIAssignID metadata from this instruction and those attached to instructions in SourceInstr...
const DebugLoc & getDebugLoc() const
Return the debug location for this node as a DebugLoc.
LLVM_ABI void setAAMetadata(const AAMDNodes &N)
Sets the AA metadata on this instruction from the AAMDNodes structure.
bool hasMetadata() const
Return true if this instruction has any metadata attached to it.
LLVM_ABI void moveBefore(InstListType::iterator InsertPos)
Unlink this instruction from its current basic block and insert it into the basic block that MovePos ...
LLVM_ABI bool isAtomic() const LLVM_READONLY
Return true if this instruction has an AtomicOrdering of unordered or higher.
LLVM_ABI void insertBefore(InstListType::iterator InsertPos)
Insert an unlinked instruction into a basic block immediately before the specified position.
LLVM_ABI InstListType::iterator eraseFromParent()
This method unlinks 'this' from the containing basic block and deletes it.
Instruction * user_back()
Specialize the methods defined in Value, as we know that an instruction can only be used by other ins...
MDNode * getMetadata(unsigned KindID) const
Get the metadata of given kind attached to this Instruction.
LLVM_ABI void setMetadata(unsigned KindID, MDNode *Node)
Set the metadata of the specified kind to the specified node.
LLVM_ABI AAMDNodes getAAMetadata() const
Returns the AA metadata for this instruction.
LLVM_ABI void dropPoisonGeneratingFlags()
Drops flags that may cause this instruction to evaluate to poison despite having non-poison inputs.
void setDebugLoc(DebugLoc Loc)
Set the debug location information for this instruction.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this instruction belongs to.
A wrapper class for inspecting calls to intrinsic functions.
LLVM_ABI void printPipeline(raw_ostream &OS, function_ref< StringRef(StringRef)> MapClassName2PassName)
Definition LICM.cpp:331
LLVM_ABI PreservedAnalyses run(Loop &L, LoopAnalysisManager &AM, LoopStandardAnalysisResults &AR, LPMUpdater &U)
Definition LICM.cpp:309
LLVM_ABI PreservedAnalyses run(LoopNest &L, LoopAnalysisManager &AM, LoopStandardAnalysisResults &AR, LPMUpdater &U)
Definition LICM.cpp:341
LLVM_ABI void printPipeline(raw_ostream &OS, function_ref< StringRef(StringRef)> MapClassName2PassName)
Definition LICM.cpp:371
This class provides an interface for updating the loop pass manager based on mutations to the loop ne...
static void getLazyBFIAnalysisUsage(AnalysisUsage &AU)
Helper for client passes to set up the analysis usage on behalf of this pass.
Helper class for promoting a collection of loads and stores into SSA Form using the SSAUpdater.
Definition SSAUpdater.h:149
An instruction for reading from memory.
void setAlignment(Align Align)
Value * getPointerOperand()
void setOrdering(AtomicOrdering Ordering)
Sets the ordering constraint of this load instruction.
bool isUnordered() const
Analysis pass that exposes the LoopInfo for a function.
Definition LoopInfo.h:587
bool contains(const LoopT *L) const
Return true if the specified loop is contained within in this loop.
BlockT * getHeader() const
void addBasicBlockToLoop(BlockT *NewBB, LoopInfoBase< BlockT, LoopT > &LI)
This method is used by other analyses to update loop information.
BlockT * getLoopPreheader() const
If there is a preheader for this loop, return it.
ArrayRef< BlockT * > getBlocks() const
Get a list of the basic blocks which make up this loop.
void getUniqueExitBlocks(SmallVectorImpl< BlockT * > &ExitBlocks) const
Return all unique successor blocks of this loop.
LoopT * getParentLoop() const
Return the parent loop if it exists or nullptr for top level loops.
Wrapper class to LoopBlocksDFS that provides a standard begin()/end() interface for the DFS reverse p...
void perform(const LoopInfo *LI)
Traverse the loop blocks and store the DFS result.
void verify(const DominatorTreeBase< BlockT, false > &DomTree) const
LoopT * getLoopFor(const BlockT *BB) const
Return the inner most loop that BB lives in.
LLVM_ABI bool wouldBeOutOfLoopUseRequiringLCSSA(const Value *V, const BasicBlock *ExitBB) const
Definition LoopInfo.cpp:970
This class represents a loop nest and can be used to query its properties.
Function * getParent() const
Return the function to which the loop-nest belongs.
Loop & getOutermostLoop() const
Return the outermost loop in the loop nest.
Captures loop safety information.
Definition MustExecute.h:60
LLVM_ABI void copyColors(BasicBlock *New, BasicBlock *Old)
Copy colors of block Old into the block New.
LLVM_ABI const DenseMap< BasicBlock *, ColorVector > & getBlockColors() const
Returns block colors map that is used to update funclet operand bundles.
virtual bool isGuaranteedToExecute(const Instruction &Inst, const DominatorTree *DT, const Loop *CurLoop) const =0
Returns true if the instruction in a loop is guaranteed to execute at least once (under the assumptio...
Represents a single loop in the control flow graph.
Definition LoopInfo.h:40
bool hasLoopInvariantOperands(const Instruction *I) const
Return true if all the operands of the specified instruction are loop invariant.
Definition LoopInfo.cpp:73
bool isLoopInvariant(const Value *V) const
Return true if the specified value is loop invariant.
Definition LoopInfo.cpp:67
BasicBlock * getBlock() const
Definition MemorySSA.h:162
bool onlyWritesMemory() const
Whether this function only (at most) writes memory.
Definition ModRef.h:252
bool doesNotAccessMemory() const
Whether this function accesses no memory.
Definition ModRef.h:246
bool onlyReadsMemory() const
Whether this function only (at most) reads memory.
Definition ModRef.h:249
An analysis that produces MemorySSA for a function.
Definition MemorySSA.h:922
MemorySSA * getMemorySSA() const
Get handle on MemorySSA.
LLVM_ABI void insertDef(MemoryDef *Def, bool RenameUses=false)
Insert a definition into the MemorySSA IR.
LLVM_ABI void insertUse(MemoryUse *Use, bool RenameUses=false)
LLVM_ABI MemoryAccess * createMemoryAccessInBB(Instruction *I, MemoryAccess *Definition, const BasicBlock *BB, MemorySSA::InsertionPlace Point, bool CreationMustSucceed=true)
Create a MemoryAccess in MemorySSA at a specified point in a block.
LLVM_ABI void removeMemoryAccess(MemoryAccess *, bool OptimizePhis=false)
Remove a MemoryAccess from MemorySSA, including updating all definitions and uses.
LLVM_ABI MemoryUseOrDef * createMemoryAccessAfter(Instruction *I, MemoryAccess *Definition, MemoryAccess *InsertPt)
Create a MemoryAccess in MemorySSA after an existing MemoryAccess.
LLVM_ABI void moveToPlace(MemoryUseOrDef *What, BasicBlock *BB, MemorySSA::InsertionPlace Where)
LLVM_ABI void wireOldPredecessorsToNewImmediatePredecessor(BasicBlock *Old, BasicBlock *New, ArrayRef< BasicBlock * > Preds, bool IdenticalEdgesWereMerged=true)
A new empty BasicBlock (New) now branches directly to Old.
MemoryAccess * getClobberingMemoryAccess(const Instruction *I, BatchAAResults &AA)
Given a memory Mod/Ref/ModRef'ing instruction, calling this will give you the nearest dominating Memo...
Definition MemorySSA.h:1035
Legacy analysis pass which computes MemorySSA.
Definition MemorySSA.h:975
Encapsulates MemorySSA, including all data associated with memory accesses.
Definition MemorySSA.h:702
AliasAnalysis & getAA()
Definition MemorySSA.h:800
DefsList * getBlockDefs(const BasicBlock *BB) const
Return the list of MemoryDef's and MemoryPhi's for a given basic block.
Definition MemorySSA.h:765
LLVM_ABI MemorySSAWalker * getSkipSelfWalker()
AccessList * getBlockAccesses(const BasicBlock *BB) const
Return the list of MemoryAccess's for a given basic block.
Definition MemorySSA.h:758
LLVM_ABI bool dominates(const MemoryAccess *A, const MemoryAccess *B) const
Given two memory accesses in potentially different blocks, determine whether MemoryAccess A dominates...
LLVM_ABI void verifyMemorySSA(VerificationLevel=VerificationLevel::Fast) const
Verify that MemorySSA is self consistent (IE definitions dominate all uses, uses appear in the right ...
MemoryUseOrDef * getMemoryAccess(const Instruction *I) const
Given a memory Mod/Ref'ing instruction, get the MemorySSA access associated with it.
Definition MemorySSA.h:720
LLVM_ABI bool locallyDominates(const MemoryAccess *A, const MemoryAccess *B) const
Given two memory accesses in the same basic block, determine whether MemoryAccess A dominates MemoryA...
bool isLiveOnEntryDef(const MemoryAccess *MA) const
Return true if MA represents the live on entry value.
Definition MemorySSA.h:740
Class that has the common methods + fields of memory uses/defs.
Definition MemorySSA.h:250
MemoryAccess * getDefiningAccess() const
Get the access that produces the memory state used by this Use.
Definition MemorySSA.h:260
Represents read-only accesses to memory.
Definition MemorySSA.h:310
The optimization diagnostic interface.
LLVM_ABI void emit(DiagnosticInfoOptimizationBase &OptDiag)
Output the remark via the diagnostic handler and to the optimization record file.
Diagnostic information for missed-optimization remarks.
Diagnostic information for applied optimization remarks.
void addIncoming(Value *V, BasicBlock *BB)
Add an incoming value to the end of the PHI list.
op_range incoming_values()
void setIncomingBlock(unsigned i, BasicBlock *BB)
BasicBlock * getIncomingBlock(unsigned i) const
Return incoming basic block number i.
int getBasicBlockIndex(const BasicBlock *BB) const
Return the first index of the specified basic block in the value list for this PHI.
unsigned getNumIncomingValues() const
Return the number of incoming edges.
static PHINode * Create(Type *Ty, unsigned NumReservedValues, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructors - NumReservedValues is a hint for the number of incoming edges that this phi node will h...
static LLVM_ABI PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
Pass interface - Implemented by all 'passes'.
Definition Pass.h:99
PointerIntPair - This class implements a pair of a pointer and small integer.
void setInt(IntType IntVal) &
PointerTy getPointer() const
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
PredIteratorCache - This class is an extremely trivial cache for predecessor iterator queries.
size_t size(BasicBlock *BB)
ArrayRef< BasicBlock * > get(BasicBlock *BB)
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
Definition Analysis.h:118
bool empty() const
Determine if the PriorityWorklist is empty or not.
bool insert(const T &X)
Insert a new element into the PriorityWorklist.
Helper class for SSA formation on a set of values defined in multiple blocks.
Definition SSAUpdater.h:39
The main scalar evolution driver.
LLVM_ABI void forgetBlockAndLoopDispositions(Value *V=nullptr)
Called when the client has changed the disposition of values in a loop or block.
LLVM_ABI void forgetLoopDispositions()
Called when the client has changed the disposition of values in this loop.
bool remove(const value_type &X)
Remove an item from the set vector.
Definition SetVector.h:181
bool empty() const
Determine if the SetVector is empty or not.
Definition SetVector.h:100
iterator begin()
Get an iterator to the beginning of the SetVector.
Definition SetVector.h:106
bool insert(const value_type &X)
Insert a new element into the SetVector.
Definition SetVector.h:151
Flags controlling how much is checked when sinking or hoisting instructions.
Definition LoopUtils.h:123
LLVM_ABI SinkAndHoistLICMFlags(unsigned LicmMssaOptCap, unsigned LicmMssaNoAccForPromotionCap, bool IsSink, Loop &L, MemorySSA &MSSA)
Definition LICM.cpp:399
unsigned LicmMssaNoAccForPromotionCap
Definition LoopUtils.h:142
A version of PriorityWorklist that selects small size optimized data structures for the vector and ma...
size_type count(ConstPtrType Ptr) const
count - Return 1 if the specified pointer is in the set, 0 otherwise.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
bool contains(ConstPtrType Ptr) const
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
A SetVector that performs no allocations if smaller than a certain size.
Definition SetVector.h:339
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
reference emplace_back(ArgTypes &&... Args)
void reserve(size_type N)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
An instruction for storing to memory.
void setAlignment(Align Align)
void setOrdering(AtomicOrdering Ordering)
Sets the ordering constraint of this store instruction.
static unsigned getPointerOperandIndex()
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
Provides information about what library functions are available for the current target.
Wrapper pass for TargetTransformInfo.
This pass provides access to the codegen interfaces that are needed for IR-level transformations.
@ TCK_SizeAndLatency
The weighted sum of size and latency.
@ TCC_Free
Expected to fold away in lowering.
EltTy front() const
unsigned size() const
The instances of the Type class are immutable: once they are created, they are never changed.
Definition Type.h:46
static UncondBrInst * Create(BasicBlock *Target, InsertPosition InsertBefore=nullptr)
A Use represents the edge between a Value definition and its users.
Definition Use.h:35
const Use & getOperandUse(unsigned i) const
Definition User.h:220
void setOperand(unsigned i, Value *Val)
Definition User.h:212
Value * getOperand(unsigned i) const
Definition User.h:207
unsigned getNumOperands() const
Definition User.h:229
LLVM Value Representation.
Definition Value.h:75
Type * getType() const
All values are typed, get the type of this value.
Definition Value.h:255
LLVM_ABI bool hasOneUser() const
Return true if there is exactly one user of this value.
Definition Value.cpp:163
LLVM_ABI std::string getNameOrAsOperand() const
Definition Value.cpp:461
bool hasOneUse() const
Return true if there is exactly one use of this value.
Definition Value.h:439
LLVM_ABI void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
Definition Value.cpp:553
iterator_range< user_iterator > users()
Definition Value.h:426
bool use_empty() const
Definition Value.h:346
iterator_range< use_iterator > uses()
Definition Value.h:380
user_iterator_impl< User > user_iterator
Definition Value.h:391
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
Definition Value.cpp:319
LLVM_ABI void takeName(Value *V)
Transfer the name from V to this value.
Definition Value.cpp:400
constexpr ScalarTy getFixedValue() const
Definition TypeSize.h:200
constexpr bool isScalable() const
Returns whether the quantity is scaled by a runtime quantity (vscale).
Definition TypeSize.h:168
An efficient, type-erasing, non-owning reference to a callable.
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
Changed
Abstract Attribute helper functions.
Definition Attributor.h:165
constexpr char Align[]
Key for Kernel::Arg::Metadata::mAlign.
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
@ BasicBlock
Various leaf nodes.
Definition ISDOpcodes.h:81
OneUse_match< SubPat > m_OneUse(const SubPat &SP)
BinaryOp_match< LHS, RHS, Instruction::Add > m_Add(const LHS &L, const RHS &R)
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoSignedWrap > m_NSWSub(const LHS &L, const RHS &R)
bool match(Val *V, const Pattern &P)
match_bind< Instruction > m_Instruction(Instruction *&I)
Match an instruction, capturing it if we match.
IntrinsicID_match m_Intrinsic()
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_Value(X))
auto m_Value()
Match an arbitrary value and ignore it.
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
BinaryOp_match< LHS, RHS, Instruction::Add, true > m_c_Add(const LHS &L, const RHS &R)
Matches a Add with LHS and RHS in either order.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWSub(const LHS &L, const RHS &R)
match_combine_or< OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoSignedWrap >, DisjointOr_match< LHS, RHS > > m_NSWAddLike(const LHS &L, const RHS &R)
Match either "add nsw" or "or disjoint".
CmpClass_match< LHS, RHS, ICmpInst > m_ICmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
match_combine_or< OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoUnsignedWrap >, DisjointOr_match< LHS, RHS > > m_NUWAddLike(const LHS &L, const RHS &R)
Match either "add nuw" or "or disjoint".
BinaryOp_match< LHS, RHS, Instruction::Sub > m_Sub(const LHS &L, const RHS &R)
initializer< Ty > init(const Ty &Val)
DiagnosticInfoOptimizationBase::Argument NV
friend class Instruction
Iterator for Instructions in a `BasicBlock.
Definition BasicBlock.h:73
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
Definition InstrProf.h:137
@ NeverOverflows
Never overflows.
LLVM_ABI 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 canSinkOrHoistInst(Instruction &I, AAResults *AA, DominatorTree *DT, Loop *CurLoop, MemorySSAUpdater &MSSAU, bool TargetExecutesOncePerLoop, SinkAndHoistLICMFlags &LICMFlags, OptimizationRemarkEmitter *ORE=nullptr)
Returns true if is legal to hoist or sink this instruction disregarding the possible introduction of ...
Definition LICM.cpp:1292
auto pred_end(const MachineBasicBlock *BB)
void set_intersect(S1Ty &S1, const S2Ty &S2)
set_intersect(A, B) - Compute A := A ^ B Identical to set_intersection, except that it works on set<>...
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 void salvageDebugInfo(const MachineRegisterInfo &MRI, MachineInstr &MI)
Assuming the instruction MI is going to be deleted, attempt to salvage debug users of MI by writing t...
Definition Utils.cpp:1690
auto successors(const MachineBasicBlock *BB)
constexpr from_range_t from_range
LLVM_ABI bool formLCSSARecursively(Loop &L, const DominatorTree &DT, const LoopInfo *LI, ScalarEvolution *SE)
Put a loop nest into LCSSA form.
Definition LCSSA.cpp:449
iterator_range< early_inc_iterator_impl< detail::IterOfRange< RangeT > > > make_early_inc_range(RangeT &&Range)
Make a range that does early increment to allow mutation of the underlying range without disrupting i...
Definition STLExtras.h:633
auto cast_or_null(const Y &Val)
Definition Casting.h:714
auto pred_size(const MachineBasicBlock *BB)
MemoryEffectsBase< IRMemLocation > MemoryEffects
Summary of how a function affects memory in the program.
Definition ModRef.h:356
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 PointerMayBeCapturedBefore(const Value *V, bool ReturnCaptures, const Instruction *I, const DominatorTree *DT, bool IncludeI=false, unsigned MaxUsesToExplore=0, const LoopInfo *LI=nullptr)
PointerMayBeCapturedBefore - Return true if this pointer value may be captured by the enclosing funct...
LLVM_ABI Pass * createLICMPass()
Definition LICM.cpp:392
LLVM_ABI SmallVector< BasicBlock *, 16 > collectChildrenInLoop(DominatorTree *DT, DomTreeNode *N, const Loop *CurLoop)
Does a BFS from a given node to all of its children inside a given loop.
DomTreeNodeBase< BasicBlock > DomTreeNode
Definition Dominators.h:94
AnalysisManager< Loop, LoopStandardAnalysisResults & > LoopAnalysisManager
The loop analysis manager.
LLVM_ABI bool hoistRegion(DomTreeNode *, AAResults *, LoopInfo *, DominatorTree *, AssumptionCache *, TargetLibraryInfo *, Loop *, MemorySSAUpdater &, ScalarEvolution *, ICFLoopSafetyInfo *, SinkAndHoistLICMFlags &, OptimizationRemarkEmitter *, bool, bool AllowSpeculation)
Walk the specified region of the CFG (defined by all blocks dominated by the specified block,...
Definition LICM.cpp:894
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 isInstructionTriviallyDead(Instruction *I, const TargetLibraryInfo *TLI=nullptr)
Return true if the result produced by the instruction is not used, and the instruction will return.
Definition Local.cpp:403
LLVM_ABI bool isGuard(const User *U)
Returns true iff U has semantics of a guard expressed in a form of call of llvm.experimental....
auto reverse(ContainerTy &&C)
Definition STLExtras.h:407
LLVM_ABI OverflowResult computeOverflowForSignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
LLVM_ABI void initializeLegacyLICMPassPass(PassRegistry &)
bool isModSet(const ModRefInfo MRI)
Definition ModRef.h:49
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:209
LLVM_TEMPLATE_ABI void appendLoopsToWorklist(RangeT &&, SmallPriorityWorklist< Loop *, 4 > &)
Utility that implements appending of loops onto a worklist given a range.
LLVM_ABI bool isNotVisibleOnUnwind(const Value *Object, bool &RequiresNoCaptureBeforeUnwind)
Return true if Object memory is not visible after an unwind, in the sense that program semantics cann...
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 void getLoopAnalysisUsage(AnalysisUsage &AU)
Helper to consistently add the set of standard passes to a loop pass's AnalysisUsage.
LLVM_ABI BasicBlock * SplitBlockPredecessors(BasicBlock *BB, ArrayRef< BasicBlock * > Preds, const char *Suffix, DominatorTree *DT, LoopInfo *LI=nullptr, MemorySSAUpdater *MSSAU=nullptr, bool PreserveLCSSA=false)
This method introduces at least one new basic block into the function and moves some of the predecess...
ModRefInfo
Flags indicating whether a memory access modifies or references memory.
Definition ModRef.h:28
TargetTransformInfo TTI
LLVM_ABI bool VerifyMemorySSA
Enables verification of MemorySSA.
Definition MemorySSA.cpp:84
LLVM_ABI bool salvageKnowledge(Instruction *I, AssumptionCache *AC=nullptr, DominatorTree *DT=nullptr)
Calls BuildAssumeFromInst and if the resulting llvm.assume is valid insert if before I.
LLVM_ABI bool hasDisableLICMTransformsHint(const Loop *L)
Look for the loop attribute that disables the LICM transformation heuristics.
LLVM_ABI OverflowResult computeOverflowForSignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
@ Add
Sum of integers.
DWARFExpression::Operation Op
LLVM_ABI bool isDereferenceableAndAlignedPointer(const Value *V, Type *Ty, Align Alignment, const SimplifyQuery &Q, bool IgnoreFree=false)
Returns true if V is always a dereferenceable pointer with alignment greater or equal than requested.
Definition Loads.cpp:245
ArrayRef(const T &OneElt) -> ArrayRef< T >
LLVM_ABI bool isIdentifiedFunctionLocal(const Value *V)
Return true if V is umabigously identified at the function-level.
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1916
LLVM_ABI OverflowResult computeOverflowForUnsignedSub(const Value *LHS, const Value *RHS, const SimplifyQuery &SQ)
TinyPtrVector< BasicBlock * > ColorVector
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 PreservedAnalyses getLoopPassPreservedAnalyses()
Returns the minimum set of Analyses that all loop passes must preserve.
auto find_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::find_if which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1771
void erase_if(Container &C, UnaryPredicate P)
Provide a container algorithm similar to C++ Library Fundamentals v2's erase_if which is equivalent t...
Definition STLExtras.h:2191
auto predecessors(const MachineBasicBlock *BB)
Type * getLoadStoreType(const Value *I)
A helper function that returns the type of a load or store instruction.
LLVM_ABI bool sinkRegion(DomTreeNode *, AAResults *, LoopInfo *, DominatorTree *, TargetLibraryInfo *, TargetTransformInfo *, Loop *CurLoop, MemorySSAUpdater &, ICFLoopSafetyInfo *, SinkAndHoistLICMFlags &, OptimizationRemarkEmitter *, Loop *OutermostLoop=nullptr)
Walk the specified region of the CFG (defined by all blocks dominated by the specified block,...
Definition LICM.cpp:565
LLVM_ABI OverflowResult computeOverflowForUnsignedAdd(const WithCache< const Value * > &LHS, const WithCache< const Value * > &RHS, const SimplifyQuery &SQ)
LLVM_ABI cl::opt< unsigned > SetLicmMssaNoAccForPromotionCap
LLVM_ABI bool canHoistLoad(LoadInst &LI, AAResults *AA, DominatorTree *DT, Loop *CurLoop, MemorySSA &MSSA, bool TargetExecutesOncePerLoop, SinkAndHoistLICMFlags &LICMFlags, OptimizationRemarkEmitter *ORE=nullptr)
Returns true if it is legal to hoist LI out of CurLoop.
Definition LICM.cpp:1251
LLVM_ABI bool isDereferenceablePointer(const Value *V, Type *Ty, const SimplifyQuery &Q, bool IgnoreFree=false)
Return true if this is always a dereferenceable pointer.
Definition Loads.cpp:265
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
AAResults AliasAnalysis
Temporary typedef for legacy code that uses a generic AliasAnalysis pointer or reference.
bool capturesNothing(CaptureComponents CC)
Definition ModRef.h:375
LLVM_ABI bool isKnownNonNegative(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Returns true if the give value is known to be non-negative.
LLVM_ABI bool promoteLoopAccessesToScalars(const SmallSetVector< Value *, 8 > &, SmallVectorImpl< BasicBlock * > &, SmallVectorImpl< BasicBlock::iterator > &, SmallVectorImpl< MemoryAccess * > &, PredIteratorCache &, LoopInfo *, DominatorTree *, AssumptionCache *AC, const TargetLibraryInfo *, TargetTransformInfo *, Loop *, MemorySSAUpdater &, ICFLoopSafetyInfo *, OptimizationRemarkEmitter *, bool AllowSpeculation, bool HasReadsOutsideSet)
Try to promote memory values to scalars by sinking stores out of the loop and moving loads to before ...
Definition LICM.cpp:2006
bool isNoModRef(const ModRefInfo MRI)
Definition ModRef.h:40
LLVM_ABI cl::opt< unsigned > SetLicmMssaOptCap
LLVM_ABI bool sinkRegionForLoopNest(DomTreeNode *, AAResults *, LoopInfo *, DominatorTree *, TargetLibraryInfo *, TargetTransformInfo *, Loop *, MemorySSAUpdater &, ICFLoopSafetyInfo *, SinkAndHoistLICMFlags &, OptimizationRemarkEmitter *)
Call sinkRegion on loops contained within the specified loop in order from innermost to outermost.
Definition LICM.cpp:632
bool isRefSet(const ModRefInfo MRI)
Definition ModRef.h:52
LLVM_ABI bool isWritableObject(const Value *Object, bool &ExplicitlyDereferenceableOnly)
Return true if the Object is writable, in the sense that any location based on this pointer that can ...
LLVM_ABI void reportFatalUsageError(Error Err)
Report a fatal error that does not indicate a bug in LLVM.
Definition Error.cpp:177
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
Definition BitVector.h:862
#define N
A collection of metadata nodes that might be associated with a memory access used by the alias-analys...
Definition Metadata.h:763
LLVM_ABI AAMDNodes merge(const AAMDNodes &Other) const
Given two sets of AAMDNodes applying to potentially different locations, determine the best AAMDNodes...
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39
The adaptor from a function pass to a loop pass computes these analyses and makes them available to t...
A lightweight accessor for an operand bundle meant to be passed around by value.
uint32_t getTagID() const
Return the tag of this operand bundle as an integer.
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition PassManager.h:89