48#define DEBUG_TYPE "lazy-value-info"
57 "Lazy Value Information Analysis",
false,
true)
64 "lvi-per-pred-ranges",
cl::Hidden,
cl::init(
false),
65 cl::desc(
"Enable tracking of ranges for a value in a block for"
66 "each block predecessor (default = false)"));
96 class LazyValueInfoCache;
97 struct LVIValueHandle final :
public CallbackVH {
98 LazyValueInfoCache *Parent;
100 LVIValueHandle(
Value *V, LazyValueInfoCache *
P =
nullptr)
101 : CallbackVH(
V), Parent(
P) { }
103 void deleted()
override;
104 void allUsesReplacedWith(
Value *V)
override {
112using BBLatticeElementMap =
114using PredecessorValueLatticeMap =
119class LazyValueInfoCache {
124 struct BlockCacheEntry {
125 SmallDenseMap<AssertingVH<Value>, ValueLatticeElement, 4> LatticeElements;
126 SmallDenseSet<AssertingVH<Value>, 4> OverDefined;
129 std::optional<NonNullPointerSet> NonNullPointers;
133 std::optional<PredecessorValueLatticeMap> PredecessorLatticeElements;
139 DenseSet<LVIValueHandle, DenseMapInfo<Value *>> ValueHandles;
141 unsigned BlockNumberEpoch;
143 const BlockCacheEntry *getBlockEntry(BasicBlock *BB)
const {
146 return BlockCache[BB->
getNumber()].get();
150 BlockCacheEntry *getOrCreateBlockEntry(BasicBlock *BB) {
156 if (BlockCacheEntry *Entry = BlockCache[
Number].
get())
159 BlockCache[
Number] = std::make_unique<BlockCacheEntry>();
161 BlockCache[
Number]->PredecessorLatticeElements =
162 std::make_optional<PredecessorValueLatticeMap>();
164 return BlockCache[
Number].get();
167 void addValueHandle(
Value *Val) {
168 auto HandleIt = ValueHandles.
find_as(Val);
169 if (HandleIt == ValueHandles.
end())
170 ValueHandles.
insert({Val,
this});
174 LazyValueInfoCache(
const Function *
F)
175 : BlockNumberEpoch(
F->getBlockNumberEpoch()) {}
177 void insertResult(
Value *Val, BasicBlock *BB,
178 const ValueLatticeElement &Result) {
179 BlockCacheEntry *
Entry = getOrCreateBlockEntry(BB);
183 if (
Result.isOverdefined())
184 Entry->OverDefined.insert(Val);
191 void insertPredecessorResults(
Value *Val, BasicBlock *BB,
192 BBLatticeElementMap &PredLatticeElements) {
193 BlockCacheEntry *
Entry = getOrCreateBlockEntry(BB);
195 Entry->PredecessorLatticeElements->insert({Val, PredLatticeElements});
200 std::optional<BBLatticeElementMap>
201 getCachedPredecessorInfo(
Value *V, BasicBlock *BB)
const {
202 const BlockCacheEntry *
Entry = getBlockEntry(BB);
206 auto LatticeIt =
Entry->PredecessorLatticeElements->find_as(V);
207 if (LatticeIt ==
Entry->PredecessorLatticeElements->end())
210 return LatticeIt->second;
213 std::optional<ValueLatticeElement> getCachedValueInfo(
Value *V,
214 BasicBlock *BB)
const {
215 const BlockCacheEntry *
Entry = getBlockEntry(BB);
219 if (
Entry->OverDefined.count(V))
222 auto LatticeIt =
Entry->LatticeElements.find_as(V);
223 if (LatticeIt ==
Entry->LatticeElements.end())
226 return LatticeIt->second;
230 isNonNullAtEndOfBlock(
Value *V, BasicBlock *BB,
231 function_ref<NonNullPointerSet(BasicBlock *)> InitFn) {
232 BlockCacheEntry *
Entry = getOrCreateBlockEntry(BB);
233 if (!
Entry->NonNullPointers) {
234 Entry->NonNullPointers = InitFn(BB);
239 return Entry->NonNullPointers->count(V);
245 ValueHandles.
clear();
249 void eraseValue(
Value *V);
253 void eraseBlock(BasicBlock *BB);
258 void threadEdgeImpl(BasicBlock *OldSucc, BasicBlock *NewSucc);
262void LazyValueInfoCache::eraseValue(
Value *V) {
263 for (
auto &Elem : BlockCache) {
267 Elem->LatticeElements.erase(V);
268 Elem->OverDefined.erase(V);
269 if (Elem->NonNullPointers)
270 Elem->NonNullPointers->erase(V);
272 Elem->PredecessorLatticeElements->erase(V);
275 auto HandleIt = ValueHandles.
find_as(V);
276 if (HandleIt != ValueHandles.
end())
277 ValueHandles.
erase(HandleIt);
280void LVIValueHandle::deleted() {
283 Parent->eraseValue(*
this);
286void LazyValueInfoCache::eraseBlock(
BasicBlock *BB) {
290 for (
auto &Elem : BlockCache)
292 Elem->PredecessorLatticeElements->clear();
297void LazyValueInfoCache::threadEdgeImpl(
BasicBlock *OldSucc,
309 std::vector<BasicBlock*> worklist;
310 worklist.push_back(OldSucc);
312 const BlockCacheEntry *
Entry = getBlockEntry(OldSucc);
313 if (!Entry ||
Entry->OverDefined.empty())
316 Entry->OverDefined.end());
322 while (!worklist.empty()) {
327 if (ToUpdate == NewSucc)
continue;
330 BlockCacheEntry *WorklistEntry =
331 ToUpdate->
getNumber() < BlockCache.size()
332 ? BlockCache[ToUpdate->
getNumber()].get()
334 if (!WorklistEntry || WorklistEntry->OverDefined.empty())
336 auto &ValueSet = WorklistEntry->OverDefined;
338 bool changed =
false;
339 for (
Value *V : ValsToClear) {
340 if (!ValueSet.erase(V))
348 if (!changed)
continue;
359 LazyValueInfoImpl *LVIImpl;
365 LazyValueInfoAnnotatedWriter(LazyValueInfoImpl *L, DominatorTree &DTree)
366 : LVIImpl(
L), DT(DTree) {}
368 void emitBasicBlockStartAnnot(
const BasicBlock *BB,
369 formatted_raw_ostream &OS)
override;
371 void emitInstructionAnnot(
const Instruction *
I,
372 formatted_raw_ostream &OS)
override;
379 LazyValueInfoCache TheCache;
391 bool pushBlockValue(
const std::pair<BasicBlock *, Value *> &BV) {
392 if (!BlockValueSet.insert(BV).second)
396 << BV.first->getName() <<
"\n");
397 BlockValueStack.push_back(BV);
408 std::optional<ValueLatticeElement> getBlockValue(
Value *Val,
BasicBlock *BB,
418 std::optional<ValueLatticeElement> solveBlockValueImpl(
Value *Val,
420 std::optional<ValueLatticeElement> solveBlockValueNonLocal(
Value *Val,
422 std::optional<ValueLatticeElement> solveBlockValuePHINode(
PHINode *PN,
424 std::optional<ValueLatticeElement> solveBlockValueSelect(
SelectInst *S,
428 std::optional<ValueLatticeElement> solveBlockValueBinaryOpImpl(
432 std::optional<ValueLatticeElement>
434 std::optional<ValueLatticeElement> solveBlockValueCast(
CastInst *CI,
436 std::optional<ValueLatticeElement>
438 std::optional<ValueLatticeElement> solveBlockValueIntrinsic(
IntrinsicInst *
II,
440 std::optional<ValueLatticeElement>
442 std::optional<ValueLatticeElement>
445 void intersectAssumeOrGuardBlockValueConstantRange(
Value *Val,
455 std::optional<ValueLatticeElement>
460 std::optional<ValueLatticeElement>
461 getValueFromICmpCondition(
Value *Val,
ICmpInst *ICI,
bool isTrueDest,
466 std::optional<ValueLatticeElement>
468 bool UseBlockValue,
unsigned Depth = 0);
470 std::optional<ValueLatticeElement> getEdgeValueLocal(
Value *Val,
503 LazyValueInfoAnnotatedWriter Writer(
this, DTree);
504 F.print(OS, &Writer);
514 TheCache.eraseBlock(BB);
523 : TheCache(
F), AC(AC), DL(DL), GuardDecl(GuardDecl) {}
527void LazyValueInfoImpl::solve() {
531 unsigned processedCount = 0;
532 while (!BlockValueStack.empty()) {
544 dbgs() <<
"Giving up on stack because we are getting too deep\n");
546 while (!StartingStack.
empty()) {
547 std::pair<BasicBlock *, Value *> &
e = StartingStack.
back();
548 TheCache.insertResult(
e.second,
e.first,
552 BlockValueSet.clear();
553 BlockValueStack.clear();
556 std::pair<BasicBlock *, Value *>
e = BlockValueStack.back();
557 assert(BlockValueSet.count(e) &&
"Stack value should be in BlockValueSet!");
558 unsigned StackSize = BlockValueStack.size();
561 if (solveBlockValue(
e.second,
e.first)) {
563 assert(BlockValueStack.size() == StackSize &&
564 BlockValueStack.back() == e &&
"Nothing should have been pushed!");
566 std::optional<ValueLatticeElement> BBLV =
567 TheCache.getCachedValueInfo(
e.second,
e.first);
568 assert(BBLV &&
"Result should be in cache!");
570 dbgs() <<
"POP " << *
e.second <<
" in " <<
e.first->getName() <<
" = "
574 BlockValueStack.pop_back();
575 BlockValueSet.erase(e);
578 assert(BlockValueStack.size() == StackSize + 1 &&
579 "Exactly one element should have been pushed!");
584std::optional<ValueLatticeElement>
591 if (std::optional<ValueLatticeElement> OptLatticeVal =
592 TheCache.getCachedValueInfo(Val, BB)) {
593 intersectAssumeOrGuardBlockValueConstantRange(Val, *OptLatticeVal, CxtI);
594 return OptLatticeVal;
598 if (!pushBlockValue({ BB, Val }))
609 case Instruction::Call:
610 case Instruction::Invoke:
614 case Instruction::Load:
628 assert(!TheCache.getCachedValueInfo(Val, BB) &&
629 "Value should not be in cache");
633 std::optional<ValueLatticeElement> Res = solveBlockValueImpl(Val, BB);
638 TheCache.insertResult(Val, BB, *Res);
642std::optional<ValueLatticeElement>
646 return solveBlockValueNonLocal(Val, BB);
649 return solveBlockValuePHINode(PN, BB);
652 return solveBlockValueSelect(SI, BB);
669 return solveBlockValueCast(CI, BB);
672 return solveBlockValueBinaryOp(BO, BB);
675 return solveBlockValueInsertElement(IEI, BB);
678 return solveBlockValueExtractValue(EVI, BB);
681 return solveBlockValueIntrinsic(
II, BB);
685 <<
"' - unknown inst def found.\n");
690 bool IsDereferenced =
true) {
704 if (
MI->isVolatile())
return;
708 if (!Len || Len->isZero())
return;
714 for (
auto &U : CB->args()) {
715 if (U->getType()->isPointerTy() &&
716 CB->paramHasNonNullAttr(CB->getArgOperandNo(&U),
723bool LazyValueInfoImpl::isNonNullAtEndOfBlock(
Value *Val,
BasicBlock *BB) {
729 return TheCache.isNonNullAtEndOfBlock(Val, BB, [](BasicBlock *BB) {
730 NonNullPointerSet NonNullPointers;
731 for (Instruction &
I : *BB)
733 return NonNullPointers;
737std::optional<ValueLatticeElement>
738LazyValueInfoImpl::solveBlockValueNonLocal(
Value *Val,
BasicBlock *BB) {
739 ValueLatticeElement
Result;
758 std::optional<BBLatticeElementMap> PredLatticeElements;
760 PredLatticeElements = std::make_optional<BBLatticeElementMap>();
765 std::optional<ValueLatticeElement> EdgeResult = getEdgeValue(Val, Pred, BB);
770 Result.mergeIn(*EdgeResult);
774 if (
Result.isOverdefined()) {
776 <<
"' - overdefined because of pred '"
777 << Pred->getName() <<
"' (non local).\n");
781 PredLatticeElements->insert({Pred, *EdgeResult});
785 TheCache.insertPredecessorResults(Val, BB, *PredLatticeElements);
792std::optional<ValueLatticeElement>
794 ValueLatticeElement
Result;
799 std::optional<BBLatticeElementMap> PredLatticeElements;
801 PredLatticeElements = std::make_optional<BBLatticeElementMap>();
808 std::optional<ValueLatticeElement> EdgeResult =
809 getEdgeValue(PhiVal, PhiBB, BB, PN);
814 Result.mergeIn(*EdgeResult);
818 if (
Result.isOverdefined()) {
820 <<
"' - overdefined because of pred (local).\n");
826 PredLatticeElements->insert({PhiBB, *EdgeResult});
830 TheCache.insertPredecessorResults(PN, BB, *PredLatticeElements);
833 assert(!
Result.isOverdefined() &&
"Possible PHI in entry block?");
839void LazyValueInfoImpl::intersectAssumeOrGuardBlockValueConstantRange(
846 for (
auto &AssumeVH : AC->assumptionsFor(Val)) {
860 I->getOperandBundleAt(AssumeVH.Index)))
864 BBLV = BBLV.
intersect(*getValueFromCondition(Val,
I->getArgOperand(0),
871 if (GuardDecl && !GuardDecl->use_empty() &&
873 for (Instruction &
I :
888 isNonNullAtEndOfBlock(Val, BB))
893std::optional<ValueLatticeElement>
896 std::optional<ValueLatticeElement> OptTrueVal =
897 getBlockValue(
SI->getTrueValue(), BB, SI);
900 ValueLatticeElement &
TrueVal = *OptTrueVal;
902 std::optional<ValueLatticeElement> OptFalseVal =
903 getBlockValue(
SI->getFalseValue(), BB, SI);
906 ValueLatticeElement &
FalseVal = *OptFalseVal;
909 const ConstantRange &TrueCR =
TrueVal.asConstantRange(
SI->getType());
910 const ConstantRange &FalseCR =
FalseVal.asConstantRange(
SI->getType());
917 ((
LHS ==
SI->getTrueValue() &&
RHS ==
SI->getFalseValue()) ||
918 (
RHS ==
SI->getTrueValue() &&
LHS ==
SI->getFalseValue()))) {
919 ConstantRange ResultCR = [&]() {
924 return TrueCR.
smin(FalseCR);
926 return TrueCR.
umin(FalseCR);
928 return TrueCR.
smax(FalseCR);
930 return TrueCR.
umax(FalseCR);
934 ResultCR,
TrueVal.isConstantRangeIncludingUndef() ||
935 FalseVal.isConstantRangeIncludingUndef());
939 if (
LHS ==
SI->getTrueValue())
941 TrueCR.
abs(),
TrueVal.isConstantRangeIncludingUndef());
942 if (
LHS ==
SI->getFalseValue())
944 FalseCR.
abs(),
FalseVal.isConstantRangeIncludingUndef());
949 if (
LHS ==
SI->getTrueValue())
952 if (
LHS ==
SI->getFalseValue())
966 TrueVal.intersect(*getValueFromCondition(
SI->getTrueValue(),
Cond,
970 FalseVal.intersect(*getValueFromCondition(
SI->getFalseValue(),
Cond,
979std::optional<ConstantRange>
981 std::optional<ValueLatticeElement> OptVal = getBlockValue(V, BB, CxtI);
984 return OptVal->asConstantRange(
V->getType());
987std::optional<ValueLatticeElement>
993 case Instruction::Trunc:
994 case Instruction::SExt:
995 case Instruction::ZExt:
1000 <<
"' - overdefined (unknown cast).\n");
1007 std::optional<ConstantRange> LHSRes = getRangeFor(CI->
getOperand(0), CI, BB);
1010 return std::nullopt;
1011 const ConstantRange &LHSRange = *LHSRes;
1018 ConstantRange Res = ConstantRange::getEmpty(ResultBitWidth);
1020 Res = LHSRange.
truncate(ResultBitWidth, Trunc->getNoWrapKind());
1027std::optional<ValueLatticeElement>
1028LazyValueInfoImpl::solveBlockValueBinaryOpImpl(
1035 auto ThreadBinOpOverSelect =
1036 [&](
Value *
X,
const ConstantRange &CRX, SelectInst *
Y,
1037 bool XIsLHS) -> std::optional<ValueLatticeElement> {
1042 return std::nullopt;
1045 return std::nullopt;
1047 return std::nullopt;
1049 ConstantRange TrueX =
1050 CRX.intersectWith(getValueFromCondition(
X,
Cond,
true,
1052 ->asConstantRange(
X->getType()));
1053 ConstantRange FalseX =
1054 CRX.intersectWith(getValueFromCondition(
X,
Cond,
false,
1056 ->asConstantRange(
X->getType()));
1062 OpFn(TrueX, TrueY).unionWith(OpFn(FalseX, FalseY)));
1064 OpFn(TrueY, TrueX).unionWith(OpFn(FalseY, FalseX)));
1071 std::optional<ConstantRange> LHSRes = getRangeFor(
LHS,
I, BB);
1073 return std::nullopt;
1077 if (
auto Res = ThreadBinOpOverSelect(
LHS, *LHSRes, SI,
true))
1081 std::optional<ConstantRange> RHSRes = getRangeFor(
RHS,
I, BB);
1083 return std::nullopt;
1087 if (
auto Res = ThreadBinOpOverSelect(
RHS, *RHSRes, SI,
false))
1091 const ConstantRange &LHSRange = *LHSRes;
1092 const ConstantRange &RHSRange = *RHSRes;
1094 std::optional<ValueLatticeElement> MergedResult =
1098 return MergedResult;
1100 std::optional<BBLatticeElementMap> PredLHS =
1101 TheCache.getCachedPredecessorInfo(
LHS, BB);
1103 return MergedResult;
1104 std::optional<BBLatticeElementMap> PredRHS =
1105 TheCache.getCachedPredecessorInfo(
RHS, BB);
1107 return MergedResult;
1109 const BBLatticeElementMap &LHSPredMap = *PredLHS;
1110 const BBLatticeElementMap &RHSPredMap = *PredRHS;
1112 BBLatticeElementMap PredLatticeElements;
1113 ValueLatticeElement OverallPredResult;
1115 auto LHSIt = LHSPredMap.find_as(Pred);
1116 if (LHSIt == LHSPredMap.end())
1117 return MergedResult;
1118 const ValueLatticeElement &LHSFromPred = LHSIt->second;
1119 std::optional<ConstantRange> LHSFromPredRes =
1121 if (!LHSFromPredRes)
1122 return MergedResult;
1124 auto RHSIt = RHSPredMap.find_as(Pred);
1125 if (RHSIt == RHSPredMap.end())
1126 return MergedResult;
1127 const ValueLatticeElement &RHSFromPred = RHSIt->second;
1128 std::optional<ConstantRange> RHSFromPredRes =
1130 if (!RHSFromPredRes)
1131 return MergedResult;
1133 const ConstantRange &LHSFromPredRange = *LHSFromPredRes;
1134 const ConstantRange &RHSFromPredRange = *RHSFromPredRes;
1135 std::optional<ValueLatticeElement> PredResult =
1138 return MergedResult;
1139 if (PredResult->isOverdefined()) {
1141 dbgs() <<
" pred BB '" << Pred->getName() <<
"' for BB '"
1143 <<
"' overdefined. Discarding all predecessor intervals.\n");
1144 return MergedResult;
1146 PredLatticeElements.insert({Pred, *PredResult});
1147 OverallPredResult.
mergeIn(*PredResult);
1153 TheCache.insertPredecessorResults(
I, BB, PredLatticeElements);
1156 <<
" to: " << OverallPredResult <<
".\n");
1159 return OverallPredResult;
1162 << OverallPredResult <<
" and " << MergedResult <<
".\n");
1163 return MergedResult->intersect(OverallPredResult);
1166std::optional<ValueLatticeElement>
1169 "all operands to binary operators are sized");
1171 unsigned NoWrapKind = OBO->getNoWrapKind();
1172 return solveBlockValueBinaryOpImpl(
1174 [BO, NoWrapKind](
const ConstantRange &CR1,
const ConstantRange &CR2) {
1179 return solveBlockValueBinaryOpImpl(
1180 BO, BB, [BO](
const ConstantRange &CR1,
const ConstantRange &CR2) {
1185std::optional<ValueLatticeElement>
1188 return solveBlockValueBinaryOpImpl(
1189 WO, BB, [WO](
const ConstantRange &CR1,
const ConstantRange &CR2) {
1194std::optional<ValueLatticeElement>
1199 <<
"' - unknown intrinsic.\n");
1205 std::optional<ConstantRange>
Range = getRangeFor(
Op,
II, BB);
1207 return std::nullopt;
1216std::optional<ValueLatticeElement>
1219 std::optional<ValueLatticeElement> OptEltVal =
1222 return std::nullopt;
1223 ValueLatticeElement &Res = *OptEltVal;
1225 std::optional<ValueLatticeElement> OptVecVal =
1228 return std::nullopt;
1234 if (OptEltVal->isConstant())
1241std::optional<ValueLatticeElement>
1246 return solveBlockValueOverflowIntrinsic(WO, BB);
1253 return getBlockValue(V, BB, EVI);
1256 <<
"' - overdefined (unknown extractvalue).\n");
1294std::optional<ValueLatticeElement>
1299 bool UseBlockValue) {
1303 RHSRange =
C->toConstantRange();
1304 }
else if (UseBlockValue) {
1305 std::optional<ValueLatticeElement>
R =
1308 return std::nullopt;
1312 ConstantRange TrueValues =
1317static std::optional<ConstantRange>
1320 bool Invert =
false;
1327 if (
RHS.isMaxSignedValue())
1328 return std::nullopt;
1332 if (
auto CR = Fn(
RHS))
1333 return Invert ? CR->inverse() : CR;
1334 return std::nullopt;
1340 unsigned BitWidth =
RHS->getType()->getScalarSizeInBits();
1358std::optional<ValueLatticeElement> LazyValueInfoImpl::getValueFromICmpCondition(
1359 Value *Val,
ICmpInst *ICI,
bool isTrueDest,
bool UseBlockValue) {
1383 return getValueFromSimpleICmpCondition(EdgePred,
RHS,
Offset, ICI,
1388 return getValueFromSimpleICmpCondition(SwappedPred,
LHS,
Offset, ICI,
1394 const APInt *
Mask, *
C;
1428 const APInt *ShAmtC;
1433 EdgePred, *
C, [&](
const APInt &
RHS) -> std::optional<ConstantRange> {
1434 APInt
New =
RHS << *ShAmtC;
1435 if ((
New.ashr(*ShAmtC)) !=
RHS)
1436 return std::nullopt;
1504std::optional<ValueLatticeElement>
1506 bool IsTrueDest,
bool UseBlockValue,
1509 return getValueFromICmpCondition(Val, ICI, IsTrueDest, UseBlockValue);
1512 return getValueFromTrunc(Val, Trunc, IsTrueDest);
1524 return getValueFromCondition(Val,
N, !IsTrueDest, UseBlockValue,
Depth);
1535 std::optional<ValueLatticeElement> LV =
1536 getValueFromCondition(Val, L, IsTrueDest, UseBlockValue,
Depth);
1538 return std::nullopt;
1539 std::optional<ValueLatticeElement> RV =
1540 getValueFromCondition(Val, R, IsTrueDest, UseBlockValue,
Depth);
1542 return std::nullopt;
1548 if (IsTrueDest ^ IsAnd) {
1553 return LV->intersect(*RV);
1574 const APInt &OpConstVal,
1589 assert((Op0Match || Op1Match) &&
1590 "Operand 0 nor Operand 1 isn't a match");
1605std::optional<ValueLatticeElement>
1613 if (BI->getSuccessor(0) != BI->getSuccessor(1)) {
1614 bool isTrueDest = BI->getSuccessor(0) == BBTo;
1615 assert(BI->getSuccessor(!isTrueDest) == BBTo &&
1616 "BBTo isn't a successor of BBFrom");
1617 Value *Condition = BI->getCondition();
1622 if (Condition == Val)
1628 std::optional<ValueLatticeElement>
Result =
1629 getValueFromCondition(Val, Condition, isTrueDest, UseBlockValue);
1631 return std::nullopt;
1633 if (!
Result->isOverdefined())
1637 assert(
Result->isOverdefined() &&
"Result isn't overdefined");
1651 APInt ConditionVal(1, isTrueDest ? 1 : 0);
1654 ValueLatticeElement OpLatticeVal =
1655 *getValueFromCondition(Usr->getOperand(0), Condition,
1659 const unsigned ResultBitWidth =
1660 Usr->getType()->getScalarSizeInBits();
1685 for (
unsigned i = 0; i < Usr->getNumOperands(); ++i) {
1686 Value *
Op = Usr->getOperand(i);
1687 ValueLatticeElement OpLatticeVal = *getValueFromCondition(
1688 Op, Condition, isTrueDest,
false);
1689 if (std::optional<APInt> OpConst =
1698 if (!
Result->isOverdefined())
1706 Value *Condition =
SI->getCondition();
1709 bool ValUsesConditionAndMayBeFoldable =
false;
1710 if (Condition != Val) {
1715 if (!ValUsesConditionAndMayBeFoldable)
1718 assert((Condition == Val || ValUsesConditionAndMayBeFoldable) &&
1719 "Condition != Val nor Val doesn't use Condition");
1721 bool DefaultCase =
SI->getDefaultDest() == BBTo;
1723 ConstantRange EdgesVals(
BitWidth, DefaultCase);
1725 for (
auto Case :
SI->cases()) {
1726 APInt CaseValue = Case.getCaseValue()->getValue();
1727 ConstantRange EdgeVal(CaseValue);
1728 if (ValUsesConditionAndMayBeFoldable) {
1731 ValueLatticeElement EdgeLatticeVal =
1744 if (Case.getCaseSuccessor() != BBTo && Condition == Val)
1745 EdgesVals = EdgesVals.difference(EdgeVal);
1746 }
else if (Case.getCaseSuccessor() == BBTo)
1747 EdgesVals = EdgesVals.unionWith(EdgeVal);
1756std::optional<ValueLatticeElement>
1763 std::optional<ValueLatticeElement> LocalResult =
1764 getEdgeValueLocal(Val, BBFrom, BBTo,
true);
1766 return std::nullopt;
1772 std::optional<ValueLatticeElement> OptInBlock =
1775 return std::nullopt;
1776 ValueLatticeElement &
InBlock = *OptInBlock;
1786 intersectAssumeOrGuardBlockValueConstantRange(Val,
InBlock, CxtI);
1788 return LocalResult->intersect(
InBlock);
1793 LLVM_DEBUG(
dbgs() <<
"LVI Getting block end value " << *V <<
" at '"
1796 assert(BlockValueStack.empty() && BlockValueSet.empty());
1797 std::optional<ValueLatticeElement> OptResult = getBlockValue(V, BB, CxtI);
1800 OptResult = getBlockValue(V, BB, CxtI);
1801 assert(OptResult &&
"Value not available after solving");
1818 intersectAssumeOrGuardBlockValueConstantRange(V, Result, CxtI);
1827 LLVM_DEBUG(
dbgs() <<
"LVI Getting edge value " << *V <<
" from '"
1831 std::optional<ValueLatticeElement> Result =
1832 getEdgeValue(V, FromBB, ToBB, CxtI);
1838 Result = getEdgeValue(V, FromBB, ToBB, CxtI);
1852 const Use *CurrU = &U;
1854 const unsigned MaxUsesToInspect = 3;
1855 for (
unsigned I = 0;
I < MaxUsesToInspect; ++
I) {
1856 std::optional<ValueLatticeElement> CondVal;
1863 if (CurrU->getOperandNo() == 1)
1865 *getValueFromCondition(V,
SI->getCondition(),
true,
1867 else if (CurrU->getOperandNo() == 2)
1869 *getValueFromCondition(V,
SI->getCondition(),
false,
1873 CondVal = *getEdgeValueLocal(V,
PHI->getIncomingBlock(*CurrU),
1874 PHI->getParent(),
false);
1888 if (!CurrI->hasOneUse() ||
1899 TheCache.threadEdgeImpl(OldSucc, NewSucc);
1910 if (
auto *Impl = Info.getImpl())
1930 F->getParent(), Intrinsic::experimental_guard);
1942 if (
auto *Impl = getImpl()) {
1949 FunctionAnalysisManager::Invalidator &Inv) {
1975 V = V->stripPointerCasts();
1990 if (Result.isConstant())
1991 return Result.getConstant();
1992 if (Result.isConstantRange()) {
1995 return ConstantInt::get(V->getType(), *SingleVal);
2001 bool UndefAllowed) {
2004 return Result.asConstantRange(V->getType(), UndefAllowed);
2008 bool UndefAllowed) {
2010 return Result.asConstantRange(U->getType(), UndefAllowed);
2019 getOrCreateImpl().getValueOnEdge(V, FromBB, ToBB, CxtI);
2021 if (Result.isConstant())
2022 return Result.getConstant();
2023 if (Result.isConstantRange()) {
2026 return ConstantInt::get(V->getType(), *SingleVal);
2036 getOrCreateImpl().getValueOnEdge(V, FromBB, ToBB, CxtI);
2038 return Result.asConstantRange(V->getType(),
true);
2088 getOrCreateImpl().getValueOnEdge(V, FromBB, ToBB, CxtI);
2095 bool UseBlockValue) {
2105 if (V->getType()->isPointerTy() &&
C->isNullValue() &&
2114 auto &Impl = getOrCreateImpl();
2116 UseBlockValue ? Impl.getValueInBlock(V, CxtI->
getParent(), CxtI)
2117 : Impl.getValueAt(V, CxtI);
2157 if (
PHI->getParent() == BB) {
2159 for (
unsigned i = 0, e =
PHI->getNumIncomingValues(); i < e; i++) {
2160 Value *Incoming =
PHI->getIncomingValue(i);
2168 Baseline = (i == 0) ? Result
2169 : (Baseline == Result ? Baseline
2188 while (++PI != PE) {
2190 if (Ret != Baseline)
2205 bool UseBlockValue) {
2215 if (UseBlockValue) {
2217 getOrCreateImpl().getValueInBlock(LHS, CxtI->
getParent(), CxtI);
2218 if (L.isOverdefined())
2222 getOrCreateImpl().getValueInBlock(RHS, CxtI->
getParent(), CxtI);
2231 if (
auto *Impl = getImpl())
2232 Impl->threadEdge(PredBB, OldSucc, NewSucc);
2236 if (
auto *Impl = getImpl())
2237 Impl->forgetValue(V);
2241 if (
auto *Impl = getImpl())
2242 Impl->eraseBlock(BB);
2246 if (
auto *Impl = getImpl())
2251 if (
auto *Impl = getImpl())
2252 Impl->printLVI(F, DTree, OS);
2256void LazyValueInfoAnnotatedWriter::emitBasicBlockStartAnnot(
2260 for (
const auto &Arg :
F->args()) {
2263 if (Result.isUnknown())
2265 OS <<
"; LatticeVal for: '" << Arg <<
"' is: " << Result <<
"\n";
2273void LazyValueInfoAnnotatedWriter::emitInstructionAnnot(
2274 const Instruction *
I, formatted_raw_ostream &OS) {
2277 SmallPtrSet<const BasicBlock*, 16> BlocksContainingLVI;
2283 auto printResult = [&](
const BasicBlock *BB) {
2284 if (!BlocksContainingLVI.
insert(BB).second)
2288 OS <<
"; LatticeVal for: '" << *
I <<
"' in BB: '";
2290 OS <<
"' is: " <<
Result <<
"\n";
2293 printResult(ParentBB);
2296 for (
const auto *BBSucc :
successors(ParentBB))
2298 printResult(BBSucc);
2301 for (
const auto *U :
I->users())
2304 printResult(UseI->getParent());
2310 OS <<
"LVI for function '" <<
F.getName() <<
"':\n";
2313 LVI.printLVI(
F, DTree, OS);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
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 DenseSet and SmallDenseSet classes.
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.
static Value * getOpcode(Value &V, Type &Ty, InstrumentationConfig &IConf, InstrumentorIRBuilderTy &IIRB)
static bool isOperationFoldable(User *Usr)
static void AddNonNullPointer(Value *Ptr, NonNullPointerSet &PtrSet, bool IsDereferenced=true)
static void AddNonNullPointersByInstruction(Instruction *I, NonNullPointerSet &PtrSet)
static std::optional< ConstantRange > getRangeViaSLT(CmpInst::Predicate Pred, APInt RHS, function_ref< std::optional< ConstantRange >(const APInt &)> Fn)
static const unsigned MaxProcessedPerValue
static ValueLatticeElement getValueFromICmpCtpop(ICmpInst::Predicate Pred, Value *RHS)
Get value range for a "ctpop(Val) Pred RHS" condition.
static bool usesOperand(User *Usr, Value *Op)
static ValueLatticeElement constantFoldUser(User *Usr, Value *Op, const APInt &OpConstVal, const DataLayout &DL)
static ValueLatticeElement getFromRangeMetadata(Instruction *BBI)
lazy value Lazy Value Information static true cl::opt< bool > PerPredRanges("lvi-per-pred-ranges", cl::Hidden, cl::init(false), cl::desc("Enable tracking of ranges for a value in a block for" "each block predecessor (default = false)"))
static Constant * getPredicateResult(CmpInst::Predicate Pred, Constant *C, const ValueLatticeElement &Val, const DataLayout &DL)
static ValueLatticeElement getValueFromOverflowCondition(Value *Val, WithOverflowInst *WO, bool IsTrueDest)
static bool isKnownNonConstant(Value *V)
Returns true if we can statically tell that this value will never be a "useful" constant.
static bool matchICmpOperand(APInt &Offset, Value *LHS, Value *Val, ICmpInst::Predicate Pred)
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
uint64_t IntrinsicInst * II
FunctionAnalysisManager FAM
#define INITIALIZE_PASS_DEPENDENCY(depName)
#define INITIALIZE_PASS_END(passName, arg, name, cfg, analysis)
#define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis)
const SmallVectorImpl< MachineOperand > & Cond
static bool InBlock(const Value *V, const BasicBlock *BB)
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
Class for arbitrary precision integers.
LLVM_ABI APInt zext(unsigned width) const
Zero extend to a new width.
static APInt getSignedMinValue(unsigned numBits)
Gets minimum signed value of APInt for a specific bit width.
uint64_t getLimitedValue(uint64_t Limit=UINT64_MAX) const
If this value is smaller than the specified limit, return it, otherwise return the limit value.
static APInt getLowBitsSet(unsigned numBits, unsigned loBitsSet)
Constructs an APInt value that has the bottom loBitsSet bits set.
static APInt getHighBitsSet(unsigned numBits, unsigned hiBitsSet)
Constructs an APInt value that has the top hiBitsSet bits set.
static APInt getZero(unsigned numBits)
Get the '0' value for the specified bit-width.
This templated class represents "all analyses that operate over <aparticular IR unit>" (e....
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Represent the analysis usage information of a pass.
AnalysisUsage & addRequired()
void setPreservesAll()
Set by analyses that do not transform their input at all.
This class represents an incoming formal argument to a Function.
A function analysis which provides an AssumptionCache.
An immutable pass that tracks lazily created AssumptionCache objects.
A cache of @llvm.assume calls within a function.
LLVM Basic Block Representation.
unsigned getNumber() const
iterator begin()
Instruction iterator methods.
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI bool isEntryBlock() const
Return true if this is the entry block of the containing function.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this basic block belongs to.
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction; assumes that the block is well-formed.
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.
BinaryOps getOpcode() const
Value handle with callbacks on RAUW and destruction.
This is the base class for all instructions that perform data casts.
Instruction::CastOps getOpcode() const
Return the opcode of this CastInst.
Type * getDestTy() const
Return the destination type, as a convenience.
static Type * makeCmpResultType(Type *opnd_type)
Create a result type for fcmp/icmp.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
@ ICMP_SLT
signed less than
@ ICMP_SLE
signed less or equal
@ ICMP_UGE
unsigned greater or equal
@ ICMP_UGT
unsigned greater than
@ ICMP_SGT
signed greater than
@ ICMP_ULT
unsigned less than
@ ICMP_SGE
signed greater or equal
@ ICMP_ULE
unsigned less or equal
Predicate getSwappedPredicate() const
For example, EQ->EQ, SLE->SGE, ULT->UGT, OEQ->OEQ, ULE->UGE, OLT->OGT, etc.
Predicate getInversePredicate() const
For example, EQ -> NE, UGT -> ULE, SLT -> SGE, OEQ -> UNE, UGT -> OLE, OLT -> UGE,...
Predicate getPredicate() const
Return the predicate for this instruction.
This is the shared class of boolean and integer constants.
static LLVM_ABI ConstantInt * getTrue(LLVMContext &Context)
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 subtract(const APInt &CI) const
Subtract the specified constant from the endpoints of this constant range.
const APInt * getSingleElement() const
If this set contains a single element, return it, otherwise return null.
static LLVM_ABI ConstantRange fromKnownBits(const KnownBits &Known, bool IsSigned)
Initialize a range based on a known bits constraint.
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 ConstantRange umin(const ConstantRange &Other) const
Return a new range representing the possible values resulting from an unsigned minimum of a value in ...
LLVM_ABI APInt getUnsignedMin() const
Return the smallest unsigned value contained in the ConstantRange.
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 isEmptySet() const
Return true if this set contains no members.
LLVM_ABI ConstantRange abs(bool IntMinIsPoison=false) const
Calculate absolute value range.
static LLVM_ABI bool isIntrinsicSupported(Intrinsic::ID IntrinsicID)
Returns true if ConstantRange calculations are supported for intrinsic with IntrinsicID.
LLVM_ABI ConstantRange overflowingBinaryOp(Instruction::BinaryOps BinOp, const ConstantRange &Other, unsigned NoWrapKind) const
Return a new range representing the possible values resulting from an application of the specified ov...
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 ConstantRange umax(const ConstantRange &Other) const
Return a new range representing the possible values resulting from an unsigned maximum of a value in ...
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...
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 APInt getUnsignedMax() const
Return the largest unsigned value contained in the ConstantRange.
static LLVM_ABI ConstantRange makeMaskNotEqualRange(const APInt &Mask, const APInt &C)
Initialize a range containing all values X that satisfy (X & Mask) / != C.
static ConstantRange getNonEmpty(APInt Lower, APInt Upper)
Create non-empty constant range with the given bounds.
LLVM_ABI ConstantRange smin(const ConstantRange &Other) const
Return a new range representing the possible values resulting from a signed minimum of a value in thi...
uint32_t getBitWidth() const
Get the bit width of this ConstantRange.
LLVM_ABI ConstantRange smax(const ConstantRange &Other) const
Return a new range representing the possible values resulting from a signed maximum of a value in thi...
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...
static LLVM_ABI ConstantRange makeExactNoWrapRegion(Instruction::BinaryOps BinOp, const APInt &Other, unsigned NoWrapKind)
Produce the range that contains X if and only if "X BinOp Other" does not wrap.
This is an important base class in LLVM.
static LLVM_ABI Constant * getIntegerValue(Type *Ty, const APInt &V)
Return the value for an integer or pointer constant, or a vector thereof, with the given scalar value...
LLVM_ABI ConstantRange toConstantRange() const
Convert constant to an approximate constant range.
bool isNullValue() const
Return true if this is the value that would be returned by getNullValue.
static LLVM_ABI Constant * getAllOnesValue(Type *Ty)
static LLVM_ABI Constant * getNullValue(Type *Ty)
Constructor to create a '0' constant of arbitrary type.
A parsed version of the target data layout string in and methods for querying it.
Implements a dense probed hash-table based set.
Analysis pass which computes a DominatorTree.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
LLVM_ABI bool dominates(const BasicBlock *BB, const Use &U) const
Return true if the (end of the) basic block BB dominates the use U.
FunctionPass class - This class is used to implement most global optimizations.
unsigned getMaxBlockNumber() const
Return a value larger than the largest block number.
unsigned getBlockNumberEpoch() const
Return the "epoch" of current block numbers.
Module * getParent()
Get the module that this global value is contained inside of...
This instruction compares its operands according to the predicate given to the constructor.
static bool isEquality(Predicate P)
Return true if this predicate is either EQ or NE.
This instruction inserts a single (scalar) element into a VectorType value.
LLVM_ABI const Function * getFunction() const
Return the function this instruction belongs to.
MDNode * getMetadata(unsigned KindID) const
Get the metadata of given kind attached to this Instruction.
unsigned getOpcode() const
Returns a member of one of the enums like Instruction::Add.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this instruction belongs to.
A wrapper class for inspecting calls to intrinsic functions.
Analysis to compute lazy value information.
LLVM_ABI Result run(Function &F, FunctionAnalysisManager &FAM)
LazyValueInfoImpl(Function *F, AssumptionCache *AC, const DataLayout &DL, Function *GuardDecl)
ValueLatticeElement getValueOnEdge(Value *V, BasicBlock *FromBB, BasicBlock *ToBB, Instruction *CxtI=nullptr)
This is the query interface to determine the lattice value for the specified Value* that is true on t...
ValueLatticeElement getValueAt(Value *V, Instruction *CxtI)
This is the query interface to determine the lattice value for the specified Value* at the specified ...
void threadEdge(BasicBlock *PredBB, BasicBlock *OldSucc, BasicBlock *NewSucc)
This is the update interface to inform the cache that an edge from PredBB to OldSucc has been threade...
void printLVI(Function &F, DominatorTree &DTree, raw_ostream &OS)
Printing the LazyValueInfo Analysis.
void forgetValue(Value *V)
This is part of the update interface to remove information related to this value from the cache.
void eraseBlock(BasicBlock *BB)
This is part of the update interface to inform the cache that a block has been deleted.
void clear()
Complete flush all previously computed values.
ValueLatticeElement getValueInBlock(Value *V, BasicBlock *BB, Instruction *CxtI=nullptr)
This is the query interface to determine the lattice value for the specified Value* at the context in...
ValueLatticeElement getValueAtUse(const Use &U)
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
Wrapper around LazyValueInfo.
bool runOnFunction(Function &F) override
runOnFunction - Virtual method overriden by subclasses to do the per-function processing of the pass.
void releaseMemory() override
releaseMemory() - This member can be implemented by a pass if it wants to be able to release its memo...
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
LazyValueInfoWrapperPass()
This pass computes, caches, and vends lazy value constraint information.
LLVM_ABI void eraseBlock(BasicBlock *BB)
Inform the analysis cache that we have erased a block.
LLVM_ABI ConstantRange getConstantRangeAtUse(const Use &U, bool UndefAllowed)
Return the ConstantRange constraint that is known to hold for the value at a specific use-site.
LLVM_ABI ConstantRange getConstantRange(Value *V, Instruction *CxtI, bool UndefAllowed)
Return the ConstantRange constraint that is known to hold for the specified value at the specified in...
LLVM_ABI void threadEdge(BasicBlock *PredBB, BasicBlock *OldSucc, BasicBlock *NewSucc)
Inform the analysis cache that we have threaded an edge from PredBB to OldSucc to be from PredBB to N...
LLVM_ABI Constant * getPredicateOnEdge(CmpInst::Predicate Pred, Value *V, Constant *C, BasicBlock *FromBB, BasicBlock *ToBB, Instruction *CxtI=nullptr)
Determine whether the specified value comparison with a constant is known to be true or false on the ...
LLVM_ABI void releaseMemory()
LLVM_ABI Constant * getConstantOnEdge(Value *V, BasicBlock *FromBB, BasicBlock *ToBB, Instruction *CxtI=nullptr)
Determine whether the specified value is known to be a constant on the specified edge.
LLVM_ABI ConstantRange getConstantRangeOnEdge(Value *V, BasicBlock *FromBB, BasicBlock *ToBB, Instruction *CxtI=nullptr)
Return the ConstantRage constraint that is known to hold for the specified value on the specified edg...
LLVM_ABI Constant * getConstant(Value *V, Instruction *CxtI)
Determine whether the specified value is known to be a constant at the specified instruction.
LLVM_ABI void printLVI(Function &F, DominatorTree &DTree, raw_ostream &OS)
Print the \LazyValueInfo Analysis.
LLVM_ABI void forgetValue(Value *V)
Remove information related to this value from the cache.
LLVM_ABI void clear()
Complete flush all previously computed values.
LLVM_ABI Constant * getPredicateAt(CmpInst::Predicate Pred, Value *V, Constant *C, Instruction *CxtI, bool UseBlockValue)
Determine whether the specified value comparison with a constant is known to be true or false at the ...
LLVM_ABI ~LazyValueInfo()
LLVM_ABI bool invalidate(Function &F, const PreservedAnalyses &PA, FunctionAnalysisManager::Invalidator &Inv)
Handle invalidation events in the new pass manager.
An instruction for reading from memory.
This is the common base class for memset/memcpy/memmove.
This class wraps the llvm.memcpy/memmove intrinsics.
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.
AnalysisType & getAnalysis() const
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information ...
A set of analyses that are preserved following a run of a transformation pass.
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
PreservedAnalysisChecker getChecker() const
Build a checker for this PreservedAnalyses and the specified analysis type.
This class represents the LLVM 'select' instruction.
Implements a dense probed hash-table based set with some number of buckets stored inline.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
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.
This class represents a truncation of integer types.
unsigned getNoWrapKind() const
Returns the no-wrap kind of the operation.
bool hasNoUnsignedWrap() const
Test whether this operation is known to never undergo unsigned overflow, aka the nuw property.
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM_ABI unsigned getIntegerBitWidth() const
bool isIntOrIntVectorTy() const
Return true if this is an integer type or a vector of integer types.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
bool isSized(SmallPtrSetImpl< Type * > *Visited=nullptr) const
Return true if it makes sense to take the size of this type.
LLVM_ABI unsigned getScalarSizeInBits() const LLVM_READONLY
If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
static LLVM_ABI IntegerType * getInt1Ty(LLVMContext &C)
A Use represents the edge between a Value definition and its users.
Value * getOperand(unsigned i) const
This class represents lattice values for constants.
static ValueLatticeElement getRange(ConstantRange CR, bool MayIncludeUndef=false)
bool isOverdefined() const
static ValueLatticeElement getNot(Constant *C)
ConstantRange asConstantRange(unsigned BW, bool UndefAllowed=false) const
bool isNotConstant() const
std::optional< APInt > asConstantInteger() const
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)
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.
Constant * getConstant() const
bool mergeIn(const ValueLatticeElement &RHS, MergeOptions Opts=MergeOptions())
Updates this object to approximate both this object and RHS.
static ValueLatticeElement getOverdefined()
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVMContext & getContext() const
All values hold a context through their type.
LLVM_ABI const Value * stripInBoundsOffsets(function_ref< void(const Value *)> Func=[](const Value *) {}) const
Strip off pointer casts and inbounds GEPs.
LLVM_ABI void printAsOperand(raw_ostream &O, bool PrintType=true, const Module *M=nullptr) const
Print the name of this Value out to the specified raw_ostream.
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
Represents an op.with.overflow intrinsic.
std::pair< iterator, bool > insert(const ValueT &V)
iterator find_as(const LookupKeyT &Val)
Alternative version of find() which allows a different, and possibly less expensive,...
bool erase(const ValueT &V)
An efficient, type-erasing, non-owning reference to a callable.
const ParentTy * getParent() const
self_iterator getIterator()
This class implements an extremely fast bulk output stream that can only output to a stream.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr std::underlying_type_t< E > Mask()
Get a bitmask with 1s in all places up to the high-order bit of E's largest value.
@ C
The default llvm calling convention, compatible with C.
@ BasicBlock
Various leaf nodes.
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.
BinaryOp_match< SrcTy, SpecificConstantMatch, TargetOpcode::G_XOR, true > m_Not(const SrcTy &&Src)
Matches a register not-ed by a G_XOR.
match_combine_or< Ty... > m_CombineOr(const Ty &...Ps)
Combine pattern matchers matching any of Ps patterns.
BinaryOp_match< LHS, RHS, Instruction::And > m_And(const LHS &L, const RHS &R)
PtrToIntSameSize_match< OpTy > m_PtrToIntSameSize(const DataLayout &DL, const OpTy &Op)
BinaryOp_match< LHS, RHS, Instruction::AShr > m_AShr(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::URem > m_URem(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.
BinaryOp_match< LHS, RHS, Instruction::And, true > m_c_And(const LHS &L, const RHS &R)
Matches an And with LHS and RHS in either order.
CastInst_match< OpTy, TruncInst > m_Trunc(const OpTy &Op)
Matches Trunc.
bool match(Val *V, const Pattern &P)
specificval_ty m_Specific(const Value *V)
Match if we have a specific specified value.
IntrinsicID_match m_Intrinsic()
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_Value(X))
auto m_Value()
Match an arbitrary value and ignore it.
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
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".
m_Intrinsic_Ty< Opnd0 >::Ty m_Ctpop(const Opnd0 &Op0)
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
BinaryOp_match< LHS, RHS, Instruction::Or, true > m_c_Or(const LHS &L, const RHS &R)
Matches an Or with LHS and RHS in either order.
BinaryOp_match< LHS, RHS, Instruction::Sub > m_Sub(const LHS &L, const RHS &R)
This namespace contains all of the command line option processing machinery.
@ User
could "use" a pointer
friend class Instruction
Iterator for Instructions in a `BasicBlock.
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
LLVM_ABI bool isValidAssumeForContext(const Instruction *I, const Instruction *CxtI, const DominatorTree *DT=nullptr, bool AllowEphemerals=false)
Return true if it is valid to use the assumptions provided by an assume intrinsic,...
auto pred_end(const MachineBasicBlock *BB)
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< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
void append_range(Container &C, Range &&R)
Wrapper function to append range R to container C.
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.
LLVM_ABI bool assumeBundleImpliesNonNull(const Value *Val, const Function *Context, OperandBundleUse OBU)
LLVM_ABI bool isGuaranteedNotToBeUndef(const Value *V, AssumptionCache *AC=nullptr, const Instruction *CtxI=nullptr, const DominatorTree *DT=nullptr, unsigned Depth=0)
Returns true if V cannot be undef, but may be poison.
LLVM_ABI ConstantRange getConstantRangeFromMetadata(const MDNode &RangeMD)
Parse out a conservative ConstantRange from !range metadata.
LLVM_ABI Value * simplifyCastInst(unsigned CastOpc, Value *Op, Type *Ty, const SimplifyQuery &Q)
Given operands for a CastInst, fold the result or return null.
LLVM_ABI FunctionPass * createLazyValueInfoPass()
createLazyValueInfoPass - This creates an instance of the LazyValueInfo pass.
auto dyn_cast_or_null(const Y &Val)
constexpr unsigned MaxAnalysisRecursionDepth
@ SPF_ABS
Floating point maxnum.
@ SPF_NABS
Absolute value.
@ SPF_UMIN
Signed minimum.
@ SPF_UMAX
Signed maximum.
@ SPF_SMAX
Unsigned minimum.
decltype(auto) get(const PointerIntPair< PointerTy, IntBits, IntType, PtrTraits, Info > &Pair)
LLVM_ABI SelectPatternResult matchSelectPattern(Value *V, Value *&LHS, Value *&RHS, Instruction::CastOps *CastOp=nullptr, unsigned Depth=0)
Pattern match integer [SU]MIN, [SU]MAX and ABS idioms, returning the kind and providing the out param...
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 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 * simplifyExtractValueInst(Value *Agg, ArrayRef< unsigned > Idxs, const SimplifyQuery &Q)
Given operands for an ExtractValueInst, fold the result or return null.
LLVM_ABI bool isKnownNonZero(const Value *V, const SimplifyQuery &Q, unsigned Depth=0)
Return true if the given value is known to be non-zero when defined.
LLVM_ABI Value * simplifyBinOp(unsigned Opcode, Value *LHS, Value *RHS, const SimplifyQuery &Q)
Given operands for a BinaryOperator, fold the result or return null.
DWARFExpression::Operation Op
bool isSafeToSpeculativelyExecuteWithVariableReplaced(const Instruction *I, bool IgnoreUBImplyingAttrs=true)
Don't use information from its non-constant operands.
PredIterator< BasicBlock, Value::user_iterator > pred_iterator
static bool hasSingleValue(const ValueLatticeElement &Val)
constexpr unsigned BitWidth
auto pred_begin(const MachineBasicBlock *BB)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
auto predecessors(const MachineBasicBlock *BB)
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
A special type used by analysis passes to provide an address that identifies that particular analysis...
SelectPatternFlavor Flavor
static bool isMinOrMax(SelectPatternFlavor SPF)
When implementing this min/max pattern as fcmp; select, does the fcmp have to be ordered?