81#define DEBUG_TYPE "jump-threading"
85STATISTIC(NumDupes,
"Number of branch blocks duplicated to eliminate phi");
89 cl::desc(
"Max block size to duplicate for jump threading"),
94 "jump-threading-implication-search-threshold",
95 cl::desc(
"The number of predecessors to search for a stronger "
96 "condition to use to thread over a weaker condition"),
100 "jump-threading-phi-threshold",
105 "jump-threading-across-loop-headers",
106 cl::desc(
"Allow JumpThreading to thread across loop headers, for testing"),
161 if (TrueWeight + FalseWeight == 0)
169 auto GetPredOutEdge =
171 BasicBlock *PhiBB) -> std::pair<BasicBlock *, BasicBlock *> {
172 auto *PredBB = IncomingBB;
173 auto *SuccBB = PhiBB;
177 return {PredBB, SuccBB};
179 auto *SinglePredBB = PredBB->getSinglePredecessor();
181 return {
nullptr,
nullptr};
185 if (Visited.
count(SinglePredBB))
186 return {
nullptr,
nullptr};
189 PredBB = SinglePredBB;
202 TrueWeight, TrueWeight + FalseWeight)
204 FalseWeight, TrueWeight + FalseWeight));
207 if (!PredOutEdge.first)
215 uint64_t PredTrueWeight, PredFalseWeight;
244 if (TTI.hasBranchDivergence(&F))
252 runImpl(F, &AM, &TLI, &TTI, &LVI, &AA,
253 std::make_unique<DomTreeUpdater>(
254 &DT,
nullptr, DomTreeUpdater::UpdateStrategy::Lazy),
263#if defined(EXPENSIVE_CHECKS)
265 DominatorTree::VerificationLevel::Full) &&
266 "DT broken after JumpThreading");
269 PostDominatorTree::VerificationLevel::Full)) &&
270 "PDT broken after JumpThreading");
273 DominatorTree::VerificationLevel::Fast) &&
274 "DT broken after JumpThreading");
277 PostDominatorTree::VerificationLevel::Fast)) &&
278 "PDT broken after JumpThreading");
281 return getPreservedAnalysis();
288 std::unique_ptr<DomTreeUpdater> DTU_,
298 DTU = std::move(DTU_);
302 F->getParent(), Intrinsic::experimental_guard);
303 HasGuards = GuardDecl && !GuardDecl->use_empty();
309 else if (F->hasMinSize())
312 BBDupThreshold = DefaultBBDupThreshold;
314 assert(DTU &&
"DTU isn't passed into JumpThreading before using it.");
315 assert(DTU->hasDomTree() &&
"JumpThreading relies on DomTree to proceed.");
321 Unreachable.insert(&BB);
326 bool EverChanged =
false;
330 for (
auto &BB : *F) {
331 if (Unreachable.count(&BB))
334 Changed = ChangedSinceLastAnalysisUpdate =
true;
339 if (&BB == &F->getEntryBlock() || DTU->isBBPendingDeletion(&BB))
346 <<
"' with terminator: " << *BB.getTerminator()
348 LoopHeaders.erase(&BB);
349 LVI->eraseBlock(&BB);
351 Changed = ChangedSinceLastAnalysisUpdate =
true;
361 BB.getFirstNonPHIOrDbg(
true)->isTerminator() &&
364 !LoopHeaders.count(&BB) && !LoopHeaders.count(Succ) &&
368 LVI->eraseBlock(&BB);
369 Changed = ChangedSinceLastAnalysisUpdate =
true;
379 for (
auto &BB : *F) {
401 if (
Cond->getParent() == KnownAtEndOfBB)
406 DVR.replaceVariableLocationOp(
Cond, ToVal,
true);
418 if (
Cond->use_empty() && !
Cond->mayHaveSideEffects()) {
419 Cond->eraseFromParent();
431 unsigned Threshold) {
432 assert(
StopAt->getParent() == BB &&
"Not an instruction from proper BB?");
437 unsigned PhiCount = 0;
477 if (
Size > Threshold)
482 if (
I->getType()->isTokenTy() &&
I->isUsedOutsideOfBlock(BB))
488 if (CI->cannotDuplicate() || CI->isConvergent())
505 else if (!CI->getType()->isVectorTy())
510 return Size > Bonus ?
Size - Bonus : 0;
568 if (!RecursionSet.
insert(V).second)
574 Result.emplace_back(KC, Pred);
576 return !Result.empty();
582 if (!
I ||
I->getParent() != BB) {
590 Constant *PredCst = LVI->getConstantOnEdge(V,
P, BB, CxtI);
599 PredCst = LVI->getPredicateOnEdge(Pred, Val, Cst,
P, BB, CxtI);
601 Result.emplace_back(KC,
P);
604 return !Result.empty();
609 for (
unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i) {
610 Value *InVal = PN->getIncomingValue(i);
612 Result.emplace_back(KC, PN->getIncomingBlock(i));
614 Constant *CI = LVI->getConstantOnEdge(InVal,
615 PN->getIncomingBlock(i),
618 Result.emplace_back(KC, PN->getIncomingBlock(i));
622 return !Result.empty();
627 Value *Source = CI->getOperand(0);
635 for (
auto &Val : Vals)
638 Result.emplace_back(Folded, Val.second);
640 return !Result.empty();
644 Value *Source = FI->getOperand(0);
652 return !Result.empty();
656 if (
I->getType()->getPrimitiveSizeInBits() == 1) {
685 for (
const auto &LHSVal : LHSVals)
687 Result.emplace_back(InterestingVal, LHSVal.second);
688 LHSKnownBBs.
insert(LHSVal.second);
690 for (
const auto &RHSVal : RHSVals)
694 if (!LHSKnownBBs.
count(RHSVal.second))
695 Result.emplace_back(InterestingVal, RHSVal.second);
698 return !Result.empty();
702 if (
I->getOpcode() == Instruction::Xor &&
711 for (
auto &R : Result)
727 for (
const auto &LHSVal : LHSVals) {
733 Result.emplace_back(KC, LHSVal.second);
737 return !Result.empty();
744 Type *CmpType = Cmp->getType();
745 Value *CmpLHS = Cmp->getOperand(0);
746 Value *CmpRHS = Cmp->getOperand(1);
755 if (PN && PN->
getParent() == BB && !LoopHeaders.contains(BB)) {
776 if (LHSInst && LHSInst->getParent() == BB)
779 Res = LVI->getPredicateOnEdge(Pred, LHS,
cast<Constant>(RHS), PredBB,
780 BB, CxtI ? CxtI : Cmp);
784 Result.emplace_back(KC, PredBB);
787 return !Result.empty();
800 Constant *Res = LVI->getPredicateOnEdge(Pred, CmpLHS, CmpConst,
P, BB,
803 Result.emplace_back(KC,
P);
806 return !Result.empty();
842 Result.emplace_back(ResC,
P);
845 return !Result.empty();
856 for (
const auto &LHSVal : LHSVals) {
861 Result.emplace_back(KC, LHSVal.second);
864 return !Result.empty();
874 if ((TrueVal || FalseVal) &&
877 for (
auto &
C : Conds) {
884 KnownCond = CI->isOne();
890 KnownCond = (TrueVal !=
nullptr);
894 if (
Constant *Val = KnownCond ? TrueVal : FalseVal)
895 Result.emplace_back(Val,
C.second);
898 return !Result.empty();
904 Constant *CI = LVI->getConstant(V, CxtI);
907 Result.emplace_back(KC, Pred);
910 return !Result.empty();
920 unsigned MinSucc = 0;
923 unsigned MinNumPreds =
pred_size(TestBB);
927 if (NumPreds < MinNumPreds) {
929 MinNumPreds = NumPreds;
951 if (DTU->isBBPendingDeletion(BB) ||
977 Condition = BI->getCondition();
979 Condition =
SI->getCondition();
982 if (IB->getNumSuccessors() == 0)
return false;
983 Condition = IB->getAddress()->stripPointerCasts();
990 bool ConstantFolded =
false;
998 I->replaceAllUsesWith(SimpleVal);
1000 I->eraseFromParent();
1001 Condition = SimpleVal;
1002 ConstantFolded =
true;
1012 std::vector<DominatorTree::UpdateType> Updates;
1018 if (i == BestSucc)
continue;
1025 <<
"' folding undef terminator: " << *BBTerm <<
'\n');
1031 DTU->applyUpdatesPermissive(Updates);
1033 FI->eraseFromParent();
1046 if (
auto *BPI = getBPI())
1047 BPI->eraseBlock(BB);
1058 return ConstantFolded;
1062 Value *CondWithoutFreeze = CondInst;
1064 CondWithoutFreeze = FI->getOperand(0);
1072 LVI->getPredicateAt(CondCmp->getPredicate(), CondCmp->getOperand(0),
1102 Value *SimplifyValue = CondWithoutFreeze;
1106 SimplifyValue = CondCmp->getOperand(0);
1132 if (CondInst->
getOpcode() == Instruction::Xor &&
1156 if (FICond && FICond->hasOneUse())
1157 Cond = FICond->getOperand(0);
1171 if (PBI->getSuccessor(0) != CurrentBB && PBI->getSuccessor(1) != CurrentBB)
1174 bool CondIsTrue = PBI->getSuccessor(0) == CurrentBB;
1175 std::optional<bool> Implication =
1182 FICond->getOperand(0))
1183 Implication = CondIsTrue;
1187 BasicBlock *KeepSucc = BI->getSuccessor(*Implication ? 0 : 1);
1188 BasicBlock *RemoveSucc = BI->getSuccessor(*Implication ? 1 : 0);
1192 UncondBI->setDebugLoc(BI->getDebugLoc());
1194 BI->eraseFromParent();
1196 FICond->eraseFromParent();
1199 if (
auto *BPI = getBPI())
1200 BPI->eraseBlock(BB);
1203 CurrentBB = CurrentPred;
1213 if (OpInst->getParent() == BB)
1260 LVI->forgetValue(NLoadI);
1265 if (AvailableVal == LoadI)
1267 if (AvailableVal->getType() != LoadI->
getType()) {
1280 if (BBIt != LoadBB->
begin())
1291 AvailablePredsTy AvailablePreds;
1299 if (!PredsScanned.
insert(PredBB).second)
1302 BBIt = PredBB->end();
1303 unsigned NumScanedInst = 0;
1304 Value *PredAvailable =
nullptr;
1308 "Attempting to CSE volatile or atomic loads");
1318 &BatchAA, &IsLoadCSE, &NumScanedInst);
1323 while (!PredAvailable && SinglePredBB && BBIt == SinglePredBB->
begin() &&
1327 BBIt = SinglePredBB->
end();
1329 Loc, AccessTy, LoadI->
isAtomic(), SinglePredBB, BBIt,
1335 if (!PredAvailable) {
1336 OneUnavailablePred = PredBB;
1345 AvailablePreds.emplace_back(PredBB, PredAvailable);
1350 if (AvailablePreds.empty())
return false;
1367 std::optional<bool> GuaranteedToTransfer;
1368 auto CanSpeculateInto = [&](
const BasicBlock *Pred) {
1372 if (!GuaranteedToTransfer)
1375 return *GuaranteedToTransfer;
1381 if (PredsScanned.
size() == AvailablePreds.size()+1 &&
1383 UnavailablePred = OneUnavailablePred;
1384 if (!CanSpeculateInto(UnavailablePred))
1386 }
else if (PredsScanned.
size() != AvailablePreds.size()) {
1399 if (!AvailablePredSet.
count(
P)) {
1400 if (!CanSpeculateInto(
P))
1407 UnavailablePred = splitBlockPreds(LoadBB, PredsToSplit,
"thread-pre-split");
1413 if (UnavailablePred) {
1415 "Can't handle critical edge here!");
1425 AvailablePreds.emplace_back(UnavailablePred, NewVal);
1441 AvailablePredsTy::iterator
I =
1444 assert(
I != AvailablePreds.end() &&
I->first ==
P &&
1445 "Didn't find entry for predecessor!");
1451 Value *&PredV =
I->second;
1454 PredV, LoadI->
getType(),
"",
P->getTerminator()->getIterator());
1459 DebugLoc DL =
P->getTerminator()->getNumSuccessors() == 1
1468 for (
LoadInst *PredLoadI : CSELoads) {
1470 LVI->forgetValue(PredLoadI);
1486 assert(!PredToDestList.empty());
1498 DestPopularity[
nullptr] = 0;
1500 DestPopularity[SuccBB] = 0;
1502 for (
const auto &PredToDest : PredToDestList)
1503 if (PredToDest.second)
1504 DestPopularity[PredToDest.second]++;
1510 return MostPopular->first;
1526 if (!Visited.
insert(V).second)
1531 assert(PredBB &&
"Expected a single predecessor");
1539 if (!
I || (
I->getParent() != BB &&
I->getParent() != PredBB)) {
1540 return LVI->getConstantOnEdge(V, PredPredBB, PredBB,
nullptr);
1545 if (
PHI->getParent() == PredBB)
1556 if (CondCmp->getParent() == BB) {
1558 BB, PredPredBB, CondCmp->getOperand(0),
DL, Visited);
1560 BB, PredPredBB, CondCmp->getOperand(1),
DL, Visited);
1577 if (LoopHeaders.count(BB))
1589 "computeValueKnownInPredecessors returned true with no values");
1592 for (
const auto &PredValue : PredValues) {
1594 <<
"': FOUND condition = " << *PredValue.first
1595 <<
" for pred '" << PredValue.second->getName() <<
"'.\n";
1610 for (
const auto &PredValue : PredValues) {
1612 if (!SeenPreds.insert(Pred).second)
1628 &&
"Unexpected terminator");
1634 if (PredToDestList.
empty()) {
1638 if (OnlyDest != DestBB)
1639 OnlyDest = MultipleDestSentinel;
1643 OnlyVal = MultipleVal;
1655 if (PredToDestList.
empty())
1661 if (OnlyDest && OnlyDest != MultipleDestSentinel) {
1663 bool SeenFirstBranchToOnlyDest =
false;
1664 std::vector <DominatorTree::UpdateType> Updates;
1667 if (SuccBB == OnlyDest && !SeenFirstBranchToOnlyDest) {
1668 SeenFirstBranchToOnlyDest =
true;
1670 SuccBB->removePredecessor(BB,
true);
1680 Term->eraseFromParent();
1681 DTU->applyUpdatesPermissive(Updates);
1682 if (
auto *BPI = getBPI())
1683 BPI->eraseBlock(BB);
1688 if (CondInst->use_empty() && !CondInst->mayHaveSideEffects())
1689 CondInst->eraseFromParent();
1697 else if (OnlyVal && OnlyVal != MultipleVal)
1710 if (MostPopularDest == MultipleDestSentinel) {
1715 [&](
const std::pair<BasicBlock *, BasicBlock *> &PredToDest) {
1716 return LoopHeaders.contains(PredToDest.second);
1719 if (PredToDestList.
empty())
1728 for (
const auto &PredToDest : PredToDestList)
1729 if (PredToDest.second == MostPopularDest) {
1742 if (!MostPopularDest)
1771 PredBBs[0] = PredBB;
1832 "computeValueKnownInPredecessors returned true with no values");
1836 unsigned NumTrue = 0, NumFalse = 0;
1837 for (
const auto &XorOpValue : XorOpValues) {
1849 if (NumTrue > NumFalse)
1851 else if (NumTrue != 0 || NumFalse != 0)
1857 for (
const auto &XorOpValue : XorOpValues) {
1858 if (XorOpValue.first != SplitVal && !
isa<UndefValue>(XorOpValue.first))
1861 BlocksToFoldInto.
push_back(XorOpValue.second);
1866 if (BlocksToFoldInto.
size() ==
1905 Value *
IV = PN.getIncomingValueForBlock(OldPred);
1914 PN.addIncoming(
IV, NewPred);
1931 if (Unreachable.count(SinglePred))
1942 if (LoopHeaders.erase(SinglePred))
1943 LoopHeaders.insert(BB);
1945 LVI->eraseBlock(SinglePred);
1976 LVI->eraseBlock(BB);
1997 for (
Use &U :
I.uses()) {
1999 if (
User->isLifetimeStartOrEnd()) {
2003 if (UserPN->getIncomingBlock(U) == BB)
2005 }
else if (
User->getParent() == BB)
2018 if (UsesToRename.
empty() && DbgVariableRecords.
empty())
2020 LLVM_DEBUG(
dbgs() <<
"JT: Renaming non-local uses of: " <<
I <<
"\n");
2029 while (!UsesToRename.
empty())
2031 if (!DbgVariableRecords.
empty()) {
2033 DbgVariableRecords.
clear();
2043 User->eraseFromParent();
2053 for (
auto It = Begin; It != End; ++It)
2073 for (
auto *
Op : DVR->location_ops()) {
2078 auto I = ValueMapping.
find(OpInst);
2079 if (
I != ValueMapping.
end())
2080 OperandsToRemap.
insert({OpInst,
I->second});
2083 for (
auto &[OldOp, MappedOp] : OperandsToRemap)
2084 DVR->replaceVariableLocationOp(OldOp, MappedOp);
2095 ValueMapping[PN] = NewPN;
2112 RetargetDbgVariableRecordIfPossible(&DVR);
2118 for (; BI != BE; ++BI) {
2120 New->setName(BI->getName());
2121 New->insertInto(NewBB, NewBB->
end());
2122 ValueMapping[&*BI] = New;
2125 CloneAndRemapDbgInfo(New, &*BI);
2130 for (
unsigned i = 0, e = New->getNumOperands(); i != e; ++i)
2133 if (
I != ValueMapping.
end())
2134 New->setOperand(i,
I->second);
2140 if (BE != RangeBB->
end() && BE->hasDbgRecords()) {
2146 RetargetDbgVariableRecordIfPossible(&DVR);
2204 if (LoopHeaders.count(PredBB))
2214 unsigned ZeroCount = 0;
2215 unsigned OneCount = 0;
2228 }
else if (CI->isOne()) {
2237 if (ZeroCount == 1) {
2238 PredPredBB = ZeroPred;
2239 }
else if (OneCount == 1) {
2240 PredPredBB = OnePred;
2250 <<
"' - would thread to self!\n");
2256 if (LoopHeaders.count(BB) || LoopHeaders.count(SuccBB)) {
2258 bool BBIsHeader = LoopHeaders.count(BB);
2259 bool SuccIsHeader = LoopHeaders.count(SuccBB);
2260 dbgs() <<
" Not threading across "
2261 << (BBIsHeader ?
"loop header BB '" :
"block BB '")
2262 << BB->
getName() <<
"' to dest "
2263 << (SuccIsHeader ?
"loop header BB '" :
"block BB '")
2265 <<
"' - it might create an irreducible loop!\n";
2279 if (BBCost > BBDupThreshold || PredBBCost > BBDupThreshold ||
2280 BBCost + PredBBCost > BBDupThreshold) {
2282 <<
"' - Cost is too high: " << PredBBCost
2283 <<
" for PredBB, " << BBCost <<
"for BB\n");
2300 bool HasProfile = doesBlockHaveProfileData(BB);
2301 auto *BFI = getOrCreateBFI(HasProfile);
2302 auto *BPI = getOrCreateBPI(BFI !=
nullptr);
2314 assert(BPI &&
"It's expected BPI to exist along with BFI");
2315 auto NewBBFreq = BFI->getBlockFreq(PredPredBB) *
2316 BPI->getEdgeProbability(PredPredBB, PredBB);
2317 BFI->setBlockFreq(NewBB, NewBBFreq);
2329 BPI->copyEdgeProbabilities(PredBB, NewBB);
2346 DTU->applyUpdatesPermissive(
2374 <<
"' - would thread to self!\n");
2380 if (LoopHeaders.count(BB) || LoopHeaders.count(SuccBB)) {
2382 bool BBIsHeader = LoopHeaders.count(BB);
2383 bool SuccIsHeader = LoopHeaders.count(SuccBB);
2384 dbgs() <<
" Not threading across "
2385 << (BBIsHeader ?
"loop header BB '" :
"block BB '") << BB->
getName()
2386 <<
"' to dest " << (SuccIsHeader ?
"loop header BB '" :
"block BB '")
2387 << SuccBB->
getName() <<
"' - it might create an irreducible loop!\n";
2394 if (JumpThreadCost > BBDupThreshold) {
2396 <<
"' - Cost is too high: " << JumpThreadCost <<
"\n");
2410 assert(SuccBB != BB &&
"Don't create an infinite loop");
2412 assert(!LoopHeaders.count(BB) && !LoopHeaders.count(SuccBB) &&
2413 "Don't thread across loop headers");
2416 bool HasProfile = doesBlockHaveProfileData(BB);
2417 auto *BFI = getOrCreateBFI(HasProfile);
2418 auto *BPI = getOrCreateBPI(BFI !=
nullptr);
2422 if (PredBBs.
size() == 1)
2423 PredBB = PredBBs[0];
2426 <<
" common predecessors.\n");
2427 PredBB = splitBlockPreds(BB, PredBBs,
".thr_comm");
2432 <<
"' to '" << SuccBB->
getName()
2433 <<
", across block:\n " << *BB <<
"\n");
2435 LVI->threadEdge(PredBB, BB, SuccBB);
2444 assert(BPI &&
"It's expected BPI to exist along with BFI");
2446 BFI->getBlockFreq(PredBB) * BPI->getEdgeProbability(PredBB, BB);
2447 BFI->setBlockFreq(NewBB, NewBBFreq);
2488 updateBlockFreqAndEdgeWeight(PredBB, BB, NewBB, SuccBB, BFI, BPI, HasProfile);
2499 const char *Suffix) {
2505 auto *BFI = getBFI();
2507 auto *BPI = getOrCreateBPI(
true);
2508 for (
auto *Pred : Preds)
2509 FreqMap.
insert(std::make_pair(
2516 std::string NewName = std::string(Suffix) +
".split-lp";
2522 std::vector<DominatorTree::UpdateType> Updates;
2523 Updates.reserve((2 * Preds.size()) + NewBBs.
size());
2524 for (
auto *NewBB : NewBBs) {
2525 BlockFrequency NewBBFreq(0);
2531 NewBBFreq += FreqMap.
lookup(Pred);
2534 BFI->setBlockFreq(NewBB, NewBBFreq);
2537 DTU->applyUpdatesPermissive(Updates);
2541bool JumpThreadingPass::doesBlockHaveProfileData(
BasicBlock *BB) {
2552void JumpThreadingPass::updateBlockFreqAndEdgeWeight(
BasicBlock *PredBB,
2559 assert(((BFI && BPI) || (!BFI && !BFI)) &&
2560 "Both BFI & BPI should either be set or unset");
2564 "It's expected to have BFI/BPI when profile info exists");
2570 auto BBOrigFreq = BFI->getBlockFreq(BB);
2571 auto NewBBFreq = BFI->getBlockFreq(NewBB);
2572 auto BBNewFreq = BBOrigFreq - NewBBFreq;
2573 BFI->setBlockFreq(BB, BBNewFreq);
2577 SmallVector<uint64_t, 4> BBSuccFreq;
2579 auto BB2SuccBBFreq = BBOrigFreq * BPI->getEdgeProbability(BB, It.index());
2581 (It.value() == SuccBB) ? BB2SuccBBFreq - NewBBFreq : BB2SuccBBFreq;
2582 BBSuccFreq.
push_back(SuccFreq.getFrequency());
2588 if (MaxBBSuccFreq == 0)
2590 {1, static_cast<unsigned>(BBSuccFreq.size())});
2592 for (uint64_t Freq : BBSuccFreq)
2601 BPI->setEdgeProbability(BB, BBSuccProbs);
2637 if (BBSuccProbs.
size() >= 2 && HasProfile) {
2638 SmallVector<uint32_t, 4> Weights;
2639 for (
auto Prob : BBSuccProbs)
2654 assert(!PredBBs.
empty() &&
"Can't handle an empty set");
2659 if (LoopHeaders.count(BB)) {
2661 <<
"' into predecessor block '" << PredBBs[0]->getName()
2662 <<
"' - it might create an irreducible loop!\n");
2668 if (DuplicationCost > BBDupThreshold) {
2670 <<
"' - Cost is too high: " << DuplicationCost <<
"\n");
2675 std::vector<DominatorTree::UpdateType> Updates;
2677 if (PredBBs.
size() == 1)
2678 PredBB = PredBBs[0];
2681 <<
" common predecessors.\n");
2682 PredBB = splitBlockPreds(BB, PredBBs,
".thr_comm");
2689 <<
"' into end of '" << PredBB->
getName()
2690 <<
"' to eliminate branch on phi. Cost: "
2691 << DuplicationCost <<
" block is:" << *BB <<
"\n");
2697 if (!OldPredBranch) {
2711 auto RItBeforeInsertPt = std::next(OldPredBranch->getReverseIterator());
2728 for (; BI != BB->
end(); ++BI) {
2730 New->insertInto(PredBB, OldPredBranch->getIterator());
2734 for (
unsigned i = 0, e = New->getNumOperands(); i != e; ++i)
2737 if (
I != ValueMapping.
end())
2738 New->setOperand(i,
I->second);
2752 ValueMapping[&*BI] =
IV;
2753 if (!New->mayHaveSideEffects()) {
2754 New->eraseFromParent();
2758 OldPredBranch->cloneDebugInfoFrom(&*BI, std::nullopt,
true);
2761 ValueMapping[&*BI] = New;
2765 New->setName(BI->getName());
2767 New->cloneDebugInfoFrom(&*BI);
2769 for (
unsigned i = 0, e = New->getNumOperands(); i != e; ++i)
2784 remapSourceAtoms(ValueMapping, std::prev(RItBeforeInsertPt)->getIterator(),
2785 OldPredBranch->getIterator());
2794 OldPredBranch->eraseFromParent();
2795 if (
auto *BPI = getBPI())
2796 BPI->copyEdgeProbabilities(BB, PredBB);
2797 DTU->applyUpdatesPermissive(Updates);
2824 PredTerm->removeFromParent();
2825 PredTerm->insertInto(NewBB, NewBB->
end());
2834 BI->applyMergedLocation(PredTerm->getDebugLoc(),
SI->getDebugLoc());
2835 BI->copyMetadata(*
SI, {LLVMContext::MD_prof});
2843 (TrueWeight + FalseWeight) != 0) {
2846 TrueWeight, TrueWeight + FalseWeight));
2848 FalseWeight, TrueWeight + FalseWeight));
2850 if (
auto *BPI = getBPI())
2851 BPI->setEdgeProbability(Pred, BP);
2854 if (
auto *BFI = getBFI()) {
2855 if ((TrueWeight + FalseWeight) == 0) {
2860 TrueWeight, TrueWeight + FalseWeight);
2861 auto NewBBFreq = BFI->getBlockFreq(Pred) * PredToNewBBProb;
2862 BFI->setBlockFreq(NewBB, NewBBFreq);
2866 SI->eraseFromParent();
2874 Phi->addIncoming(Phi->getIncomingValueForBlock(Pred), NewBB);
2880 if (!CondPHI || CondPHI->
getParent() != BB)
2920 if (!CondBr || !CondLHS || CondLHS->
getParent() != BB)
2929 if (!
SI ||
SI->getParent() != Pred || !
SI->hasOneUse())
2940 LVI->getPredicateOnEdge(CondCmp->
getPredicate(),
SI->getOperand(1),
2941 CondRHS, Pred, BB, CondCmp);
2943 LVI->getPredicateOnEdge(CondCmp->
getPredicate(),
SI->getOperand(2),
2944 CondRHS, Pred, BB, CondCmp);
2945 if ((LHSRes || RHSRes) && LHSRes != RHSRes) {
2981 if (LoopHeaders.count(BB))
2988 [](
Value *V) { return !isa<ConstantInt>(V); }))
2995 if (
SI->getParent() != BB)
2999 return Cond &&
Cond == V &&
Cond->getType()->isIntegerTy(1) && !IsAndOr;
3007 if (Cmp->getParent() == BB && Cmp->hasOneUse() &&
3010 if (isUnfoldCandidate(SelectI, Cmp->use_begin()->get())) {
3016 if (isUnfoldCandidate(SelectI, U.get())) {
3040 SI->replaceAllUsesWith(NewPN);
3042 auto *BPI = getBPI();
3043 auto *BFI = getBFI();
3050 assert(Denominator > 0 &&
3051 "At least one of the branch probabilities should be non-zero");
3059 BPI->setEdgeProbability(BB, BP);
3062 auto BBOrigFreq = BFI->getBlockFreq(BB);
3063 auto NewBBFreq = BBOrigFreq * TrueProb;
3064 BFI->setBlockFreq(NewBB, NewBBFreq);
3065 BFI->setBlockFreq(SplitBB, BBOrigFreq);
3068 SI->eraseFromParent();
3070 std::vector<DominatorTree::UpdateType> Updates;
3080 DTU->applyUpdatesPermissive(Updates);
3147 bool TrueDestIsSafe =
false;
3148 bool FalseDestIsSafe =
false;
3153 TrueDestIsSafe =
true;
3158 FalseDestIsSafe =
true;
3161 if (!TrueDestIsSafe && !FalseDestIsSafe)
3164 BasicBlock *PredUnguardedBlock = TrueDestIsSafe ? TrueDest : FalseDest;
3165 BasicBlock *PredGuardedBlock = FalseDestIsSafe ? TrueDest : FalseDest;
3171 if (
Cost > BBDupThreshold)
3176 BB, PredGuardedBlock, AfterGuard, GuardedMapping, *DTU);
3177 assert(GuardedBlock &&
"Could not create the guarded block?");
3182 BB, PredUnguardedBlock, Guard, UnguardedMapping, *DTU);
3183 assert(UnguardedBlock &&
"Could not create the unguarded block?");
3185 << GuardedBlock->
getName() <<
"\n");
3190 for (
auto BI = BB->
begin(); &*BI != AfterGuard; ++BI)
3198 if (!Inst->use_empty()) {
3200 NewPN->
addIncoming(UnguardedMapping[Inst], UnguardedBlock);
3201 NewPN->
addIncoming(GuardedMapping[Inst], GuardedBlock);
3204 Inst->replaceAllUsesWith(NewPN);
3206 Inst->dropDbgRecords();
3207 Inst->eraseFromParent();
3222template <
typename AnalysisT>
3223typename AnalysisT::Result *JumpThreadingPass::runExternalAnalysis() {
3224 assert(
FAM &&
"Can't run external analysis without FunctionAnalysisManager");
3229 if (!ChangedSinceLastAnalysisUpdate) {
3230 assert(!DTU->hasPendingUpdates() &&
3231 "Lost update of 'ChangedSinceLastAnalysisUpdate'?");
3233 return &
FAM->getResult<AnalysisT>(*F);
3235 ChangedSinceLastAnalysisUpdate =
false;
3237 auto PA = getPreservedAnalysis();
3240 PA.preserve<BranchProbabilityAnalysis>();
3241 PA.preserve<BlockFrequencyAnalysis>();
3243 FAM->invalidate(*F, PA);
3247 assert(DTU->getDomTree().verify(DominatorTree::VerificationLevel::Fast));
3248 assert((!DTU->hasPostDomTree() ||
3249 DTU->getPostDomTree().verify(
3250 PostDominatorTree::VerificationLevel::Fast)));
3252 auto *
Result = &FAM->getResult<AnalysisT>(*F);
3254 TTI = &FAM->getResult<TargetIRAnalysis>(*F);
3255 TLI = &FAM->getResult<TargetLibraryAnalysis>(*F);
3256 AA = &FAM->getResult<AAManager>(*F);
3263 assert(FAM &&
"Can't create BPI without FunctionAnalysisManager");
3264 BPI = FAM->getCachedResult<BranchProbabilityAnalysis>(*F);
3271 assert(FAM &&
"Can't create BFI without FunctionAnalysisManager");
3272 BFI = FAM->getCachedResult<BlockFrequencyAnalysis>(*F);
3281 auto *Res = getBPI();
3286 BPI = runExternalAnalysis<BranchProbabilityAnalysis>();
3292 auto *Res = getBFI();
3297 BFI = runExternalAnalysis<BlockFrequencyAnalysis>();
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
ReachingDefInfo InstSet & ToRemove
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static const Function * getParent(const Value *V)
This file contains the declarations for the subclasses of Constant, which represent the different fla...
This file defines the DenseMap class.
This is the interface for a simple mod/ref and alias analysis over globals.
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
Module.h This file contains the declarations for the Module class.
This header defines various interfaces for pass management in LLVM.
This defines the Use class.
static constexpr Value * getValue(Ty &ValueOrUse)
static unsigned getBestDestForJumpOnUndef(BasicBlock *BB)
GetBestDestForBranchOnUndef - If we determine that the specified block ends in an undefined jump,...
static cl::opt< unsigned > PhiDuplicateThreshold("jump-threading-phi-threshold", cl::desc("Max PHIs in BB to duplicate for jump threading"), cl::init(76), cl::Hidden)
static bool replaceFoldableUses(Instruction *Cond, Value *ToVal, BasicBlock *KnownAtEndOfBB)
static cl::opt< unsigned > BBDuplicateThreshold("jump-threading-threshold", cl::desc("Max block size to duplicate for jump threading"), cl::init(6), cl::Hidden)
static cl::opt< bool > ThreadAcrossLoopHeaders("jump-threading-across-loop-headers", cl::desc("Allow JumpThreading to thread across loop headers, for testing"), cl::init(false), cl::Hidden)
static unsigned getJumpThreadDuplicationCost(const TargetTransformInfo *TTI, BasicBlock *BB, Instruction *StopAt, unsigned Threshold)
Return the cost of duplicating a piece of this block from first non-phi and before StopAt instruction...
static void remapSourceAtoms(ValueToValueMapTy &VM, BasicBlock::iterator Begin, BasicBlock::iterator End)
static void addPHINodeEntriesForMappedBlock(BasicBlock *PHIBB, BasicBlock *OldPred, BasicBlock *NewPred, ValueToValueMapTy &ValueMap)
addPHINodeEntriesForMappedBlock - We're adding 'NewPred' as a new predecessor to the PHIBB block.
static BasicBlock * findMostPopularDest(BasicBlock *BB, const SmallVectorImpl< std::pair< BasicBlock *, BasicBlock * > > &PredToDestList)
findMostPopularDest - The specified list contains multiple possible threadable destinations.
static Constant * getKnownConstant(Value *Val, ConstantPreference Preference)
getKnownConstant - Helper method to determine if we can thread over a terminator with the given value...
static cl::opt< unsigned > ImplicationSearchThreshold("jump-threading-implication-search-threshold", cl::desc("The number of predecessors to search for a stronger " "condition to use to thread over a weaker condition"), cl::init(3), cl::Hidden)
static bool isOpDefinedInBlock(Value *Op, BasicBlock *BB)
Return true if Op is an instruction defined in the given block.
static void updatePredecessorProfileMetadata(PHINode *PN, BasicBlock *BB)
static bool hasAddressTakenAndUsed(BasicBlock *BB)
See the comments on JumpThreadingPass.
static bool isZero(Value *V, const DataLayout &DL, DominatorTree *DT, AssumptionCache *AC)
This file implements a map that provides insertion order iteration.
This file provides utility analysis objects describing memory locations.
FunctionAnalysisManager FAM
This file contains the declarations for profiling metadata utility functions.
const SmallVectorImpl< MachineOperand > & Cond
static DominatorTree getDomTree(Function &F)
This file defines the make_scope_exit function, which executes user-defined cleanup logic at scope ex...
This file defines the SmallPtrSet class.
This file defines the SmallVector class.
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
static const uint32_t IV[8]
A manager for alias analyses.
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
LLVM Basic Block Representation.
iterator begin()
Instruction iterator methods.
iterator_range< const_phi_iterator > phis() const
Returns a range that iterates over the phis in the basic block.
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.
LLVM_ABI DbgMarker * createMarker(Instruction *I)
Attach a DbgMarker to the given instruction.
bool hasAddressTaken() const
Returns true if there are any uses of this basic block other than direct branches,...
InstListType::const_iterator const_iterator
static BasicBlock * Create(LLVMContext &Context, const Twine &Name="", Function *Parent=nullptr, BasicBlock *InsertBefore=nullptr)
Creates a new BasicBlock.
LLVM_ABI void moveAfter(BasicBlock *MovePos)
Unlink this basic block from its current function and insert it right after MovePos in the function M...
LLVM_ABI bool hasNPredecessors(unsigned N) const
Return true if this block has exactly N predecessors.
LLVM_ABI const BasicBlock * getSinglePredecessor() const
Return the predecessor of this block if it has a single predecessor block.
const Instruction & front() const
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this basic block belongs to.
LLVM_ABI DbgMarker * getMarker(InstListType::iterator It)
Return the DbgMarker for the position given by It, so that DbgRecords can be inserted there.
InstListType::iterator iterator
Instruction iterators...
LLVM_ABI LLVMContext & getContext() const
Get the context in which this basic block lives.
LLVM_ABI bool isLandingPad() const
Return true if this basic block is a landing pad.
bool isEHPad() const
Return true if this basic block is an exception handling block.
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction; assumes that the block is well-formed.
LLVM_ABI void removePredecessor(BasicBlock *Pred, bool KeepOneInputPHIs=false)
Update PHI nodes in this BasicBlock before removal of predecessor Pred.
This class is a wrapper over an AAResults, and it is intended to be used only when there are no IR ch...
void disableDominatorTree()
Disable the use of the dominator tree during alias analysis queries.
The address of a basic block.
static LLVM_ABI BlockAddress * get(Function *F, BasicBlock *BB)
Return a BlockAddress for the specified function and basic block.
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
LLVM_ABI BlockFrequency getBlockFreq(const BasicBlock *BB) const
getblockFreq - Return block frequency.
Analysis providing branch probability information.
LLVM_ABI BranchProbability getEdgeProbability(const BasicBlock *Src, unsigned IndexInSuccessors) const
Get an edge's probability, relative to other out-edges of the Src.
static LLVM_ABI BranchProbability getBranchProbability(uint64_t Numerator, uint64_t Denominator)
uint32_t getNumerator() const
BranchProbability getCompl() const
static void normalizeProbabilities(ProbabilityIter Begin, ProbabilityIter End)
Value * getArgOperand(unsigned i) const
This class represents a function call, abstracting a target machine's calling convention.
This is the base class for all instructions that perform data casts.
static LLVM_ABI CastInst * CreateBitOrPointerCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a BitCast, a PtrToInt, or an IntToPTr cast instruction.
This class is the base class for the comparison instructions.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Predicate getPredicate() const
Return the predicate for this instruction.
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
Conditional Branch instruction.
static CondBrInst * Create(Value *Cond, BasicBlock *IfTrue, BasicBlock *IfFalse, InsertPosition InsertBefore=nullptr)
Value * getCondition() const
BasicBlock * getSuccessor(unsigned i) const
static LLVM_ABI Constant * getNot(Constant *C)
This is the shared class of boolean and integer constants.
bool isOne() const
This is just a convenience method to make client code smaller for a common case.
static LLVM_ABI ConstantInt * getTrue(LLVMContext &Context)
bool isZero() const
This is just a convenience method to make client code smaller for a common code.
static LLVM_ABI ConstantInt * getFalse(LLVMContext &Context)
const APInt & getValue() const
Return the constant as an APInt value reference.
This class represents a range of values.
LLVM_ABI ConstantRange add(const ConstantRange &Other) const
Return a new range representing the possible values resulting from an addition of a value in this ran...
static LLVM_ABI ConstantRange makeExactICmpRegion(CmpInst::Predicate Pred, const APInt &Other)
Produce the exact range such that all values in the returned range satisfy the given predicate with a...
LLVM_ABI ConstantRange inverse() const
Return a new range that is the logical not of the current set.
LLVM_ABI bool contains(const APInt &Val) const
Return true if the specified value is in the set.
This is an important base class in LLVM.
LLVM_ABI void removeDeadConstantUsers() const
If there are any dead constant users dangling off of this constant, remove them.
A parsed version of the target data layout string in and methods for querying it.
Per-instruction record of debug-info.
LLVM_ABI iterator_range< simple_ilist< DbgRecord >::iterator > cloneDebugInfoFrom(DbgMarker *From, std::optional< simple_ilist< DbgRecord >::iterator > FromHere, bool InsertAtHead=false)
Clone all DbgMarkers from From into this marker.
LLVM_ABI const BasicBlock * getParent() const
Record of a variable value-assignment, aka a non instruction representation of the dbg....
static DebugLoc getTemporary()
static DebugLoc getDropped()
ValueT lookup(const_arg_type_t< KeyT > Val) const
Return the entry for the specified key, or a default constructed value if no such entry exists.
std::pair< iterator, bool > insert(const std::pair< KeyT, ValueT > &KV)
Analysis pass which computes a DominatorTree.
static constexpr UpdateKind Delete
static constexpr UpdateKind Insert
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
LLVM_ABI bool isReachableFromEntry(const Use &U) const
Provide an overload for a Use.
This class represents a freeze function that returns random concrete value if an operand is either a ...
const BasicBlock & getEntryBlock() const
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
void flush()
Apply all pending updates to available trees and flush all BasicBlocks awaiting deletion.
This instruction compares its operands according to the predicate given to the constructor.
Indirect Branch Instruction.
LLVM_ABI iterator_range< simple_ilist< DbgRecord >::iterator > cloneDebugInfoFrom(const Instruction *From, std::optional< simple_ilist< DbgRecord >::iterator > FromHere=std::nullopt, bool InsertAtHead=false)
Clone any debug-info attached to From onto this instruction.
LLVM_ABI unsigned getNumSuccessors() const LLVM_READONLY
Return the number of successors that this instruction has.
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.
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.
LLVM_ABI BasicBlock * getSuccessor(unsigned Idx) const LLVM_READONLY
Return the specified successor. This instruction must be a terminator.
LLVM_ABI AAMDNodes getAAMetadata() const
Returns the AA metadata for this instruction.
unsigned getOpcode() const
Returns a member of one of the enums like Instruction::Add.
void setDebugLoc(DebugLoc Loc)
Set the debug location information for this instruction.
LLVM_ABI void setSuccessor(unsigned Idx, BasicBlock *BB)
Update the specified successor to point at the provided block.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this instruction belongs to.
bool isSpecialTerminator() const
A wrapper class for inspecting calls to intrinsic functions.
LLVM_ABI bool simplifyPartiallyRedundantLoad(LoadInst *LI)
simplifyPartiallyRedundantLoad - If LoadI is an obviously partially redundant load instruction,...
LLVM_ABI bool processBranchOnXOR(BinaryOperator *BO)
processBranchOnXOR - We have an otherwise unthreadable conditional branch on a xor instruction in the...
LLVM_ABI bool processGuards(BasicBlock *BB)
Try to propagate a guard from the current BB into one of its predecessors in case if another branch o...
LLVM_ABI void updateSSA(BasicBlock *BB, BasicBlock *NewBB, ValueToValueMapTy &ValueMapping)
Update the SSA form.
bool computeValueKnownInPredecessors(Value *V, BasicBlock *BB, jumpthreading::PredValueInfo &Result, jumpthreading::ConstantPreference Preference, Instruction *CxtI=nullptr)
LLVM_ABI void findLoopHeaders(Function &F)
findLoopHeaders - We do not want jump threading to turn proper loop structures into irreducible loops...
LLVM_ABI bool maybeMergeBasicBlockIntoOnlyPred(BasicBlock *BB)
Merge basic block BB into its sole predecessor if possible.
LLVM_ABI JumpThreadingPass(int T=-1)
LLVM_ABI void cloneInstructions(ValueToValueMapTy &ValueMapping, BasicBlock::iterator BI, BasicBlock::iterator BE, BasicBlock *NewBB, BasicBlock *PredBB)
Clone instructions in range [BI, BE) to NewBB.
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
LLVM_ABI Constant * evaluateOnPredecessorEdge(BasicBlock *BB, BasicBlock *PredPredBB, Value *cond, const DataLayout &DL)
LLVM_ABI bool processBranchOnPHI(PHINode *PN)
processBranchOnPHI - We have an otherwise unthreadable conditional branch on a PHI node (or freeze PH...
LLVM_ABI bool maybethreadThroughTwoBasicBlocks(BasicBlock *BB, Value *Cond)
Attempt to thread through two successive basic blocks.
LLVM_ABI bool computeValueKnownInPredecessorsImpl(Value *V, BasicBlock *BB, jumpthreading::PredValueInfo &Result, jumpthreading::ConstantPreference Preference, SmallPtrSet< Value *, 4 > &RecursionSet, Instruction *CxtI=nullptr)
computeValueKnownInPredecessors - Given a basic block BB and a value V, see if we can infer that the ...
LLVM_ABI void unfoldSelectInstr(BasicBlock *Pred, BasicBlock *BB, SelectInst *SI, PHINode *SIUse, unsigned Idx)
DomTreeUpdater * getDomTreeUpdater() const
LLVM_ABI bool runImpl(Function &F, FunctionAnalysisManager *FAM, TargetLibraryInfo *TLI, TargetTransformInfo *TTI, LazyValueInfo *LVI, AAResults *AA, std::unique_ptr< DomTreeUpdater > DTU, BlockFrequencyInfo *BFI, BranchProbabilityInfo *BPI)
LLVM_ABI bool processThreadableEdges(Value *Cond, BasicBlock *BB, jumpthreading::ConstantPreference Preference, Instruction *CxtI=nullptr)
LLVM_ABI bool threadGuard(BasicBlock *BB, IntrinsicInst *Guard, CondBrInst *BI)
Try to propagate the guard from BB which is the lower block of a diamond to one of its branches,...
LLVM_ABI bool processBlock(BasicBlock *BB)
processBlock - If there are any predecessors whose control can be threaded through to a successor,...
LLVM_ABI bool processImpliedCondition(BasicBlock *BB)
LLVM_ABI bool duplicateCondBranchOnPHIIntoPred(BasicBlock *BB, const SmallVectorImpl< BasicBlock * > &PredBBs)
duplicateCondBranchOnPHIIntoPred - PredBB contains an unconditional branch to BB which contains an i1...
LLVM_ABI void threadThroughTwoBasicBlocks(BasicBlock *PredPredBB, BasicBlock *PredBB, BasicBlock *BB, BasicBlock *SuccBB)
LLVM_ABI bool tryThreadEdge(BasicBlock *BB, const SmallVectorImpl< BasicBlock * > &PredBBs, BasicBlock *SuccBB)
tryThreadEdge - Thread an edge if it's safe and profitable to do so.
LLVM_ABI bool tryToUnfoldSelect(CmpInst *CondCmp, BasicBlock *BB)
tryToUnfoldSelect - Look for blocks of the form bb1: a = select br bb2
LLVM_ABI bool tryToUnfoldSelectInCurrBB(BasicBlock *BB)
tryToUnfoldSelectInCurrBB - Look for PHI/Select or PHI/CMP/Select in the same BB in the form bb: p = ...
LLVM_ABI void threadEdge(BasicBlock *BB, const SmallVectorImpl< BasicBlock * > &PredBBs, BasicBlock *SuccBB)
threadEdge - We have decided that it is safe and profitable to factor the blocks in PredBBs to one pr...
This is an important class for using LLVM in a threaded context.
Analysis to compute lazy value information.
This pass computes, caches, and vends lazy value constraint information.
An instruction for reading from memory.
AtomicOrdering getOrdering() const
Returns the ordering constraint of this load instruction.
SyncScope::ID getSyncScopeID() const
Returns the synchronization scope ID of this load instruction.
Align getAlign() const
Return the alignment of the access that is being performed.
static LocationSize precise(uint64_t Value)
This class implements a map that also provides access to all stored values in a deterministic order.
Representation for a specific memory location.
void addIncoming(Value *V, BasicBlock *BB)
Add an incoming value to the end of the PHI list.
void setIncomingValue(unsigned i, Value *V)
Value * getIncomingValueForBlock(const BasicBlock *BB) const
BasicBlock * getIncomingBlock(unsigned i) const
Return incoming basic block number i.
Value * getIncomingValue(unsigned i) const
Return incoming value number x.
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 PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
A set of analyses that are preserved following a run of a transformation pass.
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
PreservedAnalyses & preserve()
Mark an analysis as preserved.
Helper class for SSA formation on a set of values defined in multiple blocks.
LLVM_ABI void RewriteUse(Use &U)
Rewrite a use of the symbolic value.
LLVM_ABI void Initialize(Type *Ty, StringRef Name)
Reset this object to get ready for a new set of SSA updates with type 'Ty'.
LLVM_ABI void UpdateDebugValues(Instruction *I)
Rewrite debug value intrinsics to conform to a new SSA form.
LLVM_ABI void AddAvailableValue(BasicBlock *BB, Value *V)
Indicate that a rewritten value is available in the specified block with the specified value.
This class represents the LLVM 'select' instruction.
bool erase(PtrType Ptr)
Remove pointer from the set.
size_type count(ConstPtrType Ptr) const
count - Return 1 if the specified pointer is in the set, 0 otherwise.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
SmallSet - This maintains a set of unique values, optimizing for the case when the set is small (less...
std::pair< const_iterator, bool > insert(const T &V)
insert - Insert an element into the set if it isn't already there.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void assign(size_type NumElts, ValueParamT Elt)
reference emplace_back(ArgTypes &&... Args)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Analysis pass providing the TargetTransformInfo.
Analysis pass providing the TargetLibraryInfo.
Provides information about what library functions are available for the current target.
The instances of the Type class are immutable: once they are created, they are never changed.
bool isVectorTy() const
True if this is an instance of VectorType.
bool isIntegerTy() const
True if this is an instance of IntegerType.
Unconditional Branch instruction.
static UncondBrInst * Create(BasicBlock *Target, InsertPosition InsertBefore=nullptr)
'undef' values are things that do not have specified contents.
static LLVM_ABI UndefValue * get(Type *T)
Static factory methods - Return an 'undef' object of the specified type.
A Use represents the edge between a Value definition and its users.
void setOperand(unsigned i, Value *Val)
Value * getOperand(unsigned i) const
iterator find(const KeyT &Val)
ValueMapIteratorImpl< MapT, const Value *, false > iterator
DMAtomT AtomMap
Map {(InlinedAt, old atom number) -> new atom number}.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI const Value * DoPHITranslation(const BasicBlock *CurBB, const BasicBlock *PredBB) const
Translate PHI node to its predecessor from the given basic block.
bool hasOneUse() const
Return true if there is exactly one use of this value.
LLVM_ABI void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
LLVM_ABI const Value * stripPointerCasts() const
Strip off pointer casts, all-zero GEPs and address space casts.
iterator_range< use_iterator > uses()
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
LLVM_ABI void takeName(Value *V)
Transfer the name from V to this value.
const ParentTy * getParent() const
self_iterator getIterator()
NodeTy * getNextNode()
Get the next node, or nullptr for the list tail.
@ C
The default llvm calling convention, compatible with C.
LLVM_ABI Function * getDeclarationIfExists(const Module *M, ID id)
Look up the Function declaration of the intrinsic id in the Module M and return it if it exists.
match_combine_or< Ty... > m_CombineOr(const Ty &...Ps)
Combine pattern matchers matching any of Ps patterns.
auto m_Cmp()
Matches any compare instruction and ignore it.
BinaryOp_match< LHS, RHS, Instruction::Add > m_Add(const LHS &L, const RHS &R)
bool match(Val *V, const Pattern &P)
auto m_Value()
Match an arbitrary value and ignore it.
auto m_Constant()
Match an arbitrary Constant and ignore it.
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
auto m_ConstantInt()
Match an arbitrary ConstantInt and ignore it.
initializer< Ty > init(const Ty &Val)
A private "module" namespace for types and utilities used by JumpThreading.
SmallVector< std::pair< Constant *, BasicBlock * >, 8 > PredValueInfoTy
SmallVectorImpl< std::pair< Constant *, BasicBlock * > > PredValueInfo
friend class Instruction
Iterator for Instructions in a `BasicBlock.
This is an optimization pass for GlobalISel generic memory operations.
LLVM_ABI bool RemoveRedundantDbgInstrs(BasicBlock *BB)
Try to remove redundant dbg.value instructions from given basic block.
LLVM_ABI cl::opt< bool > ProfcheckDisableMetadataFixes
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI bool ConstantFoldTerminator(BasicBlock *BB, bool DeleteDeadConditions=false, const TargetLibraryInfo *TLI=nullptr, DomTreeUpdater *DTU=nullptr)
If a terminator instruction is predicated on a constant value, convert it into an unconditional branc...
static cl::opt< unsigned long > StopAt("sbvec-stop-at", cl::init(StopAtDisabled), cl::Hidden, cl::desc("Vectorize if the invocation count is < than this. 0 " "disables vectorization."))
LLVM_ABI void findDbgValues(Value *V, SmallVectorImpl< DbgVariableRecord * > &DbgVariableRecords)
Finds the dbg.values describing a value.
auto enumerate(FirstRange &&First, RestRanges &&...Rest)
Given two or more input ranges, returns a new range whose values are tuples (A, B,...
auto pred_end(const MachineBasicBlock *BB)
LLVM_ABI unsigned replaceNonLocalUsesWith(Instruction *From, Value *To)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto successors(const MachineBasicBlock *BB)
LLVM_ABI Constant * ConstantFoldInstruction(const Instruction *I, const DataLayout &DL, const TargetLibraryInfo *TLI=nullptr)
ConstantFoldInstruction - Try to constant fold the specified instruction.
constexpr from_range_t from_range
LLVM_ABI MDNode * getBranchWeightMDNode(const Instruction &I)
Get the branch weights metadata node.
LLVM_ABI Value * findAvailablePtrLoadStore(const MemoryLocation &Loc, Type *AccessTy, bool AtLeastAtomic, BasicBlock *ScanBB, BasicBlock::iterator &ScanFrom, unsigned MaxInstsToScan, BatchAAResults *AA, bool *IsLoadCSE, unsigned *NumScanedInst)
Scan backwards to see if we have the value of the given pointer available locally within a small numb...
LLVM_ABI void remapDebugVariable(ValueToValueMapTy &Mapping, Instruction *Inst)
Remap the operands of the debug records attached to Inst, and the operands of Inst itself if it's a d...
LLVM_ABI Constant * ConstantFoldCompareInstOperands(unsigned Predicate, Constant *LHS, Constant *RHS, const DataLayout &DL, const TargetLibraryInfo *TLI=nullptr, const Instruction *I=nullptr)
Attempt to constant fold a compare instruction (icmp/fcmp) with the specified operands.
auto pred_size(const MachineBasicBlock *BB)
LLVM_ABI bool SimplifyInstructionsInBlock(BasicBlock *BB, const TargetLibraryInfo *TLI=nullptr)
Scan the specified basic block and try to simplify any instructions in it and recursively delete dead...
LLVM_ABI void DeleteDeadBlock(BasicBlock *BB, DomTreeUpdater *DTU=nullptr, bool KeepOneInputPHIs=false)
Delete the specified block, which must have no predecessors.
LLVM_ABI Value * FindAvailableLoadedValue(LoadInst *Load, BasicBlock *ScanBB, BasicBlock::iterator &ScanFrom, unsigned MaxInstsToScan=DefMaxInstsToScan, BatchAAResults *AA=nullptr, bool *IsLoadCSE=nullptr, unsigned *NumScanedInst=nullptr)
Scan backwards to see if we have the value of the given load available locally within a small number ...
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 hasBranchWeightOrigin(const Instruction &I)
Check if Branch Weight Metadata has an "expected" field from an llvm.expect* intrinsic.
LLVM_ABI BasicBlock * DuplicateInstructionsInSplitBetween(BasicBlock *BB, BasicBlock *PredBB, Instruction *StopAt, ValueToValueMapTy &ValueMapping, DomTreeUpdater &DTU)
Split edge between BB and PredBB and duplicate all non-Phi instructions from BB between its beginning...
auto map_range(ContainerTy &&C, FuncTy F)
Return a range that applies F to the elements of C.
LLVM_ABI Value * simplifyInstruction(Instruction *I, const SimplifyQuery &Q)
See if we can compute a simplified version of this instruction.
LLVM_ABI void setBranchWeights(Instruction &I, ArrayRef< uint32_t > Weights, bool IsExpected, bool ElideAllZero=false)
Create a new branch_weights metadata node and add or overwrite a prof metadata reference to instructi...
auto dyn_cast_or_null(const Y &Val)
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
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.
constexpr detail::StaticCastFunc< To > StaticCastTo
Function objects corresponding to the Cast types defined above.
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....
LLVM_ABI bool TryToSimplifyUncondBranchFromEmptyBlock(BasicBlock *BB, DomTreeUpdater *DTU=nullptr)
BB is known to contain an unconditional branch, and contains no instructions other than PHI nodes,...
LLVM_ABI bool HasLoopOrEntryConvergenceToken(const BasicBlock *BB)
Check if the given basic block contains any loop or entry convergent intrinsic instructions.
auto reverse(ContainerTy &&C)
LLVM_ABI bool hasValidBranchWeightMD(const Instruction &I)
Checks if an instructions has valid Branch Weight Metadata.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
auto make_first_range(ContainerTy &&c)
Given a container of pairs, return a range over the first elements.
LLVM_ABI Constant * ConstantFoldCastOperand(unsigned Opcode, Constant *C, Type *DestTy, const DataLayout &DL)
Attempt to constant fold a cast with the specified operand.
LLVM_ABI void cloneNoAliasScopes(ArrayRef< MDNode * > NoAliasDeclScopes, DenseMap< MDNode *, MDNode * > &ClonedScopes, StringRef Ext, LLVMContext &Context)
Duplicate the specified list of noalias decl scopes.
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
LLVM_ABI cl::opt< unsigned > DefMaxInstsToScan
The default number of maximum instructions to scan in the block, used by FindAvailableLoadedValue().
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...
LLVM_ABI void SplitLandingPadPredecessors(BasicBlock *OrigBB, ArrayRef< BasicBlock * > Preds, const char *Suffix, const char *Suffix2, SmallVectorImpl< BasicBlock * > &NewBBs, DomTreeUpdater *DTU=nullptr, LoopInfo *LI=nullptr, MemorySSAUpdater *MSSAU=nullptr, bool PreserveLCSSA=false)
This method transforms the landing pad, OrigBB, by introducing two new basic blocks into the function...
LLVM_ABI Constant * ConstantFoldBinaryOpOperands(unsigned Opcode, Constant *LHS, Constant *RHS, const DataLayout &DL)
Attempt to constant fold a binary operation with the specified operands.
LLVM_ABI void combineMetadataForCSE(Instruction *K, const Instruction *J, bool DoesKMove)
Combine the metadata of two instructions so that K can replace J.
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...
LLVM_ABI void MergeBasicBlockIntoOnlyPred(BasicBlock *BB, DomTreeUpdater *DTU=nullptr)
BB is a block with one predecessor and its predecessor is known to have one successor (BB!...
auto lower_bound(R &&Range, T &&Value)
Provide wrappers to std::lower_bound which take ranges instead of having to pass begin/end explicitly...
LLVM_ABI void adaptNoAliasScopes(llvm::Instruction *I, const DenseMap< MDNode *, MDNode * > &ClonedScopes, LLVMContext &Context)
Adapt the metadata for the specified instruction according to the provided mapping.
DWARFExpression::Operation Op
auto max_element(R &&Range)
Provide wrappers to std::max_element which take ranges instead of having to pass begin/end explicitly...
LLVM_ABI bool isGuaranteedNotToBeUndefOrPoison(const Value *V, AssumptionCache *AC=nullptr, const Instruction *CtxI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Return true if this function can prove that V does not have undef bits and is never poison.
auto make_second_range(ContainerTy &&c)
Given a container of pairs, return a range over the second elements.
auto sum_of(R &&Range, E Init=E{0})
Returns the sum of all values in Range with Init initial value.
ValueMap< const Value *, WeakTrackingVH > ValueToValueMapTy
LLVM_ABI bool isGuaranteedToTransferExecutionToSuccessor(const Instruction *I)
Return true if this function can prove that the instruction I will always transfer execution to one o...
LLVM_ABI bool extractBranchWeights(const MDNode *ProfileData, SmallVectorImpl< uint32_t > &Weights)
Extract branch weights from MD_prof metadata.
auto pred_begin(const MachineBasicBlock *BB)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
void erase_if(Container &C, UnaryPredicate P)
Provide a container algorithm similar to C++ Library Fundamentals v2's erase_if which is equivalent t...
auto predecessors(const MachineBasicBlock *BB)
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
bool pred_empty(const BasicBlock *BB)
LLVM_ABI Instruction * SplitBlockAndInsertIfThen(Value *Cond, BasicBlock::iterator SplitBefore, bool Unreachable, MDNode *BranchWeights=nullptr, DomTreeUpdater *DTU=nullptr, LoopInfo *LI=nullptr, BasicBlock *ThenBlock=nullptr)
Split the containing block at the specified instruction - everything before SplitBefore stays in the ...
LLVM_ABI Value * simplifyCmpInst(CmpPredicate Predicate, Value *LHS, Value *RHS, const SimplifyQuery &Q)
Given operands for a CmpInst, fold the result or return null.
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
void array_pod_sort(IteratorTy Start, IteratorTy End)
array_pod_sort - This sorts an array with the specified start and end extent.
LLVM_ABI void identifyNoAliasScopesToClone(ArrayRef< BasicBlock * > BBs, SmallVectorImpl< MDNode * > &NoAliasDeclScopes)
Find the 'llvm.experimental.noalias.scope.decl' intrinsics in the specified basic blocks and extract ...
LLVM_ABI BasicBlock * SplitEdge(BasicBlock *From, BasicBlock *To, DominatorTree *DT=nullptr, LoopInfo *LI=nullptr, MemorySSAUpdater *MSSAU=nullptr, const Twine &BBName="")
Split the edge connecting the specified blocks, and return the newly created basic block between From...
AAResults AliasAnalysis
Temporary typedef for legacy code that uses a generic AliasAnalysis pointer or reference.
static auto filterDbgVars(iterator_range< simple_ilist< DbgRecord >::iterator > R)
Filter the DbgRecord range to DbgVariableRecord types only and downcast.
LLVM_ABI void FindFunctionBackedges(const Function &F, SmallVectorImpl< std::pair< const BasicBlock *, const BasicBlock * > > &Result)
Analyze the specified function to find all of the loop backedges in the function and return them.
LLVM_ABI void RemapSourceAtom(Instruction *I, ValueToValueMapTy &VM)
Remap source location atom.
LLVM_ABI std::optional< bool > isImpliedCondition(const Value *LHS, const Value *RHS, const DataLayout &DL, bool LHSIsTrue=true, unsigned Depth=0)
Return true if RHS is known to be implied true by LHS.
LLVM_ABI void mapAtomInstance(const DebugLoc &DL, ValueToValueMapTy &VMap)
Mark a cloned instruction as a new instance so that its source loc can be updated when remapped.
A collection of metadata nodes that might be associated with a memory access used by the alias-analys...
Function object to check whether the second component of a container supported by std::get (like std:...