66 if (
F.getFnAttribute(
"disable-tail-calls").getValueAsBool())
72 AttrBuilder CallerAttrs(
F.getContext(),
F.getAttributes().getRetAttrs());
73 for (
const auto &Attr : {Attribute::Alignment, Attribute::Dereferenceable,
74 Attribute::DereferenceableOrNull, Attribute::NoAlias,
75 Attribute::NonNull, Attribute::NoUndef,
76 Attribute::Range, Attribute::NoFPClass})
77 CallerAttrs.removeAttribute(Attr);
79 if (CallerAttrs.hasAttributes())
83 if (CallerAttrs.contains(Attribute::ZExt) ||
84 CallerAttrs.contains(Attribute::SExt))
95 for (
unsigned I = 0, E = ArgLocs.
size();
I != E; ++
I) {
122 IsSExt =
Call->paramHasAttr(ArgIdx, Attribute::SExt);
123 IsZExt =
Call->paramHasAttr(ArgIdx, Attribute::ZExt);
124 IsNoExt =
Call->paramHasAttr(ArgIdx, Attribute::NoExt);
125 IsInReg =
Call->paramHasAttr(ArgIdx, Attribute::InReg);
126 IsSRet =
Call->paramHasAttr(ArgIdx, Attribute::StructRet);
127 IsNest =
Call->paramHasAttr(ArgIdx, Attribute::Nest);
128 IsByVal =
Call->paramHasAttr(ArgIdx, Attribute::ByVal);
138 "multiple ABI attributes?");
154std::pair<SDValue, SDValue>
159 if (LibcallImpl == RTLIB::Unsupported)
166 Args.reserve(
Ops.size());
169 for (
unsigned i = 0; i <
Ops.size(); ++i) {
171 Type *Ty = i < OpsTypeOverrides.
size() && OpsTypeOverrides[i]
172 ? OpsTypeOverrides[i]
181 Entry.IsZExt = !Entry.IsSExt;
185 Entry.IsSExt = Entry.IsZExt =
false;
187 Args.push_back(Entry);
194 Type *OrigRetTy = RetTy;
197 bool zeroExtend = !signExtend;
202 signExtend = zeroExtend =
false;
208 Callee, std::move(Args))
218 LLVMContext &Context, std::vector<EVT> &MemOps,
unsigned Limit,
219 const MemOp &
Op,
unsigned DstAS,
unsigned SrcAS,
220 const AttributeList &FuncAttributes,
EVT *LargestVT)
const {
223 if (VT == MVT::Other) {
225 VT = MVT::LAST_INTEGER_VALUETYPE;
226 if (
Op.isFixedDstAlign()) {
227 bool LoadsFromSrc =
Op.isMemcpy() && !
Op.isMemcpyStrSrc();
228 while (VT != MVT::i8) {
231 Op.getDstAlign() >= VTSize ||
234 !LoadsFromSrc ||
Op.getSrcAlign() >= VTSize ||
244 MVT LVT = MVT::LAST_INTEGER_VALUETYPE;
255 unsigned NumMemOps = 0;
259 while (VTSize >
Size) {
270 else if (NewVT == MVT::i64 &&
282 if (NewVT == MVT::i8)
291 if (NumMemOps &&
Op.allowOverlap() && NewVTSize <
Size &&
293 VT, DstAS,
Op.isFixedDstAlign() ?
Op.getDstAlign() :
Align(1),
303 if (++NumMemOps > Limit)
306 MemOps.push_back(VT);
331 bool IsSignaling)
const {
336 assert((VT == MVT::f32 || VT == MVT::f64 || VT == MVT::f128 || VT == MVT::ppcf128)
337 &&
"Unsupported setcc type!");
340 RTLIB::Libcall LC1 = RTLIB::UNKNOWN_LIBCALL, LC2 = RTLIB::UNKNOWN_LIBCALL;
341 bool ShouldInvertCC =
false;
345 LC1 = (VT == MVT::f32) ? RTLIB::OEQ_F32 :
346 (VT == MVT::f64) ? RTLIB::OEQ_F64 :
347 (VT == MVT::f128) ? RTLIB::OEQ_F128 : RTLIB::OEQ_PPCF128;
351 LC1 = (VT == MVT::f32) ? RTLIB::UNE_F32 :
352 (VT == MVT::f64) ? RTLIB::UNE_F64 :
353 (VT == MVT::f128) ? RTLIB::UNE_F128 : RTLIB::UNE_PPCF128;
357 LC1 = (VT == MVT::f32) ? RTLIB::OGE_F32 :
358 (VT == MVT::f64) ? RTLIB::OGE_F64 :
359 (VT == MVT::f128) ? RTLIB::OGE_F128 : RTLIB::OGE_PPCF128;
363 LC1 = (VT == MVT::f32) ? RTLIB::OLT_F32 :
364 (VT == MVT::f64) ? RTLIB::OLT_F64 :
365 (VT == MVT::f128) ? RTLIB::OLT_F128 : RTLIB::OLT_PPCF128;
369 LC1 = (VT == MVT::f32) ? RTLIB::OLE_F32 :
370 (VT == MVT::f64) ? RTLIB::OLE_F64 :
371 (VT == MVT::f128) ? RTLIB::OLE_F128 : RTLIB::OLE_PPCF128;
375 LC1 = (VT == MVT::f32) ? RTLIB::OGT_F32 :
376 (VT == MVT::f64) ? RTLIB::OGT_F64 :
377 (VT == MVT::f128) ? RTLIB::OGT_F128 : RTLIB::OGT_PPCF128;
380 ShouldInvertCC =
true;
383 LC1 = (VT == MVT::f32) ? RTLIB::UO_F32 :
384 (VT == MVT::f64) ? RTLIB::UO_F64 :
385 (VT == MVT::f128) ? RTLIB::UO_F128 : RTLIB::UO_PPCF128;
389 ShouldInvertCC =
true;
392 LC1 = (VT == MVT::f32) ? RTLIB::UO_F32 :
393 (VT == MVT::f64) ? RTLIB::UO_F64 :
394 (VT == MVT::f128) ? RTLIB::UO_F128 : RTLIB::UO_PPCF128;
395 LC2 = (VT == MVT::f32) ? RTLIB::OEQ_F32 :
396 (VT == MVT::f64) ? RTLIB::OEQ_F64 :
397 (VT == MVT::f128) ? RTLIB::OEQ_F128 : RTLIB::OEQ_PPCF128;
401 ShouldInvertCC =
true;
404 LC1 = (VT == MVT::f32) ? RTLIB::OGE_F32 :
405 (VT == MVT::f64) ? RTLIB::OGE_F64 :
406 (VT == MVT::f128) ? RTLIB::OGE_F128 : RTLIB::OGE_PPCF128;
409 LC1 = (VT == MVT::f32) ? RTLIB::OGT_F32 :
410 (VT == MVT::f64) ? RTLIB::OGT_F64 :
411 (VT == MVT::f128) ? RTLIB::OGT_F128 : RTLIB::OGT_PPCF128;
414 LC1 = (VT == MVT::f32) ? RTLIB::OLE_F32 :
415 (VT == MVT::f64) ? RTLIB::OLE_F64 :
416 (VT == MVT::f128) ? RTLIB::OLE_F128 : RTLIB::OLE_PPCF128;
419 LC1 = (VT == MVT::f32) ? RTLIB::OLT_F32 :
420 (VT == MVT::f64) ? RTLIB::OLT_F64 :
421 (VT == MVT::f128) ? RTLIB::OLT_F128 : RTLIB::OLT_PPCF128;
439 if (LC1Impl == RTLIB::Unsupported) {
441 "no libcall available to soften floating-point compare");
445 if (ShouldInvertCC) {
447 CCCode = getSetCCInverse(CCCode, RetVT);
450 if (LC2 == RTLIB::UNKNOWN_LIBCALL) {
455 if (LC2Impl == RTLIB::Unsupported) {
457 "no libcall available to soften floating-point compare");
461 "unordered call should be simple boolean");
471 auto Call2 =
makeLibCall(DAG, LC2, RetVT,
Ops, CallOptions, dl, Chain);
474 CCCode = getSetCCInverse(CCCode, RetVT);
475 NewLHS = DAG.
getSetCC(dl, SetCCVT, Call2.first, NewRHS, CCCode);
528 if (!TM.shouldAssumeDSOLocal(GV))
548 const APInt &DemandedElts,
551 unsigned Opcode =
Op.getOpcode();
570 if (!Op1C || Op1C->isOpaque())
574 const APInt &
C = Op1C->getAPIntValue();
579 EVT VT =
Op.getValueType();
596 EVT VT =
Op.getValueType();
611 "ShrinkDemandedOp only supports binary operators!");
612 assert(
Op.getNode()->getNumValues() == 1 &&
613 "ShrinkDemandedOp only supports nodes with one result!");
615 EVT VT =
Op.getValueType();
624 Op.getOperand(1).getValueType().getScalarSizeInBits() ==
BitWidth &&
625 "ShrinkDemandedOp only supports operands that have the same size!");
629 if (!
Op.getNode()->hasOneUse())
645 unsigned Opcode =
Op.getOpcode();
655 assert(DemandedSize <= SmallVTBits &&
"Narrowed below demanded bits?");
679 const APInt &DemandedElts,
699 bool AssumeSingleUse)
const {
700 EVT VT =
Op.getValueType();
716 EVT VT =
Op.getValueType();
734 switch (
Op.getOpcode()) {
740 EVT SrcVT = Src.getValueType();
741 EVT DstVT =
Op.getValueType();
747 if (NumSrcEltBits == NumDstEltBits)
752 if (SrcVT.
isVector() && (NumDstEltBits % NumSrcEltBits) == 0) {
753 unsigned Scale = NumDstEltBits / NumSrcEltBits;
756 for (
unsigned i = 0; i != Scale; ++i) {
757 unsigned EltOffset = IsLE ? i : (Scale - 1 - i);
758 unsigned BitOffset = EltOffset * NumSrcEltBits;
759 DemandedSrcBits |=
DemandedBits.extractBits(NumSrcEltBits, BitOffset);
767 Src, DemandedSrcBits, DemandedSrcElts, DAG,
Depth + 1))
772 if (IsLE && (NumSrcEltBits % NumDstEltBits) == 0) {
773 unsigned Scale = NumSrcEltBits / NumDstEltBits;
777 for (
unsigned i = 0; i != NumElts; ++i)
778 if (DemandedElts[i]) {
779 unsigned Offset = (i % Scale) * NumDstEltBits;
781 DemandedSrcElts.
setBit(i / Scale);
785 Src, DemandedSrcBits, DemandedSrcElts, DAG,
Depth + 1))
799 return Op.getOperand(0);
801 return Op.getOperand(1);
812 return Op.getOperand(0);
814 return Op.getOperand(1);
824 return Op.getOperand(0);
826 return Op.getOperand(1);
836 DemandedElts, 1,
Depth + 1))
837 return Op.getOperand(0);
840 DemandedElts, 0,
Depth + 1))
841 return Op.getOperand(1);
847 if (std::optional<unsigned> MaxSA =
850 unsigned ShAmt = *MaxSA;
851 unsigned NumSignBits =
854 if (NumSignBits > ShAmt && (NumSignBits - ShAmt) >= (UpperDemandedBits))
862 if (std::optional<unsigned> MaxSA =
865 unsigned ShAmt = *MaxSA;
869 unsigned NumSignBits =
908 if (NumSignBits >= (
BitWidth - ExBits + 1))
921 EVT SrcVT = Src.getValueType();
922 EVT DstVT =
Op.getValueType();
923 if (IsLE && DemandedElts == 1 &&
939 !DemandedElts[CIdx->getZExtValue()])
950 unsigned NumSubElts =
Sub.getValueType().getVectorNumElements();
953 if (DemandedSubElts == 0)
963 bool AllUndef =
true, IdentityLHS =
true, IdentityRHS =
true;
964 for (
unsigned i = 0; i != NumElts; ++i) {
965 int M = ShuffleMask[i];
966 if (M < 0 || !DemandedElts[i])
969 IdentityLHS &= (M == (int)i);
970 IdentityRHS &= ((M - NumElts) == i);
976 return Op.getOperand(0);
978 return Op.getOperand(1);
998 unsigned Depth)
const {
999 EVT VT =
Op.getValueType();
1012 unsigned Depth)
const {
1026 "SRL or SRA node is required here!");
1029 if (!N1C || !N1C->
isOne())
1076 unsigned ShiftOpc =
Op.getOpcode();
1077 bool IsSigned =
false;
1081 unsigned NumSigned = std::min(NumSignedA, NumSignedB) - 1;
1086 unsigned NumZero = std::min(NumZeroA, NumZeroB);
1092 if (NumZero >= 2 && NumSigned < NumZero) {
1097 if (NumSigned >= 1) {
1105 if (NumZero >= 1 && NumSigned < NumZero) {
1125 EVT VT =
Op.getValueType();
1139 Add.getOperand(1)) &&
1170 unsigned Depth,
bool AssumeSingleUse)
const {
1173 "Mask size mismatches value type size!");
1178 EVT VT =
Op.getValueType();
1180 unsigned NumElts = OriginalDemandedElts.
getBitWidth();
1182 "Unexpected vector size");
1185 APInt DemandedElts = OriginalDemandedElts;
1210 bool HasMultiUse =
false;
1211 if (!AssumeSingleUse && !
Op.getNode()->hasOneUse()) {
1220 }
else if (OriginalDemandedBits == 0 || OriginalDemandedElts == 0) {
1229 switch (
Op.getOpcode()) {
1233 if (!DemandedElts[0])
1238 unsigned SrcBitWidth = Src.getScalarValueSizeInBits();
1245 if (DemandedElts == 1)
1281 EVT MemVT = LD->getMemoryVT();
1298 APInt DemandedVecElts(DemandedElts);
1300 unsigned Idx = CIdx->getZExtValue();
1304 if (!DemandedElts[Idx])
1321 if (!!DemandedVecElts)
1334 unsigned NumSubElts =
Sub.getValueType().getVectorNumElements();
1336 APInt DemandedSrcElts = DemandedElts;
1337 DemandedSrcElts.
clearBits(Idx, Idx + NumSubElts);
1348 if (!!DemandedSubElts)
1350 if (!!DemandedSrcElts)
1360 if (NewSub || NewSrc) {
1361 NewSub = NewSub ? NewSub :
Sub;
1362 NewSrc = NewSrc ? NewSrc : Src;
1375 if (Src.getValueType().isScalableVector())
1378 unsigned NumSrcElts = Src.getValueType().getVectorNumElements();
1379 APInt DemandedSrcElts = DemandedElts.
zext(NumSrcElts).
shl(Idx);
1401 EVT SubVT =
Op.getOperand(0).getValueType();
1402 unsigned NumSubVecs =
Op.getNumOperands();
1404 for (
unsigned i = 0; i != NumSubVecs; ++i) {
1405 APInt DemandedSubElts =
1406 DemandedElts.
extractBits(NumSubElts, i * NumSubElts);
1408 Known2, TLO,
Depth + 1))
1411 if (!!DemandedSubElts)
1421 APInt DemandedLHS, DemandedRHS;
1426 if (!!DemandedLHS || !!DemandedRHS) {
1431 if (!!DemandedLHS) {
1437 if (!!DemandedRHS) {
1449 if (DemandedOp0 || DemandedOp1) {
1450 Op0 = DemandedOp0 ? DemandedOp0 : Op0;
1451 Op1 = DemandedOp1 ? DemandedOp1 : Op1;
1486 LHSKnown.
One == ~RHSC->getAPIntValue()) {
1509 unsigned NumSubElts =
1530 Known2, TLO,
Depth + 1))
1556 if (DemandedOp0 || DemandedOp1) {
1557 Op0 = DemandedOp0 ? DemandedOp0 : Op0;
1558 Op1 = DemandedOp1 ? DemandedOp1 : Op1;
1577 Known2, TLO,
Depth + 1)) {
1601 if (DemandedOp0 || DemandedOp1) {
1602 Op0 = DemandedOp0 ? DemandedOp0 : Op0;
1603 Op1 = DemandedOp1 ? DemandedOp1 : Op1;
1614 for (
int I = 0;
I != 2; ++
I) {
1617 SDValue Alt =
Op.getOperand(1 -
I).getOperand(0);
1618 SDValue C2 =
Op.getOperand(1 -
I).getOperand(1);
1620 for (
int J = 0; J != 2; ++J) {
1673 if (
C->getAPIntValue() == Known2.
One) {
1682 if (!
C->isAllOnes() &&
DemandedBits.isSubsetOf(
C->getAPIntValue())) {
1694 if (ShiftC->getAPIntValue().ult(
BitWidth)) {
1695 uint64_t ShiftAmt = ShiftC->getZExtValue();
1698 : Ones.
lshr(ShiftAmt);
1715 if (!
C || !
C->isAllOnes())
1725 if (DemandedOp0 || DemandedOp1) {
1726 Op0 = DemandedOp0 ? DemandedOp0 : Op0;
1727 Op1 = DemandedOp1 ? DemandedOp1 : Op1;
1738 Known, TLO,
Depth + 1))
1741 Known2, TLO,
Depth + 1))
1753 Known, TLO,
Depth + 1))
1756 Known2, TLO,
Depth + 1))
1764 Known, TLO,
Depth + 1))
1767 Known2, TLO,
Depth + 1))
1791 DemandedElts, KnownOp0, TLO,
Depth + 1))
1822 if (std::optional<unsigned> KnownSA =
1824 unsigned ShAmt = *KnownSA;
1834 if (std::optional<unsigned> InnerSA =
1836 unsigned C1 = *InnerSA;
1838 int Diff = ShAmt - C1;
1857 if (ShAmt < InnerBits &&
DemandedBits.getActiveBits() <= InnerBits &&
1875 InnerOp, DemandedElts,
Depth + 2)) {
1876 unsigned InnerShAmt = *SA2;
1877 if (InnerShAmt < ShAmt && InnerShAmt < InnerBits &&
1879 (InnerBits - InnerShAmt + ShAmt) &&
1907 Op0, InDemandedMask, DemandedElts, TLO.
DAG,
Depth + 1);
1918 Op.getNode()->hasOneUse()) {
1929 assert(DemandedSize <= SmallVTBits &&
1930 "Narrowed below demanded bits?");
1960 Flags.setNoUnsignedWrap(IsNUW);
1965 NewShiftAmt, Flags);
1991 if (std::optional<unsigned> MaxSA =
1993 unsigned ShAmt = *MaxSA;
1994 unsigned NumSignBits =
1997 if (NumSignBits > ShAmt && (NumSignBits - ShAmt) >= (UpperDemandedBits))
2007 if (std::optional<unsigned> KnownSA =
2009 unsigned ShAmt = *KnownSA;
2019 if (std::optional<unsigned> InnerSA =
2021 unsigned C1 = *InnerSA;
2023 int Diff = ShAmt - C1;
2039 if (std::optional<unsigned> InnerSA =
2041 unsigned C1 = *InnerSA;
2043 unsigned Combined = std::min(C1 + ShAmt,
BitWidth - 1);
2055 if (
Op->getFlags().hasExact())
2090 Op0, InDemandedMask, DemandedElts, TLO.
DAG,
Depth + 1);
2104 if (std::optional<unsigned> MaxSA =
2106 unsigned ShAmt = *MaxSA;
2110 unsigned NumSignBits =
2119 DemandedElts,
Depth + 1))
2143 if (std::optional<unsigned> KnownSA =
2145 unsigned ShAmt = *KnownSA;
2152 if (std::optional<unsigned> InnerSA =
2154 unsigned LowBits =
BitWidth - ShAmt;
2159 if (*InnerSA == ShAmt) {
2169 unsigned NumSignBits =
2171 if (NumSignBits > ShAmt)
2181 if (
Op->getFlags().hasExact())
2218 Op0, InDemandedMask, DemandedElts, TLO.
DAG,
Depth + 1);
2228 DemandedElts,
Depth + 1))
2241 unsigned Amt = SA->getAPIntValue().urem(
BitWidth);
2247 Known, TLO,
Depth + 1))
2263 Known2 <<= (IsFSHL ? Amt : (
BitWidth - Amt));
2264 Known >>= (IsFSHL ? (
BitWidth - Amt) : Amt);
2271 Op0, Demanded0, DemandedElts, TLO.
DAG,
Depth + 1);
2273 Op1, Demanded1, DemandedElts, TLO.
DAG,
Depth + 1);
2274 if (DemandedOp0 || DemandedOp1) {
2275 DemandedOp0 = DemandedOp0 ? DemandedOp0 : Op0;
2276 DemandedOp1 = DemandedOp1 ? DemandedOp1 : Op1;
2292 unsigned MaxShiftAmt =
2324 unsigned Amt = SA->getAPIntValue().urem(
BitWidth);
2340 DemandedBits.countr_zero() >= (IsROTL ? Amt : RevAmt)) {
2345 DemandedBits.countl_zero() >= (IsROTL ? RevAmt : Amt)) {
2364 unsigned Opc =
Op.getOpcode();
2371 unsigned NumSignBits =
2375 if (NumSignBits >= NumDemandedUpperBits)
2441 unsigned ShiftAmount = NLZ > NTZ ? NLZ - NTZ : NTZ - NLZ;
2470 unsigned DemandedBitsLZ = OriginalDemandedBits.
countl_zero();
2501 unsigned MinSignedBits =
2503 bool AlreadySignExtended = ExVTBits >= MinSignedBits;
2506 if (!AlreadySignExtended) {
2524 InputDemandedBits.
setBit(ExVTBits - 1);
2534 if (Known.
Zero[ExVTBits - 1])
2538 if (Known.
One[ExVTBits - 1]) {
2548 EVT HalfVT =
Op.getOperand(0).getValueType();
2562 Known = KnownHi.
concat(KnownLo);
2571 EVT SrcVT = Src.getValueType();
2580 if (IsLE && IsVecInReg && DemandedElts == 1 &&
2591 APInt InDemandedElts = DemandedElts.
zext(InElts);
2602 Src, InDemandedBits, InDemandedElts, TLO.
DAG,
Depth + 1))
2612 EVT SrcVT = Src.getValueType();
2617 APInt InDemandedElts = DemandedElts.
zext(InElts);
2622 InDemandedBits.
setBit(InBits - 1);
2628 if (IsLE && IsVecInReg && DemandedElts == 1 &&
2665 Src, InDemandedBits, InDemandedElts, TLO.
DAG,
Depth + 1))
2675 EVT SrcVT = Src.getValueType();
2682 if (IsLE && IsVecInReg && DemandedElts == 1 &&
2687 APInt InDemandedElts = DemandedElts.
zext(InElts);
2696 Src, InDemandedBits, InDemandedElts, TLO.
DAG,
Depth + 1))
2705 unsigned OperandBitWidth = Src.getScalarValueSizeInBits();
2718 Src, TruncMask, DemandedElts, TLO.
DAG,
Depth + 1))
2723 switch (Src.getOpcode()) {
2734 if (Src.getNode()->hasOneUse()) {
2746 std::optional<unsigned> ShAmtC =
2748 if (!ShAmtC || *ShAmtC >=
BitWidth)
2750 unsigned ShVal = *ShAmtC;
2780 Known.
Zero |= ~InMask;
2781 Known.
One &= (~Known.Zero);
2787 ElementCount SrcEltCnt = Src.getValueType().getVectorElementCount();
2788 unsigned EltBitWidth = Src.getScalarValueSizeInBits();
2797 if (CIdx->getAPIntValue().ult(NumSrcElts))
2804 DemandedSrcBits = DemandedSrcBits.
trunc(EltBitWidth);
2813 Src, DemandedSrcBits, DemandedSrcElts, TLO.
DAG,
Depth + 1)) {
2815 TLO.
DAG.
getNode(
Op.getOpcode(), dl, VT, DemandedSrc, Idx);
2829 EVT SrcVT = Src.getValueType();
2841 unsigned ShVal =
Op.getValueSizeInBits() - 1;
2851 unsigned Scale =
BitWidth / NumSrcEltBits;
2854 for (
unsigned i = 0; i != Scale; ++i) {
2855 unsigned EltOffset = IsLE ? i : (Scale - 1 - i);
2856 unsigned BitOffset = EltOffset * NumSrcEltBits;
2857 DemandedSrcBits |=
DemandedBits.extractBits(NumSrcEltBits, BitOffset);
2864 APInt KnownSrcUndef, KnownSrcZero;
2866 KnownSrcZero, TLO,
Depth + 1))
2871 KnownSrcBits, TLO,
Depth + 1))
2873 }
else if (IsLE && (NumSrcEltBits %
BitWidth) == 0) {
2875 unsigned Scale = NumSrcEltBits /
BitWidth;
2879 for (
unsigned i = 0; i != NumElts; ++i)
2880 if (DemandedElts[i]) {
2883 DemandedSrcElts.
setBit(i / Scale);
2887 APInt KnownSrcUndef, KnownSrcZero;
2889 KnownSrcZero, TLO,
Depth + 1))
2895 KnownSrcBits, TLO,
Depth + 1))
2901 Src, DemandedSrcBits, DemandedSrcElts, TLO.
DAG,
Depth + 1)) {
2923 if (
C &&
C->getAPIntValue().countr_zero() == CTZ) {
2939 if (
Op.getOperand(0).getValueType() !=
Op.getOperand(1).getValueType())
2947 SDValue Op0 =
Op.getOperand(0), Op1 =
Op.getOperand(1);
2952 auto GetDemandedBitsLHSMask = [&](
APInt Demanded,
2961 DemandedElts, KnownOp0, TLO,
Depth + 1) ||
2978 Op0, LoMask, DemandedElts, TLO.
DAG,
Depth + 1);
2980 Op1, LoMask, DemandedElts, TLO.
DAG,
Depth + 1);
2981 if (DemandedOp0 || DemandedOp1) {
2982 Op0 = DemandedOp0 ? DemandedOp0 : Op0;
2983 Op1 = DemandedOp1 ? DemandedOp1 : Op1;
2997 if (
C && !
C->isAllOnes() && !
C->isOne() &&
2998 (
C->getAPIntValue() | HighMask).isAllOnes()) {
3010 auto getShiftLeftAmt = [&HighMask](
SDValue Mul) ->
unsigned {
3037 if (
unsigned ShAmt = getShiftLeftAmt(Op0))
3040 if (
unsigned ShAmt = getShiftLeftAmt(Op1))
3041 return foldMul(
ISD::SUB, Op1.getOperand(0), Op0, ShAmt);
3045 if (
unsigned ShAmt = getShiftLeftAmt(Op1))
3046 return foldMul(
ISD::ADD, Op1.getOperand(0), Op0, ShAmt);
3054 Op.getOpcode() !=
ISD::SUB, Flags.hasNoSignedWrap(),
3055 Flags.hasNoUnsignedWrap(), KnownOp0, KnownOp1);
3076 Known.
Zero |= SignMask;
3077 Known.
One &= ~SignMask;
3094 Known, TLO,
Depth + 1) ||
3108 Known.
Zero &= ~SignMask0;
3109 Known.
One &= ~SignMask0;
3124 Known.
Zero ^= SignMask;
3125 Known.
One ^= SignMask;
3136 if (
Op.getValueType().isScalableVector())
3155 auto *C = dyn_cast<ConstantSDNode>(V);
3156 return C && C->isOpaque();
3177 const APInt &DemandedElts,
3183 APInt KnownUndef, KnownZero;
3197 const APInt &UndefOp0,
3198 const APInt &UndefOp1) {
3201 "Vector binop only");
3206 UndefOp1.
getBitWidth() == NumElts &&
"Bad type for undef analysis");
3208 auto getUndefOrConstantElt = [&](
SDValue V,
unsigned Index,
3209 const APInt &UndefVals) {
3210 if (UndefVals[Index])
3226 for (
unsigned i = 0; i != NumElts; ++i) {
3245 bool AssumeSingleUse)
const {
3246 EVT VT =
Op.getValueType();
3247 unsigned Opcode =
Op.getOpcode();
3248 APInt DemandedElts = OriginalDemandedElts;
3262 "Mask size mismatches value type element count!");
3271 if (!AssumeSingleUse && !
Op.getNode()->hasOneUse())
3275 if (DemandedElts == 0) {
3290 auto SimplifyDemandedVectorEltsBinOp = [&](
SDValue Op0,
SDValue Op1) {
3295 if (NewOp0 || NewOp1) {
3298 NewOp1 ? NewOp1 : Op1,
Op->getFlags());
3306 if (!DemandedElts[0]) {
3315 EVT SrcVT = Src.getValueType();
3322 for (
unsigned I = 0;
I != NumElts; ++
I) {
3323 if (DemandedElts[
I]) {
3324 unsigned Offset =
I * EltSize;
3337 if (NumSrcElts == NumElts)
3339 KnownZero, TLO,
Depth + 1);
3341 APInt SrcDemandedElts, SrcZero, SrcUndef;
3345 if ((NumElts % NumSrcElts) == 0) {
3346 unsigned Scale = NumElts / NumSrcElts;
3358 for (
unsigned i = 0; i != NumElts; ++i)
3359 if (DemandedElts[i]) {
3360 unsigned Ofs = (i % Scale) * EltSizeInBits;
3361 SrcDemandedBits.
setBits(Ofs, Ofs + EltSizeInBits);
3373 for (
unsigned SubElt = 0; SubElt != Scale; ++SubElt) {
3377 for (
unsigned SrcElt = 0; SrcElt != NumSrcElts; ++SrcElt) {
3378 unsigned Elt = Scale * SrcElt + SubElt;
3379 if (DemandedElts[Elt])
3387 for (
unsigned i = 0; i != NumSrcElts; ++i) {
3388 if (SrcDemandedElts[i]) {
3390 KnownZero.
setBits(i * Scale, (i + 1) * Scale);
3392 KnownUndef.
setBits(i * Scale, (i + 1) * Scale);
3400 if ((NumSrcElts % NumElts) == 0) {
3401 unsigned Scale = NumSrcElts / NumElts;
3409 for (
unsigned i = 0; i != NumElts; ++i) {
3410 if (DemandedElts[i]) {
3439 [&](
SDValue Elt) { return Op.getOperand(0) != Elt; })) {
3441 bool Updated =
false;
3442 for (
unsigned i = 0; i != NumElts; ++i) {
3453 for (
unsigned i = 0; i != NumElts; ++i) {
3455 if (
SrcOp.isUndef()) {
3457 }
else if (EltSizeInBits ==
SrcOp.getScalarValueSizeInBits() &&
3465 EVT SubVT =
Op.getOperand(0).getValueType();
3466 unsigned NumSubVecs =
Op.getNumOperands();
3468 for (
unsigned i = 0; i != NumSubVecs; ++i) {
3471 APInt SubUndef, SubZero;
3475 KnownUndef.
insertBits(SubUndef, i * NumSubElts);
3476 KnownZero.
insertBits(SubZero, i * NumSubElts);
3481 bool FoundNewSub =
false;
3483 for (
unsigned i = 0; i != NumSubVecs; ++i) {
3487 SubOp, SubElts, TLO.
DAG,
Depth + 1);
3488 DemandedSubOps.
push_back(NewSubOp ? NewSubOp : SubOp);
3489 FoundNewSub = NewSubOp ?
true : FoundNewSub;
3505 unsigned NumSubElts =
Sub.getValueType().getVectorNumElements();
3507 APInt DemandedSrcElts = DemandedElts;
3508 DemandedSrcElts.
clearBits(Idx, Idx + NumSubElts);
3511 if (!DemandedSubElts)
3514 APInt SubUndef, SubZero;
3520 if (!DemandedSrcElts && !Src.isUndef())
3534 Src, DemandedSrcElts, TLO.
DAG,
Depth + 1);
3537 if (NewSrc || NewSub) {
3538 NewSrc = NewSrc ? NewSrc : Src;
3539 NewSub = NewSub ? NewSub :
Sub;
3541 NewSub,
Op.getOperand(2));
3550 if (Src.getValueType().isScalableVector())
3553 unsigned NumSrcElts = Src.getValueType().getVectorNumElements();
3554 APInt DemandedSrcElts = DemandedElts.
zext(NumSrcElts).
shl(Idx);
3556 APInt SrcUndef, SrcZero;
3580 if (CIdx && CIdx->getAPIntValue().ult(NumElts)) {
3581 unsigned Idx = CIdx->getZExtValue();
3582 if (!DemandedElts[Idx])
3585 APInt DemandedVecElts(DemandedElts);
3588 KnownZero, TLO,
Depth + 1))
3597 APInt VecUndef, VecZero;
3611 APInt UndefSel, ZeroSel;
3617 APInt DemandedLHS(DemandedElts);
3618 APInt DemandedRHS(DemandedElts);
3619 APInt UndefLHS, ZeroLHS;
3620 APInt UndefRHS, ZeroRHS;
3628 KnownUndef = UndefLHS & UndefRHS;
3629 KnownZero = ZeroLHS & ZeroRHS;
3633 APInt DemandedSel = DemandedElts & ~KnownZero;
3634 if (DemandedSel != DemandedElts)
3647 APInt DemandedLHS(NumElts, 0);
3648 APInt DemandedRHS(NumElts, 0);
3649 for (
unsigned i = 0; i != NumElts; ++i) {
3650 int M = ShuffleMask[i];
3651 if (M < 0 || !DemandedElts[i])
3653 assert(0 <= M && M < (
int)(2 * NumElts) &&
"Shuffle index out of range");
3654 if (M < (
int)NumElts)
3657 DemandedRHS.
setBit(M - NumElts);
3663 bool FoldLHS = !DemandedLHS && !LHS.isUndef();
3664 bool FoldRHS = !DemandedRHS && !RHS.isUndef();
3665 if (FoldLHS || FoldRHS) {
3666 LHS = FoldLHS ? TLO.
DAG.
getUNDEF(LHS.getValueType()) : LHS;
3667 RHS = FoldRHS ? TLO.
DAG.
getUNDEF(RHS.getValueType()) : RHS;
3674 APInt UndefLHS, ZeroLHS;
3675 APInt UndefRHS, ZeroRHS;
3684 bool Updated =
false;
3685 bool IdentityLHS =
true, IdentityRHS =
true;
3687 for (
unsigned i = 0; i != NumElts; ++i) {
3688 int &M = NewMask[i];
3691 if (!DemandedElts[i] || (M < (
int)NumElts && UndefLHS[M]) ||
3692 (M >= (
int)NumElts && UndefRHS[M - NumElts])) {
3696 IdentityLHS &= (M < 0) || (M == (
int)i);
3697 IdentityRHS &= (M < 0) || ((M - NumElts) == i);
3702 if (Updated && !IdentityLHS && !IdentityRHS && !TLO.
LegalOps) {
3710 for (
unsigned i = 0; i != NumElts; ++i) {
3711 int M = ShuffleMask[i];
3714 }
else if (M < (
int)NumElts) {
3720 if (UndefRHS[M - NumElts])
3722 if (ZeroRHS[M - NumElts])
3731 APInt SrcUndef, SrcZero;
3733 unsigned NumSrcElts = Src.getValueType().getVectorNumElements();
3734 APInt DemandedSrcElts = DemandedElts.
zext(NumSrcElts);
3742 Op.getValueSizeInBits() == Src.getValueSizeInBits() &&
3743 DemandedSrcElts == 1) {
3756 if (IsLE && DemandedSrcElts == 1 && Src.getOpcode() ==
ISD::AND &&
3757 Op->isOnlyUserOf(Src.getNode()) &&
3758 Op.getValueSizeInBits() == Src.getValueSizeInBits()) {
3760 EVT SrcVT = Src.getValueType();
3774 ISD::AND,
DL, SrcVT, {Src.getOperand(1), Mask})) {
3788 if (Op0 == Op1 &&
Op->isOnlyUserOf(Op0.
getNode())) {
3789 APInt UndefLHS, ZeroLHS;
3811 APInt UndefRHS, ZeroRHS;
3815 APInt UndefLHS, ZeroLHS;
3820 KnownZero = ZeroLHS & ZeroRHS;
3826 if (SimplifyDemandedVectorEltsBinOp(Op0, Op1))
3838 APInt UndefRHS, ZeroRHS;
3842 APInt UndefLHS, ZeroLHS;
3847 KnownZero = ZeroLHS;
3848 KnownUndef = UndefLHS & UndefRHS;
3853 if (SimplifyDemandedVectorEltsBinOp(Op0, Op1))
3864 APInt SrcUndef, SrcZero;
3878 KnownUndef &= DemandedElts;
3879 KnownZero &= DemandedElts;
3884 if (DemandedElts.
isSubsetOf(SrcZero | KnownZero | SrcUndef | KnownUndef))
3891 KnownZero |= SrcZero;
3892 KnownUndef &= SrcUndef;
3893 KnownUndef &= ~KnownZero;
3897 if (SimplifyDemandedVectorEltsBinOp(Op0, Op1))
3905 KnownZero, TLO,
Depth + 1))
3910 Op.getOperand(0), DemandedElts, TLO.
DAG,
Depth + 1))
3925 KnownZero, TLO,
Depth + 1))
3932 KnownZero, TLO,
Depth))
3938 TLO,
Depth, AssumeSingleUse))
3944 assert((KnownUndef & KnownZero) == 0 &&
"Elements flagged as undef AND zero");
3958 const APInt &DemandedElts,
3960 unsigned Depth)
const {
3965 "Should use MaskedValueIsZero if you don't know whether Op"
3966 " is a target node!");
3973 unsigned Depth)
const {
3980 unsigned Depth)
const {
3992 unsigned Depth)
const {
4001 unsigned Depth)
const {
4006 "Should use ComputeNumSignBits if you don't know whether Op"
4007 " is a target node!");
4024 "Should use SimplifyDemandedVectorElts if you don't know whether Op"
4025 " is a target node!");
4036 "Should use SimplifyDemandedBits if you don't know whether Op"
4037 " is a target node!");
4050 "Should use SimplifyMultipleUseDemandedBits if you don't know whether Op"
4051 " is a target node!");
4084 "Should use isGuaranteedNotToBeUndefOrPoison if you don't know whether Op"
4085 " is a target node!");
4092 return DAG.isGuaranteedNotToBeUndefOrPoison(V, Kind, Depth + 1);
4103 "Should use canCreateUndefOrPoison if you don't know whether Op"
4104 " is a target node!");
4111 const APInt &DemandedElts,
4113 unsigned Depth)
const {
4118 "Should use computeKnownFPClass if you don't know whether Op"
4119 " is a target node!");
4123 const APInt &DemandedElts,
4126 unsigned Depth)
const {
4131 "Should use isKnownNeverNaN if you don't know whether Op"
4132 " is a target node!");
4137 const APInt &DemandedElts,
4140 unsigned Depth)
const {
4145 "Should use isSplatValue if you don't know whether Op"
4146 " is a target node!");
4161 CVal = CN->getAPIntValue();
4162 EltWidth =
N.getValueType().getScalarSizeInBits();
4169 CVal = CVal.
trunc(EltWidth);
4175 return CVal.
isOne();
4217 return (
N->isOne() && !SExt) || (SExt && (
N->getValueType(0) != MVT::i1));
4220 return N->isAllOnes() && SExt;
4229 DAGCombinerInfo &DCI)
const {
4258 if (AndC &&
isNullConstant(N1) && AndC->getAPIntValue().isPowerOf2() &&
4261 AndC->getAPIntValue().getActiveBits());
4288 if (isXAndYEqZeroPreferableToXAndYEqY(
Cond, OpVT) &&
4296 if (DCI.isBeforeLegalizeOps() ||
4325 DAGCombinerInfo &DCI)
const {
4329 SelectionDAG &DAG = DCI.DAG;
4366SDValue TargetLowering::optimizeSetCCOfSignedTruncationCheck(
4368 const SDLoc &
DL)
const {
4379 ConstantSDNode *C01;
4408 auto checkConstants = [&
I1, &I01]() ->
bool {
4413 if (checkConstants()) {
4421 if (!checkConstants())
4427 const unsigned KeptBits =
I1.logBase2();
4428 const unsigned KeptBitsMinusOne = I01.
logBase2();
4431 if (KeptBits != (KeptBitsMinusOne + 1))
4436 SelectionDAG &DAG = DCI.DAG;
4445 return DAG.
getSetCC(
DL, SCCVT, SExtInReg,
X, NewCond);
4449SDValue TargetLowering::optimizeSetCCByHoistingAndByConstFromLogicalShift(
4451 DAGCombinerInfo &DCI,
const SDLoc &
DL)
const {
4453 "Should be a comparison with 0.");
4455 "Valid only for [in]equality comparisons.");
4457 unsigned NewShiftOpcode;
4460 SelectionDAG &DAG = DCI.DAG;
4463 auto Match = [&NewShiftOpcode, &
X, &
C, &
Y, &DAG,
this](
SDValue V) {
4467 unsigned OldShiftOpcode =
V.getOpcode();
4468 switch (OldShiftOpcode) {
4480 C =
V.getOperand(0);
4481 ConstantSDNode *CC =
4485 Y =
V.getOperand(1);
4487 ConstantSDNode *XC =
4490 X, XC, CC,
Y, OldShiftOpcode, NewShiftOpcode, DAG);
4507 EVT VT =
X.getValueType();
4522 DAGCombinerInfo &DCI)
const {
4525 "Unexpected binop");
4531 SelectionDAG &DAG = DCI.DAG;
4553 if (!DCI.isCalledByLegalizer())
4554 DCI.AddToWorklist(YShl1.
getNode());
4569 if (CTPOP.getOpcode() !=
ISD::CTPOP || !CTPOP.hasOneUse())
4572 EVT CTVT = CTPOP.getValueType();
4573 SDValue CTOp = CTPOP.getOperand(0);
4593 for (
unsigned i = 0; i <
Passes; i++) {
4642 auto getRotateSource = [](
SDValue X) {
4644 return X.getOperand(0);
4651 if (
SDValue R = getRotateSource(N0))
4684 if (!C1 || !C1->
isZero())
4709 if (
Or.getOperand(0) ==
Other) {
4710 X =
Or.getOperand(0);
4711 Y =
Or.getOperand(1);
4714 if (
Or.getOperand(1) ==
Other) {
4715 X =
Or.getOperand(1);
4716 Y =
Or.getOperand(0);
4726 if (matchOr(F0, F1)) {
4733 if (matchOr(F1, F0)) {
4749 const SDLoc &dl)
const {
4759 bool N0ConstOrSplat =
4761 bool N1ConstOrSplat =
4769 if (N0ConstOrSplat && !N1ConstOrSplat &&
4772 return DAG.
getSetCC(dl, VT, N1, N0, SwappedCC);
4778 if (!N0ConstOrSplat && !N1ConstOrSplat &&
4783 return DAG.
getSetCC(dl, VT, N1, N0, SwappedCC);
4792 const APInt &C1 = N1C->getAPIntValue();
4808 !Attr.hasFnAttr(Attribute::MinSize)) {
4812 return DAG.
getNode(LogicOp, dl, VT, IsXZero, IsYZero);
4858 const APInt &C1 = N1C->getAPIntValue();
4874 if ((
C->getAPIntValue()+1).isPowerOf2()) {
4875 MinBits =
C->getAPIntValue().countr_one();
4886 MinBits = LN0->getMemoryVT().getSizeInBits();
4890 MinBits = LN0->getMemoryVT().getSizeInBits();
4901 MinBits >= ReqdBits) {
4906 if (MinBits == 1 && C1 == 1)
4925 if (TopSetCC.
getValueType() == MVT::i1 && VT == MVT::i1 &&
4959 unsigned bestWidth = 0, bestOffset = 0;
4960 if (Lod->isSimple() && Lod->isUnindexed() &&
4961 (Lod->getMemoryVT().isByteSized() ||
4963 unsigned memWidth = Lod->getMemoryVT().getStoreSizeInBits();
4965 unsigned maskWidth = origWidth;
4969 origWidth = Lod->getMemoryVT().getSizeInBits();
4973 for (
unsigned width = 8; width < origWidth; width *= 2) {
4978 unsigned maxOffset = origWidth - width;
4979 for (
unsigned offset = 0; offset <= maxOffset; offset += 8) {
4980 if (Mask.isSubsetOf(newMask)) {
4981 unsigned ptrOffset =
4983 unsigned IsFast = 0;
4984 assert((ptrOffset % 8) == 0 &&
"Non-Bytealigned pointer offset");
4989 *DAG.
getContext(), Layout, newVT, Lod->getAddressSpace(),
4990 NewAlign, Lod->getMemOperand()->getFlags(), &IsFast) &&
4992 bestOffset = ptrOffset / 8;
4993 bestMask = Mask.lshr(offset);
5006 SDValue Ptr = Lod->getBasePtr();
5007 if (bestOffset != 0)
5010 DAG.
getLoad(newVT, dl, Lod->getChain(), Ptr,
5011 Lod->getPointerInfo().getWithOffset(bestOffset),
5012 Lod->getBaseAlign());
5091 ExtDstTy != ExtSrcTy &&
"Unexpected types!");
5098 return DAG.
getSetCC(dl, VT, ZextOp,
5100 }
else if ((N1C->isZero() || N1C->isOne()) &&
5147 return DAG.
getSetCC(dl, VT, Val, N1,
5150 }
else if (N1C->isOne()) {
5233 optimizeSetCCOfSignedTruncationCheck(VT, N0, N1,
Cond, DCI, dl))
5240 const APInt &C1 = N1C->getAPIntValue();
5242 APInt MinVal, MaxVal;
5264 (!N1C->isOpaque() || (
C.getBitWidth() <= 64 &&
5284 (!N1C->isOpaque() || (
C.getBitWidth() <= 64 &&
5332 if (
SDValue CC = optimizeSetCCByHoistingAndByConstFromLogicalShift(
5333 VT, N0, N1,
Cond, DCI, dl))
5340 bool CmpZero = N1C->isZero();
5341 bool CmpNegOne = N1C->isAllOnes();
5342 if ((CmpZero || CmpNegOne) && N0.
hasOneUse()) {
5345 unsigned EltBits = V.getScalarValueSizeInBits();
5346 if (V.getOpcode() !=
ISD::OR || (EltBits % 2) != 0)
5354 RHS.getConstantOperandAPInt(1) == (EltBits / 2) &&
5357 Hi = RHS.getOperand(0);
5362 LHS.getConstantOperandAPInt(1) == (EltBits / 2) &&
5365 Hi = LHS.getOperand(0);
5373 unsigned HalfBits = EltBits / 2;
5384 if (IsConcat(N0,
Lo,
Hi))
5385 return MergeConcat(
Lo,
Hi);
5423 const APInt &C1 = N1C->getAPIntValue();
5438 unsigned ShCt = AndRHS->getAPIntValue().logBase2();
5439 if (AndRHS->getAPIntValue().isPowerOf2() &&
5446 }
else if (
Cond ==
ISD::SETEQ && C1 == AndRHS->getAPIntValue()) {
5466 const APInt &AndRHSC = AndRHS->getAPIntValue();
5518 return DAG.
getSetCC(dl, VT, Shift, CmpRHS, NewCond);
5526 assert(!CFP->getValueAPF().isNaN() &&
"Unexpected NaN value");
5547 !
isFPImmLegal(CFP->getValueAPF(), CFP->getValueType(0))) {
5566 if (CFP->getValueAPF().isInfinity()) {
5567 bool IsNegInf = CFP->getValueAPF().isNegative();
5578 return DAG.
getSetCC(dl, VT, N0, N1, NewCond);
5587 "Integer types should be handled by FoldSetCC");
5593 if (UOF ==
unsigned(EqTrue))
5598 if (NewCond !=
Cond &&
5601 return DAG.
getSetCC(dl, VT, N0, N1, NewCond);
5608 if ((isSignedIntSetCC(
Cond) || isUnsignedIntSetCC(
Cond)) &&
5645 bool LegalRHSImm =
false;
5653 DAG.
getConstant(RHSC->getAPIntValue() - LHSR->getAPIntValue(),
5661 DAG.
getConstant(LHSR->getAPIntValue() ^ RHSC->getAPIntValue(),
5671 DAG.
getConstant(SUBC->getAPIntValue() - RHSC->getAPIntValue(),
5676 if (RHSC->getValueType(0).getSizeInBits() <= 64)
5685 if (
SDValue V = foldSetCCWithBinOp(VT, N0, N1,
Cond, dl, DCI))
5691 if (
SDValue V = foldSetCCWithBinOp(VT, N1, N0,
Cond, dl, DCI))
5694 if (
SDValue V = foldSetCCWithAnd(VT, N0, N1,
Cond, dl, DCI))
5697 if (
SDValue V = foldSetCCWithOr(VT, N0, N1,
Cond, dl, DCI))
5706 if (!
isIntDivCheap(VT, Attr) && !Attr.hasFnAttr(Attribute::MinSize)) {
5708 if (
SDValue Folded = buildUREMEqFold(VT, N0, N1,
Cond, DCI, dl))
5711 if (
SDValue Folded = buildSREMEqFold(VT, N0, N1,
Cond, DCI, dl))
5724 N0 = DAG.
getNOT(dl, Temp, OpVT);
5733 Temp = DAG.
getNOT(dl, N0, OpVT);
5740 Temp = DAG.
getNOT(dl, N1, OpVT);
5747 Temp = DAG.
getNOT(dl, N0, OpVT);
5754 Temp = DAG.
getNOT(dl, N1, OpVT);
5763 N0 = DAG.
getNode(ExtendCode, dl, VT, N0);
5798 GA = GASD->getGlobal();
5799 Offset += GASD->getOffset();
5803 if (
N->isAnyAdd()) {
5808 Offset += V->getSExtValue();
5813 Offset += V->getSExtValue();
5834 unsigned S = Constraint.
size();
5837 switch (Constraint[0]) {
5868 if (S > 1 && Constraint[0] ==
'{' && Constraint[S - 1] ==
'}') {
5869 if (S == 8 && Constraint.
substr(1, 6) ==
"memory")
5897 std::vector<SDValue> &
Ops,
5900 if (Constraint.
size() > 1)
5903 char ConstraintLetter = Constraint[0];
5904 switch (ConstraintLetter) {
5924 bool IsBool =
C->getConstantIntValue()->getBitWidth() == 1;
5934 if (ConstraintLetter !=
'n') {
5937 GA->getValueType(0),
5938 Offset + GA->getOffset()));
5943 BA->getBlockAddress(), BA->getValueType(0),
5944 Offset + BA->getOffset(), BA->getTargetFlags()));
5952 const unsigned OpCode =
Op.getOpcode();
5955 Op =
Op.getOperand(1);
5959 Op =
Op.getOperand(0);
5976std::pair<unsigned, const TargetRegisterClass *>
5982 assert(*(Constraint.
end() - 1) ==
'}' &&
"Not a brace enclosed constraint?");
5987 std::pair<unsigned, const TargetRegisterClass *> R =
5999 std::pair<unsigned, const TargetRegisterClass *> S =
6000 std::make_pair(PR, RC);
6045 unsigned maCount = 0;
6051 unsigned LabelNo = 0;
6054 ConstraintOperands.emplace_back(std::move(CI));
6058 if (OpInfo.multipleAlternatives.size() > maCount)
6059 maCount = OpInfo.multipleAlternatives.size();
6061 OpInfo.ConstraintVT = MVT::Other;
6064 switch (OpInfo.Type) {
6067 if (OpInfo.isIndirect) {
6068 OpInfo.CallOperandVal =
Call.getArgOperand(ArgNo);
6074 assert(!
Call.getType()->isVoidTy() &&
"Bad inline asm!");
6079 assert(ResNo == 0 &&
"Asm only has one result!");
6087 OpInfo.CallOperandVal =
Call.getArgOperand(ArgNo);
6098 if (OpInfo.CallOperandVal) {
6099 llvm::Type *OpTy = OpInfo.CallOperandVal->getType();
6100 if (OpInfo.isIndirect) {
6101 OpTy =
Call.getParamElementType(ArgNo);
6102 assert(OpTy &&
"Indirect operand must have elementtype attribute");
6107 if (STy->getNumElements() == 1)
6108 OpTy = STy->getElementType(0);
6113 unsigned BitSize =
DL.getTypeSizeInBits(OpTy);
6134 if (!ConstraintOperands.empty()) {
6136 unsigned bestMAIndex = 0;
6137 int bestWeight = -1;
6143 for (maIndex = 0; maIndex < maCount; ++maIndex) {
6145 for (
unsigned cIndex = 0, eIndex = ConstraintOperands.size();
6146 cIndex != eIndex; ++cIndex) {
6155 if (OpInfo.hasMatchingInput()) {
6157 if (OpInfo.ConstraintVT !=
Input.ConstraintVT) {
6158 if ((OpInfo.ConstraintVT.isInteger() !=
6159 Input.ConstraintVT.isInteger()) ||
6160 (OpInfo.ConstraintVT.getSizeInBits() !=
6161 Input.ConstraintVT.getSizeInBits())) {
6172 weightSum += weight;
6175 if (weightSum > bestWeight) {
6176 bestWeight = weightSum;
6177 bestMAIndex = maIndex;
6184 cInfo.selectAlternative(bestMAIndex);
6189 for (
unsigned cIndex = 0, eIndex = ConstraintOperands.size();
6190 cIndex != eIndex; ++cIndex) {
6197 if (OpInfo.hasMatchingInput()) {
6200 if (OpInfo.ConstraintVT !=
Input.ConstraintVT) {
6201 std::pair<unsigned, const TargetRegisterClass *> MatchRC =
6203 OpInfo.ConstraintVT);
6204 std::pair<unsigned, const TargetRegisterClass *> InputRC =
6206 Input.ConstraintVT);
6207 const bool OutOpIsIntOrFP = OpInfo.ConstraintVT.isInteger() ||
6208 OpInfo.ConstraintVT.isFloatingPoint();
6209 const bool InOpIsIntOrFP =
Input.ConstraintVT.isInteger() ||
6210 Input.ConstraintVT.isFloatingPoint();
6211 if ((OutOpIsIntOrFP != InOpIsIntOrFP) ||
6212 (MatchRC.second != InputRC.second)) {
6214 " with a matching output constraint of"
6215 " incompatible type!");
6221 return ConstraintOperands;
6256 if (maIndex >= (
int)
info.multipleAlternatives.size())
6257 rCodes = &
info.Codes;
6259 rCodes = &
info.multipleAlternatives[maIndex].Codes;
6263 for (
const std::string &rCode : *rCodes) {
6266 if (weight > BestWeight)
6267 BestWeight = weight;
6280 Value *CallOperandVal =
info.CallOperandVal;
6283 if (!CallOperandVal)
6286 switch (*constraint) {
6350 Ret.
reserve(OpInfo.Codes.size());
6383 "need immediate or other");
6388 std::vector<SDValue> ResultOps;
6390 return !ResultOps.empty();
6398 assert(!OpInfo.Codes.empty() &&
"Must have at least one constraint");
6401 if (OpInfo.Codes.size() == 1) {
6402 OpInfo.ConstraintCode = OpInfo.Codes[0];
6409 unsigned BestIdx = 0;
6410 for (
const unsigned E =
G.size();
6417 if (BestIdx + 1 == E) {
6423 OpInfo.ConstraintCode =
G[BestIdx].first;
6424 OpInfo.ConstraintType =
G[BestIdx].second;
6428 if (OpInfo.ConstraintCode ==
"X" && OpInfo.CallOperandVal) {
6432 Value *v = OpInfo.CallOperandVal;
6438 OpInfo.ConstraintCode =
"i";
6445 OpInfo.ConstraintCode = Repl;
6459 EVT VT =
N->getValueType(0);
6463 bool UseSRA =
false;
6470 EVT CT =
C->getValueType(0);
6471 APInt Divisor =
C->getAPIntValue();
6493 "Expected matchUnaryPredicate to return one element for scalable "
6500 Factor = Factors[0];
6518 EVT VT =
N->getValueType(0);
6522 bool UseSRL =
false;
6529 EVT CT =
C->getValueType(0);
6530 APInt Divisor =
C->getAPIntValue();
6555 "Expected matchUnaryPredicate to return one element for scalable "
6562 Factor = Factors[0];
6605 EVT VT =
N->getValueType(0);
6641 bool IsAfterLegalization,
6642 bool IsAfterLegalTypes,
6647 if (
N->getFlags().hasExact())
6650 EVT VT =
N->getValueType(0);
6689 if (
isTypeLegal(VT) && !HasMULHS && !HasSMUL_LOHI && MulVT ==
EVT()) {
6701 if (!HasMULHS && !HasSMUL_LOHI && MulVT ==
EVT())
6707 if (IsAfterLegalTypes && VT.
isVector()) {
6724 APInt Divisor =
C->getAPIntValue().trunc(EltBits);
6726 int NumeratorFactor = 0;
6737 NumeratorFactor = 1;
6740 NumeratorFactor = -1;
6759 SDValue MagicFactor, Factor, Shift, ShiftMask;
6767 Shifts.
size() == 1 && ShiftMasks.
size() == 1 &&
6768 "Expected matchUnaryPredicate to return one element for scalable "
6776 MagicFactor = MagicFactors[0];
6777 Factor = Factors[0];
6779 ShiftMask = ShiftMasks[0];
6800 SDValue Q = GetMULHS(N0, MagicFactor);
6830 bool IsAfterLegalization,
6831 bool IsAfterLegalTypes,
6836 if (
N->getFlags().hasExact())
6839 EVT VT =
N->getValueType(0);
6878 if (
isTypeLegal(VT) && !HasMULHU && !HasUMUL_LOHI && MulVT ==
EVT()) {
6890 if (!HasMULHU && !HasUMUL_LOHI && MulVT ==
EVT())
6903 if (IsAfterLegalTypes && VT.
isVector()) {
6915 const EVT WideSVT = MVT::i64;
6916 const bool HasWideMULHU =
6919 const bool HasWideUMUL_LOHI =
6922 const bool AllowWiden = (HasWideMULHU || HasWideUMUL_LOHI);
6924 bool UseNPQ =
false, UsePreShift =
false, UsePostShift =
false;
6925 bool UseWiden =
false;
6933 APInt Divisor =
C->getAPIntValue().trunc(EltBits);
6935 SDValue PreShift, MagicFactor, NPQFactor, PostShift;
6939 if (Divisor.
isOne()) {
6940 PreShift = PostShift = DAG.
getUNDEF(ShSVT);
6941 MagicFactor = NPQFactor = DAG.
getUNDEF(SVT);
6945 Divisor, std::min(KnownLeadingZeros, Divisor.
countl_zero()),
6957 "We shouldn't generate an undefined shift!");
6959 "We shouldn't generate an undefined shift!");
6961 "Unexpected pre-shift");
6968 UseNPQ |= magics.
IsAdd;
6969 UsePreShift |= magics.
PreShift != 0;
6985 SDValue PreShift, PostShift, MagicFactor, NPQFactor;
6993 NPQFactors.
size() == 1 && PostShifts.
size() == 1 &&
6994 "Expected matchUnaryPredicate to return one for scalable vectors");
7001 PreShift = PreShifts[0];
7002 MagicFactor = MagicFactors[0];
7003 PostShift = PostShifts[0];
7016 assert(HasWideUMUL_LOHI);
7019 WideN0, MagicFactor);
7051 Q = GetMULHU(Q, MagicFactor);
7064 NPQ = GetMULHU(NPQ, NPQFactor);
7083 return DAG.
getSelect(dl, VT, IsOne, N0, Q);
7097 if (SplatValue != Values.
end()) {
7102 Replacement = *SplatValue;
7106 if (!AlternativeReplacement)
7109 Replacement = AlternativeReplacement;
7119SDValue TargetLowering::buildUREMEqFold(EVT SETCCVT,
SDValue REMNode,
7122 DAGCombinerInfo &DCI,
7123 const SDLoc &
DL)
const {
7125 if (
SDValue Folded = prepareUREMEqFold(SETCCVT, REMNode, CompTargetNode,
Cond,
7127 for (SDNode *
N : Built)
7128 DCI.AddToWorklist(
N);
7136TargetLowering::prepareUREMEqFold(EVT SETCCVT,
SDValue REMNode,
7138 DAGCombinerInfo &DCI,
const SDLoc &
DL,
7139 SmallVectorImpl<SDNode *> &Created)
const {
7147 "Only applicable for (in)equality comparisons.");
7149 SelectionDAG &DAG = DCI.DAG;
7160 bool ComparingWithAllZeros =
true;
7161 bool AllComparisonsWithNonZerosAreTautological =
true;
7162 bool HadTautologicalLanes =
false;
7163 bool AllLanesAreTautological =
true;
7164 bool HadEvenDivisor =
false;
7165 bool AllDivisorsArePowerOfTwo =
true;
7166 bool HadTautologicalInvertedLanes =
false;
7169 auto BuildUREMPattern = [&](ConstantSDNode *CDiv, ConstantSDNode *CCmp) {
7175 const APInt &
Cmp = CCmp->getAPIntValue();
7177 ComparingWithAllZeros &=
Cmp.isZero();
7183 bool TautologicalInvertedLane =
D.ule(Cmp);
7184 HadTautologicalInvertedLanes |= TautologicalInvertedLane;
7189 bool TautologicalLane =
D.isOne() || TautologicalInvertedLane;
7190 HadTautologicalLanes |= TautologicalLane;
7191 AllLanesAreTautological &= TautologicalLane;
7197 AllComparisonsWithNonZerosAreTautological &= TautologicalLane;
7200 unsigned K =
D.countr_zero();
7201 assert((!
D.isOne() || (K == 0)) &&
"For divisor '1' we won't rotate.");
7202 APInt D0 =
D.lshr(K);
7205 HadEvenDivisor |= (
K != 0);
7208 AllDivisorsArePowerOfTwo &= D0.
isOne();
7212 unsigned W =
D.getBitWidth();
7214 assert((D0 *
P).isOne() &&
"Multiplicative inverse basic check failed.");
7227 "We are expecting that K is always less than all-ones for ShSVT");
7230 if (TautologicalLane) {
7254 if (AllLanesAreTautological)
7259 if (AllDivisorsArePowerOfTwo)
7264 if (HadTautologicalLanes) {
7279 "Expected matchBinaryPredicate to return one element for "
7290 if (!ComparingWithAllZeros && !AllComparisonsWithNonZerosAreTautological) {
7294 "Expecting that the types on LHS and RHS of comparisons match.");
7304 if (HadEvenDivisor) {
7317 if (!HadTautologicalInvertedLanes)
7323 assert(VT.
isVector() &&
"Can/should only get here for vectors.");
7330 SDValue TautologicalInvertedChannels =
7340 DL, SETCCVT, SETCCVT);
7342 Replacement, NewCC);
7350 TautologicalInvertedChannels);
7360SDValue TargetLowering::buildSREMEqFold(EVT SETCCVT,
SDValue REMNode,
7363 DAGCombinerInfo &DCI,
7364 const SDLoc &
DL)
const {
7366 if (
SDValue Folded = prepareSREMEqFold(SETCCVT, REMNode, CompTargetNode,
Cond,
7368 assert(Built.
size() <= 7 &&
"Max size prediction failed.");
7369 for (SDNode *
N : Built)
7370 DCI.AddToWorklist(
N);
7378TargetLowering::prepareSREMEqFold(EVT SETCCVT,
SDValue REMNode,
7380 DAGCombinerInfo &DCI,
const SDLoc &
DL,
7381 SmallVectorImpl<SDNode *> &Created)
const {
7405 "Only applicable for (in)equality comparisons.");
7407 SelectionDAG &DAG = DCI.DAG;
7421 if (!CompTarget || !CompTarget->
isZero())
7424 bool HadOneDivisor =
false;
7425 bool AllDivisorsAreOnes =
true;
7426 bool HadEvenDivisor =
false;
7427 bool AllDivisorsArePowerOfTwo =
true;
7430 auto BuildSREMPattern = [&](ConstantSDNode *
C) {
7439 APInt
D =
C->getAPIntValue().abs();
7442 HadOneDivisor |=
D.isOne();
7443 AllDivisorsAreOnes &=
D.isOne();
7446 unsigned K =
D.countr_zero();
7447 assert((!
D.isOne() || (K == 0)) &&
"For divisor '1' we won't rotate.");
7448 APInt D0 =
D.
lshr(K);
7451 HadEvenDivisor |= (
K != 0);
7455 AllDivisorsArePowerOfTwo &= D0.
isOne();
7459 unsigned W =
D.getBitWidth();
7461 assert((D0 *
P).isOne() &&
"Multiplicative inverse basic check failed.");
7471 "We are expecting that A is always less than all-ones for SVT");
7473 "We are expecting that K is always less than all-ones for ShSVT");
7510 if (AllDivisorsAreOnes)
7515 if (AllDivisorsArePowerOfTwo)
7518 SDValue PVal, AVal, KVal, QVal;
7520 if (HadOneDivisor) {
7540 QAmts.
size() == 1 &&
7541 "Expected matchUnaryPredicate to return one element for scalable "
7569 if (HadEvenDivisor) {
7587 EVT VT =
Op.getValueType();
7612 bool LegalOps,
bool OptForSize,
7614 unsigned Depth)
const {
7618 return Op.getOperand(0);
7628 EVT VT =
Op.getValueType();
7629 unsigned Opcode =
Op.getOpcode();
7639 auto RemoveDeadNode = [&](
SDValue N) {
7640 if (
N &&
N.getNode()->use_empty())
7649 std::list<HandleSDNode> Handles;
7660 if (LegalOps && !IsOpLegal)
7689 return !N.isUndef() && !isa<ConstantFPSDNode>(N);
7697 return N.isUndef() ||
7698 isFPImmLegal(neg(cast<ConstantFPSDNode>(N)->getValueAPF()), VT,
7702 if (LegalOps && !IsOpLegal)
7719 if (!Flags.hasNoSignedZeros())
7733 Handles.emplace_back(NegX);
7744 if (NegX && (CostX <= CostY)) {
7748 RemoveDeadNode(NegY);
7757 RemoveDeadNode(NegX);
7764 if (!Flags.hasNoSignedZeros())
7789 Handles.emplace_back(NegX);
7800 if (NegX && (CostX <= CostY)) {
7804 RemoveDeadNode(NegY);
7810 if (
C->isExactlyValue(2.0) &&
Op.getOpcode() ==
ISD::FMUL)
7818 RemoveDeadNode(NegX);
7826 if (!Flags.hasNoSignedZeros())
7829 SDValue X =
Op.getOperand(0),
Y =
Op.getOperand(1), Z =
Op.getOperand(2);
7838 Handles.emplace_back(NegZ);
7846 Handles.emplace_back(NegX);
7857 if (NegX && (CostX <= CostY)) {
7858 Cost = std::min(CostX, CostZ);
7861 RemoveDeadNode(NegY);
7867 Cost = std::min(CostY, CostZ);
7870 RemoveDeadNode(NegX);
7880 return DAG.
getNode(Opcode,
DL, VT, NegV);
7896 RemoveDeadNode(NegLHS);
7901 Handles.emplace_back(NegLHS);
7914 RemoveDeadNode(NegLHS);
7915 RemoveDeadNode(NegRHS);
7919 Cost = std::min(CostLHS, CostRHS);
7920 return DAG.
getSelect(
DL, VT,
Op.getOperand(0), NegLHS, NegRHS);
7949 if (!HasMULHU && !HasMULHS && !HasUMUL_LOHI && !HasSMUL_LOHI)
7961 if ((
Signed && HasSMUL_LOHI) || (!
Signed && HasUMUL_LOHI)) {
7964 Hi =
Lo.getValue(1);
7990 if (MakeMUL_LOHI(LL, RL,
Lo,
Hi,
false)) {
7991 Result.push_back(
Lo);
7992 Result.push_back(
Hi);
7995 Result.push_back(Zero);
7996 Result.push_back(Zero);
8007 if (MakeMUL_LOHI(LL, RL,
Lo,
Hi,
true)) {
8008 Result.push_back(
Lo);
8009 Result.push_back(
Hi);
8014 unsigned ShiftAmount = OuterBitSize - InnerBitSize;
8029 if (!MakeMUL_LOHI(LL, RL,
Lo,
Hi,
false))
8032 Result.push_back(
Lo);
8039 Result.push_back(
Hi);
8052 if (!MakeMUL_LOHI(LL, RH,
Lo,
Hi,
false))
8059 if (!MakeMUL_LOHI(LH, RL,
Lo,
Hi,
false))
8112 N->getOperand(0),
N->getOperand(1), Result, HiLoVT,
8113 DAG, Kind, LL, LH, RL, RH);
8115 assert(Result.size() == 2);
8150bool TargetLowering::expandUDIVREMByConstantViaUREMDecomposition(
8153 unsigned Opcode =
N->getOpcode();
8154 EVT VT =
N->getValueType(0);
8162 unsigned TrailingZeros = 0;
8171 if (Divisor.
uge(HalfMaxPlus1))
8176 unsigned BestChunkWidth = 0, AltChunkWidth = 0;
8177 for (
unsigned I = HBitWidth,
E = HBitWidth / 2;
I >
E; --
I) {
8179 if (
I == HBitWidth - 1)
8191 if (
I != HBitWidth &&
Mod == Divisor - 1)
8195 bool Alternate =
false;
8196 if (!BestChunkWidth) {
8200 BestChunkWidth = AltChunkWidth;
8205 assert(!LL == !LH &&
"Expected both input halves or no input halves!");
8207 std::tie(LL, LH) = DAG.
SplitScalar(
N->getOperand(0), dl, HiLoVT, HiLoVT);
8212 assert(ShiftAmt > 0 && ShiftAmt < HBitWidth);
8230 if (ShiftAmt < HBitWidth) {
8231 Lo = GetFSHR(
Lo,
Hi, ShiftAmt);
8234 }
else if (ShiftAmt == HBitWidth) {
8247 SDValue PartialRemL, PartialRemH;
8248 if (TrailingZeros && Opcode !=
ISD::UDIV) {
8250 if (TrailingZeros < HBitWidth) {
8254 }
else if (TrailingZeros == HBitWidth) {
8269 if (BestChunkWidth == HBitWidth) {
8272 ShiftRight(LL, LH, TrailingZeros);
8278 SDVTList VTList = DAG.
getVTList(HiLoVT, SetCCType);
8301 for (
unsigned I = 0;
I <
BitWidth - TrailingZeros;
I += BestChunkWidth) {
8303 unsigned Shift =
I + TrailingZeros;
8307 else if (Shift >= HBitWidth)
8312 Chunk = GetFSHR(LL, LH, Shift);
8314 if (
I + BestChunkWidth <
BitWidth - TrailingZeros)
8320 unsigned ChunkNum =
I / BestChunkWidth;
8321 unsigned Opc = (Alternate && (ChunkNum % 2) != 0) ?
ISD::SUB : ISD::
ADD;
8322 Sum = DAG.
getNode(
Opc, dl, HiLoVT, Sum, Chunk);
8354 if (BestChunkWidth != HBitWidth)
8355 ShiftRight(LL, LH, TrailingZeros);
8372 std::tie(QuotL, QuotH) = DAG.
SplitScalar(Quotient, dl, HiLoVT, HiLoVT);
8380 if (TrailingZeros) {
8381 if (TrailingZeros < HBitWidth) {
8393 }
else if (TrailingZeros == HBitWidth) {
8415bool TargetLowering::expandUDIVREMByConstantViaUMulHiMagic(
8416 SDNode *
N,
const APInt &Divisor, SmallVectorImpl<SDValue> &Result,
8423 assert(!Divisor.
isOne() &&
"Magic algorithm does not work for division by 1");
8428 SmallVectorImpl<SDValue> &
Result) {
8432 return expandMUL_LOHI(
Opc, VT,
DL,
LHS,
RHS, Result, HiLoVT, DAG,
8442 DAG.
getVTList(HiLoVT, MVT::i1), LL, RL);
8447 DAG.
getVTList(HiLoVT, MVT::i1), LH, RH, Overflow);
8449 return std::make_pair(OutL, OutH);
8455 if (Shift < HBitWidth) {
8459 return std::make_pair(ResL, ResH);
8462 if (Shift == HBitWidth)
8463 return std::make_pair(LH, Zero);
8464 assert(Shift - HBitWidth < HBitWidth &&
8465 "We shouldn't generate an undefined shift");
8474 Divisor, std::min(KnownLeadingZeros, Divisor.
countl_zero()));
8476 assert(!LL == !LH &&
"Expected both input halves or no input halves!");
8482 std::tie(QL, QH) = MakeSRLLong(QL, QH, Magics.
PreShift);
8492 auto [NPQL, NPQH] = MakeAddSubLong(
ISD::SUB, LL, LH, QL, QH);
8493 std::tie(NPQL, NPQH) = MakeSRLLong(NPQL, NPQH, 1);
8494 std::tie(QL, QH) = MakeAddSubLong(
ISD::ADD, NPQL, NPQH, QL, QH);
8498 std::tie(QL, QH) = MakeSRLLong(QL, QH, Magics.
PostShift);
8500 unsigned Opcode =
N->getOpcode();
8508 if (!MakeMUL_LOHIByConst(
ISD::MUL, QL, QH, Divisor, MulResult))
8514 MakeAddSubLong(
ISD::SUB, LL, LH, MulResult[0], MulResult[1]);
8527 unsigned Opcode =
N->getOpcode();
8534 "Unexpected opcode");
8540 APInt Divisor = CN->getAPIntValue();
8556 if (expandUDIVREMByConstantViaUREMDecomposition(
N, Divisor, Result, HiLoVT,
8560 if (expandUDIVREMByConstantViaUMulHiMagic(
N, Divisor, Result, HiLoVT, DAG, LL,
8576 EVT VT =
Node->getValueType(0);
8586 bool IsFSHL =
Node->getOpcode() == ISD::VP_FSHL;
8589 EVT ShVT = Z.getValueType();
8595 ShAmt = DAG.
getNode(ISD::VP_UREM,
DL, ShVT, Z, BitWidthC, Mask, VL);
8596 InvShAmt = DAG.
getNode(ISD::VP_SUB,
DL, ShVT, BitWidthC, ShAmt, Mask, VL);
8597 ShX = DAG.
getNode(ISD::VP_SHL,
DL, VT,
X, IsFSHL ? ShAmt : InvShAmt, Mask,
8599 ShY = DAG.
getNode(ISD::VP_SRL,
DL, VT,
Y, IsFSHL ? InvShAmt : ShAmt, Mask,
8607 ShAmt = DAG.
getNode(ISD::VP_AND,
DL, ShVT, Z, BitMask, Mask, VL);
8611 InvShAmt = DAG.
getNode(ISD::VP_AND,
DL, ShVT, NotZ, BitMask, Mask, VL);
8614 ShAmt = DAG.
getNode(ISD::VP_UREM,
DL, ShVT, Z, BitWidthC, Mask, VL);
8615 InvShAmt = DAG.
getNode(ISD::VP_SUB,
DL, ShVT, BitMask, ShAmt, Mask, VL);
8620 ShX = DAG.
getNode(ISD::VP_SHL,
DL, VT,
X, ShAmt, Mask, VL);
8622 ShY = DAG.
getNode(ISD::VP_SRL,
DL, VT, ShY1, InvShAmt, Mask, VL);
8625 ShX = DAG.
getNode(ISD::VP_SHL,
DL, VT, ShX1, InvShAmt, Mask, VL);
8626 ShY = DAG.
getNode(ISD::VP_SRL,
DL, VT,
Y, ShAmt, Mask, VL);
8629 return DAG.
getNode(ISD::VP_OR,
DL, VT, ShX, ShY, Mask, VL);
8634 if (
Node->isVPOpcode())
8637 EVT VT =
Node->getValueType(0);
8653 EVT ShVT = Z.getValueType();
8722 EVT VT =
Node->getValueType(0);
8740 if (!AllowVectorOps && VT.
isVector() &&
8758 ShVal = DAG.
getNode(ShOpc,
DL, VT, Op0, ShAmt);
8760 HsVal = DAG.
getNode(HsOpc,
DL, VT, Op0, HsAmt);
8766 ShVal = DAG.
getNode(ShOpc,
DL, VT, Op0, ShAmt);
8787 EVT VT,
unsigned HalveDepth = 0,
8788 unsigned TotalDepth = 0) {
8820 EVT VT =
Node->getValueType(0);
8824 unsigned Opcode =
Node->getOpcode();
8839 unsigned HalfBW = BW / 2;
8916 for (
unsigned I = 1;
I < BW;
I <<= 1) {
8939 if (BW >= 32 && BW <= 64 &&
8948 for (
unsigned I = 0;
I < 4; ++
I) {
8961 for (
unsigned I = 0;
I < 4; ++
I) {
8963 for (
unsigned J = 0; J < 4; ++J) {
8964 unsigned K = (
I + 4 - J) % 4;
8981 for (
unsigned I = 0;
I < BW; ++
I) {
9049 unsigned ShAmt = Opcode ==
ISD::CLMULR ? BW - 1 : BW;
9060 EVT VT =
Node->getValueType(0);
9073 for (
unsigned I = 1;
I < BW;
I *= 2) {
9095 EVT VT =
Node->getValueType(0);
9108 for (
unsigned S = 0; S < LogBW; ++S) {
9109 unsigned ShiftS = 1u << S;
9115 if (S + 1 < LogBW) {
9128 for (
int S = (
int)LogBW - 1; S >= 0; --S) {
9143 assert(
Node->getNumOperands() == 3 &&
"Not a double-shift!");
9144 EVT VT =
Node->getValueType(0);
9202 EVT VT =
Node->getValueType(0);
9205 Flags.setNoFPExcept(
true);
9217 EVT ResVT =
Node->getValueType(0);
9221 const uint64_t SemEnum =
Node->getConstantOperandVal(1);
9223 const auto RoundMode =
9225 const bool Saturate =
Node->getConstantOperandVal(3) != 0;
9237 "destination format (semantics enum " +
9238 Twine(SemEnum) +
")");
9243 switch (RoundMode) {
9252 "CONVERT_TO_ARBITRARY_FP: unsupported rounding mode (enum " +
9253 Twine(
static_cast<int>(RoundMode)) +
")");
9261 const unsigned DstMant = DstPrecision - 1;
9262 const unsigned DstExpBits = DstBits - DstMant - 1;
9264 const unsigned DstExpMax = (1U << DstExpBits) - 1;
9265 const uint64_t DstMantMask = (DstMant > 0) ? ((1ULL << DstMant) - 1) : 0;
9270 const unsigned DstExpMaxNormal =
9279 uint64_t DstMaxMantAtMaxExp = DstMantMask;
9282 DstMaxMantAtMaxExp = DstMantMask - 1;
9289 const unsigned SrcMant = SrcPrecision - 1;
9290 const uint64_t SrcMantMask = (1ULL << SrcMant) - 1;
9321 EVT FrexpExpScalarVT =
9341 switch (RoundMode) {
9381 if (SrcMant > DstMant) {
9382 const unsigned Shift = SrcMant - DstMant;
9412 RoundUp = ComputeRoundUp(RoundBit, StickyBits, LSB);
9427 DAG.
getSetCC(dl, SetCCVT, RoundedMant,
9430 SDValue AdjMant = DAG.
getSelect(dl, IntVT, MantOverflow, Zero, RoundedMant);
9459 int64_t MantDelta =
static_cast<int64_t
>(SrcMant) - DstMant;
9500 DenormRoundUp = ComputeRoundUp(DenormRoundBit, HasSticky, DenormLSB);
9505 DenormRoundUp = DAG.
getSelect(dl, IntVT, ShiftGEOne, DenormRoundUp, Zero);
9514 DAG.
getSetCC(dl, SetCCVT, DenormRoundedMant,
9517 DAG.
getSelect(dl, IntVT, DenormMantOF, Zero, DenormRoundedMant);
9518 SDValue DenormFinalExp = DAG.
getSelect(dl, IntVT, DenormMantOF, One, Zero);
9554 ((
uint64_t)DstExpMaxNormal << DstMant) | DstMaxMantAtMaxExp;
9573 DAG.
getNode(
ISD::OR, dl, IntVT, SignShifted, NormExpShifted), AdjMant);
9579 const uint64_t QNaNBit = (DstMant > 0) ? (1ULL << (DstMant - 1)) : 0;
9599 }
else if (Saturate) {
9602 ((
uint64_t)DstExpMaxNormal << DstMant) | DstMaxMantAtMaxExp;
9610 SDValue ZeroResult = SignShifted;
9614 DAG.
getSelect(dl, IntVT, ExpIsNeg, DenormResult, NormResult);
9618 SDValue Result = FiniteResult;
9619 Result = DAG.
getSelect(dl, IntVT, IsZero, ZeroResult, Result);
9620 Result = DAG.
getSelect(dl, IntVT, IsInf, InfResult, Result);
9621 Result = DAG.
getSelect(dl, IntVT, IsNaN, NaNResult, Result);
9631 EVT DstVT =
Node->getValueType(0);
9635 const uint64_t SemEnum =
Node->getConstantOperandVal(1);
9648 "source format (semantics enum " +
9649 Twine(SemEnum) +
")");
9656 const unsigned SrcMant = SrcPrecision - 1;
9657 const unsigned SrcExp = SrcBits - SrcMant - 1;
9665 const unsigned DstExpBits = DstBits - DstMant - 1;
9667 const int DstBias = 1 - DstMinExp;
9668 const uint64_t DstExpAllOnes = (1ULL << DstExpBits) - 1;
9686 const uint64_t MantMask = (SrcMant > 0) ? ((1ULL << SrcMant) - 1) : 0;
9687 const uint64_t ExpMask = (1ULL << SrcExp) - 1;
9719 IsNaN = DAG.
getNode(
ISD::AND, dl, SetCCVT, IsExpAllOnes, IsMantNonZero);
9725 IsNaN = DAG.
getNode(
ISD::AND, dl, SetCCVT, IsExpAllOnes, IsMantAllOnes);
9739 const int BiasAdjust = DstBias - SrcBias;
9745 if (DstMant > SrcMant) {
9748 NormDstMant = DAG.
getNode(
ISD::SHL, dl, IntVT, MantField, NormDstMantShift);
9750 NormDstMant = MantField;
9764 const unsigned IntVTBits = DstBits;
9768 const int DenormExpConst =
9769 (int)IntVTBits + DstBias - SrcBias - (
int)SrcMant;
9777 DAG.
getConstant(IntVTBits - 1, dl, IntVT), LeadingZeros);
9782 const unsigned ShiftSub = IntVTBits - 1 - DstMant;
9797 DAG.
getSelect(dl, IntVT, IsDenorm, DenormResult, NormResult);
9799 const uint64_t QNaNBit = (DstMant > 0) ? (1ULL << (DstMant - 1)) : 0;
9801 DAG.
getConstant((DstExpAllOnes << DstMant) | QNaNBit, dl, IntVT);
9805 DAG.
getConstant(DstExpAllOnes << DstMant, dl, IntVT));
9807 SDValue ZeroResult = SignShifted;
9809 SDValue Result = FiniteResult;
9810 Result = DAG.
getSelect(dl, IntVT, IsZero, ZeroResult, Result);
9811 Result = DAG.
getSelect(dl, IntVT, IsInf, InfResult, Result);
9812 Result = DAG.
getSelect(dl, IntVT, IsNaN, NaNResult, Result);
9819 unsigned OpNo =
Node->isStrictFPOpcode() ? 1 : 0;
9821 EVT SrcVT = Src.getValueType();
9822 EVT DstVT =
Node->getValueType(0);
9826 if (SrcVT != MVT::f32 || DstVT != MVT::i64)
9829 if (
Node->isStrictFPOpcode())
9892 unsigned OpNo =
Node->isStrictFPOpcode() ? 1 : 0;
9895 EVT SrcVT = Src.getValueType();
9896 EVT DstVT =
Node->getValueType(0);
9917 if (
Node->isStrictFPOpcode()) {
9919 {
Node->getOperand(0), Src });
9920 Chain = Result.getValue(1);
9934 if (
Node->isStrictFPOpcode()) {
9936 Node->getOperand(0),
true);
9961 if (
Node->isStrictFPOpcode()) {
9963 { Chain, Src, FltOfs });
9985 Result = DAG.
getSelect(dl, DstVT, Sel, True, False);
9995 if (
Node->isStrictFPOpcode())
9999 EVT SrcVT = Src.getValueType();
10000 EVT DstVT =
Node->getValueType(0);
10004 if (
Node->getFlags().hasNonNeg() &&
10052 unsigned Opcode =
Node->getOpcode();
10057 if (
Node->getFlags().hasNoNaNs()) {
10059 EVT VT =
Node->getValueType(0);
10078 EVT VT =
Node->getValueType(0);
10081 "Expanding fminnum/fmaxnum for scalable vectors is undefined.");
10091 if (!
Node->getFlags().hasNoNaNs()) {
10104 return DAG.
getNode(NewOp, dl, VT, Quiet0, Quiet1,
Node->getFlags());
10109 if (
Node->getFlags().hasNoNaNs() ||
10112 unsigned IEEE2018Op =
10115 return DAG.
getNode(IEEE2018Op, dl, VT,
Node->getOperand(0),
10116 Node->getOperand(1),
Node->getFlags());
10133 unsigned Opc =
N->getOpcode();
10134 EVT VT =
N->getValueType(0);
10147 bool MinMaxMustRespectOrderedZero =
false;
10151 MinMaxMustRespectOrderedZero =
true;
10165 if (!
N->getFlags().hasNoNaNs() &&
10174 if (!MinMaxMustRespectOrderedZero && !
N->getFlags().hasNoSignedZeros() &&
10197 unsigned Opc =
Node->getOpcode();
10198 EVT VT =
Node->getValueType(0);
10207 if (!Flags.hasNoNaNs()) {
10218 return DAG.
getNode(NewOp,
DL, VT, LHS, RHS, Flags);
10223 if (Flags.hasNoNaNs() ||
10225 unsigned IEEE2019Op =
10228 return DAG.
getNode(IEEE2019Op,
DL, VT, LHS, RHS, Flags);
10233 if ((Flags.hasNoNaNs() ||
10239 return DAG.
getNode(IEEE2008Op,
DL, VT, LHS, RHS, Flags);
10293 bool IsOrdered = NanTest ==
fcNone;
10294 bool IsUnordered = NanTest ==
fcNan;
10297 if (!IsOrdered && !IsUnordered)
10298 return std::nullopt;
10300 if (OrderedMask ==
fcZero &&
10306 return std::nullopt;
10313 EVT OperandVT =
Op.getValueType();
10325 if (OperandVT == MVT::ppcf128) {
10328 OperandVT = MVT::f64;
10335 bool IsF80 = (ScalarFloatVT == MVT::f80);
10339 if (Flags.hasNoFPExcept() &&
10342 bool IsInvertedFP =
false;
10346 FPTestMask = InvertedFPCheck;
10347 IsInvertedFP =
true;
10359 OrderedFPTestMask = FPTestMask;
10361 const bool IsOrdered = FPTestMask == OrderedFPTestMask;
10363 if (std::optional<bool> IsCmp0 =
10366 *IsCmp0 ? OrderedCmpOpcode : UnorderedCmpOpcode,
10373 *IsCmp0 ? OrderedCmpOpcode : UnorderedCmpOpcode);
10376 if (FPTestMask ==
fcNan &&
10382 bool IsOrderedInf = FPTestMask ==
fcInf;
10385 : UnorderedCmpOpcode,
10396 IsOrderedInf ? OrderedCmpOpcode : UnorderedCmpOpcode);
10401 : UnorderedCmpOpcode,
10412 IsOrdered ? OrderedCmpOpcode : UnorderedCmpOpcode);
10431 return DAG.
getSetCC(
DL, ResultVT, Abs, SmallestNormal,
10432 IsOrdered ? OrderedOp : UnorderedOp);
10455 DAG.
getSetCC(
DL, ResultVT, Abs, SmallestNormal, IsNormalOp);
10457 return DAG.
getNode(LogicOp,
DL, ResultVT, IsFinite, IsNormal);
10464 bool IsInverted =
false;
10467 Test = InvertedCheck;
10481 const unsigned ExplicitIntBitInF80 = 63;
10482 APInt ExpMask = Inf;
10484 ExpMask.
clearBit(ExplicitIntBitInF80);
10486 APInt QNaNBitMask =
10498 const auto appendResult = [&](
SDValue PartialRes) {
10508 const auto getIntBitIsSet = [&]() ->
SDValue {
10509 if (!IntBitIsSetV) {
10510 APInt IntBitMask(BitSize, 0);
10511 IntBitMask.
setBit(ExplicitIntBitInF80);
10516 return IntBitIsSetV;
10537 "finite check requires IEEE-like FP");
10555 appendResult(PartialRes);
10564 appendResult(ExpIsZero);
10571 if (
unsigned PartialCheck =
Test &
fcZero) {
10574 else if (PartialCheck ==
fcZero)
10578 appendResult(PartialRes);
10591 appendResult(PartialRes);
10594 if (
unsigned PartialCheck =
Test &
fcInf) {
10597 else if (PartialCheck ==
fcInf)
10604 appendResult(PartialRes);
10607 if (
unsigned PartialCheck =
Test &
fcNan) {
10608 APInt InfWithQnanBit = Inf | QNaNBitMask;
10610 if (PartialCheck ==
fcNan) {
10623 }
else if (PartialCheck ==
fcQNan) {
10635 appendResult(PartialRes);
10640 APInt ExpLSB = ExpMask & ~(ExpMask.
shl(1));
10643 APInt ExpLimit = ExpMask - ExpLSB;
10656 appendResult(PartialRes);
10679 EVT VT =
Node->getValueType(0);
10686 if (!(Len <= 128 && Len % 8 == 0))
10727 if (Len == 16 && !VT.
isVector()) {
10745 for (
unsigned Shift = 8; Shift < Len; Shift *= 2) {
10756 EVT VT =
Node->getValueType(0);
10765 if (!(Len <= 128 && Len % 8 == 0))
10777 SDValue Tmp1, Tmp2, Tmp3, Tmp4, Tmp5;
10780 Tmp1 = DAG.
getNode(ISD::VP_AND, dl, VT,
10784 Op = DAG.
getNode(ISD::VP_SUB, dl, VT,
Op, Tmp1, Mask, VL);
10787 Tmp2 = DAG.
getNode(ISD::VP_AND, dl, VT,
Op, Mask33, Mask, VL);
10788 Tmp3 = DAG.
getNode(ISD::VP_AND, dl, VT,
10792 Op = DAG.
getNode(ISD::VP_ADD, dl, VT, Tmp2, Tmp3, Mask, VL);
10797 Tmp5 = DAG.
getNode(ISD::VP_ADD, dl, VT,
Op, Tmp4, Mask, VL);
10798 Op = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp5, Mask0F, Mask, VL);
10809 V = DAG.
getNode(ISD::VP_MUL, dl, VT,
Op, Mask01, Mask, VL);
10812 for (
unsigned Shift = 8; Shift < Len; Shift *= 2) {
10814 V = DAG.
getNode(ISD::VP_ADD, dl, VT, V,
10815 DAG.
getNode(ISD::VP_SHL, dl, VT, V, ShiftC, Mask, VL),
10825 EVT VT =
Node->getValueType(0);
10842 return DAG.
getSelect(dl, VT, SrcIsZero,
10864 for (
unsigned i = 0; (1U << i) < NumBitsPerElt; ++i) {
10875 EVT VT =
Node->getValueType(0);
10889 for (
unsigned i = 0; (1U << i) < NumBitsPerElt; ++i) {
10892 DAG.
getNode(ISD::VP_SRL, dl, VT,
Op, Tmp, Mask, VL), Mask,
10897 return DAG.
getNode(ISD::VP_CTPOP, dl, VT,
Op, Mask, VL);
10902 EVT VT =
Node->getValueType(0);
10928 :
APInt(64, 0x0218A392CD3D5DBFULL);
10941 for (
unsigned i = 0; i <
BitWidth; i++) {
10967 EVT VT =
Node->getValueType(0);
10983 return DAG.
getSelect(dl, VT, SrcIsZero,
11027 EVT VT =
Node->getValueType(0);
11035 return DAG.
getNode(ISD::VP_CTPOP, dl, VT, Tmp, Mask, VL);
11046 SDValue Source =
N->getOperand(0);
11049 EVT SrcVT = Source.getValueType();
11050 EVT ResVT =
N->getValueType(0);
11059 Source = DAG.
getNode(ISD::VP_SETCC,
DL, SrcVT, Source, AllZero,
11067 DAG.
getNode(ISD::VP_SELECT,
DL, ResVecVT, Source, StepVec,
Splat, EVL);
11068 return DAG.
getNode(ISD::VP_REDUCE_UMIN,
DL, ResVT, ExtEVL,
Select, Mask, EVL);
11076static std::pair<SDValue, SDValue>
11079 EVT MaskVT = Mask.getValueType();
11130 return {Mask, StepVec};
11137 N->getOperand(0),
true,
DL, DAG);
11142 EVT MaskVT =
N->getOperand(0).getValueType();
11143 EVT ResVT =
N->getValueType(0);
11173 EVT StepVecVT = StepVec.getValueType();
11187 EVT VT =
N->getValueType(0);
11188 SDValue SourceValue =
N->getOperand(0);
11189 SDValue SinkValue =
N->getOperand(1);
11190 SDValue EltSizeInBytes =
N->getOperand(2);
11202 if (IsReadAfterWrite)
11228 bool IsNegative)
const {
11230 EVT VT =
N->getValueType(0);
11293 EVT VT =
N->getValueType(0);
11296 bool IsSigned =
N->getOpcode() ==
ISD::ABDS;
11371 EVT VT =
N->getValueType(0);
11375 unsigned Opc =
N->getOpcode();
11384 "Unknown AVG node");
11396 return DAG.
getNode(ShiftOpc, dl, VT, Sum,
11404 LHS = DAG.
getNode(ExtOpc, dl, ExtVT, LHS);
11405 RHS = DAG.
getNode(ExtOpc, dl, ExtVT, RHS);
11433 ISD::SHL, dl, VT, ZeroExtOverflow,
11449 return DAG.
getNode(SumOpc, dl, VT, Sign, Shift);
11454 EVT VT =
N->getValueType(0);
11461 SDValue Tmp1, Tmp2, Tmp3, Tmp4, Tmp5, Tmp6, Tmp7, Tmp8;
11528 EVT VT =
N->getValueType(0);
11537 SDValue Tmp1, Tmp2, Tmp3, Tmp4, Tmp5, Tmp6, Tmp7, Tmp8;
11546 return DAG.
getNode(ISD::VP_OR, dl, VT, Tmp1, Tmp2, Mask, EVL);
11556 Tmp2 = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp2,
11560 Tmp4 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp4, Tmp3, Mask, EVL);
11561 Tmp2 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp2, Tmp1, Mask, EVL);
11562 return DAG.
getNode(ISD::VP_OR, dl, VT, Tmp4, Tmp2, Mask, EVL);
11566 Tmp7 = DAG.
getNode(ISD::VP_AND, dl, VT,
Op,
11567 DAG.
getConstant(255ULL << 8, dl, VT), Mask, EVL);
11570 Tmp6 = DAG.
getNode(ISD::VP_AND, dl, VT,
Op,
11571 DAG.
getConstant(255ULL << 16, dl, VT), Mask, EVL);
11574 Tmp5 = DAG.
getNode(ISD::VP_AND, dl, VT,
Op,
11575 DAG.
getConstant(255ULL << 24, dl, VT), Mask, EVL);
11580 Tmp4 = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp4,
11581 DAG.
getConstant(255ULL << 24, dl, VT), Mask, EVL);
11584 Tmp3 = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp3,
11585 DAG.
getConstant(255ULL << 16, dl, VT), Mask, EVL);
11588 Tmp2 = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp2,
11589 DAG.
getConstant(255ULL << 8, dl, VT), Mask, EVL);
11592 Tmp8 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp8, Tmp7, Mask, EVL);
11593 Tmp6 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp6, Tmp5, Mask, EVL);
11594 Tmp4 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp4, Tmp3, Mask, EVL);
11595 Tmp2 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp2, Tmp1, Mask, EVL);
11596 Tmp8 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp8, Tmp6, Mask, EVL);
11597 Tmp4 = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp4, Tmp2, Mask, EVL);
11598 return DAG.
getNode(ISD::VP_OR, dl, VT, Tmp8, Tmp4, Mask, EVL);
11604 EVT VT =
N->getValueType(0);
11647 for (
unsigned I = 0, J = Sz-1;
I < Sz; ++
I, --J) {
11664 assert(
N->getOpcode() == ISD::VP_BITREVERSE);
11667 EVT VT =
N->getValueType(0);
11686 Tmp = (Sz > 8 ? DAG.
getNode(ISD::VP_BSWAP, dl, VT,
Op, Mask, EVL) :
Op);
11691 Tmp2 = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp2,
11697 Tmp = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp2, Tmp3, Mask, EVL);
11702 Tmp2 = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp2,
11708 Tmp = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp2, Tmp3, Mask, EVL);
11713 Tmp2 = DAG.
getNode(ISD::VP_AND, dl, VT, Tmp2,
11719 Tmp = DAG.
getNode(ISD::VP_OR, dl, VT, Tmp2, Tmp3, Mask, EVL);
11725std::pair<SDValue, SDValue>
11729 SDValue Chain = LD->getChain();
11730 SDValue BasePTR = LD->getBasePtr();
11731 EVT SrcVT = LD->getMemoryVT();
11732 EVT DstVT = LD->getValueType(0);
11764 LD->getPointerInfo(), SrcIntVT, LD->getBaseAlign(),
11765 LD->getMemOperand()->getFlags(), LD->getAAInfo());
11768 for (
unsigned Idx = 0; Idx < NumElem; ++Idx) {
11769 unsigned ShiftIntoIdx =
11780 Scalar = DAG.
getNode(ExtendOp, SL, DstEltVT, Scalar);
11787 return std::make_pair(
Value, Load.getValue(1));
11796 for (
unsigned Idx = 0; Idx < NumElem; ++Idx) {
11798 ExtType, SL, DstEltVT, Chain, BasePTR,
11799 LD->getPointerInfo().getWithOffset(Idx * Stride), SrcEltVT,
11800 LD->getBaseAlign(), LD->getMemOperand()->getFlags(), LD->getAAInfo());
11811 return std::make_pair(
Value, NewChain);
11818 SDValue Chain = ST->getChain();
11819 SDValue BasePtr = ST->getBasePtr();
11821 EVT StVT = ST->getMemoryVT();
11847 for (
unsigned Idx = 0; Idx < NumElem; ++Idx) {
11851 unsigned ShiftIntoIdx =
11860 return DAG.
getStore(Chain, SL, CurrVal, BasePtr, ST->getPointerInfo(),
11861 ST->getBaseAlign(), ST->getMemOperand()->getFlags(),
11867 assert(Stride &&
"Zero stride!");
11871 for (
unsigned Idx = 0; Idx < NumElem; ++Idx) {
11879 Chain, SL, Elt, Ptr, ST->getPointerInfo().getWithOffset(Idx * Stride),
11880 MemSclVT, ST->getBaseAlign(), ST->getMemOperand()->getFlags(),
11889std::pair<SDValue, SDValue>
11892 "unaligned indexed loads not implemented!");
11893 SDValue Chain = LD->getChain();
11894 SDValue Ptr = LD->getBasePtr();
11895 EVT VT = LD->getValueType(0);
11896 EVT LoadedVT = LD->getMemoryVT();
11912 LD->getMemOperand());
11914 if (LoadedVT != VT)
11918 return std::make_pair(Result, newLoad.
getValue(1));
11926 unsigned NumRegs = (LoadedBytes + RegBytes - 1) / RegBytes;
11932 SDValue StackPtr = StackBase;
11936 EVT StackPtrVT = StackPtr.getValueType();
11942 for (
unsigned i = 1; i < NumRegs; i++) {
11945 RegVT, dl, Chain, Ptr, LD->getPointerInfo().getWithOffset(
Offset),
11946 LD->getBaseAlign(), LD->getMemOperand()->getFlags(), LD->getAAInfo());
11949 Load.getValue(1), dl, Load, StackPtr,
11960 8 * (LoadedBytes -
Offset));
11963 LD->getPointerInfo().getWithOffset(
Offset), MemVT, LD->getBaseAlign(),
11964 LD->getMemOperand()->getFlags(), LD->getAAInfo());
11969 Load.getValue(1), dl, Load, StackPtr,
11976 Load = DAG.
getExtLoad(LD->getExtensionType(), dl, VT, TF, StackBase,
11981 return std::make_pair(Load, TF);
11985 "Unaligned load of unsupported type.");
11994 Align Alignment = LD->getBaseAlign();
11995 unsigned IncrementSize = NumBits / 8;
12006 NewLoadedVT, Alignment, LD->getMemOperand()->getFlags(),
12011 LD->getPointerInfo().getWithOffset(IncrementSize),
12012 NewLoadedVT, Alignment, LD->getMemOperand()->getFlags(),
12015 Hi = DAG.
getExtLoad(HiExtType, dl, VT, Chain, Ptr, LD->getPointerInfo(),
12016 NewLoadedVT, Alignment, LD->getMemOperand()->getFlags(),
12021 LD->getPointerInfo().getWithOffset(IncrementSize),
12022 NewLoadedVT, Alignment, LD->getMemOperand()->getFlags(),
12034 return std::make_pair(Result, TF);
12040 "unaligned indexed stores not implemented!");
12041 SDValue Chain = ST->getChain();
12042 SDValue Ptr = ST->getBasePtr();
12043 SDValue Val = ST->getValue();
12045 Align Alignment = ST->getBaseAlign();
12047 EVT StoreMemVT = ST->getMemoryVT();
12063 Result = DAG.
getStore(Chain, dl, Result, Ptr, ST->getPointerInfo(),
12064 Alignment, ST->getMemOperand()->getFlags());
12075 unsigned NumRegs = (StoredBytes + RegBytes - 1) / RegBytes;
12083 Chain, dl, Val, StackPtr,
12086 EVT StackPtrVT = StackPtr.getValueType();
12094 for (
unsigned i = 1; i < NumRegs; i++) {
12097 RegVT, dl, Store, StackPtr,
12101 ST->getPointerInfo().getWithOffset(
Offset),
12102 ST->getBaseAlign(),
12103 ST->getMemOperand()->getFlags()));
12122 Load.getValue(1), dl, Load, Ptr,
12123 ST->getPointerInfo().getWithOffset(
Offset), LoadMemVT,
12124 ST->getBaseAlign(), ST->getMemOperand()->getFlags(), ST->getAAInfo()));
12131 "Unaligned store of unknown type.");
12135 unsigned IncrementSize = NumBits / 8;
12155 Ptr, ST->getPointerInfo(), NewStoredVT, Alignment,
12156 ST->getMemOperand()->getFlags());
12161 ST->getPointerInfo().getWithOffset(IncrementSize), NewStoredVT, Alignment,
12162 ST->getMemOperand()->getFlags(), ST->getAAInfo());
12173 bool IsCompressedMemory)
const {
12176 EVT MaskVT = Mask.getValueType();
12178 "Incompatible types of Data and Mask");
12179 if (IsCompressedMemory) {
12192 MaskIntVT = MVT::i32;
12211 "Cannot index a scalable vector within a fixed-width vector");
12222 if (IdxCst->getZExtValue() + (NumSubElts - 1) < NElts)
12236 unsigned MaxIndex = NumSubElts < NElts ? NElts - NumSubElts : 0;
12246 DAG, VecPtr, VecVT,
12248 Index, PtrArithFlags);
12264 "Converting bits to bytes lost precision");
12266 "Sub-vector must be a vector with matching element type");
12270 EVT IdxVT = Index.getValueType();
12301 assert(EmuTlsVar &&
"Cannot find EmuTlsVar ");
12302 Args.emplace_back(DAG.
getGlobalAddress(EmuTlsVar, dl, PtrVT), VoidPtrType);
12309 std::pair<SDValue, SDValue> CallResult =
LowerCallTo(CLI);
12318 "Emulated TLS must have zero offset in GlobalAddressSDNode");
12319 return CallResult.first;
12330 EVT VT =
Op.getOperand(0).getValueType();
12332 if (VT.
bitsLT(MVT::i32)) {
12350 unsigned Opcode =
Node->getOpcode();
12357 return DAG.
getNode(AltOpcode,
DL, VT, Op0, Op1);
12398 {Op0, Op1, DAG.getCondCode(CC)})) {
12405 {Op0, Op1, DAG.getCondCode(CC)})) {
12433 unsigned Opcode =
Node->getOpcode();
12436 EVT VT = LHS.getValueType();
12439 assert(VT == RHS.getValueType() &&
"Expected operands to be the same type");
12469 unsigned OverflowOp;
12484 llvm_unreachable(
"Expected method to receive signed or unsigned saturation "
12485 "addition or subtraction node.");
12493 unsigned BitWidth = LHS.getScalarValueSizeInBits();
12496 SDValue SumDiff = Result.getValue(0);
12497 SDValue Overflow = Result.getValue(1);
12519 return DAG.
getSelect(dl, VT, Overflow, Zero, SumDiff);
12523 "Expected signed saturating add/sub opcode");
12539 bool RHSIsNonNegative =
12541 if (LHSIsNonNegative || RHSIsNonNegative) {
12543 return DAG.
getSelect(dl, VT, Overflow, SatMax, SumDiff);
12547 bool RHSIsNegative =
12549 if (LHSIsNegative || RHSIsNegative) {
12551 return DAG.
getSelect(dl, VT, Overflow, SatMin, SumDiff);
12559 return DAG.
getSelect(dl, VT, Overflow, Result, SumDiff);
12563 unsigned Opcode =
Node->getOpcode();
12566 EVT VT = LHS.getValueType();
12567 EVT ResVT =
Node->getValueType(0);
12599 unsigned Opcode =
Node->getOpcode();
12603 EVT VT = LHS.getValueType();
12608 "Expected a SHLSAT opcode");
12640 EVT VT = LHS.getValueType();
12641 assert(RHS.getValueType() == VT &&
"Mismatching operand types");
12643 assert((HiLHS && HiRHS) || (!HiLHS && !HiRHS));
12645 "Signed flag should only be set when HiLHS and RiRHS are null");
12653 unsigned HalfBits = Bits / 2;
12698 EVT VT = LHS.getValueType();
12699 assert(RHS.getValueType() == VT &&
"Mismatching operand types");
12703 RTLIB::Libcall LC = RTLIB::UNKNOWN_LIBCALL;
12704 if (WideVT == MVT::i16)
12705 LC = RTLIB::MUL_I16;
12706 else if (WideVT == MVT::i32)
12707 LC = RTLIB::MUL_I32;
12708 else if (WideVT == MVT::i64)
12709 LC = RTLIB::MUL_I64;
12710 else if (WideVT == MVT::i128)
12711 LC = RTLIB::MUL_I128;
12714 if (LibcallImpl == RTLIB::Unsupported) {
12742 SDValue Args[] = {LHS, HiLHS, RHS, HiRHS};
12743 Ret =
makeLibCall(DAG, LC, WideVT, Args, CallOptions, dl).first;
12745 SDValue Args[] = {HiLHS, LHS, HiRHS, RHS};
12746 Ret =
makeLibCall(DAG, LC, WideVT, Args, CallOptions, dl).first;
12749 "Ret value is a collection of constituent nodes holding result.");
12766 "Expected a fixed point multiplication opcode");
12771 EVT VT = LHS.getValueType();
12772 unsigned Scale =
Node->getConstantOperandVal(2);
12788 SDValue Product = Result.getValue(0);
12789 SDValue Overflow = Result.getValue(1);
12800 Result = DAG.
getSelect(dl, VT, ProdNeg, SatMin, SatMax);
12801 return DAG.
getSelect(dl, VT, Overflow, Result, Product);
12805 SDValue Product = Result.getValue(0);
12806 SDValue Overflow = Result.getValue(1);
12810 return DAG.
getSelect(dl, VT, Overflow, SatMax, Product);
12815 "Expected scale to be less than the number of bits if signed or at "
12816 "most the number of bits if unsigned.");
12817 assert(LHS.getValueType() == RHS.getValueType() &&
12818 "Expected both operands to be the same type");
12827 Lo = Result.getValue(0);
12828 Hi = Result.getValue(1);
12831 Hi = DAG.
getNode(HiOp, dl, VT, LHS, RHS);
12849 if (Scale == VTSize)
12895 return DAG.
getSelect(dl, VT, Overflow, ResultIfOverflow, Result);
12920 "Expected a fixed point division opcode");
12922 EVT VT = LHS.getValueType();
12944 if (LHSLead + RHSTrail < Scale + (
unsigned)(Saturating &&
Signed))
12947 unsigned LHSShift = std::min(LHSLead, Scale);
12948 unsigned RHSShift = Scale - LHSShift;
13012 { LHS, RHS, CarryIn });
13019 LHS.getValueType(), LHS, RHS);
13021 EVT ResultType =
Node->getValueType(1);
13032 DAG.
getSetCC(dl, SetCCType, Result,
13041 SetCC = DAG.
getSetCC(dl, SetCCType, Result, LHS, CC);
13054 LHS.getValueType(), LHS, RHS);
13056 EVT ResultType =
Node->getValueType(1);
13063 SDValue Sat = DAG.
getNode(OpcSat, dl, LHS.getValueType(), LHS, RHS);
13079 DAG.
getNode(
ISD::XOR, dl, OType, RHSNegative, ResultLowerThanLHS), dl,
13080 ResultType, ResultType);
13087 DAG.
getNode(
ISD::XOR, dl, OType, LHSLessThanRHS, ResultNegative), dl,
13088 ResultType, ResultType);
13095 EVT VT =
Node->getValueType(0);
13103 const APInt &
C = RHSC->getAPIntValue();
13105 if (
C.isPowerOf2()) {
13107 bool UseArithShift =
isSigned && !
C.isMinSignedValue();
13110 Overflow = DAG.
getSetCC(dl, SetCCVT,
13112 dl, VT, Result, ShiftAmt),
13122 static const unsigned Ops[2][3] =
13148 Result = BottomHalf;
13155 Overflow = DAG.
getSetCC(dl, SetCCVT, TopHalf,
13160 EVT RType =
Node->getValueType(1);
13165 "Unexpected result type for S/UMULO legalization");
13174 EVT VT =
Op.getValueType();
13179 bool WidenSrc =
false;
13180 switch (
Node->getOpcode()) {
13233 "Expanding reductions for scalable vectors is undefined.");
13242 for (
unsigned i = 1; i < NumElts; i++)
13243 Res = DAG.
getNode(BaseOpcode, dl, EltVT, Res,
Ops[i], Flags);
13246 if (EltVT !=
Node->getValueType(0))
13262 "Expanding reductions for scalable vectors is undefined.");
13272 for (
unsigned i = 0; i < NumElts; i++)
13273 Res = DAG.
getNode(BaseOpcode, dl, EltVT, Res,
Ops[i], Flags);
13280 EVT VT =
Node->getValueType(0);
13289 Result = DAG.
getNode(DivRemOpc, dl, VTs, Dividend, Divisor).
getValue(1);
13294 SDValue Divide = DAG.
getNode(DivOpc, dl, VT, Dividend, Divisor);
13309 EVT SrcVT = Src.getValueType();
13310 EVT DstVT =
Node->getValueType(0);
13315 assert(SatWidth <= DstWidth &&
13316 "Expected saturation width smaller than result width");
13320 APInt MinInt, MaxInt;
13331 if (SrcVT == MVT::f16 || SrcVT == MVT::bf16) {
13333 SrcVT = Src.getValueType();
13353 auto EmitMinMax = [&](
unsigned MinOpcode,
unsigned MaxOpcode,
13354 bool MayPropagateNaN) {
13364 Clamped = DAG.
getNode(MaxOpcode, dl, SrcVT, Clamped, MinFloatNode);
13366 Clamped = DAG.
getNode(MinOpcode, dl, SrcVT, Clamped, MaxFloatNode);
13369 dl, DstVT, Clamped);
13373 if (!MayPropagateNaN && !IsSigned)
13381 return DAG.
getSelect(dl, DstVT, IsNan, ZeroInt, FpToInt);
13383 if (AreExactFloatBounds) {
13433 EVT OperandVT =
Op.getValueType();
13459 Op.getValueType());
13463 KeepNarrow = DAG.
getNode(
ISD::OR, dl, WideSetCCVT, KeepNarrow, AlreadyOdd);
13474 SDValue Adjust = DAG.
getSelect(dl, ResultIntVT, NarrowIsRd, One, NegativeOne);
13476 Op = DAG.
getSelect(dl, ResultIntVT, KeepNarrow, NarrowBits, Adjusted);
13483 EVT VT =
Node->getValueType(0);
13486 if (
Node->getConstantOperandVal(1) == 1) {
13489 EVT OperandVT =
Op.getValueType();
13501 EVT I32 =
F32.changeTypeToInteger();
13537 "Unexpected opcode!");
13538 assert((
Node->getValueType(0).isScalableVector() ||
13540 "Fixed length vector types with constant offsets expected to use "
13541 "SHUFFLE_VECTOR!");
13543 EVT VT =
Node->getValueType(0);
13564 EVT PtrVT = StackPtr.getValueType();
13576 DAG.
getStore(StoreV1,
DL, V2, StackPtr2, PtrInfo, Alignment);
13592 return DAG.
getLoad(VT,
DL, StoreV2, StackPtr,
13605 EVT MaskVT = Mask.getValueType();
13622 bool HasPassthru = !Passthru.
isUndef();
13628 Chain = DAG.
getStore(Chain,
DL, Passthru, StackPtr, PtrInfo, Alignment);
13631 APInt PassthruSplatVal;
13632 bool IsSplatPassthru =
13635 if (IsSplatPassthru) {
13639 LastWriteVal = DAG.
getConstant(PassthruSplatVal,
DL, ScalarVT);
13640 }
else if (HasPassthru) {
13656 ScalarVT,
DL, Chain, LastElmtPtr,
13662 for (
unsigned I = 0;
I < NumElms;
I++) {
13666 Chain,
DL, ValI, OutPtr,
13678 if (HasPassthru &&
I == NumElms - 1) {
13688 LastWriteVal = DAG.
getSelect(
DL, ScalarVT, AllLanesSelected, ValI,
13691 Chain,
DL, LastWriteVal, OutPtr,
13696 return DAG.
getLoad(VecVT,
DL, Chain, StackPtr, PtrInfo, Alignment);
13701 EVT VT =
Node->getValueType(0);
13704 auto [Mask, StepVec] =
13712 EVT ResVT =
Node->getValueType(0);
13726 return DAG.
getSelect(
DL, ResVT, ResLoNotNumElts, ResLo, Sum);
13729 EVT StepVecVT = StepVec.getValueType();
13754 SDValue MulLHS =
N->getOperand(1);
13755 SDValue MulRHS =
N->getOperand(2);
13763 unsigned ExtOpcLHS, ExtOpcRHS;
13764 switch (
N->getOpcode()) {
13778 if (ExtMulOpVT != MulOpVT) {
13779 MulLHS = DAG.
getNode(ExtOpcLHS,
DL, ExtMulOpVT, MulLHS);
13780 MulRHS = DAG.
getNode(ExtOpcRHS,
DL, ExtMulOpVT, MulRHS);
13794 std::deque<SDValue> Subvectors = {Acc};
13795 for (
unsigned I = 0;
I < ScaleFactor;
I++)
13798 unsigned FlatNode =
13802 while (Subvectors.size() > 1) {
13803 Subvectors.push_back(
13804 DAG.
getNode(FlatNode,
DL, AccVT, {Subvectors[0], Subvectors[1]}));
13805 Subvectors.pop_front();
13806 Subvectors.pop_front();
13809 assert(Subvectors.size() == 1 &&
13810 "There should only be one subvector after tree flattening");
13812 return Subvectors[0];
13825 if (
Op.getNode() != FPNode)
13829 while (!Worklist.
empty()) {
13863 std::optional<unsigned> CallRetResNo)
const {
13864 if (LC == RTLIB::UNKNOWN_LIBCALL)
13868 if (LibcallImpl == RTLIB::Unsupported)
13872 EVT VT =
Node->getValueType(0);
13873 unsigned NumResults =
Node->getNumValues();
13883 SDValue StoreValue = ST->getValue();
13884 unsigned ResNo = StoreValue.
getResNo();
13886 if (CallRetResNo == ResNo)
13889 if (!ST->isSimple() || ST->getAddressSpace() != 0)
13892 if (StoresInChain && ST->getChain() != StoresInChain)
13896 if (ST->getAlign() <
13904 ResultStores[ResNo] = ST;
13905 StoresInChain = ST->getChain();
13912 EVT ArgVT =
Op.getValueType();
13914 Args.emplace_back(
Op, ArgTy);
13921 if (ResNo == CallRetResNo)
13923 EVT ResVT =
Node->getValueType(ResNo);
13925 ResultPtrs[ResNo] = ResultPtr;
13926 Args.emplace_back(ResultPtr,
PointerTy);
13938 Type *RetType = CallRetResNo.has_value()
13939 ?
Node->getValueType(*CallRetResNo).getTypeForEVT(Ctx)
13951 if (ResNo == CallRetResNo) {
13957 ResultPtr, PtrInfo);
13963 PtrInfo = ST->getPointerInfo();
13970 Results.push_back(LoadResult);
13979 SDValue EVL,
bool &NeedInvert,
13981 bool IsSignaling)
const {
13982 MVT OpVT = LHS.getSimpleValueType();
13984 NeedInvert =
false;
13985 assert(!EVL == !Mask &&
"VP Mask and EVL must either both be set or unset");
13986 bool IsNonVP = !EVL;
14001 bool NeedSwap =
false;
14002 InvCC = getSetCCInverse(CCCode, OpVT);
14018 if (OpVT == MVT::i1) {
14033 DAG.
getNOT(dl, LHS, MVT::i1));
14038 DAG.
getNOT(dl, RHS, MVT::i1));
14043 DAG.
getNOT(dl, LHS, MVT::i1));
14048 DAG.
getNOT(dl, RHS, MVT::i1));
14071 "If SETUE is expanded, SETOEQ or SETUNE must be legal!");
14076 "If SETO is expanded, SETOEQ must be legal!");
14093 NeedInvert = ((
unsigned)CCCode & 0x8U);
14134 SetCC1 = DAG.
getSetCC(dl, VT, LHS, RHS, CC1, Chain, IsSignaling);
14135 SetCC2 = DAG.
getSetCC(dl, VT, LHS, RHS, CC2, Chain, IsSignaling);
14137 SetCC1 = DAG.
getSetCCVP(dl, VT, LHS, RHS, CC1, Mask, EVL);
14138 SetCC2 = DAG.
getSetCCVP(dl, VT, LHS, RHS, CC2, Mask, EVL);
14143 SetCC1 = DAG.
getSetCC(dl, VT, LHS, LHS, CC1, Chain, IsSignaling);
14144 SetCC2 = DAG.
getSetCC(dl, VT, RHS, RHS, CC2, Chain, IsSignaling);
14146 SetCC1 = DAG.
getSetCCVP(dl, VT, LHS, LHS, CC1, Mask, EVL);
14147 SetCC2 = DAG.
getSetCCVP(dl, VT, RHS, RHS, CC2, Mask, EVL);
14154 LHS = DAG.
getNode(
Opc, dl, VT, SetCC1, SetCC2);
14159 LHS = DAG.
getNode(
Opc, dl, VT, SetCC1, SetCC2, Mask, EVL);
14171 EVT VT =
Node->getValueType(0);
14183 unsigned Opcode =
Node->getOpcode();
14221 std::optional<unsigned> ByteOffset;
14225 int Elt = ConstEltNo->getZExtValue();
14239 unsigned IsFast = 0;
14249 DAG, OriginalLoad->
getBasePtr(), InVecVT, EltNo);
14254 if (ResultVT.
bitsGT(VecEltVT)) {
14263 NewPtr, MPI, VecEltVT, Alignment,
14273 if (ResultVT.
bitsLT(VecEltVT))
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMDGPU Register Bank Select
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
Function Alias Analysis Results
block Block Frequency 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 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...
static bool isSigned(unsigned Opcode)
static bool ShrinkDemandedConstant(Instruction *I, unsigned OpNo, const APInt &Demanded)
Check to see if the specified operand of the specified instruction is a constant integer.
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
static bool isNonZeroModBitWidthOrUndef(const MachineRegisterInfo &MRI, Register Reg, unsigned BW)
static bool isZero(Value *V, const DataLayout &DL, DominatorTree *DT, AssumptionCache *AC)
static bool isUndef(const MachineInstr &MI)
Register const TargetRegisterInfo * TRI
Function const char * Passes
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
const SmallVectorImpl< MachineOperand > & Cond
Contains matchers for matching SelectionDAG nodes and values.
static cl::opt< unsigned > MaxSteps("has-predecessor-max-steps", cl::Hidden, cl::init(8192), cl::desc("DAG combiner limit number of steps when searching DAG " "for predecessor nodes"))
static TableGen::Emitter::Opt Y("gen-skeleton-entry", EmitSkeleton, "Generate example skeleton entry")
static std::pair< SDValue, SDValue > getLegalMaskAndStepVector(SDValue Mask, bool ZeroIsPoison, SDLoc DL, SelectionDAG &DAG)
Returns a type-legalized version of Mask as the first item in the pair.
static SDValue foldSetCCWithFunnelShift(EVT VT, SDValue N0, SDValue N1, ISD::CondCode Cond, const SDLoc &dl, SelectionDAG &DAG)
static bool lowerImmediateIfPossible(TargetLowering::ConstraintPair &P, SDValue Op, SelectionDAG *DAG, const TargetLowering &TLI)
If we have an immediate, see if we can lower it.
static SDValue expandVPFunnelShift(SDNode *Node, SelectionDAG &DAG)
static APInt getKnownUndefForVectorBinop(SDValue BO, SelectionDAG &DAG, const APInt &UndefOp0, const APInt &UndefOp1)
Given a vector binary operation and known undefined elements for each input operand,...
static SDValue BuildExactUDIV(const TargetLowering &TLI, SDNode *N, const SDLoc &dl, SelectionDAG &DAG, SmallVectorImpl< SDNode * > &Created)
Given an exact UDIV by a constant, create a multiplication with the multiplicative inverse of the con...
static bool canNarrowCLMULToLegal(const TargetLowering &TLI, LLVMContext &Ctx, EVT VT, unsigned HalveDepth=0, unsigned TotalDepth=0)
Check if CLMUL on VT can eventually reach a type with legal CLMUL through a chain of halving decompos...
static SDValue clampDynamicVectorIndex(SelectionDAG &DAG, SDValue Idx, EVT VecVT, const SDLoc &dl, ElementCount SubEC)
static unsigned getConstraintPiority(TargetLowering::ConstraintType CT)
Return a number indicating our preference for chosing a type of constraint over another,...
static std::optional< bool > isFCmpEqualZero(FPClassTest Test, const fltSemantics &Semantics, const MachineFunction &MF)
Returns a true value if if this FPClassTest can be performed with an ordered fcmp to 0,...
static bool canFoldStoreIntoLibCallOutputPointers(StoreSDNode *StoreNode, SDNode *FPNode)
Given a store node StoreNode, return true if it is safe to fold that node into FPNode,...
static void turnVectorIntoSplatVector(MutableArrayRef< SDValue > Values, std::function< bool(SDValue)> Predicate, SDValue AlternativeReplacement=SDValue())
If all values in Values that don't match the predicate are same 'splat' value, then replace all value...
static bool canExpandVectorCTPOP(const TargetLowering &TLI, EVT VT)
static SDValue foldSetCCWithRotate(EVT VT, SDValue N0, SDValue N1, ISD::CondCode Cond, const SDLoc &dl, SelectionDAG &DAG)
static SDValue BuildExactSDIV(const TargetLowering &TLI, SDNode *N, const SDLoc &dl, SelectionDAG &DAG, SmallVectorImpl< SDNode * > &Created)
Given an exact SDIV by a constant, create a multiplication with the multiplicative inverse of the con...
static SDValue simplifySetCCWithCTPOP(const TargetLowering &TLI, EVT VT, SDValue N0, const APInt &C1, ISD::CondCode Cond, const SDLoc &dl, SelectionDAG &DAG)
static SDValue combineShiftToAVG(SDValue Op, TargetLowering::TargetLoweringOpt &TLO, const TargetLowering &TLI, const APInt &DemandedBits, const APInt &DemandedElts, unsigned Depth)
This file describes how to lower LLVM code to machine code.
static int Lookup(ArrayRef< TableEntry > Table, unsigned Opcode)
static SDValue scalarizeVectorStore(StoreSDNode *Store, MVT StoreVT, SelectionDAG &DAG)
Scalarize a vector store, bitcasting to TargetVT to determine the scalar type.
static LLVM_ABI const llvm::fltSemantics & EnumToSemantics(Semantics S)
static constexpr roundingMode rmTowardZero
static LLVM_ABI ExponentType semanticsMinExponent(const fltSemantics &)
static LLVM_ABI unsigned getSizeInBits(const fltSemantics &Sem)
Returns the size of the floating point number (in bits) in the given semantics.
static constexpr roundingMode rmNearestTiesToEven
static LLVM_ABI unsigned int semanticsPrecision(const fltSemantics &)
static LLVM_ABI bool isIEEELikeFP(const fltSemantics &)
opStatus
IEEE-754R 7: Default exception handling.
opStatus convertFromAPInt(const APInt &Input, bool IsSigned, roundingMode RM)
static APFloat getSmallestNormalized(const fltSemantics &Sem, bool Negative=false)
Returns the smallest (by magnitude) normalized finite number in the given semantics.
APInt bitcastToAPInt() const
static APFloat getLargest(const fltSemantics &Sem, bool Negative=false)
Returns the largest finite number in the given semantics.
static APFloat getInf(const fltSemantics &Sem, bool Negative=false)
Factory for Positive and Negative Infinity.
static APFloat getNaN(const fltSemantics &Sem, bool Negative=false, uint64_t payload=0)
Factory for NaN values.
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.
static LLVM_ABI void udivrem(const APInt &LHS, const APInt &RHS, APInt &Quotient, APInt &Remainder)
Dual division/remainder interface.
void clearBit(unsigned BitPosition)
Set a given bit to 0.
bool isNegatedPowerOf2() const
Check if this APInt's negated value is a power of two greater than zero.
LLVM_ABI APInt zext(unsigned width) const
Zero extend to a new width.
static APInt getSignMask(unsigned BitWidth)
Get the SignMask for a specific bit width.
bool isMinSignedValue() const
Determine if this is the smallest signed value.
uint64_t getZExtValue() const
Get zero extended value.
void setHighBits(unsigned hiBits)
Set the top hiBits bits.
void setBitsFrom(unsigned loBit)
Set the top bits starting from loBit.
LLVM_ABI APInt zextOrTrunc(unsigned width) const
Zero extend or truncate to width.
unsigned getActiveBits() const
Compute the number of active bits in the value.
LLVM_ABI APInt trunc(unsigned width) const
Truncate to new width.
static APInt getMaxValue(unsigned numBits)
Gets maximum unsigned value of APInt for specific bit width.
void setBit(unsigned BitPosition)
Set the given bit to 1 whose position is given as "bitPosition".
bool isAllOnes() const
Determine if all bits are set. This is true for zero-width values.
bool ugt(const APInt &RHS) const
Unsigned greater than comparison.
static APInt getBitsSet(unsigned numBits, unsigned loBit, unsigned hiBit)
Get a value with a block of bits set.
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.
void setSignBit()
Set the sign bit to 1.
unsigned getBitWidth() const
Return the number of bits in the APInt.
static APInt getSignedMaxValue(unsigned numBits)
Gets maximum signed value of APInt for a specific bit width.
static APInt getMinValue(unsigned numBits)
Gets minimum unsigned value of APInt for a specific bit width.
bool isNegative() const
Determine sign of this APInt.
bool intersects(const APInt &RHS) const
This operation tests if there are any pairs of corresponding bits between this APInt and RHS that are...
void clearAllBits()
Set every bit to 0.
void ashrInPlace(unsigned ShiftAmt)
Arithmetic right-shift this APInt by ShiftAmt in place.
void negate()
Negate this APInt in place.
unsigned countr_zero() const
Count the number of trailing zero bits.
unsigned countl_zero() const
The APInt version of std::countl_zero.
static LLVM_ABI APInt getSplat(unsigned NewLen, const APInt &V)
Return a value containing V broadcasted over NewLen bits.
static APInt getSignedMinValue(unsigned numBits)
Gets minimum signed value of APInt for a specific bit width.
unsigned getSignificantBits() const
Get the minimum bit size for this signed APInt.
unsigned countLeadingZeros() const
bool isStrictlyPositive() const
Determine if this APInt Value is positive.
LLVM_ABI void insertBits(const APInt &SubBits, unsigned bitPosition)
Insert the bits from a smaller APInt starting at bitPosition.
void clearLowBits(unsigned loBits)
Set bottom loBits bits to 0.
unsigned logBase2() const
uint64_t getLimitedValue(uint64_t Limit=UINT64_MAX) const
If this value is smaller than the specified limit, return it, otherwise return the limit value.
APInt ashr(unsigned ShiftAmt) const
Arithmetic right-shift function.
void setAllBits()
Set every bit to 1.
LLVM_ABI APInt multiplicativeInverse() 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.
LLVM_ABI APInt sext(unsigned width) const
Sign extend to a new width.
void setBits(unsigned loBit, unsigned hiBit)
Set the bits from loBit (inclusive) to hiBit (exclusive) to 1.
APInt shl(unsigned shiftAmt) const
Left-shift function.
bool isSubsetOf(const APInt &RHS) const
This operation checks that all bits set in this APInt are also set in RHS.
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.
void clearBits(unsigned LoBit, unsigned HiBit)
Clear the bits from LoBit (inclusive) to HiBit (exclusive) to 0.
static APInt getHighBitsSet(unsigned numBits, unsigned hiBitsSet)
Constructs an APInt value that has the top hiBitsSet bits set.
static APInt getZero(unsigned numBits)
Get the '0' value for the specified bit-width.
void setLowBits(unsigned loBits)
Set the bottom loBits bits.
LLVM_ABI APInt extractBits(unsigned numBits, unsigned bitPosition) const
Return an APInt with the extracted bits [bitPosition,bitPosition+numBits).
bool isOne() const
Determine if this is a value of 1.
static APInt getBitsSetFrom(unsigned numBits, unsigned loBit)
Constructs an APInt value that has a contiguous range of bits set.
static APInt getOneBitSet(unsigned numBits, unsigned BitNo)
Return an APInt with exactly one bit set in the result.
void clearHighBits(unsigned hiBits)
Set top hiBits bits to 0.
int64_t getSExtValue() const
Get sign extended value.
void lshrInPlace(unsigned ShiftAmt)
Logical right-shift this APInt by ShiftAmt in place.
APInt lshr(unsigned shiftAmt) const
Logical right-shift function.
unsigned countr_one() const
Count the number of trailing one bits.
bool uge(const APInt &RHS) const
Unsigned greater or equal comparison.
void setBitVal(unsigned BitPosition, bool BitValue)
Set a given bit to a given value.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
Get the array size.
A "pseudo-class" with methods for operating on BUILD_VECTORs.
LLVM_ABI ConstantSDNode * getConstantSplatNode(const APInt &DemandedElts, BitVector *UndefElements=nullptr) const
Returns the demanded splatted constant or null if this is not a constant splat.
CCValAssign - Represent assignment of one arg/retval to a location.
Register getLocReg() const
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
LLVM_ABI bool isIndirectCall() const
Return true if the callsite is an indirect call.
This class represents a function call, abstracting a target machine's calling convention.
static Constant * get(LLVMContext &Context, ArrayRef< ElementTy > Elts)
get() constructor - Return a constant with array type with an element count and element type matching...
ConstantFP - Floating Point Values [float, double].
This class represents a range of values.
const APInt & getAPIntValue() const
This is an important base class in LLVM.
A parsed version of the target data layout string in and methods for querying it.
bool isLittleEndian() const
Layout endianness...
LLVM_ABI Align getABITypeAlign(Type *Ty) const
Returns the minimum ABI-required alignment for the specified type.
LLVM_ABI Align getPrefTypeAlign(Type *Ty) const
Returns the preferred stack/global alignment for the specified type.
static constexpr ElementCount get(ScalarTy MinVal, bool Scalable)
AttributeList getAttributes() const
Return the attribute list for this Function.
int64_t getOffset() const
const GlobalValue * getGlobal() const
Module * getParent()
Get the module that this global value is contained inside of...
std::vector< std::string > ConstraintCodeVector
static LLVM_ABI IntegerType * get(LLVMContext &C, unsigned NumBits)
This static method is the primary way of constructing an IntegerType.
This is an important class for using LLVM in a threaded context.
LLVM_ABI void emitError(const Instruction *I, const Twine &ErrorStr)
emitError - Emit an error message to the currently installed error handler with optional location inf...
This class is used to represent ISD::LOAD nodes.
const SDValue & getBasePtr() const
Context object for machine code objects.
Base class for the full range of assembler expressions which are needed for parsing.
Wrapper class representing physical registers. Should be passed by value.
static const MCSymbolRefExpr * create(const MCSymbol *Symbol, MCContext &Ctx, SMLoc Loc=SMLoc())
bool isInteger() const
Return true if this is an integer or a vector integer type.
TypeSize getSizeInBits() const
Returns the size of the specified MVT in bits.
static MVT getIntegerVT(unsigned BitWidth)
MVT getScalarType() const
If this is a vector, return the element type, otherwise return this.
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
void setAdjustsStack(bool V)
Align getObjectAlign(int ObjectIdx) const
Return the alignment of the specified stack object.
MachineFrameInfo & getFrameInfo()
getFrameInfo - Return the frame info object for the current function.
DenormalMode getDenormalMode(const fltSemantics &FPType) const
Returns the denormal handling type for the default rounding mode of the function.
MCSymbol * getJTISymbol(unsigned JTI, MCContext &Ctx, bool isLinkerPrivate=false) const
getJTISymbol - Return the MCSymbol for the specified non-empty jump table.
Function & getFunction()
Return the LLVM function that this machine code represents.
const TargetMachine & getTarget() const
getTarget - Return the target machine this machine code is compiled with
@ EK_LabelDifference32
EK_LabelDifference32 - Each entry is the address of the block minus the address of the jump table.
@ EK_BlockAddress
EK_BlockAddress - Each entry is a plain address of block, e.g.: .word LBB123.
Flags getFlags() const
Return the raw flags of the source value,.
static bool clobbersPhysReg(const uint32_t *RegMask, MCRegister PhysReg)
clobbersPhysReg - Returns true if this RegMask clobbers PhysReg.
MachineRegisterInfo - Keep track of information for virtual and physical registers,...
LLVM_ABI MCRegister getLiveInPhysReg(Register VReg) const
getLiveInPhysReg - If VReg is a live-in virtual register, return the corresponding live-in physical r...
unsigned getAddressSpace() const
Return the address space for the associated pointer.
AAMDNodes getAAInfo() const
Returns the AA info that describes the dereference.
bool isSimple() const
Returns true if the memory operation is neither atomic or volatile.
MachineMemOperand * getMemOperand() const
Return the unique MachineMemOperand object describing the memory reference performed by operation.
const MachinePointerInfo & getPointerInfo() const
const SDValue & getChain() const
const GlobalVariable * getNamedGlobal(StringRef Name) const
Return the global variable in the module with the specified name, of arbitrary type.
Represent a mutable reference to an array (0 or more elements consecutively in memory),...
Class to represent pointers.
static PointerType * getUnqual(Type *ElementType)
This constructs a pointer to an object of the specified type in the default address space (address sp...
static LLVM_ABI PointerType * get(Type *ElementType, unsigned AddressSpace)
This constructs a pointer to an object of the specified type in a numbered address space.
Wrapper class representing virtual and physical registers.
Wrapper class for IR location info (IR ordering and DebugLoc) to be passed into SDNode creation funct...
Represents one node in the SelectionDAG.
ArrayRef< SDUse > ops() const
unsigned getOpcode() const
Return the SelectionDAG opcode value for this node.
bool hasOneUse() const
Return true if there is exactly one use of this node.
SDNodeFlags getFlags() const
static bool hasPredecessorHelper(const SDNode *N, SmallPtrSetImpl< const SDNode * > &Visited, SmallVectorImpl< const SDNode * > &Worklist, unsigned int MaxSteps=0, bool TopologicalPrune=false)
Returns true if N is a predecessor of any node in Worklist.
const SDValue & getOperand(unsigned Num) const
EVT getValueType(unsigned ResNo) const
Return the type of a specified result.
Unlike LLVM values, Selection DAG nodes may return multiple values as the result of a computation.
SDNode * getNode() const
get the SDNode which holds the desired result
bool hasOneUse() const
Return true if there is exactly one node using value ResNo of Node.
SDValue getValue(unsigned R) const
EVT getValueType() const
Return the ValueType of the referenced return value.
TypeSize getValueSizeInBits() const
Returns the size of the value in bits.
const SDValue & getOperand(unsigned i) const
bool use_empty() const
Return true if there are no nodes using value ResNo of Node.
const APInt & getConstantOperandAPInt(unsigned i) const
uint64_t getScalarValueSizeInBits() const
unsigned getResNo() const
get the index which selects a specific result in the SDNode
uint64_t getConstantOperandVal(unsigned i) const
MVT getSimpleValueType() const
Return the simple ValueType of the referenced return value.
unsigned getOpcode() const
This is used to represent a portion of an LLVM function in a low-level Data Dependence DAG representa...
LLVM_ABI SDValue getElementCount(const SDLoc &DL, EVT VT, ElementCount EC)
bool willNotOverflowAdd(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the addition of 2 nodes can never overflow.
LLVM_ABI Align getReducedAlign(EVT VT, bool UseABI)
In most cases this function returns the ABI alignment for a given type, except for illegal vector typ...
LLVM_ABI SDValue getExtLoad(ISD::LoadExtType ExtType, const SDLoc &dl, EVT VT, SDValue Chain, SDValue Ptr, MachinePointerInfo PtrInfo, EVT MemVT, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
LLVM_ABI bool isKnownNeverLogicalZero(SDValue Op, const APInt &DemandedElts, unsigned Depth=0) const
Test whether the given floating point SDValue (or all elements of it, if it is a vector) is known to ...
SDValue getTargetGlobalAddress(const GlobalValue *GV, const SDLoc &DL, EVT VT, int64_t offset=0, unsigned TargetFlags=0)
SDValue getExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT, unsigned Opcode)
Convert Op, which must be of integer type, to the integer type VT, by either any/sign/zero-extending ...
SDValue getExtractVectorElt(const SDLoc &DL, EVT VT, SDValue Vec, unsigned Idx)
Extract element at Idx from Vec.
LLVM_ABI unsigned ComputeMaxSignificantBits(SDValue Op, unsigned Depth=0) const
Get the upper bound on bit size for this Value Op as a signed integer.
LLVM_ABI SDValue FoldSetCC(EVT VT, SDValue N1, SDValue N2, ISD::CondCode Cond, const SDLoc &dl, SDNodeFlags Flags={})
Constant fold a setcc to true or false.
bool isKnownNeverSNaN(SDValue Op, const APInt &DemandedElts, unsigned Depth=0) const
LLVM_ABI SDVTList getVTList(EVT VT)
Return an SDVTList that represents the list of values specified.
LLVM_ABI SDValue getShiftAmountConstant(uint64_t Val, EVT VT, const SDLoc &DL)
LLVM_ABI SDValue getAllOnesConstant(const SDLoc &DL, EVT VT, bool IsTarget=false, bool IsOpaque=false)
LLVM_ABI void ExtractVectorElements(SDValue Op, SmallVectorImpl< SDValue > &Args, unsigned Start=0, unsigned Count=0, EVT EltVT=EVT())
Append the extracted elements from Start to Count out of the vector Op in Args.
LLVM_ABI SDValue getFreeze(SDValue V)
Return a freeze using the SDLoc of the value operand.
LLVM_ABI SDValue getConstantPool(const Constant *C, EVT VT, MaybeAlign Align=std::nullopt, int Offs=0, bool isT=false, unsigned TargetFlags=0)
LLVM_ABI SDValue makeEquivalentMemoryOrdering(SDValue OldChain, SDValue NewMemOpChain)
If an existing load has uses of its chain, create a token factor node with that chain and the new mem...
LLVM_ABI bool isConstantIntBuildVectorOrConstantInt(SDValue N, bool AllowOpaques=true) const
Test whether the given value is a constant int or similar node.
LLVM_ABI SDValue getJumpTableDebugInfo(int JTI, SDValue Chain, const SDLoc &DL)
LLVM_ABI std::optional< unsigned > getValidMaximumShiftAmount(SDValue V, const APInt &DemandedElts, unsigned Depth=0) const
If a SHL/SRA/SRL node V has shift amounts that are all less than the element bit-width of the shift n...
LLVM_ABI SDValue UnrollVectorOp(SDNode *N, unsigned ResNE=0)
Utility function used by legalize and lowering to "unroll" a vector operation by splitting out the sc...
LLVM_ABI SDValue getVScale(const SDLoc &DL, EVT VT, APInt MulImm)
Return a node that represents the runtime scaling 'MulImm * RuntimeVL'.
LLVM_ABI SDValue getConstantFP(double Val, const SDLoc &DL, EVT VT, bool isTarget=false)
Create a ConstantFPSDNode wrapping a constant value.
static LLVM_ABI unsigned getHasPredecessorMaxSteps()
SDValue getExtractSubvector(const SDLoc &DL, EVT VT, SDValue Vec, unsigned Idx)
Return the VT typed sub-vector of Vec at Idx.
LLVM_ABI SDValue getLoad(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, MachinePointerInfo PtrInfo, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr)
Loads are not normal binary operators: their result type is not determined by their operands,...
SDValue getInsertSubvector(const SDLoc &DL, SDValue Vec, SDValue SubVec, unsigned Idx)
Insert SubVec at the Idx element of Vec.
LLVM_ABI SDValue getStepVector(const SDLoc &DL, EVT ResVT, const APInt &StepVal)
Returns a vector of type ResVT whose elements contain the linear sequence <0, Step,...
SDValue getSetCC(const SDLoc &DL, EVT VT, SDValue LHS, SDValue RHS, ISD::CondCode Cond, SDValue Chain=SDValue(), bool IsSignaling=false, SDNodeFlags Flags={})
Helper function to make it easier to build SetCC's if you just have an ISD::CondCode instead of an SD...
bool willNotOverflowSub(bool IsSigned, SDValue N0, SDValue N1) const
Determine if the result of the sub of 2 nodes can never overflow.
LLVM_ABI bool shouldOptForSize() const
LLVM_ABI SDValue getNOT(const SDLoc &DL, SDValue Val, EVT VT)
Create a bitwise NOT operation as (XOR Val, -1).
const TargetLowering & getTargetLoweringInfo() const
static constexpr unsigned MaxRecursionDepth
LLVM_ABI std::pair< EVT, EVT > GetSplitDestVTs(const EVT &VT) const
Compute the VTs needed for the low/hi parts of a type which is split (or expanded) into two not neces...
SDValue getUNDEF(EVT VT)
Return an UNDEF node. UNDEF does not have a useful SDLoc.
SDValue getBuildVector(EVT VT, const SDLoc &DL, ArrayRef< SDValue > Ops)
Return an ISD::BUILD_VECTOR node.
LLVM_ABI SDValue getBitcast(EVT VT, SDValue V)
Return a bitcast using the SDLoc of the value operand, and casting to the provided type.
SDValue getSelect(const SDLoc &DL, EVT VT, SDValue Cond, SDValue LHS, SDValue RHS, SDNodeFlags Flags=SDNodeFlags())
Helper function to make it easier to build Select's if you just have operands and don't want to check...
LLVM_ABI SDValue getNegative(SDValue Val, const SDLoc &DL, EVT VT)
Create negative operation as (SUB 0, Val).
LLVM_ABI std::optional< unsigned > getValidShiftAmount(SDValue V, const APInt &DemandedElts, unsigned Depth=0) const
If a SHL/SRA/SRL node V has a uniform shift amount that is less than the element bit-width of the shi...
LLVM_ABI SDValue getZeroExtendInReg(SDValue Op, const SDLoc &DL, EVT VT)
Return the expression required to zero extend the Op value assuming it was the smaller SrcTy value.
const DataLayout & getDataLayout() const
LLVM_ABI bool doesNodeExist(unsigned Opcode, SDVTList VTList, ArrayRef< SDValue > Ops)
Check if a node exists without modifying its flags.
LLVM_ABI SDValue getConstant(uint64_t Val, const SDLoc &DL, EVT VT, bool isTarget=false, bool isOpaque=false)
Create a ConstantSDNode wrapping a constant value.
LLVM_ABI SDValue getMemBasePlusOffset(SDValue Base, TypeSize Offset, const SDLoc &DL, const SDNodeFlags Flags=SDNodeFlags())
Returns sum of the base pointer and offset.
LLVM_ABI SDValue getGlobalAddress(const GlobalValue *GV, const SDLoc &DL, EVT VT, int64_t offset=0, bool isTargetGA=false, unsigned TargetFlags=0)
LLVM_ABI SDValue getTruncStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, EVT SVT, Align Alignment, MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
LLVM_ABI SDValue getTypeSize(const SDLoc &DL, EVT VT, TypeSize TS)
LLVM_ABI std::pair< SDValue, SDValue > SplitVector(const SDValue &N, const SDLoc &DL, const EVT &LoVT, const EVT &HiVT)
Split the vector with EXTRACT_SUBVECTOR using the provided VTs and return the low/high part.
LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, Align Alignment, MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
Helper function to build ISD::STORE nodes.
LLVM_ABI SDValue getSignedConstant(int64_t Val, const SDLoc &DL, EVT VT, bool isTarget=false, bool isOpaque=false)
SDValue getSplatVector(EVT VT, const SDLoc &DL, SDValue Op)
LLVM_ABI bool SignBitIsZero(SDValue Op, unsigned Depth=0) const
Return true if the sign bit of Op is known to be zero.
LLVM_ABI void RemoveDeadNode(SDNode *N)
Remove the specified node from the system.
SDValue getSelectCC(const SDLoc &DL, SDValue LHS, SDValue RHS, SDValue True, SDValue False, ISD::CondCode Cond, SDNodeFlags Flags=SDNodeFlags())
Helper function to make it easier to build SelectCC's if you just have an ISD::CondCode instead of an...
LLVM_ABI SDValue getSExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by either sign-extending or trunca...
LLVM_ABI bool isIdentityElement(unsigned Opc, SDNodeFlags Flags, SDValue V, unsigned OperandNo, unsigned Depth=0) const
Returns true if V is an identity element of Opc with Flags.
LLVM_ABI bool isGuaranteedNotToBeUndefOrPoison(SDValue Op, UndefPoisonKind Kind=UndefPoisonKind::UndefOrPoison, unsigned Depth=0) const
Return true if this function can prove that Op is never poison and, Kind can be used to track poison ...
LLVM_ABI bool isKnownNeverZero(SDValue Op, unsigned Depth=0) const
Test whether the given SDValue is known to contain non-zero value(s).
LLVM_ABI SDValue FoldConstantArithmetic(unsigned Opcode, const SDLoc &DL, EVT VT, ArrayRef< SDValue > Ops, SDNodeFlags Flags=SDNodeFlags())
LLVM_ABI SDValue getBoolExtOrTrunc(SDValue Op, const SDLoc &SL, EVT VT, EVT OpVT)
Convert Op, which must be of integer type, to the integer type VT, by using an extension appropriate ...
LLVM_ABI SDValue getExternalSymbol(const char *Sym, EVT VT)
const TargetMachine & getTarget() const
LLVM_ABI SDValue getIntPtrConstant(uint64_t Val, const SDLoc &DL, bool isTarget=false)
LLVM_ABI SDValue getValueType(EVT)
LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, ArrayRef< SDUse > Ops)
Gets or creates the specified node.
LLVM_ABI SDValue getFPExtendOrRound(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of float type, to the float type VT, by either extending or rounding (by tr...
LLVM_ABI bool isKnownNeverNaN(SDValue Op, const APInt &DemandedElts, bool SNaN=false, unsigned Depth=0) const
Test whether the given SDValue (or all elements of it, if it is a vector) is known to never be NaN in...
SDValue getTargetConstant(uint64_t Val, const SDLoc &DL, EVT VT, bool isOpaque=false)
LLVM_ABI unsigned ComputeNumSignBits(SDValue Op, unsigned Depth=0) const
Return the number of times the sign bit of the register is replicated into the other bits.
LLVM_ABI SDValue getBoolConstant(bool V, const SDLoc &DL, EVT VT, EVT OpVT)
Create a true or false constant of type VT using the target's BooleanContent for type OpVT.
SDValue getTargetBlockAddress(const BlockAddress *BA, EVT VT, int64_t Offset=0, unsigned TargetFlags=0)
LLVM_ABI SDValue getVectorIdxConstant(uint64_t Val, const SDLoc &DL, bool isTarget=false)
LLVM_ABI void ReplaceAllUsesOfValueWith(SDValue From, SDValue To)
Replace any uses of From with To, leaving uses of other values produced by From.getNode() alone.
MachineFunction & getMachineFunction() const
SDValue getPOISON(EVT VT)
Return a POISON node. POISON does not have a useful SDLoc.
LLVM_ABI KnownBits computeKnownBits(SDValue Op, unsigned Depth=0) const
Determine which bits of Op are known to be either zero or one and return them in Known.
LLVM_ABI SDValue getZExtOrTrunc(SDValue Op, const SDLoc &DL, EVT VT)
Convert Op, which must be of integer type, to the integer type VT, by either zero-extending or trunca...
LLVM_ABI SDValue getCondCode(ISD::CondCode Cond)
LLVM_ABI bool MaskedValueIsZero(SDValue Op, const APInt &Mask, unsigned Depth=0) const
Return true if 'Op & Mask' is known to be zero.
SDValue getObjectPtrOffset(const SDLoc &SL, SDValue Ptr, TypeSize Offset)
Create an add instruction with appropriate flags when used for addressing some offset of an object.
LLVMContext * getContext() const
LLVM_ABI bool isKnownToBeAPowerOfTwo(SDValue Val, bool OrZero=false, unsigned Depth=0) const
Test if the given value is known to have exactly one bit set.
SDValue getSetCCVP(const SDLoc &DL, EVT VT, SDValue LHS, SDValue RHS, ISD::CondCode Cond, SDValue Mask, SDValue EVL)
Helper function to make it easier to build VP_SETCCs if you just have an ISD::CondCode instead of an ...
LLVM_ABI SDValue CreateStackTemporary(TypeSize Bytes, Align Alignment)
Create a stack temporary based on the size in bytes and the alignment.
SDValue getEntryNode() const
Return the token chain corresponding to the entry of the function.
SDValue getSplat(EVT VT, const SDLoc &DL, SDValue Op)
Returns a node representing a splat of one value into all lanes of the provided vector type.
LLVM_ABI std::pair< SDValue, SDValue > SplitScalar(const SDValue &N, const SDLoc &DL, const EVT &LoVT, const EVT &HiVT)
Split the scalar node with EXTRACT_ELEMENT using the provided VTs and return the low/high part.
LLVM_ABI SDValue getVectorShuffle(EVT VT, const SDLoc &dl, SDValue N1, SDValue N2, ArrayRef< int > Mask)
Return an ISD::VECTOR_SHUFFLE node.
static void commuteMask(MutableArrayRef< int > Mask)
Change values in a shuffle permute mask assuming the two vector operands have swapped position.
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.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
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)
void append(ItTy in_start, ItTy in_end)
Add the specified range to the end of the SmallVector.
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 is used to represent ISD::STORE nodes.
Represent a constant reference to a string, i.e.
constexpr StringRef substr(size_t Start, size_t N=npos) const
Return a reference to the substring from [Start, Start + N).
bool starts_with(StringRef Prefix) const
Check if this string starts with the given Prefix.
constexpr size_t size() const
Get the string size.
constexpr const char * data() const
Get a pointer to the start of the string (which may not be null terminated).
Class to represent struct types.
LLVM_ABI void setAttributes(const CallBase *Call, unsigned ArgIdx)
Set CallLoweringInfo attribute flags based on a call instruction and called function attributes.
bool isOperationExpand(unsigned Op, EVT VT) const
Return true if the specified operation is illegal on this target or unlikely to be made legal with cu...
unsigned getBitWidthForCttzElements(EVT RetVT, ElementCount EC, bool ZeroIsPoison, const ConstantRange *VScaleRange) const
Return the minimum number of bits required to hold the maximum possible number of trailing zero vecto...
virtual bool isShuffleMaskLegal(ArrayRef< int >, EVT) const
Targets can use this to indicate that they only support some VECTOR_SHUFFLE operations,...
virtual bool shouldRemoveRedundantExtend(SDValue Op) const
Return true (the default) if it is profitable to remove a sext_inreg(x) where the sext is redundant,...
virtual bool shouldReduceLoadWidth(SDNode *Load, ISD::LoadExtType ExtTy, EVT NewVT, std::optional< unsigned > ByteOffset=std::nullopt) const
Return true if it is profitable to reduce a load to a smaller type.
EVT getValueType(const DataLayout &DL, Type *Ty, bool AllowUnknown=false) const
Return the EVT corresponding to this LLVM type.
virtual bool preferSelectsOverBooleanArithmetic(EVT VT) const
Should we prefer selects to doing arithmetic on boolean types.
virtual bool isLegalICmpImmediate(int64_t) const
Return true if the specified immediate is legal icmp immediate, that is the target has icmp instructi...
virtual MVT::SimpleValueType getCmpLibcallReturnType() const
Return the ValueType for comparison libcalls.
virtual bool isSExtCheaperThanZExt(EVT FromTy, EVT ToTy) const
Return true if sign-extension from FromTy to ToTy is cheaper than zero-extension.
MVT getVectorIdxTy(const DataLayout &DL) const
Returns the type to be used for the index operand of: ISD::INSERT_VECTOR_ELT, ISD::EXTRACT_VECTOR_ELT...
virtual bool isSafeMemOpType(MVT) const
Returns true if it's safe to use load / store of the specified type to expand memcpy / memset inline.
const TargetMachine & getTargetMachine() const
virtual bool isCtpopFast(EVT VT) const
Return true if ctpop instruction is fast.
virtual bool isZExtFree(Type *FromTy, Type *ToTy) const
Return true if any actual instruction that defines a value of type FromTy implicitly zero-extends the...
bool isPaddedAtMostSignificantBitsWhenStored(EVT VT) const
Indicates if any padding is guaranteed to go at the most significant bits when storing the type to me...
LegalizeTypeAction
This enum indicates whether a types are legal for a target, and if not, what action should be used to...
virtual bool hasBitTest(SDValue X, SDValue Y) const
Return true if the target has a bit-test instruction: (X & (1 << Y)) ==/!= 0 This knowledge can be us...
EVT getLegalTypeToTransformTo(LLVMContext &Context, EVT VT) const
Perform getTypeToTransformTo repeatedly until a legal type is obtained.
LegalizeAction getCondCodeAction(ISD::CondCode CC, MVT VT) const
Return how the condition code should be treated: either it is legal, needs to be expanded to some oth...
CallingConv::ID getLibcallImplCallingConv(RTLIB::LibcallImpl Call) const
Get the CallingConv that should be used for the specified libcall implementation.
virtual bool isCommutativeBinOp(unsigned Opcode) const
Returns true if the opcode is a commutative binary operation.
virtual bool isFPImmLegal(const APFloat &, EVT, bool ForCodeSize=false) const
Returns true if the target can instruction select the specified FP immediate natively.
virtual bool shouldTransformSignedTruncationCheck(EVT XVT, unsigned KeptBits) const
Should we tranform the IR-optimal check for whether given truncation down into KeptBits would be trun...
bool isLegalRC(const TargetRegisterInfo &TRI, const TargetRegisterClass &RC) const
Return true if the value types that can be represented by the specified register class are all legal.
virtual bool allowsMisalignedMemoryAccesses(EVT, unsigned AddrSpace=0, Align Alignment=Align(1), MachineMemOperand::Flags Flags=MachineMemOperand::MONone, unsigned *=nullptr) const
Determine if the target supports unaligned memory accesses.
bool isOperationCustom(unsigned Op, EVT VT) const
Return true if the operation uses custom lowering, regardless of whether the type is legal or not.
EVT getShiftAmountTy(EVT LHSTy, const DataLayout &DL) const
Returns the type for the shift amount of a shift opcode.
virtual bool shouldExtendTypeInLibCall(EVT Type) const
Returns true if arguments should be extended in lib calls.
virtual bool isTruncateFree(Type *FromTy, Type *ToTy) const
Return true if it's free to truncate a value of type FromTy to type ToTy.
virtual bool shouldAvoidTransformToShift(EVT VT, unsigned Amount) const
Return true if creating a shift of the type by the given amount is not profitable.
virtual bool isFPExtFree(EVT DestVT, EVT SrcVT) const
Return true if an fpext operation is free (for instance, because single-precision floating-point numb...
virtual EVT getSetCCResultType(const DataLayout &DL, LLVMContext &Context, EVT VT) const
Return the ValueType of the result of SETCC operations.
virtual EVT getTypeToTransformTo(LLVMContext &Context, EVT VT) const
For types supported by the target, this is an identity function.
BooleanContent getBooleanContents(bool isVec, bool isFloat) const
For targets without i1 registers, this gives the nature of the high-bits of boolean values held in ty...
bool isCondCodeLegal(ISD::CondCode CC, MVT VT) const
Return true if the specified condition code is legal for a comparison of the specified types on this ...
bool isTypeLegal(EVT VT) const
Return true if the target has native support for the specified value type.
virtual MVT getPointerTy(const DataLayout &DL, uint32_t AS=0) const
Return the pointer type for the given address space, defaults to the pointer type from the data layou...
ISD::CondCode getSoftFloatCmpLibcallPredicate(RTLIB::LibcallImpl Call) const
Get the comparison predicate that's to be used to test the result of the comparison libcall against z...
bool isOperationLegal(unsigned Op, EVT VT) const
Return true if the specified operation is legal on this target.
TargetLoweringBase(const TargetMachine &TM, const TargetSubtargetInfo &STI)
NOTE: The TargetMachine owns TLOF.
virtual unsigned getCustomCtpopCost(EVT VT, ISD::CondCode Cond) const
Return the maximum number of "x & (x - 1)" operations that can be done instead of deferring to a cust...
virtual bool shouldProduceAndByConstByHoistingConstFromShiftsLHSOfAnd(SDValue X, ConstantSDNode *XC, ConstantSDNode *CC, SDValue Y, unsigned OldShiftOpcode, unsigned NewShiftOpcode, SelectionDAG &DAG) const
Given the pattern (X & (C l>>/<< Y)) ==/!= 0 return true if it should be transformed into: ((X <</l>>...
BooleanContent
Enum that describes how the target represents true/false values.
@ ZeroOrOneBooleanContent
@ UndefinedBooleanContent
@ ZeroOrNegativeOneBooleanContent
virtual bool isIntDivCheap(EVT VT, AttributeList Attr) const
Return true if integer divide is usually cheaper than a sequence of several shifts,...
bool isOperationLegalOrCustom(unsigned Op, EVT VT, bool LegalOnly=false) const
Return true if the specified operation is legal on this target or can be made legal with custom lower...
virtual bool allowsMemoryAccess(LLVMContext &Context, const DataLayout &DL, EVT VT, unsigned AddrSpace=0, Align Alignment=Align(1), MachineMemOperand::Flags Flags=MachineMemOperand::MONone, unsigned *Fast=nullptr) const
Return true if the target supports a memory access of this type for the given address space and align...
virtual bool hasAndNotCompare(SDValue Y) const
Return true if the target should transform: (X & Y) == Y ---> (~X & Y) == 0 (X & Y) !...
virtual bool isNarrowingProfitable(SDNode *N, EVT SrcVT, EVT DestVT) const
Return true if it's profitable to narrow operations of type SrcVT to DestVT.
virtual bool isBinOp(unsigned Opcode) const
Return true if the node is a math/logic binary operator.
RTLIB::LibcallImpl getLibcallImpl(RTLIB::Libcall Call) const
Get the libcall impl routine name for the specified libcall.
virtual bool isCtlzFast() const
Return true if ctlz instruction is fast.
virtual bool shouldUseStrictFP_TO_INT(EVT FpVT, EVT IntVT, bool IsSigned) const
Return true if it is more correct/profitable to use strict FP_TO_INT conversion operations - canonica...
NegatibleCost
Enum that specifies when a float negation is beneficial.
LegalizeTypeAction getTypeAction(LLVMContext &Context, EVT VT) const
Return how we should legalize values of this type, either it is already legal (return 'Legal') or we ...
virtual bool shouldSignExtendTypeInLibCall(Type *Ty, bool IsSigned) const
Returns true if arguments should be sign-extended in lib calls.
std::vector< ArgListEntry > ArgListTy
virtual EVT getOptimalMemOpType(LLVMContext &Context, const MemOp &Op, const AttributeList &) const
Returns the target specific optimal type for load and store operations as a result of memset,...
virtual EVT getAsmOperandValueType(const DataLayout &DL, Type *Ty, bool AllowUnknown=false) const
bool isCondCodeLegalOrCustom(ISD::CondCode CC, MVT VT) const
Return true if the specified condition code is legal or custom for a comparison of the specified type...
bool isLoadLegal(EVT ValVT, EVT MemVT, Align Alignment, unsigned AddrSpace, unsigned ExtType, bool Atomic) const
Return true if the specified load with extension is legal on this target.
MVT getRegisterType(MVT VT) const
Return the type of registers that this ValueType will eventually require.
virtual bool isFAbsFree(EVT VT) const
Return true if an fabs operation is free to the point where it is never worthwhile to replace it with...
LegalizeAction getOperationAction(unsigned Op, EVT VT) const
Return how this operation should be treated: either it is legal, needs to be promoted to a larger siz...
bool isOperationLegalOrCustomOrPromote(unsigned Op, EVT VT, bool LegalOnly=false) const
Return true if the specified operation is legal on this target or can be made legal with custom lower...
MulExpansionKind
Enum that specifies when a multiplication should be expanded.
static ISD::NodeType getExtendForContent(BooleanContent Content)
This class defines information used to lower LLVM code to legal SelectionDAG operators that the targe...
SDValue expandAddSubSat(SDNode *Node, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::[US][ADD|SUB]SAT.
SDValue buildSDIVPow2WithCMov(SDNode *N, const APInt &Divisor, SelectionDAG &DAG, SmallVectorImpl< SDNode * > &Created) const
Build sdiv by power-of-2 with conditional move instructions Ref: "Hacker's Delight" by Henry Warren 1...
virtual ConstraintWeight getMultipleConstraintMatchWeight(AsmOperandInfo &info, int maIndex) const
Examine constraint type and operand type and determine a weight value.
bool expandMultipleResultFPLibCall(SelectionDAG &DAG, RTLIB::Libcall LC, SDNode *Node, SmallVectorImpl< SDValue > &Results, std::optional< unsigned > CallRetResNo={}) const
Expands a node with multiple results to an FP or vector libcall.
SDValue expandVPCTLZ(SDNode *N, SelectionDAG &DAG) const
Expand VP_CTLZ/VP_CTLZ_ZERO_POISON nodes.
bool expandMULO(SDNode *Node, SDValue &Result, SDValue &Overflow, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::[US]MULO.
bool expandMUL(SDNode *N, SDValue &Lo, SDValue &Hi, EVT HiLoVT, SelectionDAG &DAG, MulExpansionKind Kind, SDValue LL=SDValue(), SDValue LH=SDValue(), SDValue RL=SDValue(), SDValue RH=SDValue()) const
Expand a MUL into two nodes.
SmallVector< ConstraintPair > ConstraintGroup
virtual const MCExpr * getPICJumpTableRelocBaseExpr(const MachineFunction *MF, unsigned JTI, MCContext &Ctx) const
This returns the relocation base for the given PIC jumptable, the same as getPICJumpTableRelocBase,...
virtual Align computeKnownAlignForTargetInstr(GISelValueTracking &Analysis, Register R, const MachineRegisterInfo &MRI, unsigned Depth=0) const
Determine the known alignment for the pointer value R.
bool SimplifyDemandedVectorElts(SDValue Op, const APInt &DemandedEltMask, APInt &KnownUndef, APInt &KnownZero, TargetLoweringOpt &TLO, unsigned Depth=0, bool AssumeSingleUse=false) const
Look at Vector Op.
virtual bool isUsedByReturnOnly(SDNode *, SDValue &) const
Return true if result of the specified node is used by a return node only.
virtual void computeKnownBitsForFrameIndex(int FIOp, KnownBits &Known, const MachineFunction &MF) const
Determine which of the bits of FrameIndex FIOp are known to be 0.
SDValue scalarizeVectorStore(StoreSDNode *ST, SelectionDAG &DAG) const
virtual unsigned ComputeNumSignBitsForTargetNode(SDValue Op, const APInt &DemandedElts, const SelectionDAG &DAG, unsigned Depth=0) const
This method can be implemented by targets that want to expose additional information about sign bits ...
SDValue lowerCmpEqZeroToCtlzSrl(SDValue Op, SelectionDAG &DAG) const
SDValue expandVPBSWAP(SDNode *N, SelectionDAG &DAG) const
Expand VP_BSWAP nodes.
void softenSetCCOperands(SelectionDAG &DAG, EVT VT, SDValue &NewLHS, SDValue &NewRHS, ISD::CondCode &CCCode, const SDLoc &DL, const SDValue OldLHS, const SDValue OldRHS) const
Soften the operands of a comparison.
void forceExpandWideMUL(SelectionDAG &DAG, const SDLoc &dl, bool Signed, const SDValue LHS, const SDValue RHS, SDValue &Lo, SDValue &Hi) const
Calculate full product of LHS and RHS either via a libcall or through brute force expansion of the mu...
SDValue expandVecReduceSeq(SDNode *Node, SelectionDAG &DAG) const
Expand a VECREDUCE_SEQ_* into an explicit ordered calculation.
SDValue expandFCANONICALIZE(SDNode *Node, SelectionDAG &DAG) const
Expand FCANONICALIZE to FMUL with 1.
SDValue expandCTLZ(SDNode *N, SelectionDAG &DAG) const
Expand CTLZ/CTLZ_ZERO_POISON nodes.
SDValue expandBITREVERSE(SDNode *N, SelectionDAG &DAG) const
Expand BITREVERSE nodes.
SDValue expandCTTZ(SDNode *N, SelectionDAG &DAG) const
Expand CTTZ/CTTZ_ZERO_POISON nodes.
virtual SDValue expandIndirectJTBranch(const SDLoc &dl, SDValue Value, SDValue Addr, int JTI, SelectionDAG &DAG) const
Expands target specific indirect branch for the case of JumpTable expansion.
SDValue expandABD(SDNode *N, SelectionDAG &DAG) const
Expand ABDS/ABDU nodes.
virtual bool targetShrinkDemandedConstant(SDValue Op, const APInt &DemandedBits, const APInt &DemandedElts, TargetLoweringOpt &TLO) const
std::vector< AsmOperandInfo > AsmOperandInfoVector
SDValue expandCLMUL(SDNode *N, SelectionDAG &DAG) const
Expand carryless multiply.
SDValue expandShlSat(SDNode *Node, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::[US]SHLSAT.
SDValue expandIS_FPCLASS(EVT ResultVT, SDValue Op, FPClassTest Test, SDNodeFlags Flags, const SDLoc &DL, SelectionDAG &DAG) const
Expand check for floating point class.
virtual bool isTargetCanonicalConstantNode(SDValue Op) const
Returns true if the given Opc is considered a canonical constant for the target, which should not be ...
SDValue expandFP_TO_INT_SAT(SDNode *N, SelectionDAG &DAG) const
Expand FP_TO_[US]INT_SAT into FP_TO_[US]INT and selects or min/max.
SDValue expandCttzElts(SDNode *Node, SelectionDAG &DAG) const
Expand a CTTZ_ELTS or CTTZ_ELTS_ZERO_POISON by calculating (VL - i) for each active lane (i),...
SDValue getCheaperNegatedExpression(SDValue Op, SelectionDAG &DAG, bool LegalOps, bool OptForSize, unsigned Depth=0) const
This is the helper function to return the newly negated expression only when the cost is cheaper.
virtual unsigned computeNumSignBitsForTargetInstr(GISelValueTracking &Analysis, Register R, const APInt &DemandedElts, const MachineRegisterInfo &MRI, unsigned Depth=0) const
This method can be implemented by targets that want to expose additional information about sign bits ...
SDValue SimplifyMultipleUseDemandedBits(SDValue Op, const APInt &DemandedBits, const APInt &DemandedElts, SelectionDAG &DAG, unsigned Depth=0) const
More limited version of SimplifyDemandedBits that can be used to "lookthrough" ops that don't contrib...
SDValue expandUnalignedStore(StoreSDNode *ST, SelectionDAG &DAG) const
Expands an unaligned store to 2 half-size stores for integer values, and possibly more for vectors.
SDValue SimplifyMultipleUseDemandedVectorElts(SDValue Op, const APInt &DemandedElts, SelectionDAG &DAG, unsigned Depth=0) const
Helper wrapper around SimplifyMultipleUseDemandedBits, demanding all bits from only some vector eleme...
virtual ConstraintType getConstraintType(StringRef Constraint) const
Given a constraint, return the type of constraint it is for this target.
virtual bool findOptimalMemOpLowering(LLVMContext &Context, std::vector< EVT > &MemOps, unsigned Limit, const MemOp &Op, unsigned DstAS, unsigned SrcAS, const AttributeList &FuncAttributes, EVT *LargestVT=nullptr) const
Determines the optimal series of memory ops to replace the memset / memcpy.
virtual SDValue unwrapAddress(SDValue N) const
void expandSADDSUBO(SDNode *Node, SDValue &Result, SDValue &Overflow, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::S(ADD|SUB)O.
SDValue expandVPBITREVERSE(SDNode *N, SelectionDAG &DAG) const
Expand VP_BITREVERSE nodes.
SDValue expandABS(SDNode *N, SelectionDAG &DAG, bool IsNegative=false) const
Expand ABS nodes.
SDValue expandVecReduce(SDNode *Node, SelectionDAG &DAG) const
Expand a VECREDUCE_* into an explicit calculation.
bool ShrinkDemandedConstant(SDValue Op, const APInt &DemandedBits, const APInt &DemandedElts, TargetLoweringOpt &TLO) const
Check to see if the specified operand of the specified instruction is a constant integer.
virtual bool isGuaranteedNotToBeUndefOrPoisonForTargetNode(SDValue Op, const APInt &DemandedElts, const SelectionDAG &DAG, UndefPoisonKind Kind, unsigned Depth) const
Return true if this function can prove that Op is never poison and, Kind can be used to track poison ...
SDValue expandVPCTTZElements(SDNode *N, SelectionDAG &DAG) const
Expand VP_CTTZ_ELTS/VP_CTTZ_ELTS_ZERO_POISON nodes.
SDValue BuildSDIV(SDNode *N, SelectionDAG &DAG, bool IsAfterLegalization, bool IsAfterLegalTypes, SmallVectorImpl< SDNode * > &Created) const
Given an ISD::SDIV node expressing a divide by constant, return a DAG expression to select that will ...
virtual const char * getTargetNodeName(unsigned Opcode) const
This method returns the name of a target specific DAG node.
bool expandFP_TO_UINT(SDNode *N, SDValue &Result, SDValue &Chain, SelectionDAG &DAG) const
Expand float to UINT conversion.
bool parametersInCSRMatch(const MachineRegisterInfo &MRI, const uint32_t *CallerPreservedMask, const SmallVectorImpl< CCValAssign > &ArgLocs, const SmallVectorImpl< SDValue > &OutVals) const
Check whether parameters to a call that are passed in callee saved registers are the same as from the...
virtual bool SimplifyDemandedVectorEltsForTargetNode(SDValue Op, const APInt &DemandedElts, APInt &KnownUndef, APInt &KnownZero, TargetLoweringOpt &TLO, unsigned Depth=0) const
Attempt to simplify any target nodes based on the demanded vector elements, returning true on success...
bool expandREM(SDNode *Node, SDValue &Result, SelectionDAG &DAG) const
Expand an SREM or UREM using SDIV/UDIV or SDIVREM/UDIVREM, if legal.
std::pair< SDValue, SDValue > expandUnalignedLoad(LoadSDNode *LD, SelectionDAG &DAG) const
Expands an unaligned load to 2 half-size loads for an integer, and possibly more for vectors.
SDValue expandFMINIMUMNUM_FMAXIMUMNUM(SDNode *N, SelectionDAG &DAG) const
Expand fminimumnum/fmaximumnum into multiple comparison with selects.
void forceExpandMultiply(SelectionDAG &DAG, const SDLoc &dl, bool Signed, SDValue &Lo, SDValue &Hi, SDValue LHS, SDValue RHS, SDValue HiLHS=SDValue(), SDValue HiRHS=SDValue()) const
Calculate the product twice the width of LHS and RHS.
virtual SDValue LowerToTLSEmulatedModel(const GlobalAddressSDNode *GA, SelectionDAG &DAG) const
Lower TLS global address SDNode for target independent emulated TLS model.
virtual bool isTypeDesirableForOp(unsigned, EVT VT) const
Return true if the target has native support for the specified value type and it is 'desirable' to us...
SDValue expandVectorSplice(SDNode *Node, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::VECTOR_SPLICE.
SDValue getVectorSubVecPointer(SelectionDAG &DAG, SDValue VecPtr, EVT VecVT, EVT SubVecVT, SDValue Index, const SDNodeFlags PtrArithFlags=SDNodeFlags()) const
Get a pointer to a sub-vector of type SubVecVT at index Idx located in memory for a vector of type Ve...
SDValue expandLoopDependenceMask(SDNode *N, SelectionDAG &DAG) const
Expand LOOP_DEPENDENCE_MASK nodes.
virtual const char * LowerXConstraint(EVT ConstraintVT) const
Try to replace an X constraint, which matches anything, with another that has more specific requireme...
SDValue expandCTPOP(SDNode *N, SelectionDAG &DAG) const
Expand CTPOP nodes.
virtual void computeKnownBitsForTargetInstr(GISelValueTracking &Analysis, Register R, KnownBits &Known, const APInt &DemandedElts, const MachineRegisterInfo &MRI, unsigned Depth=0) const
Determine which of the bits specified in Mask are known to be either zero or one and return them in t...
SDValue BuildUDIV(SDNode *N, SelectionDAG &DAG, bool IsAfterLegalization, bool IsAfterLegalTypes, SmallVectorImpl< SDNode * > &Created) const
Given an ISD::UDIV node expressing a divide by constant, return a DAG expression to select that will ...
SDValue expandVectorNaryOpBySplitting(SDNode *Node, SelectionDAG &DAG) const
~TargetLowering() override
std::pair< SDValue, SDValue > LowerCallTo(CallLoweringInfo &CLI) const
This function lowers an abstract call to a function into an actual call.
SDValue expandBSWAP(SDNode *N, SelectionDAG &DAG) const
Expand BSWAP nodes.
SDValue expandFMINIMUM_FMAXIMUM(SDNode *N, SelectionDAG &DAG) const
Expand fminimum/fmaximum into multiple comparison with selects.
SDValue CTTZTableLookup(SDNode *N, SelectionDAG &DAG, const SDLoc &DL, EVT VT, SDValue Op, unsigned NumBitsPerElt) const
Expand CTTZ via Table Lookup.
bool expandDIVREMByConstant(SDNode *N, SmallVectorImpl< SDValue > &Result, EVT HiLoVT, SelectionDAG &DAG, SDValue LL=SDValue(), SDValue LH=SDValue()) const
Attempt to expand an n-bit div/rem/divrem by constant using an n/2-bit algorithm.
virtual void computeKnownBitsForTargetNode(const SDValue Op, KnownBits &Known, const APInt &DemandedElts, const SelectionDAG &DAG, unsigned Depth=0) const
Determine which of the bits specified in Mask are known to be either zero or one and return them in t...
bool isPositionIndependent() const
std::pair< StringRef, TargetLowering::ConstraintType > ConstraintPair
virtual SDValue getNegatedExpression(SDValue Op, SelectionDAG &DAG, bool LegalOps, bool OptForSize, NegatibleCost &Cost, unsigned Depth=0) const
Return the newly negated expression if the cost is not expensive and set the cost in Cost to indicate...
virtual ConstraintWeight getSingleConstraintMatchWeight(AsmOperandInfo &info, const char *constraint) const
Examine constraint string and operand type and determine a weight value.
ConstraintGroup getConstraintPreferences(AsmOperandInfo &OpInfo) const
Given an OpInfo with list of constraints codes as strings, return a sorted Vector of pairs of constra...
bool expandFP_TO_SINT(SDNode *N, SDValue &Result, SelectionDAG &DAG) const
Expand float(f32) to SINT(i64) conversion.
virtual SDValue SimplifyMultipleUseDemandedBitsForTargetNode(SDValue Op, const APInt &DemandedBits, const APInt &DemandedElts, SelectionDAG &DAG, unsigned Depth) const
More limited version of SimplifyDemandedBits that can be used to "lookthrough" ops that don't contrib...
virtual SDValue LowerAsmOutputForConstraint(SDValue &Chain, SDValue &Glue, const SDLoc &DL, const AsmOperandInfo &OpInfo, SelectionDAG &DAG) const
SDValue buildLegalVectorShuffle(EVT VT, const SDLoc &DL, SDValue N0, SDValue N1, MutableArrayRef< int > Mask, SelectionDAG &DAG) const
Tries to build a legal vector shuffle using the provided parameters or equivalent variations.
virtual SDValue getPICJumpTableRelocBase(SDValue Table, SelectionDAG &DAG) const
Returns relocation base for the given PIC jumptable.
std::pair< SDValue, SDValue > scalarizeVectorLoad(LoadSDNode *LD, SelectionDAG &DAG) const
Turn load of vector type into a load of the individual elements.
virtual std::pair< unsigned, const TargetRegisterClass * > getRegForInlineAsmConstraint(const TargetRegisterInfo *TRI, StringRef Constraint, MVT VT) const
Given a physical register constraint (e.g.
bool SimplifyDemandedBits(SDValue Op, const APInt &DemandedBits, const APInt &DemandedElts, KnownBits &Known, TargetLoweringOpt &TLO, unsigned Depth=0, bool AssumeSingleUse=false) const
Look at Op.
virtual bool SimplifyDemandedBitsForTargetNode(SDValue Op, const APInt &DemandedBits, const APInt &DemandedElts, KnownBits &Known, TargetLoweringOpt &TLO, unsigned Depth=0) const
Attempt to simplify any target nodes based on the demanded bits/elts, returning true on success.
virtual bool isDesirableToCommuteXorWithShift(const SDNode *N) const
Return true if it is profitable to combine an XOR of a logical shift to create a logical shift of NOT...
TargetLowering(const TargetLowering &)=delete
virtual bool shouldSimplifyDemandedVectorElts(SDValue Op, const TargetLoweringOpt &TLO) const
Return true if the target supports simplifying demanded vector elements by converting them to undefs.
bool isConstFalseVal(SDValue N) const
Return if the N is a constant or constant vector equal to the false value from getBooleanContents().
SDValue IncrementMemoryAddress(SDValue Addr, SDValue Mask, const SDLoc &DL, EVT DataVT, SelectionDAG &DAG, bool IsCompressedMemory) const
Increments memory address Addr according to the type of the value DataVT that should be stored.
bool isInTailCallPosition(SelectionDAG &DAG, SDNode *Node, SDValue &Chain) const
Check whether a given call node is in tail position within its function.
SDValue expandCONVERT_TO_ARBITRARY_FP(SDNode *Node, SelectionDAG &DAG) const
Expand CONVERT_TO_ARBITRARY_FP using bit manipulation.
virtual AsmOperandInfoVector ParseConstraints(const DataLayout &DL, const TargetRegisterInfo *TRI, const CallBase &Call) const
Split up the constraint string from the inline assembly value into the specific constraints and their...
virtual bool isSplatValueForTargetNode(SDValue Op, const APInt &DemandedElts, APInt &UndefElts, const SelectionDAG &DAG, unsigned Depth=0) const
Return true if vector Op has the same value across all DemandedElts, indicating any elements which ma...
SDValue expandRoundInexactToOdd(EVT ResultVT, SDValue Op, const SDLoc &DL, SelectionDAG &DAG) const
Truncate Op to ResultVT.
virtual bool shouldSplitFunctionArgumentsAsLittleEndian(const DataLayout &DL) const
For most targets, an LLVM type must be broken down into multiple smaller types.
SDValue SimplifySetCC(EVT VT, SDValue N0, SDValue N1, ISD::CondCode Cond, bool foldBooleans, DAGCombinerInfo &DCI, const SDLoc &dl) const
Try to simplify a setcc built with the specified operands and cc.
SDValue expandFunnelShift(SDNode *N, SelectionDAG &DAG) const
Expand funnel shift.
virtual bool isOffsetFoldingLegal(const GlobalAddressSDNode *GA) const
Return true if folding a constant offset with the given GlobalAddress is legal.
bool LegalizeSetCCCondCode(SelectionDAG &DAG, EVT VT, SDValue &LHS, SDValue &RHS, SDValue &CC, SDValue Mask, SDValue EVL, bool &NeedInvert, const SDLoc &dl, SDValue &Chain, bool IsSignaling=false) const
Legalize a SETCC or VP_SETCC with given LHS and RHS and condition code CC on the current target.
bool isExtendedTrueVal(const ConstantSDNode *N, EVT VT, bool SExt) const
Return if N is a True value when extended to VT.
bool ShrinkDemandedOp(SDValue Op, unsigned BitWidth, const APInt &DemandedBits, TargetLoweringOpt &TLO) const
Convert x+y to (VT)((SmallVT)x+(SmallVT)y) if the casts are free.
bool isConstTrueVal(SDValue N) const
Return if the N is a constant or constant vector equal to the true value from getBooleanContents().
SDValue expandVPCTPOP(SDNode *N, SelectionDAG &DAG) const
Expand VP_CTPOP nodes.
SDValue expandFixedPointDiv(unsigned Opcode, const SDLoc &dl, SDValue LHS, SDValue RHS, unsigned Scale, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::[US]DIVFIX[SAT].
SDValue expandPEXT(SDNode *N, SelectionDAG &DAG) const
Expand parallel bit extract (compress).
virtual void ComputeConstraintToUse(AsmOperandInfo &OpInfo, SDValue Op, SelectionDAG *DAG=nullptr) const
Determines the constraint code and constraint type to use for the specific AsmOperandInfo,...
virtual void CollectTargetIntrinsicOperands(const CallInst &I, SmallVectorImpl< SDValue > &Ops, SelectionDAG &DAG) const
virtual bool canCreateUndefOrPoisonForTargetNode(SDValue Op, const APInt &DemandedElts, const SelectionDAG &DAG, UndefPoisonKind Kind, bool ConsiderFlags, unsigned Depth) const
Return true if Op can create undef or poison from non-undef & non-poison operands.
SDValue expandVPCTTZ(SDNode *N, SelectionDAG &DAG) const
Expand VP_CTTZ/VP_CTTZ_ZERO_POISON nodes.
SDValue expandVECTOR_COMPRESS(SDNode *Node, SelectionDAG &DAG) const
Expand a vector VECTOR_COMPRESS into a sequence of extract element, store temporarily,...
virtual const Constant * getTargetConstantFromLoad(LoadSDNode *LD) const
This method returns the constant pool value that will be loaded by LD.
SDValue expandFP_ROUND(SDNode *Node, SelectionDAG &DAG) const
Expand round(fp) to fp conversion.
SDValue createSelectForFMINNUM_FMAXNUM(SDNode *Node, SelectionDAG &DAG) const
Try to convert the fminnum/fmaxnum to a compare/select sequence.
SDValue expandCONVERT_FROM_ARBITRARY_FP(SDNode *Node, SelectionDAG &DAG) const
Expand CONVERT_FROM_ARBITRARY_FP using bit manipulation.
SDValue expandROT(SDNode *N, bool AllowVectorOps, SelectionDAG &DAG) const
Expand rotations.
virtual void LowerAsmOperandForConstraint(SDValue Op, StringRef Constraint, std::vector< SDValue > &Ops, SelectionDAG &DAG) const
Lower the specified operand into the Ops vector.
virtual SDValue getSqrtInputTest(SDValue Operand, SelectionDAG &DAG, const DenormalMode &Mode, SDNodeFlags Flags={}) const
Return a target-dependent comparison result if the input operand is suitable for use with a square ro...
SDValue getVectorElementPointer(SelectionDAG &DAG, SDValue VecPtr, EVT VecVT, SDValue Index, const SDNodeFlags PtrArithFlags=SDNodeFlags()) const
Get a pointer to vector element Idx located in memory for a vector of type VecVT starting at a base a...
SDValue expandFMINNUM_FMAXNUM(SDNode *N, SelectionDAG &DAG) const
Expand fminnum/fmaxnum into fminnum_ieee/fmaxnum_ieee with quieted inputs.
virtual bool isGAPlusOffset(SDNode *N, const GlobalValue *&GA, int64_t &Offset) const
Returns true (and the GlobalValue and the offset) if the node is a GlobalAddress + offset.
virtual void computeKnownFPClassForTargetNode(const SDValue Op, KnownFPClass &Known, const APInt &DemandedElts, const SelectionDAG &DAG, unsigned Depth=0) const
Determine floating-point class information for a target node.
virtual unsigned getJumpTableEncoding() const
Return the entry encoding for a jump table in the current function.
virtual void computeKnownFPClassForTargetInstr(GISelValueTracking &Analysis, Register R, KnownFPClass &Known, const APInt &DemandedElts, const MachineRegisterInfo &MRI, unsigned Depth=0) const
std::pair< SDValue, SDValue > makeLibCall(SelectionDAG &DAG, RTLIB::LibcallImpl LibcallImpl, EVT RetVT, ArrayRef< SDValue > Ops, MakeLibCallOptions CallOptions, const SDLoc &dl, SDValue Chain=SDValue()) const
Returns a pair of (return value, chain).
SDValue expandCMP(SDNode *Node, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::[US]CMP.
void expandShiftParts(SDNode *N, SDValue &Lo, SDValue &Hi, SelectionDAG &DAG) const
Expand shift-by-parts.
virtual bool isKnownNeverNaNForTargetNode(SDValue Op, const APInt &DemandedElts, const SelectionDAG &DAG, bool SNaN=false, unsigned Depth=0) const
If SNaN is false,.
virtual SDValue PerformDAGCombine(SDNode *N, DAGCombinerInfo &DCI) const
This method will be invoked for all target nodes and for any target-independent nodes that the target...
SDValue expandFixedPointMul(SDNode *Node, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::[U|S]MULFIX[SAT].
SDValue getInboundsVectorElementPointer(SelectionDAG &DAG, SDValue VecPtr, EVT VecVT, SDValue Index) const
Get a pointer to vector element Idx located in memory for a vector of type VecVT starting at a base a...
SDValue expandIntMINMAX(SDNode *Node, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::[US][MIN|MAX].
SDValue expandVectorFindLastActive(SDNode *N, SelectionDAG &DAG) const
Expand VECTOR_FIND_LAST_ACTIVE nodes.
SDValue expandPartialReduceMLA(SDNode *Node, SelectionDAG &DAG) const
Expands PARTIAL_REDUCE_S/UMLA nodes to a series of simpler operations, consisting of zext/sext,...
void expandUADDSUBO(SDNode *Node, SDValue &Result, SDValue &Overflow, SelectionDAG &DAG) const
Method for building the DAG expansion of ISD::U(ADD|SUB)O.
SDValue expandPDEP(SDNode *N, SelectionDAG &DAG) const
Expand parallel bit deposit (expand).
virtual SDValue BuildSDIVPow2(SDNode *N, const APInt &Divisor, SelectionDAG &DAG, SmallVectorImpl< SDNode * > &Created) const
Targets may override this function to provide custom SDIV lowering for power-of-2 denominators.
SDValue scalarizeExtractedVectorLoad(EVT ResultVT, const SDLoc &DL, EVT InVecVT, SDValue EltNo, LoadSDNode *OriginalLoad, SelectionDAG &DAG) const
Replace an extraction of a load with a narrowed load.
virtual SDValue BuildSREMPow2(SDNode *N, const APInt &Divisor, SelectionDAG &DAG, SmallVectorImpl< SDNode * > &Created) const
Targets may override this function to provide custom SREM lowering for power-of-2 denominators.
bool expandUINT_TO_FP(SDNode *N, SDValue &Result, SDValue &Chain, SelectionDAG &DAG) const
Expand UINT(i64) to double(f64) conversion.
bool expandMUL_LOHI(unsigned Opcode, EVT VT, const SDLoc &dl, SDValue LHS, SDValue RHS, SmallVectorImpl< SDValue > &Result, EVT HiLoVT, SelectionDAG &DAG, MulExpansionKind Kind, SDValue LL=SDValue(), SDValue LH=SDValue(), SDValue RL=SDValue(), SDValue RH=SDValue()) const
Expand a MUL or [US]MUL_LOHI of n-bit values into two or four nodes, respectively,...
SDValue expandAVG(SDNode *N, SelectionDAG &DAG) const
Expand vector/scalar AVGCEILS/AVGCEILU/AVGFLOORS/AVGFLOORU nodes.
SDValue expandCTLS(SDNode *N, SelectionDAG &DAG) const
Expand CTLS (count leading sign bits) nodes.
void setTypeIdForCallsiteInfo(const CallBase *CB, MachineFunction &MF, MachineFunction::CallSiteInfo &CSInfo) const
Primary interface to the complete machine description for the target machine.
bool isPositionIndependent() const
const Triple & getTargetTriple() const
unsigned EmitCallSiteInfo
The flag enables call site info production.
unsigned EmitCallGraphSection
Emit section containing call graph metadata.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
iterator_range< regclass_iterator > regclasses() const
virtual StringRef getRegAsmName(MCRegister Reg) const
Return the assembly name for Reg.
bool isTypeLegalForClass(const TargetRegisterClass &RC, MVT T) const
Return true if the given TargetRegisterClass has the ValueType T.
TargetSubtargetInfo - Generic base class for all target subtargets.
bool isOSBinFormatCOFF() const
Tests whether the OS uses the COFF binary format.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
static constexpr TypeSize getFixed(ScalarTy ExactSize)
The instances of the Type class are immutable: once they are created, they are never changed.
static LLVM_ABI IntegerType * getInt32Ty(LLVMContext &C)
bool isSingleValueType() const
Return true if the type is a valid type for a register in codegen.
static LLVM_ABI Type * getVoidTy(LLVMContext &C)
Type * getScalarType() const
If this is a vector type, return the element type, otherwise return 'this'.
bool isSized(SmallPtrSetImpl< Type * > *Visited=nullptr) const
Return true if it makes sense to take the size of this type.
LLVMContext & getContext() const
Return the LLVMContext in which this type was uniqued.
bool isIntegerTy() const
True if this is an instance of IntegerType.
LLVM_ABI const fltSemantics & getFltSemantics() const
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI const Value * stripPointerCastsAndAliases() const
Strip off pointer casts, all-zero GEPs, address space casts, and aliases.
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
constexpr bool isKnownMultipleOf(ScalarTy RHS) const
This function tells the caller whether the element count is known at compile time to be a multiple of...
constexpr ScalarTy getFixedValue() const
constexpr bool isScalable() const
Returns whether the quantity is scaled by a runtime quantity (vscale).
constexpr ScalarTy getKnownMinValue() const
Returns the minimum value this quantity can represent.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
LLVM_ABI APInt ScaleBitMask(const APInt &A, unsigned NewBitWidth, bool MatchAllBits=false)
Splat/Merge neighboring bits to widen/narrow the bitmask represented by.
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.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ C
The default llvm calling convention, compatible with C.
NodeType
ISD::NodeType enum - This enum defines the target-independent operators for a SelectionDAG.
@ SETCC
SetCC operator - This evaluates to a true value iff the condition is true.
@ MERGE_VALUES
MERGE_VALUES - This node takes multiple discrete operands and returns them all as its individual resu...
@ PTRADD
PTRADD represents pointer arithmetic semantics, for targets that opt in using shouldPreservePtrArith(...
@ PARTIAL_REDUCE_SMLA
PARTIAL_REDUCE_[U|S]MLA(Accumulator, Input1, Input2) The partial reduction nodes sign or zero extend ...
@ LOOP_DEPENDENCE_RAW_MASK
@ FGETSIGN
INT = FGETSIGN(FP) - Return the sign bit of the specified floating point value as an integer 0/1 valu...
@ SMUL_LOHI
SMUL_LOHI/UMUL_LOHI - Multiply two integers of type iN, producing a signed/unsigned value of type i[2...
@ INSERT_SUBVECTOR
INSERT_SUBVECTOR(VECTOR1, VECTOR2, IDX) - Returns a vector with VECTOR2 inserted into VECTOR1.
@ BSWAP
Byte Swap and Counting operators.
@ SMULFIX
RESULT = [US]MULFIX(LHS, RHS, SCALE) - Perform fixed point multiplication on 2 integers with the same...
@ ADDC
Carry-setting nodes for multiple precision addition and subtraction.
@ FMAD
FMAD - Perform a * b + c, while getting the same result as the separately rounded operations.
@ ADD
Simple integer binary arithmetic operators.
@ LOAD
LOAD and STORE have token chains as their first operand, then the same operands as an LLVM load/store...
@ SMULFIXSAT
Same as the corresponding unsaturated fixed point instructions, but the result is clamped between the...
@ ANY_EXTEND
ANY_EXTEND - Used for integer types. The high bits are undefined.
@ CTTZ_ELTS
Returns the number of number of trailing (least significant) zero elements in a vector.
@ FMA
FMA - Perform a * b + c with no intermediate rounding step.
@ VECTOR_FIND_LAST_ACTIVE
Finds the index of the last active mask element Operands: Mask.
@ INTRINSIC_VOID
OUTCHAIN = INTRINSIC_VOID(INCHAIN, INTRINSICID, arg1, arg2, ...) This node represents a target intrin...
@ SINT_TO_FP
[SU]INT_TO_FP - These operators convert integers (whose interpreted sign depends on the first letter)...
@ CONCAT_VECTORS
CONCAT_VECTORS(VECTOR0, VECTOR1, ...) - Given a number of values of vector type with the same length ...
@ FADD
Simple binary floating point operators.
@ ABS
ABS - Determine the unsigned absolute value of a signed integer value of the same bitwidth.
@ SIGN_EXTEND_VECTOR_INREG
SIGN_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register sign-extension of the low ...
@ SDIVREM
SDIVREM/UDIVREM - Divide two integers and produce both a quotient and remainder result.
@ FMULADD
FMULADD - Performs a * b + c, with, or without, intermediate rounding.
@ BITCAST
BITCAST - This operator converts between integer, vector and FP values, as if the value was stored to...
@ BUILD_PAIR
BUILD_PAIR - This is the opposite of EXTRACT_ELEMENT in some ways.
@ CLMUL
Carry-less multiplication operations.
@ SDIVFIX
RESULT = [US]DIVFIX(LHS, RHS, SCALE) - Perform fixed point division on 2 integers with the same width...
@ BUILTIN_OP_END
BUILTIN_OP_END - This must be the last enum value in this list.
@ SIGN_EXTEND
Conversion operators.
@ AVGCEILS
AVGCEILS/AVGCEILU - Rounding averaging add - Add two integers using an integer of type i[N+2],...
@ SCALAR_TO_VECTOR
SCALAR_TO_VECTOR(VAL) - This represents the operation of loading a scalar value into element 0 of the...
@ VECREDUCE_FADD
These reductions have relaxed evaluation order semantics, and have a single vector operand.
@ FNEG
Perform various unary floating-point operations inspired by libm.
@ SSUBO
Same for subtraction.
@ BRIND
BRIND - Indirect branch.
@ FCANONICALIZE
Returns platform specific canonical encoding of a floating point number.
@ IS_FPCLASS
Performs a check of floating point class property, defined by IEEE-754.
@ SSUBSAT
RESULT = [US]SUBSAT(LHS, RHS) - Perform saturation subtraction on 2 integers with the same bit width ...
@ SELECT
Select(COND, TRUEVAL, FALSEVAL).
@ EXTRACT_ELEMENT
EXTRACT_ELEMENT - This is used to get the lower or upper (determined by a Constant,...
@ SPLAT_VECTOR
SPLAT_VECTOR(VAL) - Returns a vector with the scalar value VAL duplicated in all lanes.
@ GET_ACTIVE_LANE_MASK
GET_ACTIVE_LANE_MASK - this corrosponds to the llvm.get.active.lane.mask intrinsic.
@ CopyFromReg
CopyFromReg - This node indicates that the input value is a virtual or physical register that is defi...
@ SADDO
RESULT, BOOL = [SU]ADDO(LHS, RHS) - Overflow-aware nodes for addition.
@ VECREDUCE_ADD
Integer reductions may have a result type larger than the vector element type.
@ MULHU
MULHU/MULHS - Multiply high - Multiply two integers of type iN, producing an unsigned/signed value of...
@ SHL
Shift and rotation operations.
@ VECTOR_SHUFFLE
VECTOR_SHUFFLE(VEC1, VEC2) - Returns a vector, of the same type as VEC1/VEC2.
@ EXTRACT_SUBVECTOR
EXTRACT_SUBVECTOR(VECTOR, IDX) - Returns a subvector from VECTOR.
@ FMINNUM_IEEE
FMINNUM_IEEE/FMAXNUM_IEEE - Perform floating-point minimumNumber or maximumNumber on two values,...
@ EXTRACT_VECTOR_ELT
EXTRACT_VECTOR_ELT(VECTOR, IDX) - Returns a single element from VECTOR identified by the (potentially...
@ ZERO_EXTEND
ZERO_EXTEND - Used for integer types, zeroing the new bits.
@ SELECT_CC
Select with condition operator - This selects between a true value and a false value (ops #2 and #3) ...
@ FMINNUM
FMINNUM/FMAXNUM - Perform floating-point minimum maximum on two values, following IEEE-754 definition...
@ SSHLSAT
RESULT = [US]SHLSAT(LHS, RHS) - Perform saturation left shift.
@ SMULO
Same for multiplication.
@ VECTOR_SPLICE_LEFT
VECTOR_SPLICE_LEFT(VEC1, VEC2, OFFSET) - Shifts CONCAT_VECTORS(VEC1, VEC2) left by OFFSET elements an...
@ ANY_EXTEND_VECTOR_INREG
ANY_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register any-extension of the low la...
@ SIGN_EXTEND_INREG
SIGN_EXTEND_INREG - This operator atomically performs a SHL/SRA pair to sign extend a small value in ...
@ SMIN
[US]{MIN/MAX} - Binary minimum or maximum of signed or unsigned integers.
@ SDIVFIXSAT
Same as the corresponding unsaturated fixed point instructions, but the result is clamped between the...
@ FP_EXTEND
X = FP_EXTEND(Y) - Extend a smaller FP type into a larger FP type.
@ VSELECT
Select with a vector condition (op #0) and two vector operands (ops #1 and #2), returning a vector re...
@ UADDO_CARRY
Carry-using nodes for multiple precision addition and subtraction.
@ STRICT_FP_TO_SINT
STRICT_FP_TO_[US]INT - Convert a floating point value to a signed or unsigned integer.
@ FMINIMUM
FMINIMUM/FMAXIMUM - NaN-propagating minimum/maximum that also treat -0.0 as less than 0....
@ FP_TO_SINT
FP_TO_[US]INT - Convert a floating point value to a signed or unsigned integer.
@ TargetConstant
TargetConstant* - Like Constant*, but the DAG does not do any folding, simplification,...
@ AND
Bitwise operators - logical and, logical or, logical xor.
@ INTRINSIC_WO_CHAIN
RESULT = INTRINSIC_WO_CHAIN(INTRINSICID, arg1, arg2, ...) This node represents a target intrinsic fun...
@ AVGFLOORS
AVGFLOORS/AVGFLOORU - Averaging add - Add two integers using an integer of type i[N+1],...
@ VECTOR_SPLICE_RIGHT
VECTOR_SPLICE_RIGHT(VEC1, VEC2, OFFSET) - Shifts CONCAT_VECTORS(VEC1,VEC2) right by OFFSET elements a...
@ ADDE
Carry-using nodes for multiple precision addition and subtraction.
@ FREEZE
FREEZE - FREEZE(VAL) returns an arbitrary value if VAL is UNDEF (or is evaluated to UNDEF),...
@ INSERT_VECTOR_ELT
INSERT_VECTOR_ELT(VECTOR, VAL, IDX) - Returns VECTOR with the element at IDX replaced with VAL.
@ TokenFactor
TokenFactor - This node takes multiple tokens as input and produces a single token result.
@ CTTZ_ZERO_POISON
Bit counting operators with a poisoned result for zero inputs.
@ FFREXP
FFREXP - frexp, extract fractional and exponent component of a floating-point value.
@ FP_ROUND
X = FP_ROUND(Y, TRUNC) - Rounding 'Y' from a larger floating point type down to the precision of the ...
@ ZERO_EXTEND_VECTOR_INREG
ZERO_EXTEND_VECTOR_INREG(Vector) - This operator represents an in-register zero-extension of the low ...
@ FP_TO_SINT_SAT
FP_TO_[US]INT_SAT - Convert floating point value in operand 0 to a signed or unsigned scalar integer ...
@ TRUNCATE
TRUNCATE - Completely drop the high bits.
@ SHL_PARTS
SHL_PARTS/SRA_PARTS/SRL_PARTS - These operators are used for expanded integer shift operations.
@ FCOPYSIGN
FCOPYSIGN(X, Y) - Return the value of X with the sign of Y.
@ SADDSAT
RESULT = [US]ADDSAT(LHS, RHS) - Perform saturation addition on 2 integers with the same bit width (W)...
@ CALLSEQ_START
CALLSEQ_START/CALLSEQ_END - These operators mark the beginning and end of a call sequence,...
@ FMINIMUMNUM
FMINIMUMNUM/FMAXIMUMNUM - minimumnum/maximumnum that is same with FMINNUM_IEEE and FMAXNUM_IEEE besid...
@ ABDS
ABDS/ABDU - Absolute difference - Return the absolute difference between two numbers interpreted as s...
@ INTRINSIC_W_CHAIN
RESULT,OUTCHAIN = INTRINSIC_W_CHAIN(INCHAIN, INTRINSICID, arg1, ...) This node represents a target in...
@ ABS_MIN_POISON
ABS with a poison result for INT_MIN.
@ BUILD_VECTOR
BUILD_VECTOR(ELT0, ELT1, ELT2, ELT3,...) - Return a fixed-width vector with the specified,...
LLVM_ABI NodeType getOppositeSignednessMinMaxOpcode(unsigned MinMaxOpc)
Given a MinMaxOpc of ISD::(U|S)MIN or ISD::(U|S)MAX, returns the corresponding opcode with the opposi...
LLVM_ABI bool isBuildVectorOfConstantSDNodes(const SDNode *N)
Return true if the specified node is a BUILD_VECTOR node of all ConstantSDNode or undef.
LLVM_ABI NodeType getExtForLoadExtType(bool IsFP, LoadExtType)
bool isNormalStore(const SDNode *N)
Returns true if the specified node is a non-truncating and unindexed store.
bool isZEXTLoad(const SDNode *N)
Returns true if the specified node is a ZEXTLOAD.
LLVM_ABI CondCode getSetCCInverse(CondCode Operation, EVT Type)
Return the operation corresponding to !(X op Y), where 'op' is a valid SetCC operation.
bool isTrueWhenEqual(CondCode Cond)
Return true if the specified condition returns true if the two operands to the condition are equal.
unsigned getUnorderedFlavor(CondCode Cond)
This function returns 0 if the condition is always false if an operand is a NaN, 1 if the condition i...
LLVM_ABI CondCode getSetCCSwappedOperands(CondCode Operation)
Return the operation corresponding to (Y op X) when given the operation for (X op Y).
LLVM_ABI bool isBuildVectorAllZeros(const SDNode *N)
Return true if the specified node is a BUILD_VECTOR where all of the elements are 0 or undef.
bool isSignedIntSetCC(CondCode Code)
Return true if this is a setcc instruction that performs a signed comparison when used with integer o...
LLVM_ABI bool isConstantSplatVector(const SDNode *N, APInt &SplatValue)
Node predicates.
LLVM_ABI bool matchBinaryPredicate(SDValue LHS, SDValue RHS, std::function< bool(ConstantSDNode *, ConstantSDNode *)> Match, bool AllowUndefs=false, bool AllowTypeMismatch=false)
Attempt to match a binary predicate against a pair of scalar/splat constants or every element of a pa...
bool matchUnaryPredicate(SDValue Op, std::function< bool(ConstantSDNode *)> Match, bool AllowUndefs=false, bool AllowTruncation=false)
Hook for matching ConstantSDNode predicate.
CondCode
ISD::CondCode enum - These are ordered carefully to make the bitfields below work out,...
LLVM_ABI NodeType getVecReduceBaseOpcode(unsigned VecReduceOpcode)
Get underlying scalar opcode for VECREDUCE opcode.
LoadExtType
LoadExtType enum - This enum defines the three variants of LOADEXT (load with extension).
bool isUnsignedIntSetCC(CondCode Code)
Return true if this is a setcc instruction that performs an unsigned comparison when used with intege...
BinaryOp_match< LHS, RHS, Instruction::And > m_And(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::Add > m_Add(const LHS &L, const RHS &R)
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.
auto m_Value()
Match an arbitrary value and ignore it.
BinaryOp_match< LHS, RHS, Instruction::Or > m_Or(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::Sub > m_Sub(const LHS &L, const RHS &R)
Or< Preds... > m_AnyOf(const Preds &...preds)
bool sd_match(SDNode *N, const SelectionDAG *DAG, Pattern &&P)
NUses_match< 1, Value_match > m_OneUse()
This is an optimization pass for GlobalISel generic memory operations.
unsigned Log2_32_Ceil(uint32_t Value)
Return the ceil log base 2 of the specified value, 32 if the value is zero.
void stable_sort(R &&Range)
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI bool isNullConstant(SDValue V)
Returns true if V is a constant integer zero.
LLVM_ABI bool isAllOnesOrAllOnesSplat(const MachineInstr &MI, const MachineRegisterInfo &MRI, bool AllowUndefs=false)
Return true if the value is a constant -1 integer or a splatted vector of a constant -1 integer (with...
@ Undef
Value of the register doesn't matter.
LLVM_ABI SDValue peekThroughBitcasts(SDValue V)
Return the non-bitcasted source operand of V if it exists.
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 FPClassTest invertFPClassTestIfSimpler(FPClassTest Test, bool UseFCmp)
Evaluates if the specified FP class test is better performed as the inverse (i.e.
LLVM_ABI bool isOneOrOneSplatFP(SDValue V, bool AllowUndefs=false)
Return true if the value is a constant floating-point value, or a splatted vector of a constant float...
constexpr T alignDown(U Value, V Align, W Skew=0)
Returns the largest unsigned integer less than or equal to Value and is Skew mod Align.
LLVM_ABI bool isNullOrNullSplat(const MachineInstr &MI, const MachineRegisterInfo &MRI, bool AllowUndefs=false)
Return true if the value is a constant 0 integer or a splatted vector of a constant 0 integer (with n...
T bit_ceil(T Value)
Returns the smallest integral power of two no smaller than Value if Value is nonzero.
LLVM_ABI void reportFatalInternalError(Error Err)
Report a fatal error that indicates a bug in LLVM.
constexpr int popcount(T Value) noexcept
Count the number of set bits in a value.
LLVM_ABI ConstantFPSDNode * isConstOrConstSplatFP(SDValue N, bool AllowUndefs=false)
Returns the SDNode if it is a constant splat BuildVector or constant float.
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 getShuffleDemandedElts(int SrcWidth, ArrayRef< int > Mask, const APInt &DemandedElts, APInt &DemandedLHS, APInt &DemandedRHS, bool AllowUndefElts=false)
Transform a shuffle mask's output demanded element mask into demanded element masks for the 2 operand...
unsigned Log2_32(uint32_t Value)
Return the floor log base 2 of the specified value, -1 if the value is zero.
LLVM_ABI bool isBitwiseNot(SDValue V, bool AllowUndefs=false)
Returns true if V is a bitwise not operation.
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.
auto find_if_not(R &&Range, UnaryPredicate P)
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
FunctionAddr VTableAddr Count
LLVM_ABI ConstantRange getVScaleRange(const Function *F, unsigned BitWidth)
Determine the possible constant range of vscale with the given bit width, based on the vscale_range f...
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 isOneOrOneSplat(SDValue V, bool AllowUndefs=false)
Return true if the value is a constant 1 integer or a splatted vector of a constant 1 integer (with n...
@ Mod
The access may modify the value stored in memory.
constexpr T divideCeil(U Numerator, V Denominator)
Returns the integer ceil(Numerator / Denominator).
To bit_cast(const From &from) noexcept
@ Mul
Product of integers.
@ Xor
Bitwise or logical XOR of integers.
@ Sub
Subtraction of integers.
uint16_t MCPhysReg
An unsigned integer type large enough to represent all physical registers, but not necessarily virtua...
FunctionAddr VTableAddr Next
DWARFExpression::Operation Op
RoundingMode
Rounding mode.
@ TowardZero
roundTowardZero.
@ NearestTiesToEven
roundTiesToEven.
@ TowardPositive
roundTowardPositive.
@ NearestTiesToAway
roundTiesToAway.
@ TowardNegative
roundTowardNegative.
LLVM_ABI ConstantSDNode * isConstOrConstSplat(SDValue N, bool AllowUndefs=false, bool AllowTruncation=false)
Returns the SDNode if it is a constant splat BuildVector or constant int.
constexpr unsigned BitWidth
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI bool isZeroOrZeroSplat(SDValue N, bool AllowUndefs=false)
Return true if the value is a constant 0 integer or a splatted vector of a constant 0 integer (with n...
LLVM_ABI bool isOneConstant(SDValue V)
Returns true if V is a constant integer one.
UndefPoisonKind
Enumeration to track whether we are interested in Undef, Poison, or both.
Align commonAlignment(Align A, uint64_t Offset)
Returns the alignment that satisfies both alignments.
LLVM_ABI bool isNullFPConstant(SDValue V)
Returns true if V is an FP constant with a value of positive zero.
APFloat neg(APFloat X)
Returns the negated value of the argument.
unsigned Log2(Align A)
Returns the log2 of the alignment.
constexpr T maskTrailingOnes(unsigned N)
Create a bitmask with the N right-most bits set to 1, and all other bits set to 0.
@ Increment
Incrementally increasing token ID.
LLVM_ABI bool isAllOnesConstant(SDValue V)
Returns true if V is an integer constant with all bits set.
constexpr uint64_t NextPowerOf2(uint64_t A)
Returns the next power of two (in 64-bits) that is strictly greater than A.
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.
This struct is a compact representation of a valid (non-zero power of two) alignment.
Represent subnormal handling kind for floating point instruction inputs and outputs.
DenormalModeKind Input
Denormal treatment kind for floating point instruction inputs in the default floating-point environme...
@ PreserveSign
The sign of a flushed-to-zero number is preserved in the sign of 0.
@ PositiveZero
Denormals are flushed to positive zero.
@ IEEE
IEEE-754 denormal numbers preserved.
constexpr bool inputsAreZero() const
Return true if input denormals must be implicitly treated as 0.
TypeSize getStoreSize() const
Return the number of bytes overwritten by a store of the specified value type.
bool isSimple() const
Test if the given EVT is simple (as opposed to being extended).
static EVT getVectorVT(LLVMContext &Context, EVT VT, unsigned NumElements, bool IsScalable=false)
Returns the EVT that represents a vector NumElements in length, where each element is of type VT.
EVT changeTypeToInteger() const
Return the type converted to an equivalently sized integer or vector with integer element type.
bool bitsGT(EVT VT) const
Return true if this has more bits than VT.
bool bitsLT(EVT VT) const
Return true if this has less bits than VT.
bool isFloatingPoint() const
Return true if this is a FP or a vector FP type.
ElementCount getVectorElementCount() const
EVT getDoubleNumVectorElementsVT(LLVMContext &Context) const
TypeSize getSizeInBits() const
Return the size of the specified value type in bits.
bool isByteSized() const
Return true if the bit size is a multiple of 8.
unsigned getVectorMinNumElements() const
Given a vector type, return the minimum number of elements it contains.
uint64_t getScalarSizeInBits() const
EVT getHalfSizedIntegerVT(LLVMContext &Context) const
Finds the smallest simple value type that is greater than or equal to half the width of this EVT.
bool isPow2VectorType() const
Returns true if the given vector is a power of 2.
TypeSize getStoreSizeInBits() const
Return the number of bits overwritten by a store of the specified value type.
EVT changeVectorElementType(LLVMContext &Context, EVT EltVT) const
Return a VT for a vector type whose attributes match ourselves with the exception of the element type...
MVT getSimpleVT() const
Return the SimpleValueType held in the specified simple EVT.
static EVT getIntegerVT(LLVMContext &Context, unsigned BitWidth)
Returns the EVT that represents an integer with the given number of bits.
uint64_t getFixedSizeInBits() const
Return the size of the specified fixed width value type in bits.
bool isScalableVT() const
Return true if the type is a scalable type.
bool isFixedLengthVector() const
bool isVector() const
Return true if this is a vector value type.
EVT getScalarType() const
If this is a vector type, return the element type, otherwise return this.
LLVM_ABI Type * getTypeForEVT(LLVMContext &Context) const
This method returns an LLVM type corresponding to the specified EVT.
EVT widenIntegerElementType(LLVMContext &Context) const
Return a VT for an integer element type with doubled bit width.
bool isScalableVector() const
Return true if this is a vector type where the runtime length is machine dependent.
EVT getVectorElementType() const
Given a vector type, return the type of each element.
EVT changeElementType(LLVMContext &Context, EVT EltVT) const
Return a VT for a type whose attributes match ourselves with the exception of the element type that i...
bool isScalarInteger() const
Return true if this is an integer, but not a vector.
LLVM_ABI const fltSemantics & getFltSemantics() const
Returns an APFloat semantics tag appropriate for the value type.
unsigned getVectorNumElements() const
Given a vector type, return the number of elements it contains.
bool bitsLE(EVT VT) const
Return true if this has no more bits than VT.
EVT getHalfNumVectorElementsVT(LLVMContext &Context) const
bool isInteger() const
Return true if this is an integer or a vector integer type.
static KnownBits makeConstant(const APInt &C)
Create known bits from a known constant.
KnownBits anyextOrTrunc(unsigned BitWidth) const
Return known bits for an "any" extension or truncation of the value we're tracking.
unsigned countMinSignBits() const
Returns the number of times the sign bit is replicated into the other bits.
static LLVM_ABI KnownBits smax(const KnownBits &LHS, const KnownBits &RHS)
Compute known bits for smax(LHS, RHS).
bool isNonNegative() const
Returns true if this value is known to be non-negative.
unsigned countMinTrailingZeros() const
Returns the minimum number of trailing zero bits.
bool isUnknown() const
Returns true if we don't know any bits.
void setAllConflict()
Make all bits known to be both zero and one.
KnownBits trunc(unsigned BitWidth) const
Return known bits for a truncation of the value we're tracking.
KnownBits byteSwap() const
static LLVM_ABI std::optional< bool > sge(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_SGE result.
unsigned countMaxPopulation() const
Returns the maximum number of bits that could be one.
KnownBits reverseBits() const
KnownBits concat(const KnownBits &Lo) const
Concatenate the bits from Lo onto the bottom of *this.
unsigned getBitWidth() const
Get the bit width of this value.
static LLVM_ABI KnownBits umax(const KnownBits &LHS, const KnownBits &RHS)
Compute known bits for umax(LHS, RHS).
KnownBits zext(unsigned BitWidth) const
Return known bits for a zero extension of the value we're tracking.
void resetAll()
Resets the known state of all bits.
KnownBits unionWith(const KnownBits &RHS) const
Returns KnownBits information that is known to be true for either this or RHS or both.
bool isSignUnknown() const
Returns true if we don't know the sign bit.
KnownBits intersectWith(const KnownBits &RHS) const
Returns KnownBits information that is known to be true for both this and RHS.
KnownBits sext(unsigned BitWidth) const
Return known bits for a sign extension of the value we're tracking.
unsigned countMinLeadingZeros() const
Returns the minimum number of leading zero bits.
APInt getMaxValue() const
Return the maximal unsigned value possible given these KnownBits.
static LLVM_ABI KnownBits smin(const KnownBits &LHS, const KnownBits &RHS)
Compute known bits for smin(LHS, RHS).
static LLVM_ABI std::optional< bool > ugt(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_UGT result.
static LLVM_ABI std::optional< bool > slt(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_SLT result.
static LLVM_ABI KnownBits computeForAddSub(bool Add, bool NSW, bool NUW, const KnownBits &LHS, const KnownBits &RHS)
Compute known bits resulting from adding LHS and RHS.
static LLVM_ABI std::optional< bool > ult(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_ULT result.
static LLVM_ABI std::optional< bool > ule(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_ULE result.
bool isNegative() const
Returns true if this value is known to be negative.
static LLVM_ABI KnownBits mul(const KnownBits &LHS, const KnownBits &RHS, bool NoUndefSelfMultiply=false)
Compute known bits resulting from multiplying LHS and RHS.
KnownBits anyext(unsigned BitWidth) const
Return known bits for an "any" extension of the value we're tracking, where we don't know anything ab...
static LLVM_ABI std::optional< bool > sle(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_SLE result.
static LLVM_ABI std::optional< bool > sgt(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_SGT result.
unsigned countMinPopulation() const
Returns the number of bits known to be one.
static LLVM_ABI std::optional< bool > uge(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_UGE result.
static LLVM_ABI KnownBits umin(const KnownBits &LHS, const KnownBits &RHS)
Compute known bits for umin(LHS, RHS).
This class contains a discriminated union of information about pointers in memory operands,...
LLVM_ABI unsigned getAddrSpace() const
Return the LLVM IR address space number that this pointer points into.
static LLVM_ABI MachinePointerInfo getConstantPool(MachineFunction &MF)
Return a MachinePointerInfo record that refers to the constant pool.
MachinePointerInfo getWithOffset(int64_t O) const
static LLVM_ABI MachinePointerInfo getUnknownStack(MachineFunction &MF)
Stack memory without other information.
static LLVM_ABI MachinePointerInfo getFixedStack(MachineFunction &MF, int FI, int64_t Offset=0)
Return a MachinePointerInfo record that refers to the specified FrameIndex.
static LLVM_ABI bool hasVectorMaskArgument(RTLIB::LibcallImpl Impl)
Returns true if the function has a vector mask argument, which is assumed to be the last argument.
These are IR-level optimization flags that may be propagated to SDNodes.
bool hasNoUnsignedWrap() const
bool hasNoSignedWrap() const
void setNoSignedWrap(bool b)
This represents a list of ValueType's that has been intern'd by a SelectionDAG.
Magic data for optimising signed division by a constant.
unsigned ShiftAmount
shift amount
static LLVM_ABI SignedDivisionByConstantInfo get(const APInt &D)
Calculate the magic numbers required to implement a signed integer division by a constant as a sequen...
This contains information for each constraint that we are lowering.
std::string ConstraintCode
This contains the actual string for the code, like "m".
LLVM_ABI unsigned getMatchedOperand() const
If this is an input matching constraint, this method returns the output operand it matches.
LLVM_ABI bool isMatchingInputConstraint() const
Return true of this is an input operand that is a matching constraint like "4".
This structure contains all information that is necessary for lowering calls.
CallLoweringInfo & setIsPostTypeLegalization(bool Value=true)
CallLoweringInfo & setLibCallee(CallingConv::ID CC, Type *ResultType, SDValue Target, ArgListTy &&ArgsList)
CallLoweringInfo & setDiscardResult(bool Value=true)
CallLoweringInfo & setZExtResult(bool Value=true)
CallLoweringInfo & setDebugLoc(const SDLoc &dl)
CallLoweringInfo & setSExtResult(bool Value=true)
CallLoweringInfo & setNoReturn(bool Value=true)
CallLoweringInfo & setChain(SDValue InChain)
bool isBeforeLegalizeOps() const
LLVM_ABI void AddToWorklist(SDNode *N)
bool isCalledByLegalizer() const
bool isBeforeLegalize() const
LLVM_ABI void CommitTargetLoweringOpt(const TargetLoweringOpt &TLO)
This structure is used to pass arguments to makeLibCall function.
MakeLibCallOptions & setIsPostTypeLegalization(bool Value=true)
ArrayRef< EVT > OpsVTBeforeSoften
bool IsPostTypeLegalization
MakeLibCallOptions & setTypeListBeforeSoften(ArrayRef< EVT > OpsVT, EVT RetVT)
ArrayRef< Type * > OpsTypeOverrides
MakeLibCallOptions & setIsSigned(bool Value=true)
A convenience struct that encapsulates a DAG, and two SDValues for returning information from TargetL...
bool CombineTo(SDValue O, SDValue N)
bool LegalOperations() const
Magic data for optimising unsigned division by a constant.
unsigned PreShift
pre-shift amount
unsigned PostShift
post-shift amount
static LLVM_ABI UnsignedDivisionByConstantInfo get(const APInt &D, unsigned LeadingZeros=0, bool AllowEvenDivisorOptimization=true, bool AllowWidenOptimization=false)
Calculate the magic numbers required to implement an unsigned integer division by a constant as a seq...
bool Widen
use widen optimization
fltNonfiniteBehavior nonFiniteBehavior
fltNanEncoding nanEncoding