110#define DEBUG_TYPE "instcombine"
118 "Number of instruction combining iterations performed");
119STATISTIC(NumOneIteration,
"Number of functions with one iteration");
120STATISTIC(NumTwoIterations,
"Number of functions with two iterations");
121STATISTIC(NumThreeIterations,
"Number of functions with three iterations");
123 "Number of functions with four or more iterations");
127STATISTIC(NumDeadInst ,
"Number of dead inst eliminated");
133 "Controls which instructions are visited");
140 "instcombine-max-sink-users",
cl::init(32),
141 cl::desc(
"Maximum number of undroppable users for instruction sinking"));
145 cl::desc(
"Maximum array size considered when doing a combine"));
149 cl::desc(
"Maximum number of users to visit in alloc-site "
150 "removability analysis"));
166InstCombiner::IRBuilderInstCombineInserter::~IRBuilderInstCombineInserter() =
169void InstCombiner::IRBuilderInstCombineInserter::InsertHelper(
174 IC.AC.registerAssumption(Assume);
175 if (IC.AnnotationMetadataSource)
176 I->copyMetadata(*IC.AnnotationMetadataSource, LLVMContext::MD_annotation);
179std::optional<Instruction *>
182 if (
II.getCalledFunction()->isTargetIntrinsic()) {
183 return TTIForTargetIntrinsicsOnly.instCombineIntrinsic(*
this,
II);
190 bool &KnownBitsComputed) {
192 if (
II.getCalledFunction()->isTargetIntrinsic()) {
193 return TTIForTargetIntrinsicsOnly.simplifyDemandedUseBitsIntrinsic(
194 *
this,
II, DemandedMask, Known, KnownBitsComputed);
205 if (
II.getCalledFunction()->isTargetIntrinsic()) {
206 return TTIForTargetIntrinsicsOnly.simplifyDemandedVectorEltsIntrinsic(
207 *
this,
II, DemandedElts, PoisonElts, PoisonElts2, PoisonElts3,
217 return TTIForTargetIntrinsicsOnly.isValidAddrSpaceCast(FromAS, ToAS);
227 Builder.SetInsertPoint(Inst);
231 if (Inst && !
GEP->hasAllConstantIndices() &&
232 !
GEP->getSourceElementType()->isIntegerTy(8)) {
234 *Inst, Builder.CreateGEP(Builder.getInt8Ty(),
GEP->getPointerOperand(),
252 Value *Sum =
nullptr;
253 Value *OneUseSum =
nullptr;
254 Value *OneUseBase =
nullptr;
261 IRBuilderBase::InsertPointGuard Guard(
Builder);
263 if (RewriteGEPs && Inst)
267 if (
Offset->getType() != IdxTy)
270 if (
GEP->hasOneUse()) {
275 OneUseBase =
GEP->getPointerOperand();
284 if (RewriteGEPs && Inst &&
285 Offset->getType()->isVectorTy() ==
GEP->getType()->isVectorTy() &&
286 !(
GEP->getSourceElementType()->isIntegerTy(8) &&
291 OneUseBase ? OneUseBase :
GEP->getPointerOperand(),
Offset,
"",
298 OneUseSum = OneUseBase =
nullptr;
302 Sum =
Add(Sum, OneUseSum);
313bool InstCombinerImpl::isDesirableIntType(
unsigned BitWidth)
const {
332bool InstCombinerImpl::shouldChangeType(
unsigned FromWidth,
333 unsigned ToWidth)
const {
334 bool FromLegal = FromWidth == 1 ||
DL.isLegalInteger(FromWidth);
335 bool ToLegal = ToWidth == 1 ||
DL.isLegalInteger(ToWidth);
339 if (ToWidth < FromWidth && isDesirableIntType(ToWidth))
344 if ((FromLegal || isDesirableIntType(FromWidth)) && !ToLegal)
349 if (!FromLegal && !ToLegal && ToWidth > FromWidth)
360bool InstCombinerImpl::shouldChangeType(
Type *From,
Type *To)
const {
368 return shouldChangeType(FromWidth, ToWidth);
378 if (!OBO || !OBO->hasNoSignedWrap())
381 const APInt *BVal, *CVal;
386 bool Overflow =
false;
387 switch (
I.getOpcode()) {
388 case Instruction::Add:
389 (void)BVal->
sadd_ov(*CVal, Overflow);
391 case Instruction::Sub:
392 (void)BVal->
ssub_ov(*CVal, Overflow);
394 case Instruction::Mul:
395 (void)BVal->
smul_ov(*CVal, Overflow);
406 return OBO && OBO->hasNoUnsignedWrap();
411 return OBO && OBO->hasNoSignedWrap();
421 if (!Cast || !Cast->hasOneUse())
425 auto CastOpcode = Cast->getOpcode();
426 if (CastOpcode != Instruction::ZExt)
435 if (!BinOp2 || !BinOp2->hasOneUse() || BinOp2->getOpcode() != AssocOpcode)
461 Cast->dropPoisonGeneratingFlags();
467Value *InstCombinerImpl::simplifyIntToPtrRoundTripCast(
Value *Val) {
469 if (IntToPtr &&
DL.getTypeSizeInBits(IntToPtr->getDestTy()) ==
470 DL.getTypeSizeInBits(IntToPtr->getSrcTy())) {
472 Type *CastTy = IntToPtr->getDestTy();
475 PtrToInt->getSrcTy()->getPointerAddressSpace() &&
476 DL.getTypeSizeInBits(PtrToInt->getSrcTy()) ==
477 DL.getTypeSizeInBits(PtrToInt->getDestTy()))
478 return PtrToInt->getOperand(0);
515 if (
I.isCommutative()) {
516 if (
auto Pair = matchSymmetricPair(
I.getOperand(0),
I.getOperand(1))) {
526 if (
I.isAssociative()) {
545 PDI->setIsDisjoint(
false);
550 I.setHasNoUnsignedWrap(IsNUW);
551 I.setHasNoSignedWrap(IsNSW);
574 I.dropPoisonGeneratingFlags();
582 if (
I.isAssociative() &&
I.isCommutative()) {
603 I.dropPoisonGeneratingFlags();
624 I.dropPoisonGeneratingFlags();
660 I.dropPoisonGeneratingFlags();
662 I.setHasNoUnsignedWrap(
true);
680 if (LOp == Instruction::And)
681 return ROp == Instruction::Or || ROp == Instruction::Xor;
684 if (LOp == Instruction::Or)
685 return ROp == Instruction::And;
689 if (LOp == Instruction::Mul)
690 return ROp == Instruction::Add || ROp == Instruction::Sub;
727 assert(
Op &&
"Expected a binary operator");
728 LHS =
Op->getOperand(0);
729 RHS =
Op->getOperand(1);
730 if (TopOpcode == Instruction::Add || TopOpcode == Instruction::Sub) {
735 Instruction::Shl, ConstantInt::get(
Op->getType(), 1),
C);
736 assert(
RHS &&
"Constant folding of immediate constants failed");
737 return Instruction::Mul;
742 if (OtherOp && OtherOp->
getOpcode() == Instruction::AShr &&
745 return Instruction::AShr;
748 return Op->getOpcode();
757 assert(
A &&
B &&
C &&
D &&
"All values must be provided");
760 Value *RetVal =
nullptr;
771 if (
A ==
C || (InnerCommutative &&
A ==
D)) {
780 if (!V && (
LHS->hasOneUse() ||
RHS->hasOneUse()))
781 V = Builder.CreateBinOp(TopLevelOpcode,
B,
D,
RHS->getName());
783 RetVal = Builder.CreateBinOp(InnerOpcode,
A, V);
791 if (
B ==
D || (InnerCommutative &&
B ==
C)) {
800 if (!V && (
LHS->hasOneUse() ||
RHS->hasOneUse()))
801 V = Builder.CreateBinOp(TopLevelOpcode,
A,
C,
LHS->getName());
803 RetVal = Builder.CreateBinOp(InnerOpcode, V,
B);
818 HasNSW =
I.hasNoSignedWrap();
819 HasNUW =
I.hasNoUnsignedWrap();
822 HasNSW &= LOBO->hasNoSignedWrap();
823 HasNUW &= LOBO->hasNoUnsignedWrap();
827 HasNSW &= ROBO->hasNoSignedWrap();
828 HasNUW &= ROBO->hasNoUnsignedWrap();
831 if (TopLevelOpcode == Instruction::Add && InnerOpcode == Instruction::Mul) {
859 unsigned Opc =
I->getOpcode();
860 unsigned ConstIdx = 1;
867 case Instruction::Sub:
870 case Instruction::ICmp:
877 case Instruction::Or:
881 case Instruction::Add:
896 Constant *BitWidthC = ConstantInt::get(Ty, Ty->getScalarSizeInBits());
902 if (!Cmp || !Cmp->isNullValue())
907 bool Consumes =
false;
911 assert(NotOp !=
nullptr &&
912 "Desync between isFreeToInvert and getFreelyInverted");
914 Value *CtpopOfNotOp =
Builder.CreateIntrinsic(Ty, Intrinsic::ctpop, NotOp);
921 case Instruction::Sub:
924 case Instruction::Or:
925 case Instruction::Add:
928 case Instruction::ICmp:
964 auto IsValidBinOpc = [](
unsigned Opc) {
968 case Instruction::And:
969 case Instruction::Or:
970 case Instruction::Xor:
971 case Instruction::Add:
980 auto IsCompletelyDistributable = [](
unsigned BinOpc1,
unsigned BinOpc2,
982 assert(ShOpc != Instruction::AShr);
983 return (BinOpc1 != Instruction::Add && BinOpc2 != Instruction::Add) ||
984 ShOpc == Instruction::Shl;
987 auto GetInvShift = [](
unsigned ShOpc) {
988 assert(ShOpc != Instruction::AShr);
989 return ShOpc == Instruction::LShr ? Instruction::Shl : Instruction::LShr;
992 auto CanDistributeBinops = [&](
unsigned BinOpc1,
unsigned BinOpc2,
996 if (BinOpc1 == Instruction::And)
1001 if (!IsCompletelyDistributable(BinOpc1, BinOpc2, ShOpc))
1007 if (BinOpc2 == Instruction::And)
1018 auto MatchBinOp = [&](
unsigned ShOpnum) ->
Instruction * {
1020 Value *
X, *
Y, *ShiftedX, *Mask, *Shift;
1021 if (!
match(
I.getOperand(ShOpnum),
1025 I.getOperand(1 - ShOpnum),
1038 unsigned ShOpc = IY->getOpcode();
1039 if (ShOpc != IX->getOpcode())
1047 unsigned BinOpc = BO2->getOpcode();
1049 if (!IsValidBinOpc(
I.getOpcode()) || !IsValidBinOpc(BinOpc))
1052 if (ShOpc == Instruction::AShr) {
1066 if (BinOpc ==
I.getOpcode() &&
1067 IsCompletelyDistributable(
I.getOpcode(), BinOpc, ShOpc)) {
1082 if (!CanDistributeBinops(
I.getOpcode(), BinOpc, ShOpc, CMask, CShift))
1089 Value *NewBinOp1 =
Builder.CreateBinOp(
I.getOpcode(),
Y, NewBinOp2);
1096 return MatchBinOp(1);
1113 Value *LHS =
I.getOperand(0), *RHS =
I.getOperand(1);
1114 Value *
A, *CondVal, *TrueVal, *FalseVal;
1116 Constant *CastTrueVal, *CastFalseVal;
1118 auto MatchSelectAndCast = [&](
Value *CastOp,
Value *SelectOp) {
1127 if (MatchSelectAndCast(LHS, RHS))
1129 else if (MatchSelectAndCast(RHS, LHS))
1138 auto NewFoldedConst = [&](
bool IsTrueArm,
Value *V) {
1139 bool IsCastOpRHS = (CastOp == RHS);
1140 Value *CastVal = IsTrueArm ? CastFalseVal : CastTrueVal;
1142 return IsCastOpRHS ?
Builder.CreateBinOp(
Opc, V, CastVal)
1149 Value *NewTrueVal = NewFoldedConst(
false, TrueVal);
1151 NewFoldedConst(
true, FalseVal),
"",
nullptr,
SI);
1154 Value *NewTrueVal = NewFoldedConst(
true, TrueVal);
1156 NewFoldedConst(
false, FalseVal),
"",
nullptr,
SI);
1163 Value *LHS =
I.getOperand(0), *RHS =
I.getOperand(1);
1177 if (Op0 && Op1 && LHSOpcode == RHSOpcode)
1206 Value *LHS =
I.getOperand(0), *RHS =
I.getOperand(1);
1223 auto SQDistributive =
SQ.getWithInstruction(&
I).getWithoutUndef();
1231 C =
Builder.CreateBinOp(InnerOpcode, L, R);
1240 C =
Builder.CreateBinOp(TopLevelOpcode,
B,
C);
1249 C =
Builder.CreateBinOp(TopLevelOpcode,
A,
C);
1262 auto SQDistributive =
SQ.getWithInstruction(&
I).getWithoutUndef();
1270 A =
Builder.CreateBinOp(InnerOpcode, L, R);
1279 A =
Builder.CreateBinOp(TopLevelOpcode,
A,
C);
1288 A =
Builder.CreateBinOp(TopLevelOpcode,
A,
B);
1297static std::optional<std::pair<Value *, Value *>>
1299 if (
LHS->getParent() !=
RHS->getParent())
1300 return std::nullopt;
1302 if (
LHS->getNumIncomingValues() < 2)
1303 return std::nullopt;
1306 return std::nullopt;
1308 Value *L0 =
LHS->getIncomingValue(0);
1309 Value *R0 =
RHS->getIncomingValue(0);
1311 for (
unsigned I = 1,
E =
LHS->getNumIncomingValues();
I !=
E; ++
I) {
1315 if ((L0 == L1 && R0 == R1) || (L0 == R1 && R0 == L1))
1318 return std::nullopt;
1321 return std::optional(std::pair(L0, R0));
1324std::optional<std::pair<Value *, Value *>>
1329 return std::nullopt;
1331 case Instruction::PHI:
1333 case Instruction::Select: {
1339 return std::pair(TrueVal, FalseVal);
1340 return std::nullopt;
1342 case Instruction::Call: {
1346 if (LHSMinMax && RHSMinMax &&
1353 return std::pair(LHSMinMax->
getLHS(), LHSMinMax->
getRHS());
1354 return std::nullopt;
1357 return std::nullopt;
1367 if (!LHSIsSelect && !RHSIsSelect)
1377 FMF = FPOp->getFastMathFlags();
1378 Builder.setFastMathFlags(FMF);
1384 Value *
Cond, *True =
nullptr, *False =
nullptr;
1392 if (Opcode != Instruction::Add || (!True && !False) || (True && False))
1406 if (LHSIsSelect && RHSIsSelect &&
A ==
D) {
1412 if (LHS->hasOneUse() && RHS->hasOneUse()) {
1414 True =
Builder.CreateBinOp(Opcode,
B, E);
1415 else if (True && !False)
1416 False =
Builder.CreateBinOp(Opcode,
C,
F);
1418 }
else if (LHSIsSelect && LHS->hasOneUse()) {
1423 if (
Value *NewSel = foldAddNegate(
B,
C, RHS))
1425 }
else if (RHSIsSelect && RHS->hasOneUse()) {
1430 if (
Value *NewSel = foldAddNegate(E,
F, LHS))
1434 if (!True || !False)
1447 if (U == IgnoredUser)
1450 case Instruction::Select: {
1453 SI->swapProfMetadata();
1456 case Instruction::CondBr: {
1460 BPI->swapSuccEdgesProbabilities(BI->getParent());
1463 case Instruction::Xor:
1470 "canFreelyInvertAllUsersOf() ?");
1480 for (
unsigned Idx = 0, End = DbgVal->getNumVariableLocationOps();
1482 if (DbgVal->getVariableLocationOp(Idx) ==
I)
1483 DbgVal->setExpression(
1490Value *InstCombinerImpl::dyn_castNegVal(
Value *V)
const {
1500 if (
C->getType()->getElementType()->isIntegerTy())
1504 for (
unsigned i = 0, e = CV->getNumOperands(); i != e; ++i) {
1520 if (CV->getType()->isVectorTy() &&
1521 CV->getType()->getScalarType()->isIntegerTy() && CV->getSplatValue())
1534Instruction *InstCombinerImpl::foldFBinOpOfIntCastsFromSign(
1535 BinaryOperator &BO,
bool OpsFromSigned, std::array<Value *, 2> IntOps,
1539 Type *IntTy = IntOps[0]->getType();
1544 unsigned MaxRepresentableBits =
1549 unsigned NumUsedLeadingBits[2] = {IntSz, IntSz};
1553 auto IsNonZero = [&](
unsigned OpNo) ->
bool {
1554 if (OpsKnown[OpNo].hasKnownBits() &&
1555 OpsKnown[OpNo].getKnownBits(
SQ).isNonZero())
1560 auto IsNonNeg = [&](
unsigned OpNo) ->
bool {
1564 return OpsKnown[OpNo].getKnownBits(
SQ).isNonNegative();
1568 auto IsValidPromotion = [&](
unsigned OpNo) ->
bool {
1579 if (MaxRepresentableBits < IntSz) {
1589 NumUsedLeadingBits[OpNo] =
1590 IntSz - OpsKnown[OpNo].getKnownBits(
SQ).countMinLeadingZeros();
1598 if (MaxRepresentableBits < NumUsedLeadingBits[OpNo])
1601 return !OpsFromSigned || BO.
getOpcode() != Instruction::FMul ||
1606 if (Op1FpC !=
nullptr) {
1608 if (OpsFromSigned && BO.
getOpcode() == Instruction::FMul &&
1613 OpsFromSigned ? Instruction::FPToSI : Instruction::FPToUI, Op1FpC,
1615 if (Op1IntC ==
nullptr)
1618 : Instruction::UIToFP,
1619 Op1IntC, FPTy,
DL) != Op1FpC)
1623 IntOps[1] = Op1IntC;
1627 if (IntTy != IntOps[1]->
getType())
1630 if (Op1FpC ==
nullptr) {
1631 if (!IsValidPromotion(1))
1634 if (!IsValidPromotion(0))
1640 bool NeedsOverflowCheck =
true;
1643 unsigned OverflowMaxOutputBits = OpsFromSigned ? 2 : 1;
1644 unsigned OverflowMaxCurBits =
1645 std::max(NumUsedLeadingBits[0], NumUsedLeadingBits[1]);
1646 bool OutputSigned = OpsFromSigned;
1648 case Instruction::FAdd:
1649 IntOpc = Instruction::Add;
1650 OverflowMaxOutputBits += OverflowMaxCurBits;
1652 case Instruction::FSub:
1653 IntOpc = Instruction::Sub;
1654 OverflowMaxOutputBits += OverflowMaxCurBits;
1656 case Instruction::FMul:
1657 IntOpc = Instruction::Mul;
1658 OverflowMaxOutputBits += OverflowMaxCurBits * 2;
1664 if (OverflowMaxOutputBits < IntSz) {
1665 NeedsOverflowCheck =
false;
1668 if (IntOpc == Instruction::Sub)
1669 OutputSigned =
true;
1675 if (NeedsOverflowCheck &&
1676 !willNotOverflow(IntOpc, IntOps[0], IntOps[1], BO, OutputSigned))
1679 Value *IntBinOp =
Builder.CreateBinOp(IntOpc, IntOps[0], IntOps[1]);
1681 IntBO->setHasNoSignedWrap(OutputSigned);
1682 IntBO->setHasNoUnsignedWrap(!OutputSigned);
1685 return new SIToFPInst(IntBinOp, FPTy);
1686 return new UIToFPInst(IntBinOp, FPTy);
1700 std::array<Value *, 2> IntOps = {
nullptr,
nullptr};
1718 if (Instruction *R = foldFBinOpOfIntCastsFromSign(BO,
false,
1719 IntOps, Op1FpC, OpsKnown))
1721 return foldFBinOpOfIntCastsFromSign(BO,
true, IntOps,
1737 !
X->getType()->isIntOrIntVectorTy(1))
1745 return createSelectInstWithUnknownProfile(
X, TVal, FVal);
1754 V = IsTrueArm ?
SI->getTrueValue() :
SI->getFalseValue();
1755 }
else if (
match(
SI->getCondition(),
1762 V = IsTrueArm ? ConstantInt::get(
Op->getType(), 1)
1783 bool FoldWithMultiUse,
1784 bool SimplifyBothArms) {
1786 if (!
SI->hasOneUser() && !FoldWithMultiUse)
1789 Value *TV =
SI->getTrueValue();
1790 Value *FV =
SI->getFalseValue();
1793 if (
SI->getType()->isIntOrIntVectorTy(1))
1799 for (
Value *IntrinOp :
Op.operands())
1801 for (
Value *PhiOp : PN->operands())
1813 if (CI->hasOneUse()) {
1814 Value *Op0 = CI->getOperand(0), *Op1 = CI->getOperand(1);
1815 if (((TV == Op0 && FV == Op1) || (FV == Op0 && TV == Op1)) &&
1816 !CI->isCommutative())
1825 if (!NewTV && !NewFV)
1828 if (SimplifyBothArms && !(NewTV && NewFV))
1841 {LLVMContext::MD_prof, LLVMContext::MD_unpredictable});
1858 Ops.push_back(InValue);
1898 assert(
Op.isAssociative() &&
"The operation must be associative!");
1904 !
Op.hasOneUse() || !
SI->hasOneUse())
1907 Value *TV =
SI->getTrueValue();
1908 Value *FV =
SI->getFalseValue();
1926 if (!NewTV || !NewFV)
1930 Builder.CreateSelect(
SI->getCondition(), NewTV, NewFV,
"",
1936 bool AllowMultipleUses) {
1938 if (NumPHIValues == 0)
1945 bool IdenticalUsers =
false;
1946 if (!AllowMultipleUses && !OneUse) {
1950 if (UI != &
I && !
I.isIdenticalTo(UI))
1954 IdenticalUsers =
true;
1984 bool SeenNonSimplifiedInVal =
false;
1985 for (
unsigned i = 0; i != NumPHIValues; ++i) {
1996 auto WillFold = [&]() {
2001 const APInt *Ignored;
2022 if (!OneUse && !IdenticalUsers)
2025 if (SeenNonSimplifiedInVal)
2027 SeenNonSimplifiedInVal =
true;
2035 if (!BI || !
DT.isReachableFromEntry(InBB))
2051 for (
auto OpIndex : OpsToMoveUseToIncomingBB) {
2062 U = U->DoPHITranslation(PN->
getParent(), OpBB);
2065 Clones.
insert({OpBB, Clone});
2070 NewPhiValues[
OpIndex] = Clone;
2079 for (
unsigned i = 0; i != NumPHIValues; ++i)
2082 if (IdenticalUsers) {
2113 BO0->getOpcode() !=
Opc || BO1->getOpcode() !=
Opc ||
2114 !BO0->isAssociative() || !BO1->isAssociative() ||
2115 BO0->getParent() != BO1->getParent())
2119 "Expected commutative instructions!");
2123 Value *Start0, *Step0, *Start1, *Step1;
2130 "Expected PHIs with two incoming values!");
2137 if (!Init0 || !Init1 || !C0 || !C1)
2152 if (
Opc == Instruction::FAdd ||
Opc == Instruction::FMul) {
2156 NewBO->setFastMathFlags(Intersect);
2160 Flags.AllKnownNonZero =
false;
2161 Flags.mergeFlags(*BO0);
2162 Flags.mergeFlags(*BO1);
2163 Flags.mergeFlags(BO);
2164 Flags.applyFlags(*NewBO);
2166 NewBO->takeName(&BO);
2176 "Invalid incoming block!");
2177 NewPN->addIncoming(
Init, BB);
2178 }
else if (V == BO0) {
2183 "Invalid incoming block!");
2184 NewPN->addIncoming(NewBO, BB);
2190 <<
"\n with " << *PN1 <<
"\n " << *BO1
2217 if (!Phi0 || !Phi1 || !Phi0->hasOneUse() || !Phi1->hasOneUse() ||
2218 Phi0->getNumOperands() != Phi1->getNumOperands())
2222 if (BO.
getParent() != Phi0->getParent() ||
2239 auto CanFoldIncomingValuePair = [&](std::tuple<Use &, Use &>
T) {
2240 auto &Phi0Use = std::get<0>(
T);
2241 auto &Phi1Use = std::get<1>(
T);
2242 if (Phi0->getIncomingBlock(Phi0Use) != Phi1->getIncomingBlock(Phi1Use))
2244 Value *Phi0UseV = Phi0Use.get();
2245 Value *Phi1UseV = Phi1Use.get();
2248 else if (Phi1UseV ==
C)
2255 if (
all_of(
zip(Phi0->operands(), Phi1->operands()),
2256 CanFoldIncomingValuePair)) {
2259 assert(NewIncomingValues.
size() == Phi0->getNumOperands() &&
2260 "The number of collected incoming values should equal the number "
2261 "of the original PHINode operands!");
2262 for (
unsigned I = 0;
I < Phi0->getNumOperands();
I++)
2263 NewPhi->
addIncoming(NewIncomingValues[
I], Phi0->getIncomingBlock(
I));
2268 if (Phi0->getNumOperands() != 2 || Phi1->getNumOperands() != 2)
2275 ConstBB = Phi0->getIncomingBlock(0);
2276 OtherBB = Phi0->getIncomingBlock(1);
2278 ConstBB = Phi0->getIncomingBlock(1);
2279 OtherBB = Phi0->getIncomingBlock(0);
2290 if (!PredBlockBranch || !
DT.isReachableFromEntry(OtherBB))
2296 for (
auto BBIter = BO.
getParent()->begin(); &*BBIter != &BO; ++BBIter)
2307 Builder.SetInsertPoint(PredBlockBranch);
2309 Phi0->getIncomingValueForBlock(OtherBB),
2310 Phi1->getIncomingValueForBlock(OtherBB));
2312 NotFoldedNewBO->copyIRFlags(&BO);
2322 auto TryFoldOperand = [&](
unsigned OpIdx,
2341 if (
GEP.hasAllZeroIndices() && !Src.hasAllZeroIndices() &&
2372 for (
unsigned I = 0;
I < NumElts; ++
I) {
2374 if (ShMask[
I] >= 0) {
2375 int MaskElt = ShMask[
I];
2376 if (MaskElt >= (
int)NewCNumElts)
2379 Constant *NewCElt = NewVecC[MaskElt];
2389 NewVecC[MaskElt] = CElt;
2407template <Intrinsic::ID SpliceID>
2426 (
LHS->hasOneUse() ||
RHS->hasOneUse() ||
2428 return CreateBinOpSplice(
V1, V2,
Offset);
2440 return CreateBinOpSplice(
LHS, V2,
Offset);
2460 auto foldConstantsThroughSubVectorInsertSplat =
2461 [&](
Value *MaybeSubVector,
Value *MaybeSplat,
2466 !
match(MaybeSubVector,
2473 if (!SubVector || !Dest)
2475 auto *InsertVector =
2476 Builder.CreateInsertVector(Dest->
getType(), Dest, SubVector, Idx);
2484 if (
Instruction *Folded = foldConstantsThroughSubVectorInsertSplat(
2487 if (
Instruction *Folded = foldConstantsThroughSubVectorInsertSplat(
2494 Value *L0, *L1, *R0, *R1;
2498 LHS->hasOneUse() && RHS->hasOneUse() &&
2521 M, Intrinsic::vector_reverse, V->getType());
2532 (LHS->hasOneUse() || RHS->hasOneUse() ||
2533 (LHS == RHS && LHS->hasNUses(2))))
2534 return createBinOpReverse(
V1, V2);
2538 return createBinOpReverse(
V1, RHS);
2542 return createBinOpReverse(LHS, V2);
2553 M, Intrinsic::experimental_vp_reverse, V->getType());
2563 (LHS->hasOneUse() || RHS->hasOneUse() ||
2564 (LHS == RHS && LHS->hasNUses(2))))
2565 return createBinOpVPReverse(
V1, V2, EVL);
2569 return createBinOpVPReverse(
V1, RHS, EVL);
2575 return createBinOpVPReverse(LHS, V2, EVL);
2602 (LHS->hasOneUse() || RHS->hasOneUse() || LHS == RHS)) {
2604 return createBinOpShuffle(
V1, V2, Mask);
2619 if (LShuf->isSelect() &&
2621 RShuf->isSelect() &&
2643 "Shuffle should not change scalar type");
2655 Value *NewLHS = ConstOp1 ?
V1 : NewC;
2656 Value *NewRHS = ConstOp1 ? NewC :
V1;
2657 return createBinOpShuffle(NewLHS, NewRHS, Mask);
2692 Value *NewSplat =
Builder.CreateShuffleVector(NewBO, NewMask);
2698 R->copyFastMathFlags(&Inst);
2702 NewInstBO->copyIRFlags(R);
2732 (Op0->
hasOneUse() || Op1->hasOneUse()))) {
2758 NewBinOp->setHasNoSignedWrap();
2760 NewBinOp->setHasNoUnsignedWrap();
2776 if (!
GEP.hasAllConstantIndices())
2792 Type *Ty =
GEP.getSourceElementType();
2793 Value *NewTrueC = Builder.CreateGEP(Ty, TrueC, IndexC,
"", NW);
2794 Value *NewFalseC = Builder.CreateGEP(Ty, FalseC, IndexC,
"", NW);
2804 if (
GEP.getNumIndices() != 1)
2814 unsigned IndexSizeInBits =
DL.getIndexTypeSizeInBits(PtrTy);
2825 if (NewOffset.
isZero() ||
2826 (Src->hasOneUse() &&
GEP.getOperand(1)->hasOneUse())) {
2828 if (
GEP.hasNoUnsignedWrap() &&
2848 if (!
GEP.hasAllConstantIndices())
2859 if (InnerGEP->hasAllConstantIndices())
2862 if (!InnerGEP->hasOneUse())
2865 Skipped.push_back(InnerGEP);
2871 if (Skipped.empty())
2876 if (!InnerGEP->hasOneUse())
2881 if (InnerGEP->getType() != Ty)
2887 !InnerGEP->accumulateConstantOffset(
DL,
Offset))
2890 IC.
replaceOperand(*Skipped.back(), 0, InnerGEP->getPointerOperand());
2892 SkippedGEP->setNoWrapFlags(NW);
2914 if (Src->getResultElementType() !=
GEP.getSourceElementType())
2920 if (Src->hasOneUse() &&
GEP.getNumIndices() == 1 &&
2921 Src->getNumIndices() == 1) {
2922 Value *SrcIdx = *Src->idx_begin();
2924 const APInt *ConstOffset, *TrueVal, *FalseVal;
2937 if (!
Select->hasOneUse())
2940 if (TrueVal->getBitWidth() != ConstOffset->
getBitWidth() ||
2941 FalseVal->getBitWidth() != ConstOffset->
getBitWidth())
2944 APInt NewTrueVal = *ConstOffset + *TrueVal;
2945 APInt NewFalseVal = *ConstOffset + *FalseVal;
2946 Constant *NewTrue = ConstantInt::get(
Select->getType(), NewTrueVal);
2947 Constant *NewFalse = ConstantInt::get(
Select->getType(), NewFalseVal);
2949 Cond, NewTrue, NewFalse,
"",
2954 Builder.CreateGEP(
GEP.getResultElementType(),
2955 Src->getPointerOperand(),
2956 NewSelect,
"", Flags));
2961 bool EndsWithSequential =
false;
2964 EndsWithSequential =
I.isSequential();
2965 if (!EndsWithSequential)
2970 Value *SO1 = Src->getOperand(Src->getNumOperands() - 1);
2988 Indices.
append(Src->op_begin() + 1, Src->op_end() - 1);
2993 unsigned NumNonZeroIndices =
count_if(Indices, [](
Value *Idx) {
2995 return !
C || !
C->isNullValue();
2997 if (NumNonZeroIndices > 1)
3002 Src->getSourceElementType(), Src->getOperand(0), Indices,
"",
3008 bool &DoesConsume,
unsigned Depth) {
3027 if (!WillInvertAllUses)
3034 return Builder->CreateCmp(
I->getInversePredicate(),
I->getOperand(0),
3043 DoesConsume,
Depth))
3046 DoesConsume,
Depth))
3055 DoesConsume,
Depth))
3058 DoesConsume,
Depth))
3067 DoesConsume,
Depth))
3076 DoesConsume,
Depth))
3088 bool LocalDoesConsume = DoesConsume;
3090 LocalDoesConsume,
Depth))
3093 LocalDoesConsume,
Depth)) {
3094 DoesConsume = LocalDoesConsume;
3097 DoesConsume,
Depth);
3098 assert(NotB !=
nullptr &&
3099 "Unable to build inverted value for known freely invertable op");
3101 return Builder->CreateBinaryIntrinsic(
3104 Cond, NotA, NotB,
"",
3112 bool LocalDoesConsume = DoesConsume;
3114 for (
Use &U : PN->operands()) {
3115 BasicBlock *IncomingBlock = PN->getIncomingBlock(U);
3119 if (NewIncomingVal ==
nullptr)
3122 if (NewIncomingVal == V)
3125 IncomingValues.
emplace_back(NewIncomingVal, IncomingBlock);
3128 DoesConsume = LocalDoesConsume;
3133 Builder->CreatePHI(PN->getType(), PN->getNumIncomingValues());
3134 for (
auto [Val, Pred] : IncomingValues)
3143 DoesConsume,
Depth))
3144 return Builder ?
Builder->CreateSExt(AV, V->getType()) : NonNull;
3150 DoesConsume,
Depth))
3151 return Builder ?
Builder->CreateTrunc(AV, V->getType()) : NonNull;
3159 bool IsLogical,
Value *
A,
3161 bool LocalDoesConsume = DoesConsume;
3163 LocalDoesConsume,
Depth))
3166 LocalDoesConsume,
Depth)) {
3168 LocalDoesConsume,
Depth);
3169 DoesConsume = LocalDoesConsume;
3171 return Builder ?
Builder->CreateLogicalOp(Opcode, NotA, NotB) : NonNull;
3172 return Builder ?
Builder->CreateBinOp(Opcode, NotA, NotB) : NonNull;
3179 return TryInvertAndOrUsingDeMorgan(Instruction::And,
false,
A,
3183 return TryInvertAndOrUsingDeMorgan(Instruction::Or,
false,
A,
3187 return TryInvertAndOrUsingDeMorgan(Instruction::And,
true,
A,
3191 return TryInvertAndOrUsingDeMorgan(Instruction::Or,
true,
A,
3200 Type *GEPEltType =
GEP.getSourceElementType();
3211 if (
GEP.getNumIndices() == 1 &&
3220 return PtrOpGep && PtrOpGep->hasAllConstantIndices() &&
3223 return match(V, m_APInt(C)) && !C->isZero();
3247 if (!Op2 || Op1->getNumOperands() != Op2->getNumOperands() ||
3248 Op1->getSourceElementType() != Op2->getSourceElementType())
3256 Type *CurTy =
nullptr;
3258 for (
unsigned J = 0,
F = Op1->getNumOperands(); J !=
F; ++J) {
3259 if (Op1->getOperand(J)->getType() != Op2->getOperand(J)->getType())
3262 if (Op1->getOperand(J) != Op2->getOperand(J)) {
3271 assert(CurTy &&
"No current type?");
3291 CurTy = Op1->getSourceElementType();
3299 NW &= Op2->getNoWrapFlags();
3309 NewGEP->setNoWrapFlags(NW);
3321 Builder.SetInsertPoint(PN);
3322 NewPN = Builder.CreatePHI(Op1->getOperand(DI)->getType(),
3330 NewGEP->setOperand(DI, NewPN);
3333 NewGEP->insertBefore(*
GEP.getParent(),
GEP.getParent()->getFirstInsertionPt());
3340 Type *GEPType =
GEP.getType();
3341 Type *GEPEltType =
GEP.getSourceElementType();
3344 SQ.getWithInstruction(&
GEP)))
3351 auto VWidth = GEPFVTy->getNumElements();
3352 APInt PoisonElts(VWidth, 0);
3364 bool MadeChange =
false;
3368 Type *NewScalarIndexTy =
3369 DL.getIndexType(
GEP.getPointerOperandType()->getScalarType());
3378 Type *IndexTy = (*I)->getType();
3379 Type *NewIndexType =
3388 if (EltTy->
isSized() &&
DL.getTypeAllocSize(EltTy).isZero())
3394 if (IndexTy != NewIndexType) {
3400 if (
GEP.hasNoUnsignedWrap() &&
GEP.hasNoUnsignedSignedWrap())
3401 *
I =
Builder.CreateZExt(*
I, NewIndexType,
"",
true);
3403 *
I =
Builder.CreateSExt(*
I, NewIndexType);
3405 *
I =
Builder.CreateTrunc(*
I, NewIndexType,
"",
GEP.hasNoUnsignedWrap(),
3406 GEP.hasNoUnsignedSignedWrap());
3415 if (!GEPEltType->
isIntegerTy(8) &&
GEP.hasAllConstantIndices()) {
3420 GEP.getNoWrapFlags()));
3432 if (LastIdx && LastIdx->isNullValue() && !LastIdx->getType()->isVectorTy()) {
3440 if (FirstIdx && FirstIdx->isNullValue() &&
3441 !FirstIdx->getType()->isVectorTy()) {
3447 GEP.getPointerOperand(),
3449 GEP.getNoWrapFlags()));
3456 return Op->getType()->isVectorTy() && getSplatValue(Op);
3459 for (
auto &
Op :
GEP.operands()) {
3460 if (
Op->getType()->isVectorTy())
3470 GEP.getNoWrapFlags());
3473 Res =
Builder.CreateVectorSplat(EC, Res);
3478 bool SeenNonZeroIndex =
false;
3479 for (
auto [IdxNum, Idx] :
enumerate(Indices)) {
3482 if (
C &&
C->isNullValue() && IdxNum == 0)
3485 if (!SeenNonZeroIndex) {
3486 SeenNonZeroIndex =
true;
3493 Builder.CreateGEP(GEPEltType, PtrOp, FrontIndices,
3494 GEP.getName() +
".split",
GEP.getNoWrapFlags());
3501 BackIndices,
GEP.getNoWrapFlags());
3505 auto IsCanonicalType = [](
Type *Ty) {
3507 Ty = AT->getElementType();
3508 return Ty->isIntegerTy(8);
3510 if (Indices.
size() == 1 && !IsCanonicalType(GEPEltType)) {
3511 TypeSize Scale =
DL.getTypeAllocSize(GEPEltType);
3516 GEP.setSourceElementType(NewElemTy);
3517 GEP.setResultElementType(NewElemTy);
3532 if (
GEP.getNumIndices() == 1) {
3533 unsigned AS =
GEP.getPointerAddressSpace();
3534 if (
GEP.getOperand(1)->getType()->getScalarSizeInBits() ==
3535 DL.getIndexSizeInBits(AS)) {
3536 uint64_t TyAllocSize =
DL.getTypeAllocSize(GEPEltType).getFixedValue();
3538 if (TyAllocSize == 1) {
3547 GEPType ==
Y->getType()) {
3548 bool HasNonAddressBits =
3549 DL.getAddressSizeInBits(AS) !=
DL.getPointerSizeInBits(AS);
3556 }
else if (
auto *ExactIns =
3560 if (ExactIns->isExact()) {
3568 GEP.getPointerOperand(), V,
3569 GEP.getNoWrapFlags());
3572 if (ExactIns->isExact() && ExactIns->hasOneUse()) {
3578 std::optional<APInt> NewC;
3598 if (NewC.has_value()) {
3601 ConstantInt::get(V->getType(), *NewC),
true);
3603 GEP.getPointerOperand(), NewOp,
3604 GEP.getNoWrapFlags());
3614 if (!
GEP.isInBounds()) {
3617 APInt BasePtrOffset(IdxWidth, 0);
3618 Value *UnderlyingPtrOp =
3622 DL, CanBeNull,
nullptr);
3625 if (!CanBeNull && DerefBytes != 0) {
3626 if (
GEP.accumulateConstantOffset(
DL, BasePtrOffset) &&
3628 APInt AllocSize(IdxWidth, DerefBytes);
3629 if (BasePtrOffset.
ule(AllocSize)) {
3631 GEP.getSourceElementType(), PtrOp, Indices,
GEP.getName());
3638 if (
GEP.hasNoUnsignedSignedWrap() && !
GEP.hasNoUnsignedWrap() &&
3640 return isKnownNonNegative(Idx, SQ.getWithInstruction(&GEP));
3648 if (
GEP.getNumIndices() == 1) {
3651 auto GetPreservedNoWrapFlags = [&](
bool AddIsNUW) {
3654 if (
GEP.hasNoUnsignedWrap() && AddIsNUW)
3655 return GEP.getNoWrapFlags();
3671 Builder.CreateGEP(
GEP.getSourceElementType(),
GEP.getPointerOperand(),
3674 Builder.CreateGEP(
GEP.getSourceElementType(),
3675 NewPtr, Idx2,
"", NWFlags));
3686 bool NUW =
match(
GEP.getOperand(1),
3689 auto *NewPtr =
Builder.CreateGEP(
3690 GEP.getSourceElementType(),
GEP.getPointerOperand(),
3691 Builder.CreateSExt(Idx1,
GEP.getOperand(1)->getType()),
"", NWFlags);
3694 Builder.CreateGEP(
GEP.getSourceElementType(), NewPtr,
3695 Builder.CreateSExt(
C,
GEP.getOperand(1)->getType()),
3704 if (Indices.
size() == 1 &&
GEP.isInBounds() &&
GEP.hasNoUnsignedWrap()) {
3718 GEP.getNoWrapFlags());
3754 return Dest && Dest->Ptr == UsedV;
3757static std::optional<ModRefInfo>
3770 return std::nullopt;
3771 switch (
I->getOpcode()) {
3774 return std::nullopt;
3776 case Instruction::AddrSpaceCast:
3777 case Instruction::BitCast:
3778 case Instruction::GetElementPtr:
3783 case Instruction::ICmp: {
3789 return std::nullopt;
3790 unsigned OtherIndex = (ICI->
getOperand(0) == PI) ? 1 : 0;
3792 return std::nullopt;
3797 auto AlignmentAndSizeKnownValid = [](
CallBase *CB) {
3801 const APInt *Alignment;
3803 return match(CB->getArgOperand(0),
m_APInt(Alignment)) &&
3809 if (CB && TLI.
getLibFunc(*CB->getCalledFunction(), TheLibFunc) &&
3810 TLI.
has(TheLibFunc) && TheLibFunc == LibFunc_aligned_alloc &&
3811 !AlignmentAndSizeKnownValid(CB))
3812 return std::nullopt;
3817 case Instruction::Call:
3820 switch (
II->getIntrinsicID()) {
3822 return std::nullopt;
3824 case Intrinsic::memmove:
3825 case Intrinsic::memcpy:
3826 case Intrinsic::memset: {
3828 if (
MI->isVolatile())
3829 return std::nullopt;
3835 return std::nullopt;
3839 case Intrinsic::assume:
3840 case Intrinsic::invariant_start:
3841 case Intrinsic::invariant_end:
3842 case Intrinsic::lifetime_start:
3843 case Intrinsic::lifetime_end:
3844 case Intrinsic::objectsize:
3847 case Intrinsic::launder_invariant_group:
3848 case Intrinsic::strip_invariant_group:
3875 return std::nullopt;
3877 case Instruction::Store: {
3879 if (
SI->isVolatile() ||
SI->getPointerOperand() != PI)
3880 return std::nullopt;
3882 return std::nullopt;
3888 case Instruction::Load: {
3891 return std::nullopt;
3893 return std::nullopt;
3901 }
while (!Worklist.
empty());
3929 std::unique_ptr<DIBuilder> DIB;
3937 bool KnowInitUndef =
false;
3938 bool KnowInitZero =
false;
3943 KnowInitUndef =
true;
3944 else if (
Init->isNullValue())
3945 KnowInitZero =
true;
3949 auto &
F = *
MI.getFunction();
3950 if (
F.hasFnAttribute(Attribute::SanitizeMemory) ||
3951 F.hasFnAttribute(Attribute::SanitizeAddress))
3952 KnowInitUndef =
false;
3967 if (
II->getIntrinsicID() == Intrinsic::objectsize) {
3970 II,
DL, &
TLI,
AA,
true, &InsertedInstructions);
3971 for (
Instruction *Inserted : InsertedInstructions)
3979 if (KnowInitZero &&
isRefSet(*Removable)) {
3982 auto *M =
Builder.CreateMemSet(
3985 MTI->getLength(), MTI->getDestAlign());
3986 M->copyMetadata(*MTI);
3999 *
C, ConstantInt::get(
C->getType(),
C->isFalseWhenEqual()));
4001 for (
auto *DVR : DVRs)
4002 if (DVR->isAddressOfVariable())
4009 assert(KnowInitZero || KnowInitUndef);
4024 F,
II->getNormalDest(),
II->getUnwindDest(), {},
"",
II->getParent());
4025 NewII->setDebugLoc(
II->getDebugLoc());
4053 for (
auto *DVR : DVRs)
4054 if (DVR->isAddressOfVariable() || DVR->getExpression()->startsWithDeref())
4055 DVR->eraseFromParent();
4101 if (FreeInstrBB->
size() != 2) {
4103 if (&Inst == &FI || &Inst == FreeInstrBBTerminator ||
4107 if (!Cast || !Cast->isNoopCast(
DL))
4128 "Broken CFG: missing edge from predecessor to successor");
4133 if (&Instr == FreeInstrBBTerminator)
4138 "Only the branch instruction should remain");
4149 Attrs = Attrs.removeParamAttribute(FI.
getContext(), 0, Attribute::NonNull);
4150 Attribute Dereferenceable = Attrs.getParamAttr(0, Attribute::Dereferenceable);
4151 if (Dereferenceable.
isValid()) {
4153 Attrs = Attrs.removeParamAttribute(FI.
getContext(), 0,
4154 Attribute::Dereferenceable);
4155 Attrs = Attrs.addDereferenceableOrNullParamAttr(FI.
getContext(), 0, Bytes);
4194 if (
TLI.getLibFunc(FI, Func) &&
TLI.has(Func) && Func == LibFunc_free)
4210 bool HasDereferenceable =
4211 F->getAttributes().getRetDereferenceableBytes() > 0;
4212 if (
F->hasRetAttribute(Attribute::NonNull) ||
4213 (HasDereferenceable &&
4215 if (
Value *V = simplifyNonNullOperand(RetVal, HasDereferenceable))
4220 if (!AttributeFuncs::isNoFPClassCompatibleType(RetTy))
4223 FPClassTest ReturnClass =
F->getAttributes().getRetNoFPClass();
4224 if (ReturnClass ==
fcNone)
4229 SQ.getWithInstruction(&RI)))
4246 if (Prev->isEHPad())
4276 if (BBI != FirstInstr)
4278 }
while (BBI != FirstInstr && BBI->isDebugOrPseudoInst());
4292 if (!
DeadEdges.insert({From, To}).second)
4297 for (
Use &U : PN.incoming_values())
4314 std::next(
I->getReverseIterator())))) {
4315 if (!Inst.use_empty() && !Inst.getType()->isTokenTy()) {
4319 if (Inst.isEHPad() || Inst.getType()->isTokenTy())
4322 Inst.dropDbgRecords();
4344 return DeadEdges.contains({Pred, BB}) ||
DT.dominates(BB, Pred);
4357 if (Succ == LiveSucc)
4374 BPI->swapSuccEdgesProbabilities(BI.getParent());
4395 "Unexpected number of branch weights!");
4404 BPI->swapSuccEdgesProbabilities(BI.getParent());
4422 BPI->swapSuccEdgesProbabilities(BI.getParent());
4443 if (
DT.dominates(Edge0, U)) {
4449 if (
DT.dominates(Edge1, U)) {
4456 DC.registerBranch(&BI);
4466 unsigned CstOpIdx = IsTrueArm ? 1 : 2;
4471 BasicBlock *CstBB =
SI.findCaseValue(
C)->getCaseSuccessor();
4472 if (CstBB !=
SI.getDefaultDest())
4485 for (
auto Case :
SI.cases())
4486 if (!CR.
contains(Case.getCaseValue()->getValue()))
4495 const APInt *CondOpC;
4498 auto MaybeInvertible = [&](
Value *
Cond) -> InvertFn {
4501 return [](
const APInt &Case,
const APInt &
C) {
return Case -
C; };
4505 return [](
const APInt &Case,
const APInt &
C) {
return C - Case; };
4511 return [](
const APInt &Case,
const APInt &
C) {
return Case ^
C; };
4518 if (
auto InvertFn = MaybeInvertible(
Cond); InvertFn &&
Cond->hasOneUse()) {
4519 for (
auto &Case :
SI.cases()) {
4520 const APInt &New = InvertFn(Case.getCaseValue()->getValue(), *CondOpC);
4521 Case.setValue(ConstantInt::get(
SI.getContext(), New));
4529 all_of(
SI.cases(), [&](
const auto &Case) {
4530 return Case.getCaseValue()->getValue().countr_zero() >= ShiftAmt;
4536 Value *NewCond = Op0;
4543 for (
auto Case :
SI.cases()) {
4544 const APInt &CaseVal = Case.getCaseValue()->getValue();
4546 : CaseVal.
lshr(ShiftAmt);
4547 Case.setValue(ConstantInt::get(
SI.getContext(), ShiftedCase));
4559 if (
all_of(
SI.cases(), [&](
const auto &Case) {
4560 const APInt &CaseVal = Case.getCaseValue()->getValue();
4561 return IsZExt ? CaseVal.isIntN(NewWidth)
4562 : CaseVal.isSignedIntN(NewWidth);
4564 for (
auto &Case :
SI.cases()) {
4565 APInt TruncatedCase = Case.getCaseValue()->getValue().
trunc(NewWidth);
4566 Case.setValue(ConstantInt::get(
SI.getContext(), TruncatedCase));
4588 for (
const auto &
C :
SI.cases()) {
4590 std::min(LeadingKnownZeros,
C.getCaseValue()->getValue().countl_zero());
4592 std::min(LeadingKnownOnes,
C.getCaseValue()->getValue().countl_one());
4595 unsigned NewWidth = Known.
getBitWidth() - std::max(LeadingKnownZeros, LeadingKnownOnes);
4601 if (NewWidth > 0 && NewWidth < Known.
getBitWidth() &&
4602 shouldChangeType(Known.
getBitWidth(), NewWidth)) {
4607 for (
auto Case :
SI.cases()) {
4608 APInt TruncatedCase = Case.getCaseValue()->getValue().
trunc(NewWidth);
4609 Case.setValue(ConstantInt::get(
SI.getContext(), TruncatedCase));
4620 SI.findCaseValue(CI)->getCaseSuccessor());
4634 const APInt *
C =
nullptr;
4636 if (*EV.
idx_begin() == 0 && (OvID == Intrinsic::smul_with_overflow ||
4637 OvID == Intrinsic::umul_with_overflow)) {
4642 if (
C->isPowerOf2()) {
4643 return BinaryOperator::CreateShl(
4645 ConstantInt::get(WO->getLHS()->getType(),
C->logBase2()));
4653 if (!WO->hasOneUse())
4667 assert(*EV.
idx_begin() == 1 &&
"Unexpected extract index for overflow inst");
4670 if (OvID == Intrinsic::usub_with_overflow)
4675 if (OvID == Intrinsic::smul_with_overflow &&
4676 WO->getLHS()->getType()->isIntOrIntVectorTy(1))
4677 return BinaryOperator::CreateAnd(WO->getLHS(), WO->getRHS());
4680 if (OvID == Intrinsic::umul_with_overflow && WO->getLHS() == WO->getRHS()) {
4681 unsigned BitWidth = WO->getLHS()->getType()->getScalarSizeInBits();
4684 return new ICmpInst(
4686 ConstantInt::get(WO->getLHS()->getType(),
4697 WO->getBinaryOp(), *
C, WO->getNoWrapKind());
4702 auto *OpTy = WO->getRHS()->getType();
4703 auto *NewLHS = WO->getLHS();
4705 NewLHS =
Builder.CreateAdd(NewLHS, ConstantInt::get(OpTy,
Offset));
4707 ConstantInt::get(OpTy, NewRHSC));
4724 const APFloat *ConstVal =
nullptr;
4725 Value *VarOp =
nullptr;
4726 bool ConstIsTrue =
false;
4733 ConstIsTrue =
false;
4738 Builder.SetInsertPoint(&EV);
4744 Value *NewEV = Builder.CreateExtractValue(NewFrexp, 0,
"mantissa");
4749 Constant *ConstantMantissa = ConstantFP::get(TrueVal->getType(), Mantissa);
4751 Value *NewSel = Builder.CreateSelectFMF(
4752 Cond, ConstIsTrue ? ConstantMantissa : NewEV,
4753 ConstIsTrue ? NewEV : ConstantMantissa,
SelectInst,
"select.frexp");
4763 SQ.getWithInstruction(&EV)))
4777 const unsigned *exti, *exte, *insi, *inse;
4778 for (exti = EV.
idx_begin(), insi =
IV->idx_begin(),
4779 exte = EV.
idx_end(), inse =
IV->idx_end();
4780 exti != exte && insi != inse;
4794 if (exti == exte && insi == inse)
4809 Value *NewEV =
Builder.CreateExtractValue(
IV->getAggregateOperand(),
4827 if (
Instruction *R = foldExtractOfOverflowIntrinsic(EV))
4833 STy && STy->isScalableTy())
4841 if (L->isSimple() && L->hasOneUse()) {
4846 for (
unsigned Idx : EV.
indices())
4853 L->getPointerOperand(), Indices);
4887 switch (Personality) {
4931 bool MakeNewInstruction =
false;
4937 bool isLastClause = i + 1 == e;
4945 if (AlreadyCaught.
insert(TypeInfo).second) {
4950 MakeNewInstruction =
true;
4957 MakeNewInstruction =
true;
4958 CleanupFlag =
false;
4977 if (!NumTypeInfos) {
4980 MakeNewInstruction =
true;
4981 CleanupFlag =
false;
4985 bool MakeNewFilter =
false;
4989 assert(NumTypeInfos > 0 &&
"Should have handled empty filter already!");
4995 MakeNewInstruction =
true;
5002 if (NumTypeInfos > 1)
5003 MakeNewFilter =
true;
5007 NewFilterElts.
reserve(NumTypeInfos);
5012 bool SawCatchAll =
false;
5013 for (
unsigned j = 0; j != NumTypeInfos; ++j) {
5041 if (SeenInFilter.
insert(TypeInfo).second)
5047 MakeNewInstruction =
true;
5052 if (NewFilterElts.
size() < NumTypeInfos)
5053 MakeNewFilter =
true;
5055 if (MakeNewFilter) {
5057 NewFilterElts.
size());
5059 MakeNewInstruction =
true;
5068 if (MakeNewFilter && !NewFilterElts.
size()) {
5069 assert(MakeNewInstruction &&
"New filter but not a new instruction!");
5070 CleanupFlag =
false;
5081 for (
unsigned i = 0, e = NewClauses.
size(); i + 1 < e; ) {
5084 for (j = i; j != e; ++j)
5091 for (
unsigned k = i; k + 1 < j; ++k)
5095 std::stable_sort(NewClauses.
begin() + i, NewClauses.
begin() + j,
5097 MakeNewInstruction =
true;
5116 for (
unsigned i = 0; i + 1 < NewClauses.
size(); ++i) {
5126 for (
unsigned j = NewClauses.
size() - 1; j != i; --j) {
5127 Value *LFilter = NewClauses[j];
5138 NewClauses.
erase(J);
5139 MakeNewInstruction =
true;
5143 unsigned LElts = LTy->getNumElements();
5153 assert(FElts <= LElts &&
"Should have handled this case earlier!");
5155 NewClauses.
erase(J);
5156 MakeNewInstruction =
true;
5165 assert(FElts > 0 &&
"Should have eliminated the empty filter earlier!");
5166 for (
unsigned l = 0; l != LElts; ++l)
5169 NewClauses.
erase(J);
5170 MakeNewInstruction =
true;
5181 bool AllFound =
true;
5182 for (
unsigned f = 0; f != FElts; ++f) {
5185 for (
unsigned l = 0; l != LElts; ++l) {
5187 if (LTypeInfo == FTypeInfo) {
5197 NewClauses.
erase(J);
5198 MakeNewInstruction =
true;
5206 if (MakeNewInstruction) {
5214 if (NewClauses.empty())
5223 assert(!CleanupFlag &&
"Adding a cleanup, not removing one?!");
5253 if (!OrigOpInst || !OrigOpInst->hasOneUse() ||
isa<PHINode>(OrigOp))
5267 Value *MaybePoisonOperand =
nullptr;
5268 for (
Value *V : OrigOpInst->operands()) {
5271 (MaybePoisonOperand && MaybePoisonOperand == V))
5273 if (!MaybePoisonOperand)
5274 MaybePoisonOperand = V;
5279 OrigOpInst->dropPoisonGeneratingAnnotations();
5282 if (!MaybePoisonOperand)
5285 Builder.SetInsertPoint(OrigOpInst);
5286 Value *FrozenMaybePoisonOperand =
Builder.CreateFreeze(
5287 MaybePoisonOperand, MaybePoisonOperand->
getName() +
".fr");
5289 OrigOpInst->replaceUsesOfWith(MaybePoisonOperand, FrozenMaybePoisonOperand);
5300 Use *StartU =
nullptr;
5318 Value *StartV = StartU->get();
5330 if (!Visited.
insert(V).second)
5333 if (Visited.
size() > 32)
5350 I->dropPoisonGeneratingAnnotations();
5352 if (StartNeedsFreeze) {
5380 MoveBefore = *MoveBeforeOpt;
5384 MoveBefore.setHeadBit(
false);
5387 if (&FI != &*MoveBefore) {
5388 FI.
moveBefore(*MoveBefore->getParent(), MoveBefore);
5393 Changed |=
Op->replaceUsesWithIf(&FI, [&](
Use &U) ->
bool {
5394 if (!
DT.dominates(&FI, U))
5397 Users.push_back(U.getUser());
5401 for (
auto *U :
Users) {
5415 for (
auto *U : V->users()) {
5425 Value *Op0 =
I.getOperand(0);
5455 auto getUndefReplacement = [&](
Type *Ty) {
5456 auto pickCommonConstantFromPHI = [](
PHINode &PN) ->
Value * {
5460 for (
Value *V : PN.incoming_values()) {
5471 if (BestValue && BestValue !=
C)
5480 Value *BestValue =
nullptr;
5481 for (
auto *U :
I.users()) {
5482 Value *V = NullValue;
5491 if (
Value *MaybeV = pickCommonConstantFromPHI(*
PHI))
5497 else if (BestValue != V)
5498 BestValue = NullValue;
5500 assert(BestValue &&
"Must have at least one use");
5501 assert(BestValue != &
I &&
"Cannot replace with itself");
5515 Type *Ty =
C->getType();
5528 !
C->containsConstantExpression()) {
5529 if (
Constant *Repl = getFreezeVectorReplacement(
C))
5563 for (
const User *U :
I.users()) {
5564 if (Visited.
insert(U).second)
5569 while (!AllocaUsers.
empty()) {
5592 if (
isa<PHINode>(
I) ||
I->isEHPad() ||
I->mayThrow() || !
I->willReturn() ||
5609 if (CI->isConvergent())
5615 if (
I->mayWriteToMemory()) {
5622 if (
I->mayReadFromMemory() &&
5623 !
I->hasMetadata(LLVMContext::MD_invariant_load)) {
5630 E =
I->getParent()->end();
5632 if (Scan->mayWriteToMemory())
5636 I->dropDroppableUses([&](
const Use *U) {
5638 if (
I &&
I->getParent() != DestBlock) {
5648 I->moveBefore(*DestBlock, InsertPos);
5658 if (!DbgVariableRecords.
empty())
5660 DbgVariableRecords);
5683 for (
auto &DVR : DbgVariableRecords)
5684 if (DVR->getParent() != DestBlock)
5685 DbgVariableRecordsToSalvage.
push_back(DVR);
5691 if (DVR->getParent() == SrcBlock)
5692 DbgVariableRecordsToSink.
push_back(DVR);
5699 return B->getInstruction()->comesBefore(
A->getInstruction());
5706 using InstVarPair = std::pair<const Instruction *, DebugVariable>;
5708 if (DbgVariableRecordsToSink.
size() > 1) {
5714 DVR->getDebugLoc()->getInlinedAt());
5715 CountMap[std::make_pair(DVR->getInstruction(), DbgUserVariable)] += 1;
5721 for (
auto It : CountMap) {
5722 if (It.second > 1) {
5723 FilterOutMap[It.first] =
nullptr;
5724 DupSet.
insert(It.first.first);
5735 DVR.getDebugLoc()->getInlinedAt());
5737 FilterOutMap.
find(std::make_pair(Inst, DbgUserVariable));
5738 if (FilterIt == FilterOutMap.
end())
5740 if (FilterIt->second !=
nullptr)
5742 FilterIt->second = &DVR;
5757 DVR->getDebugLoc()->getInlinedAt());
5761 if (!FilterOutMap.
empty()) {
5762 InstVarPair IVP = std::make_pair(DVR->getInstruction(), DbgUserVariable);
5763 auto It = FilterOutMap.
find(IVP);
5766 if (It != FilterOutMap.
end() && It->second != DVR)
5770 if (!SunkVariables.
insert(DbgUserVariable).second)
5773 if (DVR->isDbgAssign())
5781 if (DVRClones.
empty())
5795 assert(InsertPos.getHeadBit());
5797 InsertPos->getParent()->insertDbgRecordBefore(DVRClone, InsertPos);
5821 if (
I ==
nullptr)
continue;
5836 auto getOptionalSinkBlockForInst =
5837 [
this](
Instruction *
I) -> std::optional<BasicBlock *> {
5839 return std::nullopt;
5843 unsigned NumUsers = 0;
5845 for (
Use &U :
I->uses()) {
5851 if (
II->getIntrinsicID() != Intrinsic::assume ||
5852 !
II->getOperandBundle(
"dereferenceable"))
5857 return std::nullopt;
5863 UserBB = PN->getIncomingBlock(U);
5867 if (UserParent && UserParent != UserBB)
5868 return std::nullopt;
5869 UserParent = UserBB;
5873 if (NumUsers == 0) {
5876 if (UserParent == BB || !
DT.isReachableFromEntry(UserParent))
5877 return std::nullopt;
5889 return std::nullopt;
5891 assert(
DT.dominates(BB, UserParent) &&
"Dominance relation broken?");
5899 return std::nullopt;
5904 auto OptBB = getOptionalSinkBlockForInst(
I);
5906 auto *UserParent = *OptBB;
5914 for (
Use &U :
I->operands())
5922 Builder.SetCurrentDebugLocation(
I->getDebugLoc());
5937 <<
" New = " << *Result <<
'\n');
5942 Result->setDebugLoc(Result->getDebugLoc().orElse(
I->getDebugLoc()));
5944 Result->copyMetadata(*
I, LLVMContext::MD_annotation);
5946 I->replaceAllUsesWith(Result);
5949 Result->takeName(
I);
5964 Result->insertInto(InstParent, InsertPos);
5968 AC.registerAssumption(Assume);
5971 Worklist.pushUsersToWorkList(*Result);
5977 <<
" New = " << *
I <<
'\n');
6009 if (!
I->hasMetadataOtherThanDebugLoc())
6012 auto Track = [](
Metadata *ScopeList,
auto &Container) {
6014 if (!MDScopeList || !Container.insert(MDScopeList).second)
6016 for (
const auto &
MDOperand : MDScopeList->operands())
6018 Container.insert(MDScope);
6021 Track(
I->getMetadata(LLVMContext::MD_alias_scope), UsedAliasScopesAndLists);
6022 Track(
I->getMetadata(LLVMContext::MD_noalias), UsedNoAliasScopesAndLists);
6031 "llvm.experimental.noalias.scope.decl in use ?");
6034 "llvm.experimental.noalias.scope should refer to a single scope");
6037 return !UsedAliasScopesAndLists.contains(MD) ||
6038 !UsedNoAliasScopesAndLists.contains(MD);
6062 if (Succ != LiveSucc &&
DeadEdges.insert({BB, Succ}).second)
6063 for (
PHINode &PN : Succ->phis())
6064 for (
Use &U : PN.incoming_values())
6073 return DeadEdges.contains({Pred, BB}) ||
DT.dominates(BB, Pred);
6075 HandleOnlyLiveSuccessor(BB,
nullptr);
6082 if (!Inst.use_empty() &&
6083 (Inst.getNumOperands() == 0 ||
isa<Constant>(Inst.getOperand(0))))
6087 Inst.replaceAllUsesWith(
C);
6090 Inst.eraseFromParent();
6096 for (
Use &U : Inst.operands()) {
6101 Constant *&FoldRes = FoldedConstants[
C];
6107 <<
"\n Old = " << *
C
6108 <<
"\n New = " << *FoldRes <<
'\n');
6117 if (!Inst.isDebugOrPseudoInst()) {
6118 InstrsForInstructionWorklist.
push_back(&Inst);
6119 SeenAliasScopes.
analyse(&Inst);
6129 HandleOnlyLiveSuccessor(BB,
nullptr);
6133 bool CondVal =
Cond->getZExtValue();
6134 HandleOnlyLiveSuccessor(BB, BI->getSuccessor(!CondVal));
6140 HandleOnlyLiveSuccessor(BB,
nullptr);
6144 HandleOnlyLiveSuccessor(BB,
6145 SI->findCaseValue(
Cond)->getCaseSuccessor());
6155 if (LiveBlocks.
count(&BB))
6158 unsigned NumDeadInstInBB;
6162 NumDeadInst += NumDeadInstInBB;
6179 Inst->eraseFromParent();
6194 Visited[BB->getNumber()] =
true;
6196 if (Visited[Succ->getNumber()])
6208 auto &
DL =
F.getDataLayout();
6210 !
F.hasFnAttribute(
"instcombine-no-verify-fixpoint");
6216 bool MadeIRChange =
false;
6221 unsigned Iteration = 0;
6225 <<
" on " <<
F.getName()
6226 <<
" reached; stopping without verifying fixpoint\n");
6231 ++NumWorklistIterations;
6232 LLVM_DEBUG(
dbgs() <<
"\n\nINSTCOMBINE ITERATION #" << Iteration <<
" on "
6233 <<
F.getName() <<
"\n");
6235 InstCombinerImpl IC(Worklist,
F,
AA, AC, TLI,
TTI, DT, ORE, BFI, BPI, PSI,
6239 MadeChangeInThisIteration |= IC.
run();
6240 if (!MadeChangeInThisIteration)
6243 MadeIRChange =
true;
6246 "Instruction Combining on " +
Twine(
F.getName()) +
6249 "Use 'instcombine<no-verify-fixpoint>' or function attribute "
6250 "'instcombine-no-verify-fixpoint' to suppress this error.");
6256 else if (Iteration == 2)
6258 else if (Iteration == 3)
6259 ++NumThreeIterations;
6261 ++NumFourOrMoreIterations;
6263 return MadeIRChange;
6271 OS, MapClassName2PassName);
6273 OS <<
"max-iterations=" << Options.MaxIterations <<
";";
6274 OS << (Options.VerifyFixpoint ?
"" :
"no-") <<
"verify-fixpoint";
6278char InstCombinePass::ID = 0;
6284 if (LRT.shouldSkip(&ID))
6297 auto *BFI = (PSI && PSI->hasProfileSummary()) ?
6302 BFI, BPI, PSI, Options)) {
6304 LRT.update(&ID,
false);
6310 LRT.update(&ID,
true);
6352 if (
auto *WrapperPass =
6354 BPI = &WrapperPass->getBPI();
6365 "Combine redundant instructions",
false,
false)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMDGPU Register Bank Select
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
This is the interface for LLVM's primary stateless and local alias analysis.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
This file contains the declarations for the subclasses of Constant, which represent the different fla...
This file provides an implementation of debug counters.
#define DEBUG_COUNTER(VARNAME, COUNTERNAME, DESC)
This file defines the DenseMap class.
static bool isSigned(unsigned Opcode)
This is the interface for a simple mod/ref and alias analysis over globals.
This file provides various utilities for inspecting and working with the control flow graph in LLVM I...
This header defines various interfaces for pass management in LLVM.
This defines the Use class.
iv Induction Variable Users
static bool rightDistributesOverLeft(Instruction::BinaryOps LOp, bool HasNUW, bool HasNSW, Intrinsic::ID ROp)
Return whether "(X ROp Y) LOp Z" is always equal to "(X LOp Z) ROp (Y LOp Z)".
static bool leftDistributesOverRight(Instruction::BinaryOps LOp, bool HasNUW, bool HasNSW, Intrinsic::ID ROp)
Return whether "X LOp (Y ROp Z)" is always equal to "(X LOp Y) ROp (X LOp Z)".
This file provides internal interfaces used to implement the InstCombine.
This file provides the primary interface to the instcombine pass.
static Value * simplifySwitchOnSelectUsingRanges(SwitchInst &SI, SelectInst *Select, bool IsTrueArm)
static bool isUsedWithinShuffleVector(Value *V)
static bool isNeverEqualToUnescapedAlloc(Value *V, const TargetLibraryInfo &TLI, Instruction *AI)
static Constant * constantFoldBinOpWithSplat(unsigned Opcode, Constant *Vector, Constant *Splat, bool SplatLHS, const DataLayout &DL)
static bool shorter_filter(const Value *LHS, const Value *RHS)
static Instruction * combineConstantOffsets(GetElementPtrInst &GEP, InstCombinerImpl &IC)
Combine constant offsets separated by variable offsets.
static Instruction * foldSelectGEP(GetElementPtrInst &GEP, InstCombiner::BuilderTy &Builder)
Thread a GEP operation with constant indices through the constant true/false arms of a select.
static bool shouldMergeGEPs(GEPOperator &GEP, GEPOperator &Src)
static cl::opt< unsigned > MaxArraySize("instcombine-maxarray-size", cl::init(1024), cl::desc("Maximum array size considered when doing a combine"))
static Instruction * foldSpliceBinOp(BinaryOperator &Inst, InstCombiner::BuilderTy &Builder)
static cl::opt< unsigned > ShouldLowerDbgDeclare("instcombine-lower-dbg-declare", cl::Hidden, cl::init(true))
static bool hasNoSignedWrap(BinaryOperator &I)
static bool simplifyAssocCastAssoc(BinaryOperator *BinOp1, InstCombinerImpl &IC)
Combine constant operands of associative operations either before or after a cast to eliminate one of...
static bool combineInstructionsOverFunction(Function &F, InstructionWorklist &Worklist, AliasAnalysis *AA, AssumptionCache &AC, TargetLibraryInfo &TLI, TargetTransformInfo &TTI, DominatorTree &DT, OptimizationRemarkEmitter &ORE, BlockFrequencyInfo *BFI, BranchProbabilityInfo *BPI, ProfileSummaryInfo *PSI, const InstCombineOptions &Opts)
static Value * simplifyInstructionWithPHI(Instruction &I, PHINode *PN, Value *InValue, BasicBlock *InBB, const DataLayout &DL, const SimplifyQuery SQ)
static bool shouldCanonicalizeGEPToPtrAdd(GetElementPtrInst &GEP)
Return true if we should canonicalize the gep to an i8 ptradd.
static Value * getIdentityValue(Instruction::BinaryOps Opcode, Value *V)
This function returns identity value for given opcode, which can be used to factor patterns like (X *...
static Value * foldFrexpOfSelect(ExtractValueInst &EV, IntrinsicInst *FrexpCall, SelectInst *SelectInst, InstCombiner::BuilderTy &Builder)
static std::optional< std::pair< Value *, Value * > > matchSymmetricPhiNodesPair(PHINode *LHS, PHINode *RHS)
static std::optional< ModRefInfo > isAllocSiteRemovable(Instruction *AI, SmallVectorImpl< Instruction * > &Users, const TargetLibraryInfo &TLI, bool KnowInit)
static cl::opt< unsigned > MaxAllocSiteRemovableUsers("instcombine-max-allocsite-removable-users", cl::Hidden, cl::init(2048), cl::desc("Maximum number of users to visit in alloc-site " "removability analysis"))
static Value * foldOperationIntoSelectOperand(Instruction &I, SelectInst *SI, Value *NewOp, InstCombiner &IC)
static Instruction * canonicalizeGEPOfConstGEPI8(GetElementPtrInst &GEP, GEPOperator *Src, InstCombinerImpl &IC)
static Instruction * tryToMoveFreeBeforeNullTest(CallInst &FI, const DataLayout &DL)
Move the call to free before a NULL test.
static Value * simplifyOperationIntoSelectOperand(Instruction &I, SelectInst *SI, bool IsTrueArm)
static Value * tryFactorization(BinaryOperator &I, const SimplifyQuery &SQ, InstCombiner::BuilderTy &Builder, Instruction::BinaryOps InnerOpcode, Value *A, Value *B, Value *C, Value *D)
This tries to simplify binary operations by factorizing out common terms (e.
static bool isRemovableWrite(CallBase &CB, Value *UsedV, const TargetLibraryInfo &TLI)
Given a call CB which uses an address UsedV, return true if we can prove the call's only possible eff...
static Instruction::BinaryOps getBinOpsForFactorization(Instruction::BinaryOps TopOpcode, BinaryOperator *Op, Value *&LHS, Value *&RHS, BinaryOperator *OtherOp)
This function predicates factorization using distributive laws.
static bool hasNoUnsignedWrap(BinaryOperator &I)
static bool SoleWriteToDeadLocal(Instruction *I, TargetLibraryInfo &TLI)
Check for case where the call writes to an otherwise dead alloca.
static cl::opt< unsigned > MaxSinkNumUsers("instcombine-max-sink-users", cl::init(32), cl::desc("Maximum number of undroppable users for instruction sinking"))
static Instruction * foldGEPOfPhi(GetElementPtrInst &GEP, PHINode *PN, IRBuilderBase &Builder)
static bool isCatchAll(EHPersonality Personality, Constant *TypeInfo)
Return 'true' if the given typeinfo will match anything.
static cl::opt< bool > EnableCodeSinking("instcombine-code-sinking", cl::desc("Enable code sinking"), cl::init(true))
static bool maintainNoSignedWrap(BinaryOperator &I, Value *B, Value *C)
static GEPNoWrapFlags getMergedGEPNoWrapFlags(GEPOperator &GEP1, GEPOperator &GEP2)
Determine nowrap flags for (gep (gep p, x), y) to (gep p, (x + y)) transform.
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
static bool IsSelect(unsigned Opcode, bool CheckOnlyCC=false)
Check if the opcode is a SELECT or SELECT_CC variant.
#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 unsigned getNumElements(Type *Ty)
BaseType
A given derived pointer can have multiple base pointers through phi/selects.
This file defines the SmallPtrSet class.
This file defines the SmallVector class.
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
static SymbolRef::Type getType(const Symbol *Sym)
static const uint32_t IV[8]
bool isNoAliasScopeDeclDead(Instruction *Inst)
void analyse(Instruction *I)
A manager for alias analyses.
A wrapper pass to provide the legacy pass manager access to a suitably prepared AAResults object.
static constexpr roundingMode rmNearestTiesToEven
static LLVM_ABI unsigned int semanticsPrecision(const fltSemantics &)
Class for arbitrary precision integers.
static APInt getAllOnes(unsigned numBits)
Return an APInt of a specified width with all bits set.
static LLVM_ABI void udivrem(const APInt &LHS, const APInt &RHS, APInt &Quotient, APInt &Remainder)
Dual division/remainder interface.
bool isMinSignedValue() const
Determine if this is the smallest signed value.
static LLVM_ABI void sdivrem(const APInt &LHS, const APInt &RHS, APInt &Quotient, APInt &Remainder)
LLVM_ABI APInt trunc(unsigned width) const
Truncate to new width.
bool isAllOnes() const
Determine if all bits are set. This is true for zero-width values.
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
unsigned getBitWidth() const
Return the number of bits in the APInt.
LLVM_ABI APInt sadd_ov(const APInt &RHS, bool &Overflow) const
APInt ashr(unsigned ShiftAmt) const
Arithmetic right-shift function.
LLVM_ABI APInt smul_ov(const APInt &RHS, bool &Overflow) const
bool isMaxSignedValue() const
Determine if this is the largest signed value.
bool isNonNegative() const
Determine if this APInt Value is non-negative (>= 0)
bool ule(const APInt &RHS) const
Unsigned less or equal comparison.
bool isPowerOf2() const
Check if this APInt's value is a power of two greater than zero.
static APInt getLowBitsSet(unsigned numBits, unsigned loBitsSet)
Constructs an APInt value that has the bottom loBitsSet bits set.
LLVM_ABI APInt ssub_ov(const APInt &RHS, bool &Overflow) const
APInt lshr(unsigned shiftAmt) const
Logical right-shift function.
PassT::Result * getCachedResult(IRUnitT &IR) const
Get the cached result of an analysis pass for a given IR unit.
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()
AnalysisUsage & addPreserved()
Add the specified Pass class to the set of analyses preserved by this pass.
LLVM_ABI void setPreservesCFG()
This function should be called by the pass, iff they do not:
Represent a constant reference to an array (0 or more elements consecutively in memory),...
ArrayRef< T > take_front(size_t N=1) const
Return a copy of *this with only the first N elements.
size_t size() const
Get the array size.
Class to represent array types.
static LLVM_ABI ArrayType * get(Type *ElementType, uint64_t NumElements)
This static method is the primary way to construct an ArrayType.
uint64_t getNumElements() const
Type * getElementType() const
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.
Functions, function parameters, and return types can have attributes to indicate how they should be t...
LLVM_ABI uint64_t getDereferenceableBytes() const
Returns the number of dereferenceable bytes from the dereferenceable attribute.
bool isValid() const
Return true if the attribute is any kind of attribute.
Legacy wrapper pass to provide the BasicAAResult object.
LLVM Basic Block Representation.
iterator_range< const_phi_iterator > phis() const
Returns a range that iterates over the phis in the basic block.
LLVM_ABI const_iterator getFirstInsertionPt() const
Returns an iterator to the first instruction in this block that is suitable for inserting a non-PHI i...
LLVM_ABI InstListType::const_iterator getFirstNonPHIIt() const
Returns an iterator to the first instruction in this block that is not a PHINode instruction.
LLVM_ABI bool isEntryBlock() const
Return true if this is the entry block of the containing function.
LLVM_ABI const BasicBlock * getSinglePredecessor() const
Return the predecessor of this block if it has a single predecessor block.
const Instruction & front() const
LLVM_ABI const BasicBlock * getUniquePredecessor() const
Return the predecessor of this block if it has a unique predecessor block.
InstListType::iterator iterator
Instruction iterators...
LLVM_ABI const_iterator getFirstNonPHIOrDbgOrAlloca() const
Returns an iterator to the first instruction in this block that is not a PHINode, a debug intrinsic,...
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction; assumes that the block is well-formed.
static LLVM_ABI BinaryOperator * CreateNeg(Value *Op, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Helper functions to construct and inspect unary operations (NEG and NOT) via binary operators SUB and...
BinaryOps getOpcode() const
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.
static BinaryOperator * CreateNUW(BinaryOps Opc, Value *V1, Value *V2, const Twine &Name="")
Analysis pass which computes BlockFrequencyInfo.
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
Analysis pass which computes BranchProbabilityInfo.
Analysis providing branch probability information.
Represents analyses that only rely on functions' control flow.
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
Function * getCalledFunction() const
Returns the function called, or null if this is an indirect function invocation or the function signa...
void setAttributes(AttributeList A)
Set the attributes for this call.
bool doesNotThrow() const
Determine if the call cannot unwind.
Value * getArgOperand(unsigned i) const
AttributeList getAttributes() const
Return the attributes for this call.
This class represents a function call, abstracting a target machine's calling convention.
static CallInst * Create(FunctionType *Ty, Value *F, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
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 ...
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
@ ICMP_UGT
unsigned greater than
@ ICMP_ULT
unsigned less than
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,...
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
Conditional Branch instruction.
LLVM_ABI void swapSuccessors()
Swap the successors of this branch instruction.
Value * getCondition() const
BasicBlock * getSuccessor(unsigned i) const
ConstantArray - Constant Array Declarations.
static LLVM_ABI Constant * get(ArrayType *T, ArrayRef< Constant * > V)
A vector constant whose element type is a simple 1/2/4/8-byte integer or float/double,...
static LLVM_ABI Constant * getSub(Constant *C1, Constant *C2, bool HasNUW=false, bool HasNSW=false)
static LLVM_ABI Constant * getNot(Constant *C)
static LLVM_ABI Constant * getAdd(Constant *C1, Constant *C2, bool HasNUW=false, bool HasNSW=false)
static LLVM_ABI Constant * getBinOpIdentity(unsigned Opcode, Type *Ty, bool AllowRHSConstant=false, bool NSZ=false)
Return the identity constant for a binary opcode.
static LLVM_ABI Constant * getNeg(Constant *C, bool HasNSW=false)
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 ConstantInt * getBool(LLVMContext &Context, bool V)
This class represents a range of values.
LLVM_ABI bool getEquivalentICmp(CmpInst::Predicate &Pred, APInt &RHS) const
Set up Pred and RHS such that ConstantRange::makeExactICmpRegion(Pred, RHS) == *this.
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 bool contains(const APInt &Val) const
Return true if the specified value is in the set.
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.
Constant Vector Declarations.
static LLVM_ABI Constant * getSplat(ElementCount EC, Constant *Elt)
Return a ConstantVector with the specified constant in each element.
static LLVM_ABI Constant * get(ArrayRef< Constant * > V)
This is an important base class in LLVM.
static LLVM_ABI Constant * replaceUndefsWith(Constant *C, Constant *Replacement)
Try to replace undefined constant C or undefined elements in C with Replacement.
static LLVM_ABI Constant * getAllOnesValue(Type *Ty)
const Constant * stripPointerCasts() const
static LLVM_ABI Constant * getNullValue(Type *Ty)
Constructor to create a '0' constant of arbitrary type.
LLVM_ABI Constant * getAggregateElement(unsigned Elt) const
For aggregates (struct/array/vector) return the constant that corresponds to the specified element if...
static LLVM_ABI DIExpression * appendOpsToArg(const DIExpression *Expr, ArrayRef< uint64_t > Ops, unsigned ArgNo, bool StackValue=false)
Create a copy of Expr by appending the given list of Ops to each instance of the operand DW_OP_LLVM_a...
A parsed version of the target data layout string in and methods for querying it.
Record of a variable value-assignment, aka a non instruction representation of the dbg....
static bool shouldExecute(CounterInfo &Counter)
Identifies a unique instance of a variable.
ValueT lookup(const_arg_type_t< KeyT > Val) const
Return the entry for the specified key, or a default constructed value if no such entry exists.
iterator find(const_arg_type_t< KeyT > Val)
std::pair< iterator, bool > insert(const std::pair< KeyT, ValueT > &KV)
Analysis pass which computes a DominatorTree.
Legacy analysis pass which computes a DominatorTree.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Convenience struct for specifying and reasoning about fast-math flags.
This class represents a freeze function that returns random concrete value if an operand is either a ...
FunctionPass class - This class is used to implement most global optimizations.
bool skipFunction(const Function &F) const
Optional passes call this function to check whether the pass should be skipped.
const BasicBlock & getEntryBlock() const
Represents flags for the getelementptr instruction/expression.
static GEPNoWrapFlags inBounds()
static GEPNoWrapFlags all()
static GEPNoWrapFlags noUnsignedWrap()
GEPNoWrapFlags intersectForReassociate(GEPNoWrapFlags Other) const
Given (gep (gep p, x), y), determine the nowrap flags for (gep (gep, p, y), x).
bool hasNoUnsignedWrap() const
GEPNoWrapFlags intersectForOffsetAdd(GEPNoWrapFlags Other) const
Given (gep (gep p, x), y), determine the nowrap flags for (gep p, x+y).
static GEPNoWrapFlags none()
GEPNoWrapFlags getNoWrapFlags() const
an instruction for type-safe pointer arithmetic to access elements of arrays and structs
static LLVM_ABI Type * getTypeAtIndex(Type *Ty, Value *Idx)
Return the type of the element at the given index of an indexable type.
static GetElementPtrInst * Create(Type *PointeeType, Value *Ptr, ArrayRef< Value * > IdxList, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
static LLVM_ABI Type * getIndexedType(Type *Ty, ArrayRef< Value * > IdxList)
Returns the result type of a getelementptr with the given source element type and indexes.
static GetElementPtrInst * CreateInBounds(Type *PointeeType, Value *Ptr, ArrayRef< Value * > IdxList, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Create an "inbounds" getelementptr.
Legacy wrapper pass to provide the GlobalsAAResult object.
This instruction compares its operands according to the predicate given to the constructor.
CmpPredicate getCmpPredicate() const
static bool isEquality(Predicate P)
Return true if this predicate is either EQ or NE.
Common base class shared among various IRBuilders.
Value * CreatePtrAdd(Value *Ptr, Value *Offset, const Twine &Name="", GEPNoWrapFlags NW=GEPNoWrapFlags::none())
ConstantInt * getInt(const APInt &AI)
Get a constant integer value.
virtual void InsertHelper(Instruction *I, const Twine &Name, BasicBlock::iterator InsertPt) const
This instruction inserts a struct field of array element value into an aggregate value.
static InsertValueInst * Create(Value *Agg, Value *Val, ArrayRef< unsigned > Idxs, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
LLVM_ABI InstCombinePass(InstCombineOptions Opts={})
LLVM_ABI void printPipeline(raw_ostream &OS, function_ref< StringRef(StringRef)> MapClassName2PassName)
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
Instruction * foldBinOpOfSelectAndCastOfSelectCondition(BinaryOperator &I)
Tries to simplify binops of select and cast of the select condition.
Instruction * visitCondBrInst(CondBrInst &BI)
Instruction * foldBinOpIntoSelectOrPhi(BinaryOperator &I)
This is a convenience wrapper function for the above two functions.
bool SimplifyAssociativeOrCommutative(BinaryOperator &I)
Performs a few simplifications for operators which are associative or commutative.
Instruction * visitGEPOfGEP(GetElementPtrInst &GEP, GEPOperator *Src)
Value * foldUsingDistributiveLaws(BinaryOperator &I)
Tries to simplify binary operations which some other binary operation distributes over.
Instruction * foldBinOpShiftWithShift(BinaryOperator &I)
Instruction * visitUnreachableInst(UnreachableInst &I)
Instruction * foldOpIntoPhi(Instruction &I, PHINode *PN, bool AllowMultipleUses=false)
Given a binary operator, cast instruction, or select which has a PHI node as operand #0,...
void handleUnreachableFrom(Instruction *I, SmallVectorImpl< BasicBlock * > &Worklist)
Value * SimplifyDemandedVectorElts(Value *V, APInt DemandedElts, APInt &PoisonElts, unsigned Depth=0, bool AllowMultipleUsers=false) override
The specified value produces a vector with any number of elements.
Instruction * visitFreeze(FreezeInst &I)
Instruction * foldBinOpSelectBinOp(BinaryOperator &Op)
In some cases it is beneficial to fold a select into a binary operator.
void handlePotentiallyDeadBlocks(SmallVectorImpl< BasicBlock * > &Worklist)
bool prepareWorklist(Function &F)
Perform early cleanup and prepare the InstCombine worklist.
Instruction * FoldOpIntoSelect(Instruction &Op, SelectInst *SI, bool FoldWithMultiUse=false, bool SimplifyBothArms=false)
Given an instruction with a select as one operand and a constant as the other operand,...
Instruction * visitFree(CallInst &FI, Value *FreedOp)
Instruction * visitExtractValueInst(ExtractValueInst &EV)
void handlePotentiallyDeadSuccessors(BasicBlock *BB, BasicBlock *LiveSucc)
Instruction * foldBinopWithRecurrence(BinaryOperator &BO)
Try to fold binary operators whose operands are simple interleaved recurrences to a single recurrence...
Instruction * eraseInstFromFunction(Instruction &I) override
Combiner aware instruction erasure.
Instruction * visitLandingPadInst(LandingPadInst &LI)
Instruction * visitReturnInst(ReturnInst &RI)
Instruction * visitSwitchInst(SwitchInst &SI)
Instruction * foldBinopWithPhiOperands(BinaryOperator &BO)
For a binary operator with 2 phi operands, try to hoist the binary operation before the phi.
bool SimplifyDemandedFPClass(Instruction *I, unsigned Op, FPClassTest DemandedMask, KnownFPClass &Known, const SimplifyQuery &Q, unsigned Depth=0)
bool mergeStoreIntoSuccessor(StoreInst &SI)
Try to transform: if () { *P = v1; } else { *P = v2 } or: *P = v1; if () { *P = v2; }...
Instruction * tryFoldInstWithCtpopWithNot(Instruction *I)
Instruction * visitUncondBrInst(UncondBrInst &BI)
void CreateNonTerminatorUnreachable(Instruction *InsertAt)
Create and insert the idiom we use to indicate a block is unreachable without having to rewrite the C...
Value * pushFreezeToPreventPoisonFromPropagating(FreezeInst &FI)
bool run()
Run the combiner over the entire worklist until it is empty.
Instruction * foldVectorBinop(BinaryOperator &Inst)
Canonicalize the position of binops relative to shufflevector.
bool removeInstructionsBeforeUnreachable(Instruction &I)
Value * SimplifySelectsFeedingBinaryOp(BinaryOperator &I, Value *LHS, Value *RHS)
void tryToSinkInstructionDbgVariableRecords(Instruction *I, BasicBlock::iterator InsertPos, BasicBlock *SrcBlock, BasicBlock *DestBlock, SmallVectorImpl< DbgVariableRecord * > &DPUsers)
void addDeadEdge(BasicBlock *From, BasicBlock *To, SmallVectorImpl< BasicBlock * > &Worklist)
Constant * unshuffleConstant(ArrayRef< int > ShMask, Constant *C, VectorType *NewCTy)
Find a constant NewC that has property: shuffle(NewC, poison, ShMask) = C for lanes that select NewC.
Instruction * visitAllocSite(Instruction &FI)
Instruction * visitGetElementPtrInst(GetElementPtrInst &GEP)
Value * tryFactorizationFolds(BinaryOperator &I)
This tries to simplify binary operations by factorizing out common terms (e.
Instruction * foldFreezeIntoRecurrence(FreezeInst &I, PHINode *PN)
bool tryToSinkInstruction(Instruction *I, BasicBlock *DestBlock)
Try to move the specified instruction from its current block into the beginning of DestBlock,...
bool freezeOtherUses(FreezeInst &FI)
void freelyInvertAllUsersOf(Value *V, Value *IgnoredUser=nullptr)
Freely adapt every user of V as-if V was changed to !V.
The core instruction combiner logic.
const DataLayout & getDataLayout() const
bool isFreeToInvert(Value *V, bool WillInvertAllUses, bool &DoesConsume)
Return true if the specified value is free to invert (apply ~ to).
static unsigned getComplexity(Value *V)
Assign a complexity or rank value to LLVM Values.
unsigned ComputeNumSignBits(const Value *Op, const Instruction *CxtI=nullptr, unsigned Depth=0) const
Instruction * InsertNewInstBefore(Instruction *New, BasicBlock::iterator Old)
Inserts an instruction New before instruction Old.
Instruction * replaceInstUsesWith(Instruction &I, Value *V)
A combiner-aware RAUW-like routine.
uint64_t MaxArraySizeForCombine
Maximum size of array considered when transforming.
static bool shouldAvoidAbsorbingNotIntoSelect(const SelectInst &SI)
void replaceUse(Use &U, Value *NewValue)
Replace use and add the previously used value to the worklist.
static bool isCanonicalPredicate(CmpPredicate Pred)
Predicate canonicalization reduces the number of patterns that need to be matched by other transforms...
Instruction * AnnotationMetadataSource
Source for annotation metadata, used by the IRBuilder inserter.
InstructionWorklist & Worklist
A worklist of the instructions that need to be simplified.
Instruction * InsertNewInstWith(Instruction *New, BasicBlock::iterator Old)
Same as InsertNewInstBefore, but also sets the debug loc.
BranchProbabilityInfo * BPI
ReversePostOrderTraversal< BasicBlock * > & RPOT
void computeKnownBits(const Value *V, KnownBits &Known, const Instruction *CxtI, unsigned Depth=0) const
IRBuilder< TargetFolder, IRBuilderInstCombineInserter > BuilderTy
An IRBuilder that automatically inserts new instructions into the worklist.
LLVM_ABI std::optional< Instruction * > targetInstCombineIntrinsic(IntrinsicInst &II)
void addToWorklist(Instruction *I)
LLVM_ABI Value * getFreelyInvertedImpl(Value *V, bool WillInvertAllUses, BuilderTy *Builder, bool &DoesConsume, unsigned Depth)
Return nonnull value if V is free to invert under the condition of WillInvertAllUses.
SmallDenseSet< std::pair< const BasicBlock *, const BasicBlock * >, 8 > BackEdges
Backedges, used to avoid pushing instructions across backedges in cases where this may result in infi...
LLVM_ABI std::optional< Value * > targetSimplifyDemandedVectorEltsIntrinsic(IntrinsicInst &II, APInt DemandedElts, APInt &UndefElts, APInt &UndefElts2, APInt &UndefElts3, std::function< void(Instruction *, unsigned, APInt, APInt &)> SimplifyAndSetOp)
LLVM_ABI void computeBackEdges()
Instruction * replaceOperand(Instruction &I, unsigned OpNum, Value *V)
Replace operand of instruction and add old operand to the worklist.
static Constant * getSafeVectorConstantForBinop(BinaryOperator::BinaryOps Opcode, Constant *In, bool IsRHSConstant)
Some binary operators require special handling to avoid poison and undefined behavior.
SmallDenseSet< std::pair< BasicBlock *, BasicBlock * >, 8 > DeadEdges
Edges that are known to never be taken.
LLVM_ABI std::optional< Value * > targetSimplifyDemandedUseBitsIntrinsic(IntrinsicInst &II, APInt DemandedMask, KnownBits &Known, bool &KnownBitsComputed)
LLVM_ABI bool isValidAddrSpaceCast(unsigned FromAS, unsigned ToAS) const
Value * getFreelyInverted(Value *V, bool WillInvertAllUses, BuilderTy *Builder, bool &DoesConsume)
bool isBackEdge(const BasicBlock *From, const BasicBlock *To)
bool isKnownToBeAPowerOfTwo(const Value *V, bool OrZero=false, const Instruction *CxtI=nullptr, unsigned Depth=0)
void visit(Iterator Start, Iterator End)
The legacy pass manager's instcombine pass.
InstructionCombiningPass()
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
bool runOnFunction(Function &F) override
runOnFunction - Virtual method overriden by subclasses to do the per-function processing of the pass.
InstructionWorklist - This is the worklist management logic for InstCombine and other simplification ...
LLVM_ABI void dropUBImplyingAttrsAndMetadata(ArrayRef< unsigned > Keep={})
Drop any attributes or metadata that can cause immediate undefined behavior.
static bool isBitwiseLogicOp(unsigned Opcode)
Determine if the Opcode is and/or/xor.
LLVM_ABI void copyIRFlags(const Value *V, bool IncludeWrapFlags=true)
Convenience method to copy supported exact, fast-math, and (optionally) wrapping flags from V to this...
const DebugLoc & getDebugLoc() const
Return the debug location for this node as a DebugLoc.
LLVM_ABI const Module * getModule() const
Return the module owning the function this instruction belongs to or nullptr it the function does not...
LLVM_ABI void setAAMetadata(const AAMDNodes &N)
Sets the AA metadata on this instruction from the AAMDNodes structure.
LLVM_ABI bool isAssociative() const LLVM_READONLY
Return true if the instruction is associative:
LLVM_ABI bool isCommutative() const LLVM_READONLY
Return true if the instruction is commutative:
LLVM_ABI void moveBefore(InstListType::iterator InsertPos)
Unlink this instruction from its current basic block and insert it into the basic block that MovePos ...
LLVM_ABI void setFastMathFlags(FastMathFlags FMF)
Convenience function for setting multiple fast-math flags on this instruction, which must be an opera...
LLVM_ABI const Function * getFunction() const
Return the function this instruction belongs to.
bool isTerminator() const
LLVM_ABI FastMathFlags getFastMathFlags() const LLVM_READONLY
Convenience function for getting all the fast-math flags, which must be an operator which supports th...
LLVM_ABI bool willReturn() const LLVM_READONLY
Return true if the instruction will return (unwinding is considered as a form of returning control fl...
unsigned getOpcode() const
Returns a member of one of the enums like Instruction::Add.
bool isBitwiseLogicOp() const
Return true if this is and/or/xor.
LLVM_ABI void dropPoisonGeneratingFlags()
Drops flags that may cause this instruction to evaluate to poison despite having non-poison inputs.
void setDebugLoc(DebugLoc Loc)
Set the debug location information for this instruction.
LLVM_ABI void copyMetadata(const Instruction &SrcInst, ArrayRef< unsigned > WL=ArrayRef< unsigned >())
Copy metadata from SrcInst to this instruction.
Class to represent integer types.
static LLVM_ABI IntegerType * get(LLVMContext &C, unsigned NumBits)
This static method is the primary way of constructing an IntegerType.
A wrapper class for inspecting calls to intrinsic functions.
static InvokeInst * Create(FunctionType *Ty, Value *Func, BasicBlock *IfNormal, BasicBlock *IfException, ArrayRef< Value * > Args, const Twine &NameStr, InsertPosition InsertBefore=nullptr)
The landingpad instruction holds all of the information necessary to generate correct exception handl...
bool isCleanup() const
Return 'true' if this landingpad instruction is a cleanup.
unsigned getNumClauses() const
Get the number of clauses for this landing pad.
static LLVM_ABI LandingPadInst * Create(Type *RetTy, unsigned NumReservedClauses, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructors - NumReservedClauses is a hint for the number of incoming clauses that this landingpad w...
LLVM_ABI void addClause(Constant *ClauseVal)
Add a catch or filter clause to the landing pad.
bool isCatch(unsigned Idx) const
Return 'true' if the clause and index Idx is a catch clause.
bool isFilter(unsigned Idx) const
Return 'true' if the clause and index Idx is a filter clause.
Constant * getClause(unsigned Idx) const
Get the value of the clause at index Idx.
void setCleanup(bool V)
Indicate that this landingpad instruction is a cleanup.
A function/module analysis which provides an empty LastRunTrackingInfo.
This is an alternative analysis pass to BlockFrequencyInfoWrapperPass.
static void getLazyBFIAnalysisUsage(AnalysisUsage &AU)
Helper for client passes to set up the analysis usage on behalf of this pass.
An instruction for reading from memory.
Value * getPointerOperand()
bool isVolatile() const
Return true if this is a load from a volatile memory location.
const MDOperand & getOperand(unsigned I) const
unsigned getNumOperands() const
Return number of MDNode operands.
Tracking metadata reference owned by Metadata.
This is the common base class for memset/memcpy/memmove.
static LLVM_ABI MemoryLocation getForDest(const MemIntrinsic *MI)
Return a location representing the destination of a memory set or transfer.
static ICmpInst::Predicate getPredicate(Intrinsic::ID ID)
Returns the comparison predicate underlying the intrinsic.
A Module instance is used to store all the information related to an LLVM module.
MDNode * getScopeList() const
Utility class for integer operators which may exhibit overflow - Add, Sub, Mul, and Shl.
bool hasNoSignedWrap() const
Test whether this operation is known to never undergo signed overflow, aka the nsw property.
bool hasNoUnsignedWrap() const
Test whether this operation is known to never undergo unsigned overflow, aka the nuw property.
void addIncoming(Value *V, BasicBlock *BB)
Add an incoming value to the end of the PHI list.
op_range incoming_values()
BasicBlock * getIncomingBlock(unsigned i) const
Return incoming basic block number i.
Value * getIncomingValue(unsigned i) const
Return incoming value number x.
unsigned getNumIncomingValues() const
Return the number of incoming edges.
static PHINode * Create(Type *Ty, unsigned NumReservedValues, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructors - NumReservedValues is a hint for the number of incoming edges that this phi node will h...
PassRegistry - This class manages the registration and intitialization of the pass subsystem as appli...
AnalysisType & getAnalysis() const
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information ...
AnalysisType * getAnalysisIfAvailable() const
getAnalysisIfAvailable<AnalysisType>() - Subclasses use this function to get analysis information tha...
In order to facilitate speculative execution, many instructions do not invoke immediate undefined beh...
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
A set of analyses that are preserved following a run of a transformation pass.
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
PreservedAnalyses & preserveSet()
Mark an analysis set as preserved.
PreservedAnalyses & preserve()
Mark an analysis as preserved.
An analysis pass based on the new PM to deliver ProfileSummaryInfo.
An analysis pass based on legacy pass manager to deliver ProfileSummaryInfo.
Analysis providing profile information.
bool hasProfileSummary() const
Returns true if profile summary is available.
A global registry used in conjunction with static constructors to make pluggable components (like tar...
Return a value (possibly void), from a function.
Value * getReturnValue() const
Convenience accessor. Returns null if there is no return value.
This class represents the LLVM 'select' instruction.
const Value * getFalseValue() const
const Value * getCondition() const
static SelectInst * Create(Value *C, Value *S1, Value *S2, const Twine &NameStr="", InsertPosition InsertBefore=nullptr, const Instruction *MDFrom=nullptr)
const Value * getTrueValue() const
bool insert(const value_type &X)
Insert a new element into the SetVector.
This instruction constructs a fixed permutation of two input vectors.
size_type count(ConstPtrType Ptr) const
count - Return 1 if the specified pointer is in the set, 0 otherwise.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
A SetVector that performs no allocations if smaller than a certain size.
SmallSet - This maintains a set of unique values, optimizing for the case when the set is small (less...
std::pair< const_iterator, bool > insert(const T &V)
insert - Insert an element into the set if it isn't already there.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
reference emplace_back(ArgTypes &&... Args)
void reserve(size_type N)
iterator erase(const_iterator CI)
void append(ItTy in_start, ItTy in_end)
Add the specified range to the end of the SmallVector.
typename SuperClass::iterator iterator
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.
Represent a constant reference to a string, i.e.
Analysis pass providing the TargetTransformInfo.
Analysis pass providing the TargetLibraryInfo.
Provides information about what library functions are available for the current target.
bool has(LibFunc F) const
Tests whether a library function is available.
bool getLibFunc(StringRef funcName, LibFunc &F) const
Searches for a particular function name.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
The instances of the Type class are immutable: once they are created, they are never changed.
bool isVectorTy() const
True if this is an instance of VectorType.
LLVM_ABI bool isScalableTy(SmallPtrSetImpl< const Type * > &Visited) const
Return true if this is a type whose size is a known multiple of vscale.
bool isPointerTy() const
True if this is an instance of PointerType.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
static LLVM_ABI IntegerType * getInt8Ty(LLVMContext &C)
Type * getScalarType() const
If this is a vector type, return the element type, otherwise return 'this'.
bool isStructTy() const
True if this is an instance of StructType.
LLVM_ABI TypeSize getPrimitiveSizeInBits() const LLVM_READONLY
Return the basic size of this type if it is a primitive 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.
bool isIntegerTy() const
True if this is an instance of IntegerType.
LLVM_ABI const fltSemantics & getFltSemantics() const
Unconditional Branch instruction.
static LLVM_ABI UndefValue * get(Type *T)
Static factory methods - Return an 'undef' object of the specified type.
This function has undefined behavior.
A Use represents the edge between a Value definition and its users.
LLVM_ABI bool isDroppable() const
A droppable user is a user for which uses can be dropped without affecting correctness and should be ...
LLVM_ABI bool replaceUsesOfWith(Value *From, Value *To)
Replace uses of one Value with another.
Value * getOperand(unsigned i) const
unsigned getNumOperands() const
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
const Value * stripAndAccumulateInBoundsConstantOffsets(const DataLayout &DL, APInt &Offset) const
This is a wrapper around stripAndAccumulateConstantOffsets with the in-bounds requirement set to fals...
LLVM_ABI bool hasOneUser() const
Return true if there is exactly one user of this value.
bool hasOneUse() const
Return true if there is exactly one use of this value.
LLVMContext & getContext() const
All values hold a context through their type.
iterator_range< user_iterator > users()
bool hasUseList() const
Check if this Value has a use-list.
LLVM_ABI bool hasNUses(unsigned N) const
Return true if this Value has exactly N uses.
LLVM_ABI const Value * stripPointerCasts() const
Strip off pointer casts, all-zero GEPs and address space casts.
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.
LLVM_ABI uint64_t getPointerDereferenceableBytes(const DataLayout &DL, bool &CanBeNull, bool *CanBeFreed) const
Returns the number of bytes known to be dereferenceable for the pointer value.
Base class of all SIMD vector types.
ElementCount getElementCount() const
Return an ElementCount instance to represent the (possibly scalable) number of elements in the vector...
static LLVM_ABI VectorType * get(Type *ElementType, ElementCount EC)
This static method is the primary way to construct an VectorType.
Value handle that is nullable, but tries to track the Value.
constexpr ScalarTy getFixedValue() const
constexpr bool isScalable() const
Returns whether the quantity is scaled by a runtime quantity (vscale).
An efficient, type-erasing, non-owning reference to a callable.
TypeSize getSequentialElementStride(const DataLayout &DL) const
Type * getIndexedType() const
const ParentTy * getParent() const
reverse_self_iterator getReverseIterator()
self_iterator getIterator()
This class implements an extremely fast bulk output stream that can only output to a stream.
A raw_ostream that writes to an std::string.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
Abstract Attribute helper functions.
@ C
The default llvm calling convention, compatible with C.
LLVM_ABI Function * getOrInsertDeclaration(Module *M, ID id, ArrayRef< Type * > OverloadTys={})
Look up the Function declaration of the intrinsic id in the Module M.
BinaryOp_match< SpecificConstantMatch, SrcTy, TargetOpcode::G_SUB > m_Neg(const SrcTy &&Src)
Matches a register negated by a G_SUB.
BinaryOp_match< SrcTy, SpecificConstantMatch, TargetOpcode::G_XOR, true > m_Not(const SrcTy &&Src)
Matches a register not-ed by a G_XOR.
OneUse_match< SubPat > m_OneUse(const SubPat &SP)
match_combine_or< Ty... > m_CombineOr(const Ty &...Ps)
Combine pattern matchers matching any of Ps patterns.
match_combine_and< Ty... > m_CombineAnd(const Ty &...Ps)
Combine pattern matchers matching all of Ps patterns.
cst_pred_ty< is_all_ones > m_AllOnes()
Match an integer or vector with all bits set.
BinaryOp_match< LHS, RHS, Instruction::And > m_And(const LHS &L, const RHS &R)
PtrAdd_match< PointerOpTy, OffsetOpTy > m_PtrAdd(const PointerOpTy &PointerOp, const OffsetOpTy &OffsetOp)
Matches GEP with i8 source element type.
BinaryOp_match< LHS, RHS, Instruction::Add > m_Add(const LHS &L, const RHS &R)
CmpClass_match< LHS, RHS, FCmpInst > m_FCmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::AShr > m_AShr(const LHS &L, const RHS &R)
auto m_PtrToIntOrAddr(const OpTy &Op)
Matches PtrToInt or PtrToAddr.
OneOps_match< OpTy, Instruction::Freeze > m_Freeze(const OpTy &Op)
Matches FreezeInst.
auto m_Poison()
Match an arbitrary poison constant.
ap_match< APInt > m_APInt(const APInt *&Res)
Match a ConstantInt or splatted ConstantVector, binding the specified pointer to the contained APInt.
CastInst_match< OpTy, TruncInst > m_Trunc(const OpTy &Op)
Matches Trunc.
BinaryOp_match< LHS, RHS, Instruction::Xor > m_Xor(const LHS &L, const RHS &R)
br_match m_UnconditionalBr(BasicBlock *&Succ)
ap_match< APInt > m_APIntAllowPoison(const APInt *&Res)
Match APInt while allowing poison in splat vector constants.
auto m_ConstantExpr()
Match a constant expression or a constant that contains a constant expression.
specific_intval< false > m_SpecificInt(const APInt &V)
Match a specific integer value or vector with all elements equal to the value.
bool match(Val *V, const Pattern &P)
BinOpPred_match< LHS, RHS, is_idiv_op > m_IDiv(const LHS &L, const RHS &R)
Matches integer division operations.
match_bind< Instruction > m_Instruction(Instruction *&I)
Match an instruction, capturing it if we match.
specificval_ty m_Specific(const Value *V)
Match if we have a specific specified value.
DisjointOr_match< LHS, RHS > m_DisjointOr(const LHS &L, const RHS &R)
BinOpPred_match< LHS, RHS, is_right_shift_op > m_Shr(const LHS &L, const RHS &R)
Matches logical shift operations.
ap_match< APFloat > m_APFloat(const APFloat *&Res)
Match a ConstantFP or splatted ConstantVector, binding the specified pointer to the contained APFloat...
cst_pred_ty< is_nonnegative > m_NonNegative()
Match an integer or vector of non-negative values.
IntrinsicID_match m_Intrinsic()
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_Value(X))
ThreeOps_match< Cond, LHS, RHS, Instruction::Select > m_Select(const Cond &C, const LHS &L, const RHS &R)
Matches SelectInst.
auto m_BinOp()
Match an arbitrary binary operation and ignore it.
ExtractValue_match< Ind, Val_t > m_ExtractValue(const Val_t &V)
Match a single index ExtractValue instruction.
match_combine_or< CastInst_match< OpTy, UIToFPInst >, CastInst_match< OpTy, SIToFPInst > > m_IToFP(const OpTy &Op)
auto m_Value()
Match an arbitrary value and ignore it.
BinaryOp_match< LHS, RHS, Instruction::Mul > m_Mul(const LHS &L, const RHS &R)
auto m_Constant()
Match an arbitrary Constant and ignore it.
ContainsMatchingVectorElement_match< SPTy > m_ContainsMatchingVectorElement(const SPTy &SubPattern)
Match a vector constant where at least one of its elements matches the subpattern.
NNegZExt_match< OpTy > m_NNegZExt(const OpTy &Op)
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
Splat_match< T > m_ConstantSplat(const T &SubPattern)
Match a constant splat. TODO: Extend this to non-constant splats.
TwoOps_match< V1_t, V2_t, Instruction::ShuffleVector > m_Shuffle(const V1_t &v1, const V2_t &v2)
Matches ShuffleVectorInst independently of mask value.
ThreeOps_match< decltype(m_Value()), LHS, RHS, Instruction::Select, true > m_c_Select(const LHS &L, const RHS &R)
Match Select(C, LHS, RHS) or Select(C, RHS, LHS)
SpecificCmpClass_match< LHS, RHS, ICmpInst > m_SpecificICmp(CmpPredicate MatchPred, const LHS &L, const RHS &R)
CastInst_match< OpTy, ZExtInst > m_ZExt(const OpTy &Op)
Matches ZExt.
BinaryOp_match< LHS, RHS, Instruction::UDiv > m_UDiv(const LHS &L, const RHS &R)
match_immconstant_ty m_ImmConstant()
Match an arbitrary immediate Constant and ignore it.
SelectLike_match< CondTy, LTy, RTy > m_SelectLike(const CondTy &C, const LTy &TrueC, const RTy &FalseC)
Matches a value that behaves like a boolean-controlled select, i.e.
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".
CastOperator_match< OpTy, Instruction::BitCast > m_BitCast(const OpTy &Op)
Matches BitCast.
match_combine_or< CastInst_match< OpTy, SExtInst >, NNegZExt_match< OpTy > > m_SExtLike(const OpTy &Op)
Match either "sext" or "zext nneg".
BinaryOp_match< LHS, RHS, Instruction::SDiv > m_SDiv(const LHS &L, const RHS &R)
match_combine_or< OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoSignedWrap >, DisjointOr_match< LHS, RHS > > m_NSWAddLike(const LHS &L, const RHS &R)
Match either "add nsw" or "or disjoint".
m_Intrinsic_Ty< Opnd0 >::Ty m_Ctpop(const Opnd0 &Op0)
AnyBinaryOp_match< LHS, RHS, true > m_c_BinOp(const LHS &L, const RHS &R)
Matches a BinaryOperator with LHS and RHS in either order.
BinaryOp_match< LHS, RHS, Instruction::LShr > m_LShr(const LHS &L, const RHS &R)
CmpClass_match< LHS, RHS, ICmpInst > m_ICmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
match_combine_or< CastInst_match< OpTy, ZExtInst >, CastInst_match< OpTy, SExtInst > > m_ZExtOrSExt(const OpTy &Op)
BinOpPred_match< LHS, RHS, is_shift_op > m_Shift(const LHS &L, const RHS &R)
Matches shift operations.
BinaryOp_match< LHS, RHS, Instruction::Shl > m_Shl(const LHS &L, const RHS &R)
cstfp_pred_ty< is_non_zero_fp > m_NonZeroFP()
Match a floating-point non-zero.
m_Intrinsic_Ty< Opnd0 >::Ty m_VecReverse(const Opnd0 &Op0)
auto m_MaxOrMin(const Opnd0 &Op0, const Opnd1 &Op1)
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
brc_match< Cond_t, match_bind< BasicBlock >, match_bind< BasicBlock > > m_Br(const Cond_t &C, BasicBlock *&T, BasicBlock *&F)
BinaryOp_match< LHS, RHS, Instruction::SRem > m_SRem(const LHS &L, const RHS &R)
auto m_Undef()
Match an arbitrary undef constant.
BinaryOp_match< LHS, RHS, Instruction::Or > m_Or(const LHS &L, const RHS &R)
CastInst_match< OpTy, SExtInst > m_SExt(const OpTy &Op)
Matches SExt.
is_zero m_Zero()
Match any null constant or a vector with all elements equal to 0.
match_combine_or< OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoUnsignedWrap >, DisjointOr_match< LHS, RHS > > m_NUWAddLike(const LHS &L, const RHS &R)
Match either "add nuw" or "or disjoint".
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2 >::Ty m_VectorInsert(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2)
BinaryOp_match< LHS, RHS, Instruction::Sub > m_Sub(const LHS &L, const RHS &R)
match_unless< Ty > m_Unless(const Ty &M)
Match if the inner matcher does NOT match.
auto m_ConstantInt()
Match an arbitrary ConstantInt and ignore it.
initializer< Ty > init(const Ty &Val)
friend class Instruction
Iterator for Instructions in a `BasicBlock.
This is an optimization pass for GlobalISel generic memory operations.
auto drop_begin(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the first N elements excluded.
LLVM_ABI Intrinsic::ID getInverseMinMaxIntrinsic(Intrinsic::ID MinMaxID)
detail::zippy< detail::zip_shortest, T, U, Args... > zip(T &&t, U &&u, Args &&...args)
zip iterator for two or more iteratable types.
void stable_sort(R &&Range)
LLVM_ABI void initializeInstructionCombiningPassPass(PassRegistry &)
LLVM_ABI cl::opt< bool > ProfcheckDisableMetadataFixes
LLVM_ABI unsigned removeAllNonTerminatorAndEHPadInstructions(BasicBlock *BB)
Remove all instructions from a basic block other than its terminator and any present EH pad instructi...
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI Value * simplifyGEPInst(Type *SrcTy, Value *Ptr, ArrayRef< Value * > Indices, GEPNoWrapFlags NW, const SimplifyQuery &Q)
Given operands for a GetElementPtrInst, fold the result or return null.
LLVM_ABI Constant * getInitialValueOfAllocation(const Value *V, const TargetLibraryInfo *TLI, Type *Ty)
If this is a call to an allocation function that initializes memory to a fixed value,...
bool succ_empty(const Instruction *I)
LLVM_ABI Value * simplifyFreezeInst(Value *Op, const SimplifyQuery &Q)
Given an operand for a Freeze, see if we can fold the result.
LLVM_ABI FunctionPass * createInstructionCombiningPass()
LLVM_ABI void findDbgValues(Value *V, SmallVectorImpl< DbgVariableRecord * > &DbgVariableRecords)
Finds the dbg.values describing a value.
auto enumerate(FirstRange &&First, RestRanges &&...Rest)
Given two or more input ranges, returns a new range whose values are tuples (A, B,...
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI void salvageDebugInfo(const MachineRegisterInfo &MRI, MachineInstr &MI)
Assuming the instruction MI is going to be deleted, attempt to salvage debug users of MI by writing t...
auto successors(const MachineBasicBlock *BB)
LLVM_ABI Constant * ConstantFoldInstruction(const Instruction *I, const DataLayout &DL, const TargetLibraryInfo *TLI=nullptr)
ConstantFoldInstruction - Try to constant fold the specified instruction.
LLVM_ABI bool isRemovableAlloc(const CallBase *V, const TargetLibraryInfo *TLI)
Return true if this is a call to an allocation function that does not have side effects that we are r...
LLVM_ABI std::optional< StringRef > getAllocationFamily(const Value *I, const TargetLibraryInfo *TLI)
If a function is part of an allocation family (e.g.
OuterAnalysisManagerProxy< ModuleAnalysisManager, Function > ModuleAnalysisManagerFunctionProxy
Provide the ModuleAnalysisManager to Function proxy.
LLVM_ABI Value * lowerObjectSizeCall(IntrinsicInst *ObjectSize, const DataLayout &DL, const TargetLibraryInfo *TLI, bool MustSucceed)
Try to turn a call to @llvm.objectsize into an integer value of the given Type.
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI Value * simplifyInstructionWithOperands(Instruction *I, ArrayRef< Value * > NewOps, const SimplifyQuery &Q)
Like simplifyInstruction but the operands of I are replaced with NewOps.
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.
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...
gep_type_iterator gep_type_end(const User *GEP)
LLVM_ABI Value * getSplatValue(const Value *V)
Get splat value if the input is a splat vector or return nullptr.
LLVM_ABI Value * getReallocatedOperand(const CallBase *CB)
If this is a call to a realloc function, return the reallocated operand.
APFloat frexp(const APFloat &X, int &Exp, APFloat::roundingMode RM)
Equivalent of C standard library function.
RelativeUniformCounterPtr ValuesPtrExpr VTableAddr Value
LLVM_ABI bool isAllocLikeFn(const Value *V, const TargetLibraryInfo *TLI)
Tests if a value is a call or invoke to a library function that allocates memory (either malloc,...
LLVM_ABI bool handleUnreachableTerminator(Instruction *I, SmallVectorImpl< Value * > &PoisonedValues)
If a terminator in an unreachable basic block has an operand of type Instruction, transform it into p...
int countr_zero(T Val)
Count number of 0's from the least significant bit to the most stopping at the first 1.
LLVM_ABI void setBranchWeights(Instruction &I, ArrayRef< uint32_t > Weights, bool IsExpected, bool ElideAllZero=false)
Create a new branch_weights metadata node and add or overwrite a prof metadata reference to instructi...
LLVM_ABI bool matchSimpleRecurrence(const PHINode *P, BinaryOperator *&BO, Value *&Start, Value *&Step)
Attempt to match a simple first order recurrence cycle of the form: iv = phi Ty [Start,...
LLVM_ABI Value * simplifyAddInst(Value *LHS, Value *RHS, bool IsNSW, bool IsNUW, const SimplifyQuery &Q)
Given operands for an Add, fold the result or return null.
LLVM_ABI Constant * ConstantFoldConstant(const Constant *C, const DataLayout &DL, const TargetLibraryInfo *TLI=nullptr)
ConstantFoldConstant - Fold the constant using the specified DataLayout.
auto dyn_cast_or_null(const Y &Val)
constexpr bool has_single_bit(T Value) noexcept
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI bool isInstructionTriviallyDead(Instruction *I, const TargetLibraryInfo *TLI=nullptr)
Return true if the result produced by the instruction is not used, and the instruction will return.
LLVM_ABI bool isSplatValue(const Value *V, int Index=-1, unsigned Depth=0)
Return true if each element of the vector value V is poisoned or equal to every other non-poisoned el...
LLVM_ABI Value * emitGEPOffset(IRBuilderBase *Builder, const DataLayout &DL, User *GEP, bool NoAssumptions=false)
Given a getelementptr instruction/constantexpr, emit the code necessary to compute the offset from th...
constexpr unsigned MaxAnalysisRecursionDepth
auto reverse(ContainerTy &&C)
bool isModSet(const ModRefInfo MRI)
FPClassTest
Floating-point class tests, supported by 'is_fpclass' intrinsic.
LLVM_ABI bool LowerDbgDeclare(Function &F)
Lowers dbg.declare records into appropriate set of dbg.value records.
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.
generic_gep_type_iterator<> gep_type_iterator
LLVM_ABI void ConvertDebugDeclareToDebugValue(DbgVariableRecord *DVR, StoreInst *SI, DIBuilder &Builder)
Inserts a dbg.value record before a store to an alloca'd value that has an associated dbg....
LLVM_ABI void salvageDebugInfoForDbgValues(Instruction &I, ArrayRef< DbgVariableRecord * > DPInsns)
Implementation of salvageDebugInfo, applying only to instructions in Insns, rather than all debug use...
LLVM_ABI Constant * ConstantFoldCastOperand(unsigned Opcode, Constant *C, Type *DestTy, const DataLayout &DL)
Attempt to constant fold a cast with the specified operand.
LLVM_ABI bool canCreateUndefOrPoison(const Operator *Op, bool ConsiderFlagsAndMetadata=true)
canCreateUndefOrPoison returns true if Op can create undef or poison from non-undef & non-poison oper...
LLVM_ABI EHPersonality classifyEHPersonality(const Value *Pers)
See if the given exception handling personality function is one that we understand.
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 Constant * ConstantFoldBinaryOpOperands(unsigned Opcode, Constant *LHS, Constant *RHS, const DataLayout &DL)
Attempt to constant fold a binary operation with the specified operands.
LLVM_ABI bool replaceAllDbgUsesWith(Instruction &From, Value &To, Instruction &DomPoint, DominatorTree &DT)
Point debug users of From to To or salvage them.
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.
constexpr int PoisonMaskElem
auto drop_end(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the last N elements excluded.
ModRefInfo
Flags indicating whether a memory access modifies or references memory.
@ Ref
The access may reference the value stored in memory.
@ ModRef
The access may reference and may modify the value stored in memory.
@ Mod
The access may modify the value stored in memory.
@ NoModRef
The access neither references nor modifies the value stored in memory.
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
bool isSafeToSpeculativelyExecuteWithVariableReplaced(const Instruction *I, bool IgnoreUBImplyingAttrs=true)
Don't use information from its non-constant operands.
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.
ArrayRef(const T &OneElt) -> ArrayRef< T >
LLVM_ABI Value * getFreedOperand(const CallBase *CB, const TargetLibraryInfo *TLI)
If this if a call to a free function, return the freed operand.
constexpr unsigned BitWidth
LLVM_ABI bool isGuaranteedToTransferExecutionToSuccessor(const Instruction *I)
Return true if this function can prove that the instruction I will always transfer execution to one o...
LLVM_ABI Constant * getLosslessInvCast(Constant *C, Type *InvCastTo, unsigned CastOp, const DataLayout &DL, PreservedCastFlags *Flags=nullptr)
Try to cast C to InvC losslessly, satisfying CastOp(InvC) equals C, or CastOp(InvC) is a refined valu...
LLVM_ABI bool extractBranchWeights(const MDNode *ProfileData, SmallVectorImpl< uint32_t > &Weights)
Extract branch weights from MD_prof metadata.
auto count_if(R &&Range, UnaryPredicate P)
Wrapper function around std::count_if to count the number of times an element satisfying a given pred...
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
gep_type_iterator gep_type_begin(const User *GEP)
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.
bool equal(L &&LRange, R &&RRange)
Wrapper function around std::equal to detect if pair-wise elements between two ranges are the same.
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
AAResults AliasAnalysis
Temporary typedef for legacy code that uses a generic AliasAnalysis pointer or reference.
static auto filterDbgVars(iterator_range< simple_ilist< DbgRecord >::iterator > R)
Filter the DbgRecord range to DbgVariableRecord types only and downcast.
LLVM_ABI void initializeInstCombine(PassRegistry &)
Initialize all passes linked into the InstCombine library.
LLVM_ABI void findDbgUsers(Value *V, SmallVectorImpl< DbgVariableRecord * > &DbgVariableRecords)
Finds the debug info records describing a value.
LLVM_ABI Constant * ConstantFoldBinaryInstruction(unsigned Opcode, Constant *V1, Constant *V2)
bool isRefSet(const ModRefInfo MRI)
LLVM_ABI std::optional< bool > isImpliedCondition(const Value *LHS, const Value *RHS, const DataLayout &DL, bool LHSIsTrue=true, unsigned Depth=0)
Return true if RHS is known to be implied true by LHS.
LLVM_ABI void reportFatalUsageError(Error Err)
Report a fatal error that does not indicate a bug in LLVM.
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
unsigned countMinLeadingOnes() const
Returns the minimum number of leading one bits.
unsigned getBitWidth() const
Get the bit width of this value.
unsigned countMinLeadingZeros() const
Returns the minimum number of leading zero bits.
A CRTP mix-in to automatically provide informational APIs needed for passes.
SimplifyQuery getWithInstruction(const Instruction *I) const