35#define DEBUG_TYPE "instcombine"
54 unsigned Opc =
I->getOpcode();
56 case Instruction::Add:
57 case Instruction::Sub:
58 case Instruction::Mul:
59 case Instruction::And:
61 case Instruction::Xor:
62 case Instruction::AShr:
63 case Instruction::LShr:
64 case Instruction::Shl:
65 case Instruction::UDiv:
66 case Instruction::URem: {
72 if (
Opc == Instruction::LShr ||
Opc == Instruction::AShr)
76 case Instruction::Trunc:
77 case Instruction::ZExt:
78 case Instruction::SExt:
82 if (
I->getOperand(0)->getType() == Ty)
83 return I->getOperand(0);
88 Opc == Instruction::SExt);
91 if (Trunc->getType()->getScalarSizeInBits() <=
92 Ty->getScalarSizeInBits()) {
93 NewTrunc->setHasNoSignedWrap(Trunc->hasNoSignedWrap());
94 NewTrunc->setHasNoUnsignedWrap(Trunc->hasNoUnsignedWrap());
97 if (Trunc->hasNoUnsignedWrap())
102 case Instruction::Select: {
110 case Instruction::PHI: {
121 case Instruction::FPToUI:
122 case Instruction::FPToSI:
124 I->getOperand(0), Ty);
126 case Instruction::Call:
128 switch (
II->getIntrinsicID()) {
131 case Intrinsic::vscale: {
133 I->getModule(), Intrinsic::vscale, {Ty});
137 case Intrinsic::umin:
138 case Intrinsic::umax:
139 case Intrinsic::smin:
140 case Intrinsic::smax: {
146 I->getModule(),
II->getIntrinsicID(), {Ty});
150 case Intrinsic::abs: {
154 I->getModule(),
II->getIntrinsicID(), {Ty});
156 {Arg, ConstantInt::getFalse(I->getContext())});
162 case Instruction::ShuffleVector: {
185 Processed[V] = Result;
199InstCombinerImpl::isEliminableCastPair(
const CastInst *CI1,
216 if ((Res == Instruction::IntToPtr && SrcTy != DstIntPtrTy) ||
217 (Res == Instruction::PtrToInt && DstTy != SrcIntPtrTy))
239 if (CSrc->hasOneUse())
252 if (!Cmp || Cmp->getOperand(0)->getType() != Sel->getType() ||
258 if (CI.
getOpcode() != Instruction::BitCast ||
288 if (SrcTy && DestTy &&
289 SrcTy->getNumElements() == DestTy->getNumElements() &&
290 SrcTy->getPrimitiveSizeInBits() == DestTy->getPrimitiveSizeInBits()) {
303class TypeEvaluationHelper {
308 [[nodiscard]]
static bool canEvaluateTruncated(
Value *V,
Type *Ty,
314 [[nodiscard]]
static bool canEvaluateZExtd(
Value *V,
Type *Ty,
315 unsigned &BitsToClear,
322 [[nodiscard]]
static bool canEvaluateSExtd(
Value *V,
Type *Ty);
327 [[nodiscard]]
static bool canAlwaysEvaluateInType(
Value *V,
Type *Ty);
330 [[nodiscard]]
bool allPendingVisited()
const {
332 [
this](
Value *V) {
return Visited.contains(V); });
340 if (canAlwaysEvaluateInType(V, Ty))
349 const auto [It,
Inserted] = Visited.insert({
V,
false});
366 return It->getSecond();
427 if (!
I->hasOneUse()) {
428 for (Use &U :
I->uses()) {
436 Pending.push_back(
U.getUser());
440 const bool Result = Pred(V, Ty);
449 [[nodiscard]]
bool canNotEvaluateInType(
Value *V,
Type *Ty);
451 [[nodiscard]]
bool canEvaluateTruncatedImpl(
Value *V,
Type *Ty,
452 InstCombinerImpl &IC,
454 [[nodiscard]]
bool canEvaluateTruncatedPred(
Value *V,
Type *Ty,
455 InstCombinerImpl &IC,
457 [[nodiscard]]
bool canEvaluateZExtdImpl(
Value *V,
Type *Ty,
458 unsigned &BitsToClear,
459 InstCombinerImpl &IC,
461 [[nodiscard]]
bool canEvaluateSExtdImpl(
Value *V,
Type *Ty);
462 [[nodiscard]]
bool canEvaluateSExtdPred(
Value *V,
Type *Ty);
466 SmallDenseMap<Value *, bool, 8> Visited;
469 SmallVector<Value *, 8> Pending;
476bool TypeEvaluationHelper::canAlwaysEvaluateInType(
Value *V,
Type *Ty) {
490bool TypeEvaluationHelper::canNotEvaluateInType(
Value *V,
Type *Ty) {
512bool TypeEvaluationHelper::canEvaluateTruncated(
Value *V,
Type *Ty,
515 TypeEvaluationHelper TYH;
516 return TYH.canEvaluateTruncatedImpl(V, Ty, IC, CxtI) &&
519 TYH.allPendingVisited();
522bool TypeEvaluationHelper::canEvaluateTruncatedImpl(
Value *V,
Type *Ty,
525 return canEvaluate(V, Ty, [
this, &IC, CxtI](
Value *V,
Type *Ty) {
526 return canEvaluateTruncatedPred(V, Ty, IC, CxtI);
530bool TypeEvaluationHelper::canEvaluateTruncatedPred(
Value *V,
Type *Ty,
534 Type *OrigTy =
V->getType();
535 switch (
I->getOpcode()) {
536 case Instruction::Add:
537 case Instruction::Sub:
538 case Instruction::Mul:
539 case Instruction::And:
540 case Instruction::Or:
541 case Instruction::Xor:
543 return canEvaluateTruncatedImpl(
I->getOperand(0), Ty, IC, CxtI) &&
544 canEvaluateTruncatedImpl(
I->getOperand(1), Ty, IC, CxtI);
546 case Instruction::UDiv:
547 case Instruction::URem: {
557 return canEvaluateTruncatedImpl(
I->getOperand(0), Ty, IC, CxtI) &&
558 canEvaluateTruncatedImpl(
I->getOperand(1), Ty, IC, CxtI);
562 case Instruction::Shl: {
569 return canEvaluateTruncatedImpl(
I->getOperand(0), Ty, IC, CxtI) &&
570 canEvaluateTruncatedImpl(
I->getOperand(1), Ty, IC, CxtI);
573 case Instruction::LShr: {
588 auto DemandedBits = Trunc->getType()->getScalarSizeInBits();
590 return canEvaluateTruncatedImpl(
I->getOperand(0), Ty, IC, CxtI) &&
591 canEvaluateTruncatedImpl(
I->getOperand(1), Ty, IC, CxtI);
594 return canEvaluateTruncatedImpl(
I->getOperand(0), Ty, IC, CxtI) &&
595 canEvaluateTruncatedImpl(
I->getOperand(1), Ty, IC, CxtI);
599 case Instruction::AShr: {
609 unsigned ShiftedBits = OrigBitWidth -
BitWidth;
612 return canEvaluateTruncatedImpl(
I->getOperand(0), Ty, IC, CxtI) &&
613 canEvaluateTruncatedImpl(
I->getOperand(1), Ty, IC, CxtI);
616 case Instruction::Trunc:
619 case Instruction::ZExt:
620 case Instruction::SExt:
624 case Instruction::Select: {
626 return canEvaluateTruncatedImpl(
SI->getTrueValue(), Ty, IC, CxtI) &&
627 canEvaluateTruncatedImpl(
SI->getFalseValue(), Ty, IC, CxtI);
629 case Instruction::PHI: {
636 return canEvaluateTruncatedImpl(IncValue, Ty, IC, CxtI);
639 case Instruction::FPToUI:
640 case Instruction::FPToSI: {
647 Semantics,
I->getOpcode() == Instruction::FPToSI);
650 case Instruction::ShuffleVector:
651 return canEvaluateTruncatedImpl(
I->getOperand(0), Ty, IC, CxtI) &&
652 canEvaluateTruncatedImpl(
I->getOperand(1), Ty, IC, CxtI);
654 case Instruction::Call: {
659 return canEvaluateTruncatedImpl(AbsOp, Ty, IC, CxtI);
666 Value *Op0 = MM->getLHS();
667 Value *Op1 = MM->getRHS();
669 if (MM->isSigned()) {
680 return canEvaluateTruncatedImpl(Op0, Ty, IC, CxtI) &&
681 canEvaluateTruncatedImpl(Op1, Ty, IC, CxtI);
704 Value *VecInput =
nullptr;
713 unsigned VecWidth = VecType->getPrimitiveSizeInBits();
715 unsigned ShiftAmount = ShiftVal ? ShiftVal->
getZExtValue() : 0;
717 if ((VecWidth % DestWidth != 0) || (ShiftAmount % DestWidth != 0))
722 unsigned NumVecElts = VecWidth / DestWidth;
723 if (VecType->getElementType() != DestType) {
728 unsigned Elt = ShiftAmount / DestWidth;
730 Elt = NumVecElts - 1 - Elt;
750 Type *SrcType = Src->getType();
756 unsigned DstBits = DstType->getScalarSizeInBits();
757 unsigned TruncRatio = SrcBits / DstBits;
758 if ((SrcBits % DstBits) != 0)
763 const APInt *ShiftAmount =
nullptr;
771 auto VecElts = VecOpTy->getElementCount();
773 uint64_t BitCastNumElts = VecElts.getKnownMinValue() * TruncRatio;
776 if (Cst->
uge(std::numeric_limits<uint64_t>::max() / TruncRatio))
780 ? (VecOpIdx + 1) * TruncRatio - 1
781 : VecOpIdx * TruncRatio;
787 if (ShiftAmount->
uge(SrcBits) || ShiftAmount->
urem(DstBits) != 0)
793 assert(IdxOfs < TruncRatio &&
794 "IdxOfs is expected to be less than TruncRatio.");
799 assert(BitCastNumElts <= std::numeric_limits<uint32_t>::max() &&
813 "Don't narrow to an illegal scalar type");
825 BinaryOperator *Or0, *Or1;
829 Value *ShVal0, *ShVal1, *ShAmt0, *ShAmt1;
836 if (Or0->
getOpcode() == BinaryOperator::LShr) {
842 Or1->
getOpcode() == BinaryOperator::LShr &&
843 "Illegal or(shift,shift) pair");
852 unsigned MaxShiftAmountWidth =
Log2_32(NarrowWidth);
853 APInt HiBitMask = ~APInt::getLowBitsSet(WideWidth, MaxShiftAmountWidth);
860 if (ShVal0 != ShVal1)
866 unsigned Mask = Width - 1;
879 Value *ShAmt = matchShiftAmount(ShAmt0, ShAmt1, NarrowWidth);
882 ShAmt = matchShiftAmount(ShAmt1, ShAmt0, NarrowWidth);
900 Value *NarrowShAmt =
Builder.CreateZExtOrTrunc(ShAmt, DestTy);
903 X =
Y =
Builder.CreateTrunc(ShVal0, DestTy);
904 if (ShVal0 != ShVal1)
905 Y =
Builder.CreateTrunc(ShVal1, DestTy);
906 Intrinsic::ID IID = IsFshl ? Intrinsic::fshl : Intrinsic::fshr;
923 BinaryOperator *BinOp;
930 case Instruction::And:
931 case Instruction::Or:
932 case Instruction::Xor:
933 case Instruction::Add:
934 case Instruction::Sub:
935 case Instruction::Mul: {
962 case Instruction::LShr:
963 case Instruction::AShr: {
968 unsigned MaxShiftAmt = SrcWidth - DestWidth;
972 APInt(SrcWidth, MaxShiftAmt)))) {
974 bool IsExact = OldShift->isExact();
979 OldShift->getOpcode() == Instruction::AShr
980 ?
Builder.CreateAShr(
A, ShAmt, OldShift->getName(), IsExact)
981 :
Builder.CreateLShr(
A, ShAmt, OldShift->getName(), IsExact);
991 if (Instruction *NarrowOr = narrowFunnelShift(Trunc))
1013 Value *NarrowOp = Builder.CreateTrunc(ShufVec, NewTruncTy);
1028 assert((Opcode == Instruction::Trunc || Opcode == Instruction::FPTrunc) &&
1029 "Unexpected instruction for shrinking");
1050 Type *DestTy = Trunc.
getType(), *SrcTy = Src->getType();
1052 unsigned SrcWidth = SrcTy->getScalarSizeInBits();
1058 if ((DestTy->
isVectorTy() || shouldChangeType(SrcTy, DestTy)) &&
1059 TypeEvaluationHelper::canEvaluateTruncated(Src, DestTy, *
this, &Trunc)) {
1064 dbgs() <<
"ICE: EvaluateInDifferentType converting expression type"
1077 if (DestWidth * 2 < SrcWidth) {
1078 auto *NewDestTy = DestITy->getExtendedType();
1079 if (shouldChangeType(SrcTy, NewDestTy) &&
1080 TypeEvaluationHelper::canEvaluateTruncated(Src, NewDestTy, *
this,
1083 dbgs() <<
"ICE: EvaluateInDifferentType converting expression type"
1084 " to reduce the width of operand of"
1097 if (DestWidth == 1) {
1120 Constant *One = ConstantInt::get(SrcTy,
APInt(SrcWidth, 1));
1128 Constant *One = ConstantInt::get(SrcTy,
APInt(SrcWidth, 1));
1164 A->getType() == DestTy &&
B->getType() == DestTy) {
1166 Trunc,
Builder.CreateBinaryIntrinsic(Intrinsic::uadd_sat,
A,
B));
1173 A->getType() == DestTy &&
B->getType() == DestTy) {
1175 Trunc,
Builder.CreateBinaryIntrinsic(Intrinsic::usub_sat,
A,
B));
1179 unsigned AWidth =
A->getType()->getScalarSizeInBits();
1180 unsigned MaxShiftAmt = SrcWidth - std::max(DestWidth, AWidth);
1182 bool IsExact = OldSh->isExact();
1187 APInt(SrcWidth, MaxShiftAmt)))) {
1188 auto GetNewShAmt = [&](
unsigned Width) {
1189 Constant *MaxAmt = ConstantInt::get(SrcTy, Width - 1,
false);
1198 if (
A->getType() == DestTy) {
1199 Constant *ShAmt = GetNewShAmt(DestWidth);
1201 return IsExact ? BinaryOperator::CreateExactAShr(
A, ShAmt)
1202 : BinaryOperator::CreateAShr(
A, ShAmt);
1206 if (Src->hasOneUse()) {
1207 Constant *ShAmt = GetNewShAmt(AWidth);
1224 if (Src->hasOneUse() &&
1232 APInt Threshold =
APInt(
C->getType()->getScalarSizeInBits(), DestWidth);
1234 Value *NewTrunc =
Builder.CreateTrunc(
A, DestTy,
A->getName() +
".tr");
1243 if (SrcTy->isIntegerTy() &&
isPowerOf2_64(SrcTy->getPrimitiveSizeInBits()) &&
1251 APInt UpperBound =
C->getUniqueInteger();
1254 if (!UpperBound.
isZero() && UpperBound - 1 == TruncatedMax) {
1256 {ConstantInt::get(SrcTy, 0),
A});
1258 Intrinsic::smin, {SrcTy},
1259 {
SMax, ConstantInt::get(SrcTy, TruncatedMax)});
1272 unsigned AWidth =
A->getType()->getScalarSizeInBits();
1273 if (AWidth == DestWidth && AWidth >
Log2_32(SrcWidth)) {
1274 Value *WidthDiff = ConstantInt::get(
A->getType(), SrcWidth - AWidth);
1277 return BinaryOperator::CreateAdd(NarrowCtlz, WidthDiff);
1287 if (
Log2_32(*MaxVScale) < DestWidth)
1299 Trunc,
Builder.CreateIntrinsic(DestTy, CI->getIntrinsicID(),
1300 {CI->getLHS(), CI->getRHS()}));
1302 if (DestWidth == 1 &&
1345 return Changed ? &Trunc :
nullptr;
1365 Value *In = Cmp->getOperand(0);
1366 Value *Sh = ConstantInt::get(In->getType(),
1367 In->getType()->getScalarSizeInBits() - 1);
1368 In = Builder.CreateLShr(In, Sh, In->getName() +
".lobit");
1369 if (In->getType() != Zext.
getType())
1370 In = Builder.CreateIntCast(In, Zext.
getType(),
false );
1380 if (Op1CV->
isZero() && Cmp->isEquality()) {
1385 uint32_t ShAmt = KnownZeroMask.logBase2();
1386 bool IsExpectShAmt = KnownZeroMask.isPowerOf2() &&
1388 if (IsExpectShAmt &&
1389 (Cmp->getOperand(0)->getType() == Zext.
getType() ||
1391 Value *In = Cmp->getOperand(0);
1395 In = Builder.CreateLShr(In, ConstantInt::get(In->getType(), ShAmt),
1396 In->getName() +
".lobit");
1401 In =
Builder.CreateXor(In, ConstantInt::get(
In->getType(), 1));
1412 if (
Cmp->isEquality()) {
1421 Value *Shift =
And->getOperand(
X ==
And->getOperand(0) ? 1 : 0);
1428 Builder.CreateAnd(Lshr, ConstantInt::get(
X->getType(), 1));
1456bool TypeEvaluationHelper::canEvaluateZExtd(
Value *V,
Type *Ty,
1457 unsigned &BitsToClear,
1460 TypeEvaluationHelper TYH;
1461 return TYH.canEvaluateZExtdImpl(V, Ty, BitsToClear, IC, CxtI);
1463bool TypeEvaluationHelper::canEvaluateZExtdImpl(
Value *V,
Type *Ty,
1464 unsigned &BitsToClear,
1468 if (canAlwaysEvaluateInType(V, Ty))
1472 if (canNotEvaluateInType(V, Ty))
1477 switch (
I->getOpcode()) {
1478 case Instruction::ZExt:
1479 case Instruction::SExt:
1480 case Instruction::Trunc:
1482 case Instruction::And:
1483 case Instruction::Or:
1484 case Instruction::Xor:
1485 case Instruction::Add:
1486 case Instruction::Sub:
1487 case Instruction::Mul:
1488 if (!canEvaluateZExtdImpl(
I->getOperand(0), Ty, BitsToClear, IC, CxtI) ||
1489 !canEvaluateZExtdImpl(
I->getOperand(1), Ty, Tmp, IC, CxtI))
1492 if (BitsToClear == 0 && Tmp == 0)
1497 if (Tmp == 0 &&
I->isBitwiseLogicOp()) {
1500 unsigned VSize =
V->getType()->getScalarSizeInBits();
1506 if (
I->getOpcode() == Instruction::And)
1515 case Instruction::Shl: {
1520 if (!canEvaluateZExtdImpl(
I->getOperand(0), Ty, BitsToClear, IC, CxtI))
1522 BitsToClear = ShiftAmt < BitsToClear ? BitsToClear - ShiftAmt : 0;
1527 case Instruction::LShr: {
1532 if (!canEvaluateZExtdImpl(
I->getOperand(0), Ty, BitsToClear, IC, CxtI))
1534 BitsToClear += ShiftAmt;
1535 if (BitsToClear >
V->getType()->getScalarSizeInBits())
1536 BitsToClear =
V->getType()->getScalarSizeInBits();
1542 case Instruction::Select:
1543 if (!canEvaluateZExtdImpl(
I->getOperand(1), Ty, Tmp, IC, CxtI) ||
1544 !canEvaluateZExtdImpl(
I->getOperand(2), Ty, BitsToClear, IC, CxtI) ||
1551 case Instruction::PHI: {
1567 case Instruction::Call:
1571 if (
II->getIntrinsicID() == Intrinsic::vscale)
1595 Type *SrcTy = Src->getType(), *DestTy = Zext.
getType();
1598 if (SrcTy->isIntOrIntVectorTy(1) && Zext.
hasNonNeg())
1602 unsigned BitsToClear;
1603 if (shouldChangeType(SrcTy, DestTy) &&
1604 TypeEvaluationHelper::canEvaluateZExtd(Src, DestTy, BitsToClear, *
this,
1607 "Can't clear more bits than in SrcTy");
1611 dbgs() <<
"ICE: EvaluateInDifferentType converting expression type"
1612 " to avoid zero extend: "
1619 if (
SrcOp->hasOneUse())
1622 uint32_t SrcBitsKept = SrcTy->getScalarSizeInBits() - BitsToClear;
1635 return BinaryOperator::CreateAnd(Res,
C);
1646 Value *
A = CSrc->getOperand(0);
1647 unsigned SrcSize =
A->getType()->getScalarSizeInBits();
1648 unsigned MidSize = CSrc->getType()->getScalarSizeInBits();
1654 if (SrcSize < DstSize) {
1656 Constant *AndConst = ConstantInt::get(
A->getType(), AndValue);
1661 if (SrcSize == DstSize) {
1663 return BinaryOperator::CreateAnd(
A, ConstantInt::get(
A->getType(),
1666 if (SrcSize > DstSize) {
1669 return BinaryOperator::CreateAnd(Trunc,
1670 ConstantInt::get(Trunc->
getType(),
1676 return transformZExtICmp(Cmp, Zext);
1684 X->getType() == DestTy) {
1686 return BinaryOperator::CreateXor(
Builder.CreateAnd(
X, ZC), ZC);
1695 X->getType() == DestTy) {
1697 return BinaryOperator::CreateAnd(
X, ZextC);
1703 X->getType() == DestTy) {
1715 unsigned TypeWidth = Src->getType()->getScalarSizeInBits();
1716 if (
Log2_32(*MaxVScale) < TypeWidth)
1725 SrcTy->getScalarSizeInBits() >
1744 Value *Op0 = Cmp->getOperand(0), *Op1 = Cmp->getOperand(1);
1755 Value *In = Builder.CreateAShr(Op0, Sh, Op0->
getName() +
".lobit");
1756 if (In->getType() != Sext.
getType())
1757 In = Builder.CreateIntCast(In, Sext.
getType(),
true );
1766 if (Cmp->hasOneUse() &&
1767 Cmp->isEquality() && (Op1C->isZero() || Op1C->getValue().isPowerOf2())){
1771 if (KnownZeroMask.isPowerOf2()) {
1772 Value *In = Cmp->getOperand(0);
1775 if (!Op1C->isZero() && Op1C->getValue() != KnownZeroMask) {
1785 unsigned ShiftAmt = KnownZeroMask.countr_zero();
1789 ConstantInt::get(
In->getType(), ShiftAmt));
1799 unsigned ShiftAmt = KnownZeroMask.countl_zero();
1803 ConstantInt::get(
In->getType(), ShiftAmt));
1806 In =
Builder.CreateAShr(In, ConstantInt::get(
In->getType(),
1807 KnownZeroMask.getBitWidth() - 1),
"sext");
1827bool TypeEvaluationHelper::canEvaluateSExtd(
Value *V,
Type *Ty) {
1828 TypeEvaluationHelper TYH;
1829 return TYH.canEvaluateSExtdImpl(V, Ty) && TYH.allPendingVisited();
1832bool TypeEvaluationHelper::canEvaluateSExtdImpl(
Value *V,
Type *Ty) {
1833 return canEvaluate(V, Ty, [
this](
Value *V,
Type *Ty) {
1834 return canEvaluateSExtdPred(V, Ty);
1838bool TypeEvaluationHelper::canEvaluateSExtdPred(
Value *V,
Type *Ty) {
1840 "Can't sign extend type to a smaller type");
1843 switch (
I->getOpcode()) {
1844 case Instruction::SExt:
1845 case Instruction::ZExt:
1846 case Instruction::Trunc:
1848 case Instruction::And:
1849 case Instruction::Or:
1850 case Instruction::Xor:
1851 case Instruction::Add:
1852 case Instruction::Sub:
1853 case Instruction::Mul:
1855 return canEvaluateSExtdImpl(
I->getOperand(0), Ty) &&
1856 canEvaluateSExtdImpl(
I->getOperand(1), Ty);
1861 case Instruction::Select:
1862 return canEvaluateSExtdImpl(
I->getOperand(1), Ty) &&
1863 canEvaluateSExtdImpl(
I->getOperand(2), Ty);
1865 case Instruction::PHI: {
1871 if (!canEvaluateSExtdImpl(IncValue, Ty))
1893 Type *SrcTy = Src->getType(), *DestTy = Sext.
getType();
1900 CI->setNonNeg(
true);
1905 bool ShouldExtendExpression =
true;
1906 Value *TruncSrc =
nullptr;
1911 ShouldExtendExpression =
false;
1912 if (ShouldExtendExpression && shouldChangeType(SrcTy, DestTy) &&
1913 TypeEvaluationHelper::canEvaluateSExtd(Src, DestTy)) {
1916 dbgs() <<
"ICE: EvaluateInDifferentType converting expression type"
1917 " to avoid sign extend: "
1928 Value *ShAmt = ConstantInt::get(DestTy, DestBitSize - SrcBitSize);
1929 return BinaryOperator::CreateAShr(
Builder.CreateShl(Res, ShAmt,
"sext"),
1937 unsigned XBitSize =
X->getType()->getScalarSizeInBits();
1942 ResTrunc->setHasNoSignedWrap(
true);
1947 if (Src->hasOneUse() &&
X->getType() == DestTy) {
1949 Constant *ShAmt = ConstantInt::get(DestTy, DestBitSize - SrcBitSize);
1950 return BinaryOperator::CreateAShr(
Builder.CreateShl(
X, ShAmt), ShAmt);
1958 if (Src->hasOneUse() &&
1967 return transformSExtICmp(Cmp, Sext);
1984 Constant *BA =
nullptr, *CA =
nullptr;
1990 assert(WideCurrShAmt &&
"Constant folding of ImmConstant cannot fail");
1999 return BinaryOperator::CreateAShr(
A, NewShAmt);
2007 Type *XTy =
X->getType();
2009 Constant *ShlAmtC = ConstantInt::get(XTy, XBitSize - SrcBitSize);
2010 Constant *AshrAmtC = ConstantInt::get(XTy, XBitSize - 1);
2012 return BinaryOperator::CreateAShr(
Builder.CreateShl(
X, ShlAmtC),
2026 if (
Log2_32(*MaxVScale) < (SrcBitSize - 1))
2037 Sext,
Builder.CreateIntrinsic(DestTy, CI->getIntrinsicID(),
2038 {CI->getLHS(), CI->getRHS()}));
2043 X->getType() == DestTy) {
2061 bool PreferBFloat) {
2082 if (Ty->getScalarType()->isPPC_FP128Ty())
2102 Type *MinType =
nullptr;
2104 unsigned NumElts = CVVTy->getNumElements();
2108 for (
unsigned I = 0;
I != NumElts; ++
I) {
2133 return FPExt->getOperand(0)->getType();
2161 return V->getType();
2167 Type *SrcTy = V->getType();
2168 assert(SrcTy->isIntOrIntVectorTy() &&
"Expected an integer type");
2169 int SrcSize = (int)SrcTy->getScalarSizeInBits() - IsSigned;
2174 if (SrcSize <= DestNumSigBits)
2183 int SrcNumSigBits =
F->getType()->getFPMantissaWidth();
2190 if (SrcNumSigBits > 0 && DestNumSigBits > 0 &&
2191 SrcNumSigBits <= DestNumSigBits)
2198 int SigBits = (int)SrcTy->getScalarSizeInBits() -
2201 if (SigBits <= DestNumSigBits)
2208 if (SigBits <= DestNumSigBits)
2217 assert((Opcode == CastInst::SIToFP || Opcode == CastInst::UIToFP) &&
2219 Value *Src =
I.getOperand(0);
2220 Type *FPTy =
I.getType();
2237 if (BO && BO->hasOneUse()) {
2240 unsigned OpWidth = BO->getType()->getFPMantissaWidth();
2243 unsigned SrcWidth = std::max(LHSWidth, RHSWidth);
2244 unsigned DstWidth = Ty->getFPMantissaWidth();
2245 switch (BO->getOpcode()) {
2247 case Instruction::FAdd:
2248 case Instruction::FSub:
2267 if (OpWidth >= 2*DstWidth+1 && DstWidth >= SrcWidth) {
2268 Value *LHS =
Builder.CreateFPTrunc(BO->getOperand(0), Ty);
2269 Value *RHS =
Builder.CreateFPTrunc(BO->getOperand(1), Ty);
2275 case Instruction::FMul:
2281 if (OpWidth >= LHSWidth + RHSWidth && DstWidth >= SrcWidth) {
2282 Value *LHS =
Builder.CreateFPTrunc(BO->getOperand(0), Ty);
2283 Value *RHS =
Builder.CreateFPTrunc(BO->getOperand(1), Ty);
2287 case Instruction::FDiv:
2294 if (OpWidth >= 2*DstWidth && DstWidth >= SrcWidth) {
2295 Value *LHS =
Builder.CreateFPTrunc(BO->getOperand(0), Ty);
2296 Value *RHS =
Builder.CreateFPTrunc(BO->getOperand(1), Ty);
2300 case Instruction::FRem: {
2305 if (SrcWidth == OpWidth)
2308 if (LHSWidth == SrcWidth) {
2309 LHS =
Builder.CreateFPTrunc(BO->getOperand(0), LHSMinType);
2310 RHS =
Builder.CreateFPTrunc(BO->getOperand(1), LHSMinType);
2312 LHS =
Builder.CreateFPTrunc(BO->getOperand(0), RHSMinType);
2313 RHS =
Builder.CreateFPTrunc(BO->getOperand(1), RHSMinType);
2316 Value *ExactResult =
Builder.CreateFRemFMF(LHS, RHS, BO);
2325 if (
Op &&
Op->hasOneUse()) {
2328 FMF &= FPMO->getFastMathFlags();
2340 X->getType() == Ty) {
2344 Builder.CreateSelectFMF(
Cond,
X, NarrowY, FMF,
"narrow.sel",
Op);
2348 X->getType() == Ty) {
2352 Builder.CreateSelectFMF(
Cond, NarrowY,
X, FMF,
"narrow.sel",
Op);
2358 switch (
II->getIntrinsicID()) {
2360 case Intrinsic::ceil:
2361 case Intrinsic::fabs:
2362 case Intrinsic::floor:
2363 case Intrinsic::nearbyint:
2364 case Intrinsic::rint:
2365 case Intrinsic::round:
2366 case Intrinsic::roundeven:
2367 case Intrinsic::trunc: {
2368 Value *Src =
II->getArgOperand(0);
2369 if (!Src->hasOneUse())
2375 if (
II->getIntrinsicID() != Intrinsic::fabs) {
2377 if (!FPExtSrc || FPExtSrc->
getSrcTy() != Ty)
2387 II->getOperandBundlesAsDefs(OpBundles);
2429template <
typename FPToIntTy>
2431 constexpr bool IsSaturating = std::is_same_v<FPToIntTy, IntrinsicInst>;
2437 Value *
X = OpI->getOperand(0);
2438 Type *XType =
X->getType();
2439 Type *DestType = FI.getType();
2442 bool IsOutputSigned;
2443 if constexpr (IsSaturating)
2444 IsOutputSigned = FI.getIntrinsicID() == Intrinsic::fptosi_sat;
2455 if constexpr (!IsSaturating) {
2463 if (OutputSize > OpI->getType()->getFPMantissaWidth())
2475 if constexpr (IsSaturating) {
2478 if (IsInputSigned != IsOutputSigned || DestWidth < SrcWidth)
2482 if (DestWidth > SrcWidth) {
2483 if (IsInputSigned && IsOutputSigned)
2487 if (DestWidth < SrcWidth)
2490 assert(XType == DestType &&
"Unexpected types for int to FP to int casts");
2546 UI->setNonNeg(
true);
2558 DL.getPointerSizeInBits(AS)) {
2570 auto UsesPointerAsInt = [](
User *U) {
2581 Base->getType()->getPointerAddressSpace() &&
2598 if (!
GEP || !
GEP->hasOneUse())
2601 Ptr =
GEP->getPointerOperand();
2610 Type *IdxTy =
DL.getIndexType(PtrTy);
2612 Res->
getType() == IntTy && IntTy == IdxTy) {
2625 return Builder.CreateZExtOrTrunc(Res, IntTy);
2636 unsigned TySize = Ty->getScalarSizeInBits();
2637 unsigned PtrSize =
DL.getPointerSizeInBits(AS);
2638 if (TySize != PtrSize) {
2651 Mask->getType() == Ty)
2652 return BinaryOperator::CreateAnd(
Builder.CreatePtrToInt(Ptr, Ty), Mask);
2657 Value *Vec, *Scalar, *Index;
2664 Value *NewCast =
Builder.CreatePtrToInt(Scalar, Ty->getScalarType());
2681 Mask->getType() == Ty)
2682 return BinaryOperator::CreateAnd(
Builder.CreatePtrToAddr(Ptr), Mask);
2715 if (SrcTy->getElementType() != DestTy->getElementType()) {
2720 if (SrcTy->getElementType()->getPrimitiveSizeInBits() !=
2721 DestTy->getElementType()->getPrimitiveSizeInBits())
2734 assert(SrcElts != DestElts &&
"Element counts should be different.");
2743 if (SrcElts > DestElts) {
2752 ShuffleMask = ShuffleMaskStorage;
2754 ShuffleMask = ShuffleMask.take_back(DestElts);
2756 ShuffleMask = ShuffleMask.take_front(DestElts);
2767 unsigned DeltaElts = DestElts - SrcElts;
2769 ShuffleMaskStorage.insert(ShuffleMaskStorage.begin(), DeltaElts, NullElt);
2771 ShuffleMaskStorage.append(DeltaElts, NullElt);
2772 ShuffleMask = ShuffleMaskStorage;
2779 return Value % Ty->getPrimitiveSizeInBits() == 0;
2783 return Value / Ty->getPrimitiveSizeInBits();
2800 "Shift should be a multiple of the element type size");
2808 if (V->getType() == VecEltTy) {
2811 if (
C->isNullValue())
2816 ElementIndex = Elements.size() - ElementIndex - 1;
2819 if (Elements[ElementIndex])
2822 Elements[ElementIndex] = V;
2841 C->getType()->getPrimitiveSizeInBits()));
2845 for (
unsigned i = 0; i != NumElts; ++i) {
2846 unsigned ShiftI = i * ElementSize;
2848 Instruction::LShr,
C, ConstantInt::get(
C->getType(), ShiftI));
2860 if (!V->hasOneUse())
return false;
2863 if (!
I)
return false;
2864 switch (
I->getOpcode()) {
2865 default:
return false;
2866 case Instruction::BitCast:
2867 if (
I->getOperand(0)->getType()->isVectorTy())
2871 case Instruction::ZExt:
2873 I->getOperand(0)->getType()->getPrimitiveSizeInBits(),
2878 case Instruction::Or:
2883 case Instruction::Shl: {
2886 if (!CI)
return false;
2923 DestVecTy->getElementType(),
2931 for (
unsigned i = 0, e = Elements.size(); i != e; ++i) {
2932 if (!Elements[i])
continue;
2947 Value *VecOp, *Index;
2965 if (DestType->
isVectorTy() && FixedVType && FixedVType->getNumElements() == 1)
2992 if (
X->getType()->isFPOrFPVectorTy() &&
2993 Y->getType()->isIntOrIntVectorTy()) {
2995 Builder.CreateBitCast(BO->
getOperand(0),
Y->getType());
2999 if (
X->getType()->isIntOrIntVectorTy() &&
3000 Y->getType()->isFPOrFPVectorTy()) {
3002 Builder.CreateBitCast(BO->
getOperand(1),
X->getType());
3036 Value *CastedC = Builder.CreateBitCast(
C, DestTy);
3059 CondVTy->getElementCount() != DestVecTy->getElementCount())
3068 SrcVecTy->getElementCount())))) {
3071 Value *CastedTVal = Builder.CreateBitCast(TVal, DestTy);
3072 Value *CastedFVal = Builder.CreateBitCast(FVal, DestTy);
3080 if ((DestVecTy !=
nullptr) != (SrcVecTy !=
nullptr))
3087 Value *CastedVal = Builder.CreateBitCast(FVal, DestTy);
3094 Value *CastedVal = Builder.CreateBitCast(TVal, DestTy);
3125 Type *SrcTy = Src->getType();
3129 SmallSetVector<PHINode *, 4> OldPhiNodes;
3137 while (!PhiWorklist.
empty()) {
3139 for (
Value *IncValue : OldPN->incoming_values()) {
3148 Value *Addr = LI->getOperand(0);
3157 if (LI->hasOneUse() && LI->isSimple())
3165 if (OldPhiNodes.
insert(PNode))
3176 Type *TyA = BCI->getOperand(0)->getType();
3177 Type *TyB = BCI->getType();
3178 if (TyA != DestTy || TyB != SrcTy)
3185 for (
auto *OldPN : OldPhiNodes) {
3186 for (User *V : OldPN->users()) {
3188 if (!
SI->isSimple() ||
SI->getOperand(0) != OldPN)
3192 Type *TyB = BCI->getOperand(0)->getType();
3193 Type *TyA = BCI->getType();
3194 if (TyA != DestTy || TyB != SrcTy)
3200 if (!OldPhiNodes.contains(
PHI))
3209 SmallDenseMap<PHINode *, PHINode *> NewPNodes;
3210 for (
auto *OldPN : OldPhiNodes) {
3211 Builder.SetInsertPoint(OldPN);
3212 PHINode *NewPN =
Builder.CreatePHI(DestTy, OldPN->getNumOperands());
3213 NewPNodes[OldPN] = NewPN;
3217 for (
auto *OldPN : OldPhiNodes) {
3218 PHINode *NewPN = NewPNodes[OldPN];
3219 for (
unsigned j = 0, e = OldPN->getNumOperands(); j != e; ++j) {
3220 Value *
V = OldPN->getOperand(j);
3221 Value *NewV =
nullptr;
3234 NewV = BCI->getOperand(0);
3236 NewV = NewPNodes[PrevPN];
3239 NewPN->
addIncoming(NewV, OldPN->getIncomingBlock(j));
3253 for (
auto *OldPN : OldPhiNodes) {
3254 PHINode *NewPN = NewPNodes[OldPN];
3257 assert(
SI->isSimple() &&
SI->getOperand(0) == OldPN);
3261 SI->setOperand(0, NewBC);
3266 Type *TyB = BCI->getOperand(0)->getType();
3267 Type *TyA = BCI->getType();
3268 assert(TyA == DestTy && TyB == SrcTy);
3299 if (
X->getType() != FTy)
3304 return Builder.CreateCopySign(Builder.CreateBitCast(
Y, FTy),
X);
3311 Type *SrcTy = Src->getType();
3316 if (DestTy == Src->getType())
3342 if (SrcVTy->getNumElements() == 1) {
3347 Builder.CreateExtractElement(Src,
3356 return new BitCastInst(InsElt->getOperand(1), DestTy);
3366 Y->getType()->isIntegerTy() && isDesirableIntType(
BitWidth)) {
3368 if (
DL.isBigEndian())
3369 IndexC = SrcVTy->getNumElements() - 1 - IndexC;
3375 unsigned EltWidth =
Y->getType()->getScalarSizeInBits();
3379 return BinaryOperator::CreateOr(AndX, ZextY);
3387 Value *ShufOp0 = Shuf->getOperand(0);
3388 Value *ShufOp1 = Shuf->getOperand(1);
3391 if (Shuf->hasOneUse() && DestTy->
isVectorTy() &&
3393 ShufElts == SrcVecElts) {
3414 if (DestTy->
isIntegerTy() && ShufElts.getKnownMinValue() % 2 == 0 &&
3415 Shuf->hasOneUse() && Shuf->isReverse()) {
3416 unsigned IntrinsicNum = 0;
3418 SrcTy->getScalarSizeInBits() == 8) {
3419 IntrinsicNum = Intrinsic::bswap;
3420 }
else if (SrcTy->getScalarSizeInBits() == 1) {
3421 IntrinsicNum = Intrinsic::bitreverse;
3423 if (IntrinsicNum != 0) {
3424 assert(ShufOp0->
getType() == SrcTy &&
"Unexpected shuffle mask");
3428 Value *ScalarX =
Builder.CreateBitCast(ShufOp0, DestTy);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
static std::optional< bool > isBigEndian(const SmallDenseMap< int64_t, int64_t, 8 > &MemOffset2Idx, int64_t LowestIdx)
Given a map from byte offsets in memory to indices in a load/store, determine if that map corresponds...
This file defines the DenseMap class.
static bool isSigned(unsigned Opcode)
static bool collectInsertionElements(Value *V, unsigned Shift, SmallVectorImpl< Value * > &Elements, Type *VecEltTy, bool isBigEndian)
V is a value which is inserted into a vector of VecEltTy.
static bool hasStoreUsersOnly(CastInst &CI)
Check if all users of CI are StoreInsts.
static Value * foldCopySignIdioms(BitCastInst &CI, InstCombiner::BuilderTy &Builder, const SimplifyQuery &SQ)
Fold (bitcast (or (and (bitcast X to int), signmask), nneg Y) to fp) to copysign((bitcast Y to fp),...
static Type * shrinkFPConstantVector(Value *V, bool PreferBFloat)
static Instruction * canonicalizeBitCastExtElt(BitCastInst &BitCast, InstCombinerImpl &IC)
Canonicalize scalar bitcasts of extracted elements into a bitcast of the vector followed by extract e...
static Instruction * shrinkSplatShuffle(TruncInst &Trunc, InstCombiner::BuilderTy &Builder)
Try to narrow the width of a splat shuffle.
static Instruction * foldFPtoI(Instruction &FI, InstCombiner &IC)
static Instruction * foldBitCastSelect(BitCastInst &BitCast, InstCombiner::BuilderTy &Builder)
Change the type of a select if we can eliminate a bitcast.
static Instruction * foldBitCastBitwiseLogic(BitCastInst &BitCast, InstCombiner::BuilderTy &Builder)
Change the type of a bitwise logic operation if we can eliminate a bitcast.
static bool fitsInFPType(APFloat F, const fltSemantics &Sem)
Return a Constant* for the specified floating-point constant if it fits in the specified FP type with...
static Instruction * optimizeVectorResizeWithIntegerBitCasts(Value *InVal, VectorType *DestTy, InstCombinerImpl &IC)
This input value (which is known to have vector type) is being zero extended or truncated to the spec...
static Instruction * shrinkInsertElt(CastInst &Trunc, InstCombiner::BuilderTy &Builder)
Try to narrow the width of an insert element.
SmallDenseMap< Value *, Value *, 8 > EvaluatedMap
static Type * getMinimumFPType(Value *V, Type *PreferredTy, InstCombiner &IC)
Find the minimum FP type we can safely truncate to.
static bool isMultipleOfTypeSize(unsigned Value, Type *Ty)
static Value * optimizeIntegerToVectorInsertions(BitCastInst &CI, InstCombinerImpl &IC)
If the input is an 'or' instruction, we may be doing shifts and ors to assemble the elements of the v...
static Type * shrinkFPConstant(LLVMContext &Ctx, const APFloat &F, bool PreferBFloat)
static Instruction * foldVecExtTruncToExtElt(TruncInst &Trunc, InstCombinerImpl &IC)
Whenever an element is extracted from a vector, optionally shifted down, and then truncated,...
static Value * EvaluateInDifferentTypeImpl(Value *V, Type *Ty, bool isSigned, InstCombinerImpl &IC, EvaluatedMap &Processed)
static unsigned getTypeSizeIndex(unsigned Value, Type *Ty)
static Instruction * foldVecTruncToExtElt(TruncInst &Trunc, InstCombinerImpl &IC)
Given a vector that is bitcast to an integer, optionally logically right-shifted, and truncated,...
This file provides internal interfaces used to implement the InstCombine.
This file provides the interface for the instcombine pass implementation.
static Value * getOpcode(Value &V, Type &Ty, InstrumentationConfig &IConf, InstrumentorIRBuilderTy &IIRB)
uint64_t IntrinsicInst * II
const SmallVectorImpl< MachineOperand > & Cond
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallVector class.
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
static SymbolRef::Type getType(const Symbol *Sym)
static const fltSemantics & IEEEsingle()
static const fltSemantics & BFloat()
static const fltSemantics & IEEEdouble()
static constexpr roundingMode rmNearestTiesToEven
static const fltSemantics & IEEEhalf()
static LLVM_ABI unsigned int semanticsIntSizeInBits(const fltSemantics &, bool)
Class for arbitrary precision integers.
LLVM_ABI APInt udiv(const APInt &RHS) const
Unsigned division operation.
static APInt getAllOnes(unsigned numBits)
Return an APInt of a specified width with all bits set.
LLVM_ABI APInt zext(unsigned width) const
Zero extend to a new width.
uint64_t getZExtValue() const
Get zero extended value.
static APInt getMaxValue(unsigned numBits)
Gets maximum unsigned value of APInt for specific bit width.
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
LLVM_ABI APInt urem(const APInt &RHS) const
Unsigned remainder operation.
unsigned getBitWidth() const
Return the number of bits in the APInt.
bool ult(const APInt &RHS) const
Unsigned less than comparison.
int32_t exactLogBase2() const
unsigned countr_zero() const
Count the number of trailing zero bits.
static APInt getLowBitsSet(unsigned numBits, unsigned loBitsSet)
Constructs an APInt value that has the bottom loBitsSet bits set.
static APInt getHighBitsSet(unsigned numBits, unsigned hiBitsSet)
Constructs an APInt value that has the top hiBitsSet bits set.
static APInt getBitsSetFrom(unsigned numBits, unsigned loBit)
Constructs an APInt value that has a contiguous range of bits set.
unsigned countr_one() const
Count the number of trailing one bits.
bool uge(const APInt &RHS) const
Unsigned greater or equal comparison.
This class represents a conversion between pointers from one address space to another.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Functions, function parameters, and return types can have attributes to indicate how they should be t...
LLVM_ABI std::optional< unsigned > getVScaleRangeMax() const
Returns the maximum value for the vscale_range attribute or std::nullopt when unknown.
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 * CreateFMulFMF(Value *V1, Value *V2, FastMathFlags FMF, const Twine &Name="")
static BinaryOperator * CreateFDivFMF(Value *V1, Value *V2, FastMathFlags FMF, const Twine &Name="")
This class represents a no-op cast from one type to another.
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)
This is the base class for all instructions that perform data casts.
Type * getSrcTy() const
Return the source type, as a convenience.
Instruction::CastOps getOpcode() const
Return the opcode of this CastInst.
static LLVM_ABI unsigned isEliminableCastPair(Instruction::CastOps firstOpcode, Instruction::CastOps secondOpcode, Type *SrcTy, Type *MidTy, Type *DstTy, const DataLayout *DL)
Determine how a pair of casts can be eliminated, if they can be at all.
static LLVM_ABI CastInst * CreateIntegerCast(Value *S, Type *Ty, bool isSigned, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a ZExt, BitCast, or Trunc for int -> int casts.
static LLVM_ABI CastInst * CreateFPCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create an FPExt, BitCast, or FPTrunc for fp -> fp casts.
static LLVM_ABI CastInst * CreateTruncOrBitCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a Trunc or BitCast cast instruction.
static LLVM_ABI CastInst * CreateBitOrPointerCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a BitCast, a PtrToInt, or an IntToPTr cast instruction.
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 ...
Type * getDestTy() const
Return the destination type, as a convenience.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
@ ICMP_SLT
signed less than
@ ICMP_UGE
unsigned greater or equal
@ ICMP_SGT
signed greater than
@ ICMP_ULT
unsigned less than
@ ICMP_ULE
unsigned less or equal
static LLVM_ABI Constant * getSub(Constant *C1, Constant *C2, bool HasNUW=false, bool HasNSW=false)
static LLVM_ABI Constant * getBitCast(Constant *C, Type *Ty, bool OnlyIfReduced=false)
static LLVM_ABI Constant * getTrunc(Constant *C, Type *Ty, bool OnlyIfReduced=false)
ConstantFP - Floating Point Values [float, double].
const APFloat & getValueAPF() const
This is the shared class of boolean and integer constants.
static LLVM_ABI ConstantInt * getTrue(LLVMContext &Context)
uint64_t getZExtValue() const
Return the constant as a 64-bit unsigned integer value after it has been zero extended as appropriate...
bool uge(uint64_t Num) const
This function will return true iff this constant represents a value with active bits bigger than 64 b...
This is an important base class in LLVM.
static LLVM_ABI Constant * mergeUndefsWith(Constant *C, Constant *Other)
Merges undefs of a Constant with another Constant, along with the undefs already present.
static LLVM_ABI Constant * getAllOnesValue(Type *Ty)
static LLVM_ABI Constant * getNullValue(Type *Ty)
Constructor to create a '0' constant of arbitrary type.
LLVM_ABI bool isElementWiseEqual(Value *Y) const
Return true if this constant and a constant 'Y' are element-wise equal.
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.
This class represents an extension of floating point types.
This class represents a cast from floating point to signed integer.
This class represents a cast from floating point to unsigned integer.
This class represents a truncation of floating point types.
Convenience struct for specifying and reasoning about fast-math flags.
Class to represent fixed width SIMD vectors.
static LLVM_ABI FixedVectorType * get(Type *ElementType, unsigned NumElts)
FunctionType * getFunctionType() const
Returns the FunctionType for me.
Attribute getFnAttribute(Attribute::AttrKind Kind) const
Return the attribute for the given attribute kind.
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
static GetElementPtrInst * Create(Type *PointeeType, Value *Ptr, ArrayRef< Value * > IdxList, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
This instruction compares its operands according to the predicate given to the constructor.
Value * CreateInsertElement(Type *VecTy, Value *NewElt, Value *Idx, const Twine &Name="")
ConstantInt * getInt64(uint64_t C)
Get a constant 64-bit value.
ConstantInt * getInt32(uint32_t C)
Get a constant 32-bit value.
Value * CreateBitCast(Value *V, Type *DestTy, const Twine &Name="")
static InsertElementInst * Create(Value *Vec, Value *NewElt, Value *Idx, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Instruction * visitZExt(ZExtInst &Zext)
Instruction * visitAddrSpaceCast(AddrSpaceCastInst &CI)
Instruction * foldExtractionOfVectorDeinterleave(ZExtInst &RootZExt)
Instruction * visitSExt(SExtInst &Sext)
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,...
Instruction * visitFPToSI(FPToSIInst &FI)
Instruction * visitTrunc(TruncInst &CI)
Instruction * visitUIToFP(CastInst &CI)
Instruction * visitPtrToInt(PtrToIntInst &CI)
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 * foldItoFPtoI(FPToIntTy &FI)
fpto{s/u}i.sat --> X or zext(X) or sext(X) or trunc(X) This is safe if the intermediate type has enou...
Instruction * visitSIToFP(CastInst &CI)
Instruction * commonCastTransforms(CastInst &CI)
Implement the transforms common to all CastInst visitors.
Instruction * eraseInstFromFunction(Instruction &I) override
Combiner aware instruction erasure.
Instruction * visitFPTrunc(FPTruncInst &CI)
Value * foldPtrToIntOrAddrOfGEP(Type *IntTy, Value *Ptr)
Instruction * visitBitCast(BitCastInst &CI)
Instruction * visitIntToPtr(IntToPtrInst &CI)
Instruction * visitFPToUI(FPToUIInst &FI)
Instruction * visitPtrToAddr(PtrToAddrInst &CI)
Value * EvaluateInDifferentType(Value *V, Type *Ty, bool isSigned)
Given an expression that CanEvaluateTruncated or CanEvaluateSExtd returns true for,...
bool SimplifyDemandedInstructionBits(Instruction &Inst)
Tries to simplify operands to an integer instruction based on its demanded bits.
Instruction * visitFPExt(CastInst &CI)
LoadInst * combineLoadToNewType(LoadInst &LI, Type *NewTy, const Twine &Suffix="")
Helper to combine a load to a new type.
The core instruction combiner logic.
const DataLayout & getDataLayout() const
unsigned ComputeMaxSignificantBits(const Value *Op, const Instruction *CxtI=nullptr, unsigned Depth=0) const
unsigned ComputeNumSignBits(const Value *Op, const Instruction *CxtI=nullptr, unsigned Depth=0) const
Instruction * replaceInstUsesWith(Instruction &I, Value *V)
A combiner-aware RAUW-like routine.
LLVM_ABI bool canBeCastedExactlyIntToFP(Value *V, Type *FPTy, bool IsSigned, const Instruction *CxtI=nullptr) const
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.
void computeKnownBits(const Value *V, KnownBits &Known, const Instruction *CxtI, unsigned Depth=0) const
LLVM_ABI bool isKnownExactCastIntToFP(CastInst &I) const
Return true if the cast from integer to FP can be proven to be exact for all possible inputs (the con...
IRBuilder< TargetFolder, IRBuilderInstCombineInserter > BuilderTy
An IRBuilder that automatically inserts new instructions into the worklist.
bool MaskedValueIsZero(const Value *V, const APInt &Mask, const Instruction *CxtI=nullptr, unsigned Depth=0) const
const SimplifyQuery & getSimplifyQuery() const
LLVM_ABI void copyFastMathFlags(FastMathFlags FMF)
Convenience function for transferring all fast-math flag values to this instruction,...
static bool isBitwiseLogicOp(unsigned Opcode)
Determine if the Opcode is and/or/xor.
LLVM_ABI const Module * getModule() const
Return the module owning the function this instruction belongs to or nullptr it the function does not...
Instruction * user_back()
Specialize the methods defined in Value, as we know that an instruction can only be used by other ins...
LLVM_ABI const Function * getFunction() const
Return the function this instruction belongs to.
LLVM_ABI void setNonNeg(bool b=true)
Set or clear the nneg flag on this instruction, which must be a zext instruction.
LLVM_ABI bool hasNonNeg() const LLVM_READONLY
Determine whether the the nneg flag is set.
LLVM_ABI FastMathFlags getFastMathFlags() const LLVM_READONLY
Convenience function for getting all the fast-math flags, which must be an operator which supports th...
unsigned getOpcode() const
Returns a member of one of the enums like Instruction::Add.
LLVM_ABI void setIsExact(bool b=true)
Set or clear the exact flag on this instruction, which must be an operator which supports this flag.
This class represents a cast from an integer to a pointer.
unsigned getAddressSpace() const
Returns the address space of this instruction's pointer type.
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.
This is an important class for using LLVM in a threaded context.
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...
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
This class represents a cast from a pointer to an address (non-capturing ptrtoint).
Value * getPointerOperand()
Gets the pointer operand.
This class represents a cast from a pointer to an integer.
Value * getPointerOperand()
Gets the pointer operand.
unsigned getPointerAddressSpace() const
Returns the address space of the pointer operand.
This class represents a sign extension of integer types.
This class represents the LLVM 'select' instruction.
static SelectInst * Create(Value *C, Value *S1, Value *S2, const Twine &NameStr="", InsertPosition InsertBefore=nullptr, const Instruction *MDFrom=nullptr)
bool insert(const value_type &X)
Insert a new element into the SetVector.
This instruction constructs a fixed permutation of two input vectors.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
This class represents a truncation of integer types.
void setHasNoSignedWrap(bool B)
void setHasNoUnsignedWrap(bool B)
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.
The instances of the Type class are immutable: once they are created, they are never changed.
LLVM_ABI unsigned getIntegerBitWidth() const
bool isVectorTy() const
True if this is an instance of VectorType.
static LLVM_ABI IntegerType * getInt32Ty(LLVMContext &C)
bool isIntOrIntVectorTy() const
Return true if this is an integer type or a vector of integer types.
bool isBFloatTy() const
Return true if this is 'bfloat', a 16-bit bfloat type.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
Type * getScalarType() const
If this is a vector type, return the element type, otherwise return 'this'.
LLVM_ABI TypeSize getPrimitiveSizeInBits() const LLVM_READONLY
Return the basic size of this type if it is a primitive type.
LLVM_ABI Type * getWithNewType(Type *EltTy) const
Given vector type, change the element type, whilst keeping the old number of elements.
LLVM_ABI unsigned getScalarSizeInBits() const LLVM_READONLY
If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
bool isPtrOrPtrVectorTy() const
Return true if this is a pointer type or a vector of pointer types.
bool isX86_AMXTy() const
Return true if this is X86 AMX.
bool isIntegerTy() const
True if this is an instance of IntegerType.
static LLVM_ABI Type * getDoubleTy(LLVMContext &C)
bool isFPOrFPVectorTy() const
Return true if this is a FP type or a vector of FP.
static LLVM_ABI Type * getFloatTy(LLVMContext &C)
LLVM_ABI int getFPMantissaWidth() const
Return the width of the mantissa of this type.
LLVM_ABI const fltSemantics & getFltSemantics() const
static LLVM_ABI Type * getBFloatTy(LLVMContext &C)
static LLVM_ABI Type * getHalfTy(LLVMContext &C)
Value * getOperand(unsigned i) const
LLVM Value Representation.
Type * getType() const
All values are typed, get the type 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()
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.
static LLVM_ABI VectorType * get(Type *ElementType, ElementCount EC)
This static method is the primary way to construct an VectorType.
static LLVM_ABI bool isValidElementType(Type *ElemTy)
Return true if the specified type is valid as a element type.
This class represents zero extension of integer types.
static constexpr bool isKnownLE(const FixedOrScalableQuantity &LHS, const FixedOrScalableQuantity &RHS)
static constexpr bool isKnownGE(const FixedOrScalableQuantity &LHS, const FixedOrScalableQuantity &RHS)
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr std::underlying_type_t< E > Mask()
Get a bitmask with 1s in all places up to the high-order bit of E's largest value.
@ C
The default llvm calling convention, compatible with C.
LLVM_ABI Function * getOrInsertDeclaration(Module *M, ID id, ArrayRef< Type * > OverloadTys={})
Look up the Function declaration of the intrinsic id in the Module M.
SpecificConstantMatch m_ZeroInt()
Convenience matchers for specific integer values.
BinaryOp_match< SpecificConstantMatch, SrcTy, TargetOpcode::G_SUB > m_Neg(const SrcTy &&Src)
Matches a register negated by a G_SUB.
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.
cst_pred_ty< is_lowbit_mask > m_LowBitMask()
Match an integer or vector with only the low bit(s) set.
BinaryOp_match< LHS, RHS, Instruction::And > m_And(const LHS &L, const RHS &R)
PtrToIntSameSize_match< OpTy > m_PtrToIntSameSize(const DataLayout &DL, const OpTy &Op)
BinaryOp_match< LHS, RHS, Instruction::Add > m_Add(const LHS &L, const RHS &R)
cst_pred_ty< is_sign_mask > m_SignMask()
Match an integer or vector with only the sign bit(s) set.
BinaryOp_match< LHS, RHS, Instruction::AShr > m_AShr(const LHS &L, const RHS &R)
cst_pred_ty< is_power2 > m_Power2()
Match an integer or vector power-of-2.
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.
BinaryOp_match< LHS, RHS, Instruction::And, true > m_c_And(const LHS &L, const RHS &R)
Matches an And with LHS and RHS in either order.
CastInst_match< OpTy, TruncInst > m_Trunc(const OpTy &Op)
Matches Trunc.
BinaryOp_match< LHS, RHS, Instruction::Xor > m_Xor(const LHS &L, const RHS &R)
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)
match_deferred< Value > m_Deferred(Value *const &V)
Like m_Specific(), but works if the specific value to match is determined as part of the same match()...
specificval_ty m_Specific(const Value *V)
Match if we have a specific specified value.
BinOpPred_match< LHS, RHS, is_right_shift_op > m_Shr(const LHS &L, const RHS &R)
Matches logical shift operations.
specific_intval< true > m_SpecificIntAllowPoison(const APInt &V)
TwoOps_match< Val_t, Idx_t, Instruction::ExtractElement > m_ExtractElt(const Val_t &Val, const Idx_t &Idx)
Matches ExtractElementInst.
cst_pred_ty< is_one > m_One()
Match an integer 1 or a vector with all elements equal to 1.
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.
IntrinsicID_match m_VScale()
Matches a call to llvm.vscale().
auto m_BinOp()
Match an arbitrary binary operation and ignore it.
BinOpPred_match< LHS, RHS, is_logical_shift_op > m_LogicalShift(const LHS &L, const RHS &R)
Matches logical shift operations.
MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty > m_SMin(const LHS &L, const RHS &R)
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.
auto m_Constant()
Match an arbitrary Constant and ignore it.
NoWrapTrunc_match< OpTy, TruncInst::NoSignedWrap > m_NSWTrunc(const OpTy &Op)
Matches trunc nsw.
TwoOps_match< V1_t, V2_t, Instruction::ShuffleVector > m_Shuffle(const V1_t &v1, const V2_t &v2)
Matches ShuffleVectorInst independently of mask value.
match_combine_or< CastInst_match< OpTy, FPToUIInst >, CastInst_match< OpTy, FPToSIInst > > m_FPToI(const OpTy &Op)
CastInst_match< OpTy, FPExtInst > m_FPExt(const OpTy &Op)
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.
BinOpPred_match< LHS, RHS, is_bitwiselogic_op, true > m_c_BitwiseLogic(const LHS &L, const RHS &R)
Matches bitwise logic operations in either order.
cst_pred_ty< is_negated_power2 > m_NegatedPower2()
Match a integer or vector negated power-of-2.
match_immconstant_ty m_ImmConstant()
Match an arbitrary immediate Constant and ignore it.
NoWrapTrunc_match< OpTy, TruncInst::NoUnsignedWrap > m_NUWTrunc(const OpTy &Op)
Matches trunc nuw.
BinaryOp_match< LHS, RHS, Instruction::Add, true > m_c_Add(const LHS &L, const RHS &R)
Matches a Add with LHS and RHS in either order.
CastOperator_match< OpTy, Instruction::BitCast > m_BitCast(const OpTy &Op)
Matches BitCast.
CastInst_match< OpTy, FPToSIInst > m_FPToSI(const OpTy &Op)
MaxMin_match< ICmpInst, LHS, RHS, smax_pred_ty > m_SMax(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::LShr > m_LShr(const LHS &L, const RHS &R)
match_combine_or< CastInst_match< OpTy, ZExtInst >, CastInst_match< OpTy, SExtInst > > m_ZExtOrSExt(const OpTy &Op)
FNeg_match< OpTy > m_FNeg(const OpTy &X)
Match 'fneg X' as 'fsub -0.0, X'.
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)
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_Ctlz(const Opnd0 &Op0, const Opnd1 &Op1)
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.
BinaryOp_match< LHS, RHS, Instruction::Or, true > m_c_Or(const LHS &L, const RHS &R)
Matches an Or with LHS and RHS in either order.
CastOperator_match< OpTy, Instruction::IntToPtr > m_IntToPtr(const OpTy &Op)
Matches IntToPtr.
ThreeOps_match< Val_t, Elt_t, Idx_t, Instruction::InsertElement > m_InsertElt(const Val_t &Val, const Elt_t &Elt, const Idx_t &Idx)
Matches InsertElementInst.
ElementWiseBitCast_match< OpTy > m_ElementWiseBitCast(const OpTy &Op)
BinaryOp_match< LHS, RHS, Instruction::Sub > m_Sub(const LHS &L, const RHS &R)
MaxMin_match< ICmpInst, LHS, RHS, umin_pred_ty > m_UMin(const LHS &L, const RHS &R)
cst_pred_ty< icmp_pred_with_threshold > m_SpecificInt_ICMP(ICmpInst::Predicate Predicate, const APInt &Threshold)
Match an integer or vector with every element comparing 'pred' (eg/ne/...) to Threshold.
auto m_ConstantInt()
Match an arbitrary ConstantInt and ignore it.
friend class Instruction
Iterator for Instructions in a `BasicBlock.
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
LLVM_ABI KnownFPClass computeKnownFPClass(const Value *V, const APInt &DemandedElts, FPClassTest InterestedClasses, const SimplifyQuery &SQ, unsigned Depth=0)
Determine which floating-point classes are valid for V, and return them in KnownFPClass bit sets.
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 Constant * ConstantFoldSelectInstruction(Constant *Cond, Constant *V1, Constant *V2)
Attempt to constant fold a select instruction with the specified operands.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
unsigned Log2_64_Ceil(uint64_t Value)
Return the ceil log base 2 of the specified value, 64 if the value is zero.
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...
constexpr bool isPowerOf2_64(uint64_t Value)
Return true if the argument is a power of two > 0 (64 bit edition.)
LLVM_ABI Value * simplifyCastInst(unsigned CastOpc, Value *Op, Type *Ty, const SimplifyQuery &Q)
Given operands for a CastInst, fold the result or return null.
auto dyn_cast_or_null(const Y &Val)
unsigned Log2_32(uint32_t Value)
Return the floor log base 2 of the specified value, -1 if the value is zero.
auto reverse(ContainerTy &&C)
constexpr bool isPowerOf2_32(uint32_t Value)
Return true if the argument is a power of two > 0.
FPClassTest
Floating-point class tests, supported by 'is_fpclass' intrinsic.
LLVM_ABI void computeKnownBits(const Value *V, KnownBits &Known, const DataLayout &DL, AssumptionCache *AC=nullptr, const Instruction *CxtI=nullptr, const DominatorTree *DT=nullptr, bool UseInstrInfo=true, unsigned Depth=0)
Determine which bits of V are known to be either zero or one and return them in the KnownZero/KnownOn...
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
SmallVector< ValueTypeFromRangeType< R >, Size > to_vector(R &&Range)
Given a range of type R, iterate the entire range and return a SmallVector with elements of the vecto...
LLVM_ABI Constant * ConstantFoldCastOperand(unsigned Opcode, Constant *C, Type *DestTy, const DataLayout &DL)
Attempt to constant fold a cast with the specified operand.
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
LLVM_ABI 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.
@ SMax
Signed integer max implemented in terms of select(cmp()).
@ And
Bitwise or logical AND of integers.
@ SMin
Signed integer min implemented in terms of select(cmp()).
DWARFExpression::Operation Op
constexpr unsigned BitWidth
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
auto seq(T Begin, T End)
Iterate over an integral type from Begin up to - but not including - End.
LLVM_ABI Constant * ConstantFoldIntegerCast(Constant *C, Type *DestTy, bool IsSigned, const DataLayout &DL)
Constant fold a zext, sext or trunc, depending on IsSigned and whether the DestTy is wider or narrowe...
LLVM_ABI bool isKnownNonNegative(const Value *V, const SimplifyQuery &SQ, unsigned Depth=0)
Returns true if the give value is known to be non-negative.
LLVM_ABI Constant * ConstantFoldBinaryInstruction(unsigned Opcode, Constant *V1, Constant *V2)
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
unsigned countMinTrailingZeros() const
Returns the minimum number of trailing zero bits.
unsigned countMinLeadingZeros() const
Returns the minimum number of leading zero bits.
APInt getMaxValue() const
Return the maximal unsigned value possible given these KnownBits.
bool isKnownNever(FPClassTest Mask) const
Return true if it's known this can never be one of the mask entries.
SimplifyQuery getWithInstruction(const Instruction *I) const