41#define DEBUG_TYPE "sccp"
82 <<
" as a constant\n");
86 LLVM_DEBUG(
dbgs() <<
" Constant: " << *Const <<
" = " << *V <<
'\n');
89 V->replaceAllUsesWith(Const);
99 return Const->toConstantRange();
101 unsigned Bitwidth =
Op->getType()->getScalarSizeInBits();
102 return ConstantRange::getFull(Bitwidth);
113 auto GetRange = [&Solver, &InsertedValues](
Value *
Op) {
127 if (NUWRange.contains(RangeA)) {
136 if (NSWRange.contains(RangeA)) {
143 if (
Range.isAllNonNegative()) {
148 if (TI->hasNoSignedWrap() && TI->hasNoUnsignedWrap())
152 uint64_t DestWidth = TI->getDestTy()->getScalarSizeInBits();
153 if (!TI->hasNoUnsignedWrap()) {
154 if (
Range.getActiveBits() <= DestWidth) {
155 TI->setHasNoUnsignedWrap(
true);
159 if (!TI->hasNoSignedWrap()) {
160 if (
Range.getMinSignedBits() <= DestWidth) {
161 TI->setHasNoSignedWrap(
true);
166 if (
GEP->hasNoUnsignedWrap() || !
GEP->hasNoUnsignedSignedWrap())
170 [&](
Value *V) { return GetRange(V).isAllNonNegative(); })) {
171 GEP->setNoWrapFlags(
GEP->getNoWrapFlags() |
185 auto isNonNegative = [&Solver, &InsertedValues](
Value *V) {
191 case Instruction::SIToFP:
192 case Instruction::SExt: {
195 if (!isNonNegative(Op0))
199 : Instruction::UIToFP,
204 case Instruction::AShr: {
207 if (!isNonNegative(Op0))
213 case Instruction::SDiv:
214 case Instruction::SRem: {
217 if (!isNonNegative(Op0) || !isNonNegative(Op1))
219 auto NewOpcode = Inst.
getOpcode() == Instruction::SDiv ? Instruction::UDiv
222 if (Inst.
getOpcode() == Instruction::SDiv)
231 assert(NewInst &&
"Expected replacement instruction");
233 InsertedValues.
insert(NewInst);
245 auto GetRange = [&Solver, &InsertedValues](
Value *
Op) {
260 Value *LHS = Cmp->getOperand(0);
261 Value *RHS = Cmp->getOperand(1);
262 unsigned BitWidth = LHS->getType()->getScalarSizeInBits();
276 if (!RHSLower.
icmp(Pred, LRange) || !LRange.
icmp(Pred, RHSUpper))
293 auto MatchTwoInstructionExactRangeCheck =
294 [&]() -> std::optional<ConstantRange> {
299 Value *LHS = ICmp->getOperand(0);
305 if (ICmp->isEquality()) {
316 if (
auto CR = MatchTwoInstructionExactRangeCheck()) {
321 auto ConvertCRToICmp =
322 [&](
const std::optional<ConstantRange> &NewCR) ->
Value * {
326 if (NewCR && NewCR->getEquivalentICmp(Pred, RHS)) {
329 Builder.CreateICmp(Pred,
X, ConstantInt::get(
X->getType(), RHS));
330 InsertedValues.
insert(NewICmp);
339 if (
auto *V = ConvertCRToICmp(CR->exactIntersectWith(LRange)))
342 if (
auto *V = ConvertCRToICmp(CR->exactUnionWith(LRange.
inverse())))
354 bool MadeChanges =
false;
356 if (Inst.getType()->isVoidTy())
360 Inst.eraseFromParent();
370 Inst.replaceAllUsesWith(V);
371 Inst.eraseFromParent();
382 bool HasNonFeasibleEdges =
false;
385 FeasibleSuccessors.
insert(Succ);
387 HasNonFeasibleEdges =
true;
391 if (!HasNonFeasibleEdges)
398 "Terminator must be a br, switch or indirectbr");
400 if (FeasibleSuccessors.
size() == 0) {
405 Succ->removePredecessor(BB);
406 if (SeenSuccs.
insert(Succ).second)
412 }
else if (FeasibleSuccessors.
size() == 1) {
416 bool HaveSeenOnlyFeasibleSuccessor =
false;
418 if (Succ == OnlyFeasibleSuccessor && !HaveSeenOnlyFeasibleSuccessor) {
421 HaveSeenOnlyFeasibleSuccessor =
true;
425 Succ->removePredecessor(BB);
433 }
else if (FeasibleSuccessors.
size() > 1) {
440 if (!FeasibleSuccessors.
contains(DefaultDest)) {
441 if (!NewUnreachableBB) {
451 SI->setDefaultDest(NewUnreachableBB);
456 for (
auto CI =
SI->case_begin(); CI !=
SI->case_end();) {
457 if (FeasibleSuccessors.
contains(CI->getCaseSuccessor())) {
485 Attribute OldAttr =
F->getAttributeAtIndex(AttrIndex, Attribute::Range);
489 F->addAttributeAtIndex(
496 !
F->hasAttributeAtIndex(AttrIndex, Attribute::NonNull)) {
497 F->addAttributeAtIndex(AttrIndex,
512 if (!
A.getType()->isStructTy())
548 TrackedMultipleRetVals;
580 using Edge = std::pair<BasicBlock *, BasicBlock *>;
600 void pushUsersToWorkList(
Value *V);
610 bool MayIncludeUndef =
false);
613 assert(!V->getType()->isStructTy() &&
"structs should use mergeInValue");
614 return markConstant(ValueState[V], V,
C);
646 assert(!V->getType()->isStructTy() &&
"Should use getStructValueState");
648 auto I = ValueState.try_emplace(V);
665 assert(V->getType()->isStructTy() &&
"Should use getValueState");
667 "Invalid element #");
669 auto I = StructValueState.insert(
677 Constant *Elt =
C->getAggregateElement(i);
695 while (!ToInvalidate.
empty()) {
698 if (!Invalidated.insert(Inst).second)
701 if (!BBExecutable.count(Inst->
getParent()))
708 Function *
F = RetInst->getParent()->getParent();
709 if (
auto It = TrackedRetVals.find(
F); It != TrackedRetVals.end()) {
712 }
else if (MRVFunctionsTracked.count(
F)) {
714 for (
unsigned I = 0, E = STy->getNumElements();
I != E; ++
I)
719 for (
unsigned I = 0, E = STy->getNumElements();
I != E; ++
I) {
720 if (
auto It = StructValueState.find({Inst, I});
721 It != StructValueState.end()) {
726 }
else if (
auto It = ValueState.find(Inst); It != ValueState.end()) {
738 auto It = AdditionalUsers.find(V);
739 if (It != AdditionalUsers.end())
740 for (
User *U : It->second)
756 void addAdditionalUser(
Value *V,
User *U) { AdditionalUsers[V].insert(U); }
759 void handleCallOverdefined(
CallBase &CB);
760 void handleCallResult(
CallBase &CB);
761 void handleCallArguments(
CallBase &CB);
789 markOverdefined(&CPI);
790 visitTerminator(CPI);
807 visitTerminator(CBI);
810 void visitCallBase(CallBase &CB);
811 void visitResumeInst(ResumeInst &
I) {
813 void visitUnreachableInst(UnreachableInst &
I) {
815 void visitFenceInst(FenceInst &
I) {
818 void visitInstruction(Instruction &
I);
822 FnPredicateInfo.insert({&
F, std::make_unique<PredicateInfo>(
823 F, DT, AC, PredicateInfoAllocator)});
827 auto It = FnPredicateInfo.find(&
F);
828 if (It == FnPredicateInfo.end())
834 if (BC->getType() == BC->getOperand(0)->getType()) {
835 if (It->second->getPredicateInfoFor(&Inst)) {
837 Inst.replaceAllUsesWith(
Op);
838 Inst.eraseFromParent();
851 auto It = FnPredicateInfo.find(
I->getParent()->getParent());
852 if (It == FnPredicateInfo.end())
854 return It->second->getPredicateInfoFor(
I);
860 : DL(DL), GetTLI(GetTLI), Ctx(Ctx) {}
873 MRVFunctionsTracked.insert(
F);
874 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i)
875 TrackedMultipleRetVals.try_emplace(std::make_pair(
F, i));
876 }
else if (!
F->getReturnType()->isVoidTy())
877 TrackedRetVals.try_emplace(
F);
881 MustPreserveReturnsInFunctions.insert(
F);
885 return MustPreserveReturnsInFunctions.count(
F);
889 TrackingIncomingArguments.insert(
F);
893 return TrackingIncomingArguments.count(
F);
897 return TrackingIncomingArguments;
907 return BBExecutable.count(BB);
913 std::vector<ValueLatticeElement> StructValues;
915 assert(STy &&
"getStructLatticeValueFor() can be called only on structs");
916 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i) {
917 auto I = StructValueState.find(std::make_pair(V, i));
918 assert(
I != StructValueState.end() &&
"Value not in valuemap!");
919 StructValues.push_back(
I->second);
932 assert(!
F->getReturnType()->isVoidTy() &&
933 (TrackedRetVals.count(
F) || MRVFunctionsTracked.count(
F)) &&
934 "All non void specializations should be tracked");
936 handleCallResult(*
Call);
940 assert(!V->getType()->isStructTy() &&
941 "Should use getStructLatticeValueFor");
944 assert(
I != ValueState.end() &&
945 "V not found in ValueState nor Paramstate map!");
950 return TrackedRetVals;
955 return TrackedGlobals;
959 return MRVFunctionsTracked;
964 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i)
965 markOverdefined(getStructValueState(V, i), V);
967 markOverdefined(ValueState[V], V);
971 if (
A->getType()->isIntOrIntVectorTy()) {
972 if (std::optional<ConstantRange>
Range =
A->getRange())
975 if (
A->hasNonNullAttr())
982 if (
A->getType()->isStructTy())
983 return (
void)markOverdefined(
A);
998 BBExecutable.erase(&BB);
1002 bool ResolvedUndefs =
true;
1003 while (ResolvedUndefs) {
1005 ResolvedUndefs =
false;
1012 bool ResolvedUndefs =
true;
1013 while (ResolvedUndefs) {
1015 ResolvedUndefs =
false;
1022 bool ResolvedUndefs =
true;
1023 while (ResolvedUndefs) {
1025 ResolvedUndefs =
false;
1026 for (
Value *V : Invalidated)
1030 Invalidated.clear();
1037 if (!BBExecutable.insert(BB).second)
1040 BBWorkList.push_back(BB);
1049 if (CurI &&
I->getParent() == CurI->
getParent() && !
I->comesBefore(CurI))
1054 InstWorkList.insert(
I);
1057void SCCPInstVisitor::pushUsersToWorkList(
Value *V) {
1062 auto Iter = AdditionalUsers.find(V);
1063 if (Iter != AdditionalUsers.end()) {
1067 for (
User *U : Iter->second)
1078 pushUsersToWorkList(V);
1083 if (!
IV.markConstant(
C, MayIncludeUndef))
1086 pushUsersToWorkList(V);
1092 if (!
IV.markNotConstant(
C))
1094 LLVM_DEBUG(
dbgs() <<
"markNotConstant: " << *
C <<
": " << *V <<
'\n');
1095 pushUsersToWorkList(V);
1101 if (!
IV.markConstantRange(CR))
1103 LLVM_DEBUG(
dbgs() <<
"markConstantRange: " << CR <<
": " << *V <<
'\n');
1104 pushUsersToWorkList(V);
1109 if (!
IV.markOverdefined())
1114 <<
"Function '" <<
F->getName() <<
"'\n";
1115 else dbgs() << *V <<
'\n');
1117 pushUsersToWorkList(V);
1123 const auto &It = TrackedMultipleRetVals.find(std::make_pair(
F, i));
1124 assert(It != TrackedMultipleRetVals.end());
1135 assert(
C->getType() == Ty &&
"Type mismatch");
1149 if (V->getType()->isStructTy()) {
1153 std::vector<Constant *> ConstVals;
1155 for (
unsigned I = 0, E = ST->getNumElements();
I != E; ++
I) {
1169 assert(Const &&
"Constant is nullptr here!");
1175 assert(!Args.empty() &&
"Specialization without arguments");
1176 assert(
F->arg_size() == Args[0].Formal->getParent()->arg_size() &&
1177 "Functions should have the same number of arguments");
1179 auto Iter = Args.begin();
1182 for (
auto End =
F->arg_end(); NewArg != End; ++NewArg, ++OldArg) {
1189 if (Iter != Args.end() && Iter->Formal == &*OldArg) {
1191 for (
unsigned I = 0, E = STy->getNumElements();
I != E; ++
I) {
1193 NewValue.
markConstant(Iter->Actual->getAggregateElement(
I));
1196 ValueState[&*NewArg].markConstant(Iter->Actual);
1201 for (
unsigned I = 0, E = STy->getNumElements();
I != E; ++
I) {
1203 NewValue = StructValueState[{&*OldArg,
I}];
1207 NewValue = ValueState[&*OldArg];
1213void SCCPInstVisitor::visitInstruction(
Instruction &
I) {
1216 LLVM_DEBUG(
dbgs() <<
"SCCP: Don't know how to handle: " <<
I <<
'\n');
1217 markOverdefined(&
I);
1223 if (
IV.mergeIn(MergeWithV, Opts)) {
1224 pushUsersToWorkList(V);
1225 LLVM_DEBUG(
dbgs() <<
"Merged " << MergeWithV <<
" into " << *V <<
" : "
1233 if (!KnownFeasibleEdges.insert(Edge(Source, Dest)).second)
1241 <<
" -> " << Dest->
getName() <<
'\n');
1243 for (PHINode &PN : Dest->
phis())
1244 pushToWorkList(&PN);
1251void SCCPInstVisitor::getFeasibleSuccessors(
Instruction &TI,
1255 if (BI->isUnconditional()) {
1260 const ValueLatticeElement &BCValue = getValueState(BI->getCondition());
1261 ConstantInt *CI =
getConstantInt(BCValue, BI->getCondition()->getType());
1266 Succs[0] = Succs[1] =
true;
1271 Succs[CI->
isZero()] =
true;
1283 if (!
SI->getNumCases()) {
1287 const ValueLatticeElement &SCValue = getValueState(
SI->getCondition());
1288 if (ConstantInt *CI =
1290 Succs[
SI->findCaseValue(CI)->getSuccessorIndex()] =
true;
1298 unsigned ReachableCaseCount = 0;
1299 for (
const auto &Case :
SI->cases()) {
1300 const APInt &CaseValue = Case.getCaseValue()->getValue();
1302 Succs[Case.getSuccessorIndex()] =
true;
1303 ++ReachableCaseCount;
1307 Succs[
SI->case_default()->getSuccessorIndex()] =
1322 const ValueLatticeElement &IBRValue = getValueState(IBR->getAddress());
1324 getConstant(IBRValue, IBR->getAddress()->getType()));
1334 "Block address of a different function ?");
1335 for (
unsigned i = 0; i < IBR->getNumSuccessors(); ++i) {
1337 if (IBR->getDestination(i) ==
T) {
1348 LLVM_DEBUG(
dbgs() <<
"Unknown terminator instruction: " << TI <<
'\n');
1358 return KnownFeasibleEdges.count(
Edge(From, To));
1378void SCCPInstVisitor::visitPHINode(
PHINode &PN) {
1382 return (
void)markOverdefined(&PN);
1384 if (isInstFullyOverDefined(PN))
1399 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i) {
1403 for (
unsigned j : FeasibleIncomingIndices) {
1410 ValueLatticeElement &PhiStateRef = getStructValueState(&PN, i);
1411 mergeInValue(PhiStateRef, &PN, PhiState,
1412 ValueLatticeElement::MergeOptions().setMaxWidenSteps(
1413 FeasibleIncomingIndices.size() + 1));
1415 std::max((
unsigned)FeasibleIncomingIndices.size(),
1419 ValueLatticeElement PhiState = getValueState(&PN);
1420 for (
unsigned i : FeasibleIncomingIndices) {
1431 ValueLatticeElement &PhiStateRef = ValueState[&PN];
1432 mergeInValue(PhiStateRef, &PN, PhiState,
1433 ValueLatticeElement::MergeOptions().setMaxWidenSteps(
1434 FeasibleIncomingIndices.size() + 1));
1436 std::max((
unsigned)FeasibleIncomingIndices.size(),
1441void SCCPInstVisitor::visitReturnInst(
ReturnInst &
I) {
1442 if (
I.getNumOperands() == 0)
1446 Value *ResultOp =
I.getOperand(0);
1450 auto TFRVI = TrackedRetVals.find(
F);
1451 if (TFRVI != TrackedRetVals.end()) {
1452 mergeInValue(TFRVI->second,
F, getValueState(ResultOp));
1458 if (!TrackedMultipleRetVals.empty()) {
1460 if (MRVFunctionsTracked.count(
F))
1461 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i)
1462 mergeInValue(TrackedMultipleRetVals[std::make_pair(
F, i)],
F,
1463 getStructValueState(ResultOp, i));
1467void SCCPInstVisitor::visitTerminator(
Instruction &TI) {
1469 getFeasibleSuccessors(TI, SuccFeasible);
1474 for (
unsigned i = 0, e = SuccFeasible.
size(); i != e; ++i)
1475 if (SuccFeasible[i])
1479void SCCPInstVisitor::visitCastInst(
CastInst &
I) {
1482 if (ValueState[&
I].isOverdefined())
1486 if (BC->getType() == BC->getOperand(0)->getType()) {
1488 handlePredicate(&
I,
I.getOperand(0), PI);
1494 const ValueLatticeElement &OpSt = getValueState(
I.getOperand(0));
1498 if (Constant *OpC =
getConstant(OpSt,
I.getOperand(0)->getType())) {
1502 auto &LV = ValueState[&
I];
1509 if (
I.getDestTy()->isIntOrIntVectorTy() &&
1510 I.getSrcTy()->isIntOrIntVectorTy() &&
1511 I.getOpcode() != Instruction::BitCast) {
1512 ConstantRange OpRange =
1514 auto &LV = getValueState(&
I);
1516 Type *DestTy =
I.getDestTy();
1520 Trunc->getNoWrapKind());
1525 markOverdefined(&
I);
1534 addAdditionalUser(
LHS, &EVI);
1535 addAdditionalUser(
RHS, &EVI);
1537 const ValueLatticeElement &
L = getValueState(
LHS);
1538 if (
L.isUnknownOrUndef())
1540 ConstantRange LR =
L.asConstantRange(Ty,
false);
1542 const ValueLatticeElement &
R = getValueState(
RHS);
1543 if (
R.isUnknownOrUndef())
1546 ConstantRange RR =
R.asConstantRange(Ty,
false);
1551 assert(Idx == 1 &&
"Index can only be 0 or 1");
1556 markOverdefined(&EVI);
1564 return (
void)markOverdefined(&EVI);
1568 if (ValueState[&EVI].isOverdefined())
1569 return (
void)markOverdefined(&EVI);
1573 return (
void)markOverdefined(&EVI);
1579 return handleExtractOfWithOverflow(EVI, WO, i);
1580 ValueLatticeElement EltVal = getStructValueState(AggVal, i);
1581 mergeInValue(ValueState[&EVI], &EVI, EltVal);
1584 return (
void)markOverdefined(&EVI);
1591 return (
void)markOverdefined(&IVI);
1595 if (ValueState[&IVI].isOverdefined())
1596 return (
void)markOverdefined(&IVI);
1601 return (
void)markOverdefined(&IVI);
1607 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i) {
1610 ValueLatticeElement EltVal = getStructValueState(Aggr, i);
1611 mergeInValue(getStructValueState(&IVI, i), &IVI, EltVal);
1618 markOverdefined(getStructValueState(&IVI, i), &IVI);
1620 ValueLatticeElement InVal = getValueState(Val);
1621 mergeInValue(getStructValueState(&IVI, i), &IVI, InVal);
1626void SCCPInstVisitor::visitSelectInst(
SelectInst &
I) {
1629 if (
I.getType()->isStructTy())
1630 return (
void)markOverdefined(&
I);
1634 if (ValueState[&
I].isOverdefined())
1635 return (
void)markOverdefined(&
I);
1637 const ValueLatticeElement &CondValue = getValueState(
I.getCondition());
1641 if (ConstantInt *CondCB =
1643 Value *OpVal = CondCB->isZero() ?
I.getFalseValue() :
I.getTrueValue();
1644 const ValueLatticeElement &OpValState = getValueState(OpVal);
1647 assert(ValueState.contains(&
I) &&
"&I is not in ValueState map.");
1648 mergeInValue(ValueState[&
I], &
I, OpValState);
1655 ValueLatticeElement TVal = getValueState(
I.getTrueValue());
1656 ValueLatticeElement FVal = getValueState(
I.getFalseValue());
1658 ValueLatticeElement &State = ValueState[&
I];
1662 pushUsersToWorkListMsg(State, &
I);
1666void SCCPInstVisitor::visitUnaryOperator(
Instruction &
I) {
1667 ValueLatticeElement V0State = getValueState(
I.getOperand(0));
1669 ValueLatticeElement &
IV = ValueState[&
I];
1672 if (
IV.isOverdefined())
1673 return (
void)markOverdefined(&
I);
1682 return (
void)markConstant(
IV, &
I,
C);
1684 markOverdefined(&
I);
1687void SCCPInstVisitor::visitFreezeInst(
FreezeInst &
I) {
1690 if (
I.getType()->isStructTy())
1691 return (
void)markOverdefined(&
I);
1693 ValueLatticeElement V0State = getValueState(
I.getOperand(0));
1694 ValueLatticeElement &
IV = ValueState[&
I];
1697 if (
IV.isOverdefined())
1698 return (
void)markOverdefined(&
I);
1708 markOverdefined(&
I);
1712void SCCPInstVisitor::visitBinaryOperator(
Instruction &
I) {
1713 ValueLatticeElement V1State = getValueState(
I.getOperand(0));
1714 ValueLatticeElement V2State = getValueState(
I.getOperand(1));
1716 ValueLatticeElement &
IV = ValueState[&
I];
1717 if (
IV.isOverdefined())
1725 return (
void)markOverdefined(&
I);
1744 ValueLatticeElement NewV;
1746 return (
void)mergeInValue(ValueState[&
I], &
I, NewV);
1751 if (!
I.getType()->isIntOrIntVectorTy())
1752 return markOverdefined(&
I);
1761 ConstantRange
R = ConstantRange::getEmpty(
I.getType()->getScalarSizeInBits());
1763 R =
A.overflowingBinaryOp(BO->getOpcode(),
B, OBO->getNoWrapKind());
1765 R =
A.binaryOp(BO->getOpcode(),
B);
1774void SCCPInstVisitor::visitCmpInst(
CmpInst &
I) {
1777 if (ValueState[&
I].isOverdefined())
1778 return (
void)markOverdefined(&
I);
1780 Value *Op1 =
I.getOperand(0);
1781 Value *Op2 =
I.getOperand(1);
1785 auto V1State = getValueState(Op1);
1786 auto V2State = getValueState(Op2);
1790 ValueLatticeElement CV;
1792 mergeInValue(ValueState[&
I], &
I, CV);
1801 markOverdefined(&
I);
1807 if (ValueState[&
I].isOverdefined())
1808 return (
void)markOverdefined(&
I);
1810 const ValueLatticeElement &PtrState = getValueState(
I.getPointerOperand());
1816 if (
I.hasNoUnsignedWrap() ||
1819 return (
void)markNotNull(ValueState[&
I], &
I);
1820 return (
void)markOverdefined(&
I);
1824 Operands.
reserve(
I.getNumOperands());
1826 for (
unsigned i = 0, e =
I.getNumOperands(); i != e; ++i) {
1827 const ValueLatticeElement &State = getValueState(
I.getOperand(i));
1831 if (Constant *
C =
getConstant(State,
I.getOperand(i)->getType())) {
1836 return (
void)markOverdefined(&
I);
1840 markConstant(&
I,
C);
1842 markOverdefined(&
I);
1845void SCCPInstVisitor::visitAllocaInst(
AllocaInst &
I) {
1847 return (
void)markNotNull(ValueState[&
I], &
I);
1849 markOverdefined(&
I);
1852void SCCPInstVisitor::visitStoreInst(
StoreInst &
SI) {
1854 if (
SI.getOperand(0)->getType()->isStructTy())
1861 auto I = TrackedGlobals.find(GV);
1862 if (
I == TrackedGlobals.end())
1866 mergeInValue(
I->second, GV, getValueState(
SI.getOperand(0)),
1867 ValueLatticeElement::MergeOptions().setCheckWiden(
false));
1868 if (
I->second.isOverdefined())
1869 TrackedGlobals.erase(
I);
1874 if (CB->getType()->isIntOrIntVectorTy())
1875 if (std::optional<ConstantRange>
Range = CB->getRange())
1877 if (CB->getType()->isPointerTy() && CB->isReturnNonNull())
1882 if (
I->getType()->isIntOrIntVectorTy())
1883 if (
MDNode *Ranges =
I->getMetadata(LLVMContext::MD_range))
1886 if (
I->hasMetadata(LLVMContext::MD_nonnull))
1895void SCCPInstVisitor::visitLoadInst(
LoadInst &
I) {
1898 if (
I.getType()->isStructTy() ||
I.isVolatile())
1899 return (
void)markOverdefined(&
I);
1903 if (ValueState[&
I].isOverdefined())
1904 return (
void)markOverdefined(&
I);
1906 const ValueLatticeElement &PtrVal = getValueState(
I.getOperand(0));
1912 ValueLatticeElement &
IV = ValueState[&
I];
1917 return (
void)markOverdefined(
IV, &
I);
1924 if (!TrackedGlobals.empty()) {
1926 auto It = TrackedGlobals.find(GV);
1927 if (It != TrackedGlobals.end()) {
1936 return (
void)markConstant(
IV, &
I,
C);
1943void SCCPInstVisitor::visitCallBase(
CallBase &CB) {
1944 handleCallResult(CB);
1945 handleCallArguments(CB);
1948void SCCPInstVisitor::handleCallOverdefined(
CallBase &CB) {
1957 return (
void)markOverdefined(&CB);
1963 for (
const Use &
A : CB.
args()) {
1964 if (
A.get()->getType()->isStructTy())
1965 return markOverdefined(&CB);
1966 if (
A.get()->getType()->isMetadataTy())
1968 const ValueLatticeElement &State = getValueState(
A);
1973 return (
void)markOverdefined(&CB);
1979 return (
void)markOverdefined(&CB);
1984 return (
void)markConstant(&CB,
C);
1991void SCCPInstVisitor::handleCallArguments(
CallBase &CB) {
1996 if (TrackingIncomingArguments.count(
F)) {
2005 if (AI->hasByValAttr() && !
F->onlyReadsMemory()) {
2006 markOverdefined(&*AI);
2011 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i) {
2012 ValueLatticeElement CallArg = getStructValueState(*CAI, i);
2013 mergeInValue(getStructValueState(&*AI, i), &*AI, CallArg,
2017 ValueLatticeElement CallArg =
2027 ValueLatticeElement CopyOfVal = getValueState(CopyOf);
2028 const std::optional<PredicateConstraint> &Constraint = PI->
getConstraint();
2030 mergeInValue(ValueState[
I],
I, CopyOfVal);
2035 Value *OtherOp = Constraint->OtherOp;
2038 if (getValueState(OtherOp).isUnknown()) {
2039 addAdditionalUser(OtherOp,
I);
2043 ValueLatticeElement CondVal = getValueState(OtherOp);
2044 ValueLatticeElement &
IV = ValueState[
I];
2047 ConstantRange::getFull(DL.getTypeSizeInBits(CopyOf->
getType()));
2059 if (CopyOfCR.isEmptySet())
2060 CopyOfCR = ConstantRange::getFull(CopyOfCR.getBitWidth());
2061 auto NewCR = ImposedCR.intersectWith(CopyOfCR);
2065 if (!CopyOfCR.contains(NewCR) && CopyOfCR.getSingleMissingElement())
2073 addAdditionalUser(OtherOp,
I);
2081 addAdditionalUser(OtherOp,
I);
2082 mergeInValue(
IV,
I, CondVal);
2086 addAdditionalUser(OtherOp,
I);
2091 return (
void)mergeInValue(
IV,
I, CopyOfVal);
2094void SCCPInstVisitor::handleCallResult(
CallBase &CB) {
2098 if (
II->getIntrinsicID() == Intrinsic::vscale) {
2101 return (
void)mergeInValue(ValueState[
II],
II,
2104 if (
II->getIntrinsicID() == Intrinsic::experimental_get_vector_length) {
2105 Value *CountArg =
II->getArgOperand(0);
2106 Value *VF =
II->getArgOperand(1);
2113 ConstantRange
Count = getValueState(CountArg)
2114 .asConstantRange(CountArg->
getType(),
false)
2116 ConstantRange MaxLanes = getValueState(VF)
2117 .asConstantRange(VF->
getType(),
false)
2133 return (
void)mergeInValue(ValueState[
II],
II,
2143 const ValueLatticeElement &State = getValueState(
Op);
2152 return (
void)mergeInValue(ValueState[
II],
II,
2160 if (!
F ||
F->isDeclaration())
2161 return handleCallOverdefined(CB);
2165 if (!MRVFunctionsTracked.count(
F))
2166 return handleCallOverdefined(CB);
2170 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i)
2171 mergeInValue(getStructValueState(&CB, i), &CB,
2172 TrackedMultipleRetVals[std::make_pair(
F, i)],
2175 auto TFRVI = TrackedRetVals.find(
F);
2176 if (TFRVI == TrackedRetVals.end())
2177 return handleCallOverdefined(CB);
2184bool SCCPInstVisitor::isInstFullyOverDefined(
Instruction &Inst) {
2189 for (
unsigned i = 0, e = STy->getNumElements(); i < e; ++i) {
2190 if (!getStructValueState(&Inst, i).isOverdefined())
2196 return getValueState(&Inst).isOverdefined();
2201 while (!BBWorkList.empty() || !InstWorkList.empty()) {
2203 while (!InstWorkList.empty()) {
2205 Invalidated.erase(
I);
2213 while (!BBWorkList.empty()) {
2215 BBVisited.insert(BB);
2229 if (
I.getType()->isVoidTy())
2238 if (MRVFunctionsTracked.count(
F))
2247 for (
unsigned i = 0, e = STy->getNumElements(); i != e; ++i) {
2250 markOverdefined(LV, &
I);
2268 if (TrackedRetVals.count(
F))
2278 markOverdefined(&
I);
2296 bool MadeChange =
false;
2298 if (!BBExecutable.count(&BB))
2306 <<
"\nResolved undefs in " <<
F.getName() <<
'\n');
2325 Visitor->addPredicateInfo(
F, DT, AC);
2329 Visitor->removeSSACopies(
F);
2333 return Visitor->markBlockExecutable(BB);
2337 return Visitor->getPredicateInfoFor(
I);
2341 Visitor->trackValueOfGlobalVariable(GV);
2345 Visitor->addTrackedFunction(
F);
2349 Visitor->addToMustPreserveReturnsInFunctions(
F);
2353 return Visitor->mustPreserveReturn(
F);
2357 Visitor->addArgumentTrackedFunction(
F);
2361 return Visitor->isArgumentTrackedFunction(
F);
2366 return Visitor->getArgumentTrackedFunctions();
2372 return Visitor->resolvedUndefsIn(
F);
2376 Visitor->solveWhileResolvedUndefsIn(M);
2381 Visitor->solveWhileResolvedUndefsIn(WorkList);
2385 Visitor->solveWhileResolvedUndefs();
2389 return Visitor->isBlockExecutable(BB);
2393 return Visitor->isEdgeFeasible(From, To);
2396std::vector<ValueLatticeElement>
2398 return Visitor->getStructLatticeValueFor(V);
2402 return Visitor->removeLatticeValueFor(V);
2406 Visitor->resetLatticeValueFor(
Call);
2410 return Visitor->getLatticeValueFor(V);
2415 return Visitor->getTrackedRetVals();
2420 return Visitor->getTrackedGlobals();
2424 return Visitor->getMRVFunctionsTracked();
2430 Visitor->trackValueOfArgument(V);
2434 return Visitor->isStructLatticeConstant(
F, STy);
2439 return Visitor->getConstant(LV, Ty);
2443 return Visitor->getConstantOrNull(V);
2448 Visitor->setLatticeValueForSpecializationArguments(
F, Args);
2452 Visitor->markFunctionUnreachable(
F);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
uint64_t IntrinsicInst * II
static ValueLatticeElement::MergeOptions getMaxWidenStepsOpts()
Returns MergeOptions with MaxWidenSteps set to MaxNumRangeExtensions.
static const unsigned MaxNumRangeExtensions
static ValueLatticeElement getValueFromMetadata(const Instruction *I)
std::pair< BasicBlock *, BasicBlock * > Edge
This file implements a set that has insertion order iteration characteristics.
static ConstantInt * getConstantInt(Value *V, const DataLayout &DL)
Extract ConstantInt from value, looking through IntToPtr and PointerNullValue.
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
static const uint32_t IV[8]
Class for arbitrary precision integers.
unsigned countr_zero() const
Count the number of trailing zero bits.
bool ule(const APInt &RHS) const
Unsigned less or equal comparison.
static APInt getZero(unsigned numBits)
Get the '0' value for the specified bit-width.
an instruction to allocate memory on the stack
This class represents an incoming formal argument to a Function.
A cache of @llvm.assume calls within a function.
Functions, function parameters, and return types can have attributes to indicate how they should be t...
LLVM_ABI const ConstantRange & getRange() const
Returns the value of the range attribute.
static LLVM_ABI Attribute get(LLVMContext &Context, AttrKind Kind, uint64_t Val=0)
Return a uniquified Attribute object.
bool isValid() const
Return true if the attribute is any kind of attribute.
LLVM Basic Block Representation.
iterator_range< const_phi_iterator > phis() const
Returns a range that iterates over the phis in the basic block.
const Function * getParent() const
Return the enclosing method, or null if none.
static BasicBlock * Create(LLVMContext &Context, const Twine &Name="", Function *Parent=nullptr, BasicBlock *InsertBefore=nullptr)
Creates a new BasicBlock.
LLVM_ABI LLVMContext & getContext() const
Get the context in which this basic block lives.
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction if the block is well formed or null if the block is not well forme...
LLVM_ABI void removePredecessor(BasicBlock *Pred, bool KeepOneInputPHIs=false)
Update PHI nodes in this BasicBlock before removal of predecessor Pred.
LLVM_ABI unsigned getNoWrapKind() const
Returns one of OBO::NoSignedWrap or OBO::NoUnsignedWrap.
LLVM_ABI Instruction::BinaryOps getBinaryOp() const
Returns the binary operation underlying the intrinsic.
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.
Function * getFunction() const
BasicBlock * getBasicBlock() const
static BranchInst * Create(BasicBlock *IfTrue, InsertPosition InsertBefore=nullptr)
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
std::optional< OperandBundleUse > getOperandBundle(StringRef Name) const
Return an operand bundle by name, if present.
Function * getCalledFunction() const
Returns the function called, or null if this is an indirect function invocation or the function signa...
User::op_iterator arg_begin()
Return the iterator pointing to the beginning of the argument list.
LLVM_ABI bool isMustTailCall() const
Tests if this call site must be tail call optimized.
iterator_range< User::op_iterator > args()
Iteration adapter for range-for loops.
CallBr instruction, tracking function calls that may not return control but instead transfer it to a ...
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 * Create(Instruction::CastOps, Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Provides a way to construct any of the CastInst subclasses using an opcode instead of the subclass's ...
This class is the base class for the comparison instructions.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
@ ICMP_SLE
signed less or equal
@ ICMP_ULE
unsigned less or equal
This is the shared class of boolean and integer constants.
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)
static LLVM_ABI ConstantPointerNull * get(PointerType *T)
Static factory methods - Return objects of the specified value.
This class represents a range of values.
LLVM_ABI ConstantRange multiply(const ConstantRange &Other) const
Return a new range representing the possible values resulting from a multiplication of a value in thi...
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...
const APInt * getSingleElement() const
If this set contains a single element, return it, otherwise return null.
LLVM_ABI ConstantRange castOp(Instruction::CastOps CastOp, uint32_t BitWidth) const
Return a new range representing the possible values resulting from an application of the specified ca...
LLVM_ABI bool isFullSet() const
Return true if this set contains all of the elements possible for this data-type.
LLVM_ABI bool icmp(CmpInst::Predicate Pred, const ConstantRange &Other) const
Does the predicate Pred hold between ranges this and Other?
static LLVM_ABI ConstantRange intrinsic(Intrinsic::ID IntrinsicID, ArrayRef< ConstantRange > Ops)
Compute range of intrinsic result for the given operand ranges.
LLVM_ABI bool isSizeLargerThan(uint64_t MaxSize) const
Compare set size of this range with Value.
static LLVM_ABI bool isIntrinsicSupported(Intrinsic::ID IntrinsicID)
Returns true if ConstantRange calculations are supported for intrinsic with IntrinsicID.
bool isSingleElement() const
Return true if this set contains exactly one member.
LLVM_ABI ConstantRange truncate(uint32_t BitWidth, unsigned NoWrapKind=0) const
Return a new range in the specified integer type, which must be strictly smaller than the current typ...
LLVM_ABI bool isAllNonNegative() const
Return true if all values in this range are non-negative.
static LLVM_ABI ConstantRange makeAllowedICmpRegion(CmpInst::Predicate Pred, const ConstantRange &Other)
Produce the smallest range such that all values that may satisfy the given predicate with any value c...
const APInt & getUpper() const
Return the upper value for this range.
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.
LLVM_ABI APInt getUnsignedMax() const
Return the largest unsigned value contained in the ConstantRange.
LLVM_ABI ConstantRange intersectWith(const ConstantRange &CR, PreferredRangeType Type=Smallest) const
Return the range that results from the intersection of this range with another range.
static LLVM_ABI ConstantRange makeGuaranteedNoWrapRegion(Instruction::BinaryOps BinOp, const ConstantRange &Other, unsigned NoWrapKind)
Produce the largest range containing all X such that "X BinOp Y" is guaranteed not to wrap (overflow)...
LLVM_ABI ConstantRange binaryOp(Instruction::BinaryOps BinOp, const ConstantRange &Other) const
Return a new range representing the possible values resulting from an application of the specified bi...
LLVM_ABI ConstantRange sub(const ConstantRange &Other) const
Return a new range representing the possible values resulting from a subtraction of a value in this r...
static LLVM_ABI Constant * get(StructType *T, ArrayRef< Constant * > V)
This is an important base class in LLVM.
static LLVM_ABI Constant * getNullValue(Type *Ty)
Constructor to create a '0' constant of arbitrary type.
LLVM_ABI bool isNullValue() const
Return true if this is the value that would be returned by getNullValue.
A parsed version of the target data layout string in and methods for querying it.
static DebugLoc getTemporary()
DenseMapIterator< KeyT, ValueT, KeyInfoT, BucketT, true > const_iterator
Implements a dense probed hash-table based set.
static constexpr UpdateKind Delete
static constexpr UpdateKind Insert
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
This class represents a freeze function that returns random concrete value if an operand is either a ...
static GEPNoWrapFlags noUnsignedWrap()
void applyUpdatesPermissive(ArrayRef< UpdateT > Updates)
Submit updates to all available trees.
an instruction for type-safe pointer arithmetic to access elements of arrays and structs
Module * getParent()
Get the module that this global value is contained inside of...
Type * getValueType() const
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
This provides a uniform API for creating instructions and inserting them into a basic block: either a...
This instruction inserts a struct field of array element value into an aggregate value.
Value * getInsertedValueOperand()
Value * getAggregateOperand()
unsigned getNumIndices() const
idx_iterator idx_begin() const
Base class for instruction visitors.
void visit(Iterator Start, Iterator End)
LLVM_ABI void setHasNoUnsignedWrap(bool b=true)
Set or clear the nuw flag on this instruction, which must be an operator which supports this flag.
LLVM_ABI bool hasNoUnsignedWrap() const LLVM_READONLY
Determine whether the no unsigned wrap flag is set.
LLVM_ABI unsigned getNumSuccessors() const LLVM_READONLY
Return the number of successors that this instruction has.
LLVM_ABI bool hasNoSignedWrap() const LLVM_READONLY
Determine whether the no signed wrap flag is set.
LLVM_ABI void setHasNoSignedWrap(bool b=true)
Set or clear the nsw flag on this instruction, which must be an operator which supports this flag.
const DebugLoc & getDebugLoc() const
Return the debug location for this node as a DebugLoc.
LLVM_ABI InstListType::iterator eraseFromParent()
This method unlinks 'this' from the containing basic block and deletes it.
LLVM_ABI bool isExact() const LLVM_READONLY
Determine whether the exact flag is set.
LLVM_ABI BasicBlock * getSuccessor(unsigned Idx) const LLVM_READONLY
Return the specified successor. This instruction must be a terminator.
LLVM_ABI void setNonNeg(bool b=true)
Set or clear the nneg flag on this instruction, which must be a zext instruction.
LLVM_ABI bool hasNonNeg() const LLVM_READONLY
Determine whether the the nneg flag is set.
unsigned getOpcode() const
Returns a member of one of the enums like Instruction::Add.
LLVM_ABI void setIsExact(bool b=true)
Set or clear the exact flag on this instruction, which must be an operator which supports this flag.
void setDebugLoc(DebugLoc Loc)
Set the debug location information for this instruction.
bool isSpecialTerminator() const
This is an important class for using LLVM in a threaded context.
@ OB_clang_arc_attachedcall
An instruction for reading from memory.
This class implements a map that also provides access to all stored values in a deterministic order.
A Module instance is used to store all the information related to an LLVM module.
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.
LLVM_ABI std::optional< PredicateConstraint > getConstraint() const
Fetch condition in the form of PredicateConstraint, if possible.
Return a value (possibly void), from a function.
Helper class for SCCPSolver.
const MapVector< Function *, ValueLatticeElement > & getTrackedRetVals() const
const PredicateBase * getPredicateInfoFor(Instruction *I)
std::vector< ValueLatticeElement > getStructLatticeValueFor(Value *V) const
bool resolvedUndef(Instruction &I)
void markFunctionUnreachable(Function *F)
bool markBlockExecutable(BasicBlock *BB)
bool resolvedUndefsIn(Function &F)
While solving the dataflow for a function, we don't compute a result for operations with an undef ope...
Constant * getConstant(const ValueLatticeElement &LV, Type *Ty) const
SCCPInstVisitor(const DataLayout &DL, std::function< const TargetLibraryInfo &(Function &)> GetTLI, LLVMContext &Ctx)
const DenseMap< GlobalVariable *, ValueLatticeElement > & getTrackedGlobals() const
const ValueLatticeElement & getLatticeValueFor(Value *V) const
void removeLatticeValueFor(Value *V)
void trackValueOfArgument(Argument *A)
void visitCallInst(CallInst &I)
void markOverdefined(Value *V)
bool isArgumentTrackedFunction(Function *F)
void addTrackedFunction(Function *F)
void solveWhileResolvedUndefs()
void solveWhileResolvedUndefsIn(Module &M)
void trackValueOfGlobalVariable(GlobalVariable *GV)
Constant * getConstantOrNull(Value *V) const
void removeSSACopies(Function &F)
const SmallPtrSet< Function *, 16 > & getMRVFunctionsTracked() const
const SmallPtrSetImpl< Function * > & getArgumentTrackedFunctions() const
void resetLatticeValueFor(CallBase *Call)
Invalidate the Lattice Value of Call and its users after specializing the call.
ValueLatticeElement getArgAttributeVL(Argument *A)
void addPredicateInfo(Function &F, DominatorTree &DT, AssumptionCache &AC)
void addToMustPreserveReturnsInFunctions(Function *F)
void addArgumentTrackedFunction(Function *F)
bool isStructLatticeConstant(Function *F, StructType *STy)
void solveWhileResolvedUndefsIn(SmallVectorImpl< Function * > &WorkList)
bool isBlockExecutable(BasicBlock *BB) const
bool mustPreserveReturn(Function *F)
void setLatticeValueForSpecializationArguments(Function *F, const SmallVectorImpl< ArgInfo > &Args)
bool isEdgeFeasible(BasicBlock *From, BasicBlock *To) const
SCCPSolver - This interface class is a general purpose solver for Sparse Conditional Constant Propaga...
LLVM_ABI void visitCall(CallInst &I)
LLVM_ABI void resetLatticeValueFor(CallBase *Call)
Invalidate the Lattice Value of Call and its users after specializing the call.
LLVM_ABI void trackValueOfGlobalVariable(GlobalVariable *GV)
trackValueOfGlobalVariable - Clients can use this method to inform the SCCPSolver that it should trac...
LLVM_ABI bool tryToReplaceWithConstant(Value *V)
LLVM_ABI void inferArgAttributes() const
LLVM_ABI bool isStructLatticeConstant(Function *F, StructType *STy)
LLVM_ABI void addPredicateInfo(Function &F, DominatorTree &DT, AssumptionCache &AC)
LLVM_ABI void solve()
Solve - Solve for constants and executable blocks.
LLVM_ABI void visit(Instruction *I)
LLVM_ABI void trackValueOfArgument(Argument *V)
trackValueOfArgument - Mark the specified argument overdefined unless it have range attribute.
LLVM_ABI const DenseMap< GlobalVariable *, ValueLatticeElement > & getTrackedGlobals() const
getTrackedGlobals - Get and return the set of inferred initializers for global variables.
LLVM_ABI void addTrackedFunction(Function *F)
addTrackedFunction - If the SCCP solver is supposed to track calls into and out of the specified func...
LLVM_ABI void solveWhileResolvedUndefsIn(Module &M)
LLVM_ABI const PredicateBase * getPredicateInfoFor(Instruction *I)
LLVM_ABI const SmallPtrSetImpl< Function * > & getArgumentTrackedFunctions() const
LLVM_ABI const SmallPtrSet< Function *, 16 > & getMRVFunctionsTracked() const
getMRVFunctionsTracked - Get the set of functions which return multiple values tracked by the pass.
LLVM_ABI bool resolvedUndefsIn(Function &F)
resolvedUndefsIn - While solving the dataflow for a function, we assume that branches on undef values...
LLVM_ABI void addArgumentTrackedFunction(Function *F)
LLVM_ABI void solveWhileResolvedUndefs()
LLVM_ABI void removeLatticeValueFor(Value *V)
LLVM_ABI std::vector< ValueLatticeElement > getStructLatticeValueFor(Value *V) const
LLVM_ABI Constant * getConstantOrNull(Value *V) const
Return either a Constant or nullptr for a given Value.
LLVM_ABI bool simplifyInstsInBlock(BasicBlock &BB, SmallPtrSetImpl< Value * > &InsertedValues, Statistic &InstRemovedStat, Statistic &InstReplacedStat)
LLVM_ABI Constant * getConstant(const ValueLatticeElement &LV, Type *Ty) const
Helper to return a Constant if LV is either a constant or a constant range with a single element.
LLVM_ABI const ValueLatticeElement & getLatticeValueFor(Value *V) const
LLVM_ABI void addToMustPreserveReturnsInFunctions(Function *F)
Add function to the list of functions whose return cannot be modified.
LLVM_ABI bool removeNonFeasibleEdges(BasicBlock *BB, DomTreeUpdater &DTU, BasicBlock *&NewUnreachableBB) const
LLVM_ABI bool isBlockExecutable(BasicBlock *BB) const
LLVM_ABI void inferReturnAttributes() const
LLVM_ABI bool markBlockExecutable(BasicBlock *BB)
markBlockExecutable - This method can be used by clients to mark all of the blocks that are known to ...
LLVM_ABI void setLatticeValueForSpecializationArguments(Function *F, const SmallVectorImpl< ArgInfo > &Args)
Set the Lattice Value for the arguments of a specialization F.
static LLVM_ABI bool isConstant(const ValueLatticeElement &LV)
LLVM_ABI const MapVector< Function *, ValueLatticeElement > & getTrackedRetVals() const
getTrackedRetVals - Get the inferred return value map.
LLVM_ABI bool isEdgeFeasible(BasicBlock *From, BasicBlock *To) const
LLVM_ABI bool mustPreserveReturn(Function *F)
Returns true if the return of the given function cannot be modified.
static LLVM_ABI bool isOverdefined(const ValueLatticeElement &LV)
LLVM_ABI void markFunctionUnreachable(Function *F)
Mark all of the blocks in function F non-executable.
LLVM_ABI bool isArgumentTrackedFunction(Function *F)
Returns true if the given function is in the solver's set of argument-tracked functions.
LLVM_ABI SCCPSolver(const DataLayout &DL, std::function< const TargetLibraryInfo &(Function &)> GetTLI, LLVMContext &Ctx)
LLVM_ABI void markOverdefined(Value *V)
markOverdefined - Mark the specified value overdefined.
LLVM_ABI void removeSSACopies(Function &F)
This class represents the LLVM 'select' instruction.
A templated base class for SmallPtrSet which provides the typesafe interface that is common across al...
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.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void assign(size_type NumElts, ValueParamT Elt)
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.
Class to represent struct types.
unsigned getNumElements() const
Random access to the elements.
A wrapper class to simplify modification of SwitchInst cases along with their prof branch_weights met...
Provides information about what library functions are available for the current target.
This class represents a truncation of integer types.
The instances of the Type class are immutable: once they are created, they are never changed.
bool isPointerTy() const
True if this is an instance of PointerType.
bool isSingleValueType() const
Return true if the type is a valid type for a register in codegen.
bool isStructTy() const
True if this is an instance of StructType.
LLVM_ABI unsigned getScalarSizeInBits() const LLVM_READONLY
If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
bool isVoidTy() const
Return true if this is 'void'.
static LLVM_ABI UndefValue * get(Type *T)
Static factory methods - Return an 'undef' object of the specified type.
This function has undefined behavior.
Value * getOperand(unsigned i) const
This class represents lattice values for constants.
static ValueLatticeElement getRange(ConstantRange CR, bool MayIncludeUndef=false)
bool isOverdefined() const
LLVM_ABI Constant * getCompare(CmpInst::Predicate Pred, Type *Ty, const ValueLatticeElement &Other, const DataLayout &DL) const
true, false or undef constants, or nullptr if the comparison cannot be evaluated.
bool isConstantRangeIncludingUndef() const
static ValueLatticeElement getNot(Constant *C)
ConstantRange asConstantRange(unsigned BW, bool UndefAllowed=false) const
bool isNotConstant() const
void setNumRangeExtensions(unsigned N)
const ConstantRange & getConstantRange(bool UndefAllowed=true) const
Returns the constant range for this value.
bool isConstantRange(bool UndefAllowed=true) const
Returns true if this value is a constant range.
static ValueLatticeElement get(Constant *C)
unsigned getNumRangeExtensions() const
Constant * getNotConstant() const
LLVM_ABI ValueLatticeElement intersect(const ValueLatticeElement &Other) const
Combine two sets of facts about the same value into a single set of facts.
bool isUnknownOrUndef() const
Constant * getConstant() const
bool mergeIn(const ValueLatticeElement &RHS, MergeOptions Opts=MergeOptions())
Updates this object to approximate both this object and RHS.
bool markConstant(Constant *V, bool MayIncludeUndef=false)
static ValueLatticeElement getOverdefined()
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI std::string getNameOrAsOperand() const
LLVM_ABI void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
iterator_range< user_iterator > users()
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.
Represents an op.with.overflow intrinsic.
const ParentTy * getParent() const
self_iterator getIterator()
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
const APInt & umin(const APInt &A, const APInt &B)
Determine the smaller of two APInts considered to be unsigned.
@ C
The default llvm calling convention, compatible with C.
@ BasicBlock
Various leaf nodes.
OneUse_match< SubPat > m_OneUse(const SubPat &SP)
cst_pred_ty< is_lowbit_mask > m_LowBitMask()
Match an integer or vector with only the low bit(s) set.
BinaryOp_match< LHS, RHS, Instruction::And > m_And(const LHS &L, const RHS &R)
ap_match< APInt > m_APInt(const APInt *&Res)
Match a ConstantInt or splatted ConstantVector, binding the specified pointer to the contained APInt.
bool match(Val *V, const Pattern &P)
cst_pred_ty< is_negated_power2 > m_NegatedPower2()
Match a integer or vector negated power-of-2.
match_combine_or< BinaryOp_match< LHS, RHS, Instruction::Add >, DisjointOr_match< LHS, RHS > > m_AddLike(const LHS &L, const RHS &R)
Match either "add" or "or disjoint".
class_match< Value > m_Value()
Match an arbitrary value and ignore it.
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
static bool replaceSignedInst(SCCPSolver &Solver, SmallPtrSetImpl< Value * > &InsertedValues, Instruction &Inst)
Try to replace signed instructions with their unsigned equivalent.
LLVM_ABI bool canConstantFoldCallTo(const CallBase *Call, const Function *F)
canConstantFoldCallTo - Return true if its even possible to fold a call to the specified function.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto successors(const MachineBasicBlock *BB)
static ConstantRange getRange(Value *Op, SCCPSolver &Solver, const SmallPtrSetImpl< Value * > &InsertedValues)
Helper for getting ranges from Solver.
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...
LLVM_ABI Constant * ConstantFoldCall(const CallBase *Call, Function *F, ArrayRef< Constant * > Operands, const TargetLibraryInfo *TLI=nullptr, bool AllowNonDeterministic=true)
ConstantFoldCall - Attempt to constant fold a call to the specified function with the specified argum...
LLVM_ABI ConstantRange getConstantRangeFromMetadata(const MDNode &RangeMD)
Parse out a conservative ConstantRange from !range metadata.
LLVM_ABI Value * simplifyInstruction(Instruction *I, const SimplifyQuery &Q)
See if we can compute a simplified version of this instruction.
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 Constant * ConstantFoldUnaryOpOperand(unsigned Opcode, Constant *Op, const DataLayout &DL)
Attempt to constant fold a unary operation with the specified operand.
LLVM_ABI bool NullPointerIsDefined(const Function *F, unsigned AS=0)
Check whether null pointer dereferencing is considered undefined behavior for a given function or an ...
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
LLVM_ABI bool wouldInstructionBeTriviallyDead(const Instruction *I, const TargetLibraryInfo *TLI=nullptr)
Return true if the result produced by the instruction would have no side effects if it was not used.
FunctionAddr VTableAddr Count
LLVM_ABI ConstantRange getVScaleRange(const Function *F, unsigned BitWidth)
Determine the possible constant range of vscale with the given bit width, based on the vscale_range f...
LLVM_ABI Constant * ConstantFoldCastOperand(unsigned Opcode, Constant *C, Type *DestTy, const DataLayout &DL)
Attempt to constant fold a cast with the specified operand.
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
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 Value * simplifyBinOp(unsigned Opcode, Value *LHS, Value *RHS, const SimplifyQuery &Q)
Given operands for a BinaryOperator, fold the result or return null.
@ Sub
Subtraction of integers.
DWARFExpression::Operation Op
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.
constexpr unsigned BitWidth
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI Constant * ConstantFoldLoadFromConstPtr(Constant *C, Type *Ty, APInt Offset, const DataLayout &DL)
Return the value that a load from C with offset Offset would produce if it is constant and determinab...
BumpPtrAllocatorImpl<> BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
LLVM_ABI Constant * ConstantFoldInstOperands(const Instruction *I, ArrayRef< Constant * > Ops, const DataLayout &DL, const TargetLibraryInfo *TLI=nullptr, bool AllowNonDeterministic=true)
ConstantFoldInstOperands - Attempt to constant fold an instruction with the specified operands.
static bool refineInstruction(SCCPSolver &Solver, const SmallPtrSetImpl< Value * > &InsertedValues, Instruction &Inst)
Try to use Inst's value range from Solver to infer the NUW flag.
static void inferAttribute(Function *F, unsigned AttrIndex, const ValueLatticeElement &Val)
Implement std::hash so that hash_code can be used in STL containers.
Struct to control some aspects related to merging constant ranges.
MergeOptions & setMaxWidenSteps(unsigned Steps=1)