57 "disable-i2p-p2i-opt",
cl::init(
false),
58 cl::desc(
"Disables inttoptr/ptrtoint roundtrip optimization"));
64std::optional<TypeSize>
74 assert(!
Size.isScalable() &&
"Array elements cannot have a scalable size");
84std::optional<TypeSize>
104 return "both values to select must have same type";
107 return "select values cannot have token type";
112 return "vector select condition element type must be i1";
115 return "selected values for vector select must be vectors";
117 return "vector select requires selected vectors to have "
118 "the same vector length as select condition";
120 return "select condition must be i1 or <n x i1>";
129PHINode::PHINode(
const PHINode &PN)
131 ReservedSpace(PN.getNumOperands()) {
151 Op<-1>().set(
nullptr);
164 bool DeletePHIIfEmpty) {
168 for (
unsigned Idx =
NumOps; Idx-- > 0;) {
169 if (Predicate(Idx)) {
170 unsigned LastIdx =
NumOps - 1;
171 if (Idx != LastIdx) {
194void PHINode::growOperands() {
196 unsigned NumOps = e + e / 2;
210 if (ConstantValue !=
this)
215 if (ConstantValue ==
this)
217 return ConstantValue;
226 Value *ConstantValue =
nullptr;
230 if (ConstantValue && ConstantValue != Incoming)
232 ConstantValue = Incoming;
242LandingPadInst::LandingPadInst(
Type *RetTy,
unsigned NumReservedValues,
243 const Twine &NameStr,
246 init(NumReservedValues, NameStr);
251 ReservedSpace(LP.getNumOperands()) {
256 for (
unsigned I = 0,
E = ReservedSpace;
I !=
E; ++
I)
263 const Twine &NameStr,
265 return new LandingPadInst(RetTy, NumReservedClauses, NameStr, InsertBefore);
268void LandingPadInst::init(
unsigned NumReservedValues,
const Twine &NameStr) {
269 ReservedSpace = NumReservedValues;
278void LandingPadInst::growOperands(
unsigned Size) {
280 if (ReservedSpace >= e +
Size)
return;
281 ReservedSpace = (std::max(e, 1U) +
Size / 2) * 2;
288 assert(OpNo < ReservedSpace &&
"Growing didn't work!");
300 case Instruction::Call:
302 case Instruction::Invoke:
304 case Instruction::CallBr:
316 if (ChildOB.getTagName() != OpB.
getTag())
341 return CI->isMustTailCall();
348 return CI->isTailCall();
354 return F->getIntrinsicID();
362 Mask |=
F->getAttributes().getRetNoFPClass();
370 Mask |=
F->getAttributes().getParamNoFPClass(i);
378 FnAttr =
F->getRetAttribute(Attribute::Range);
403 if (
Attrs.hasAttrSomewhere(Kind, &Index))
406 if (
F->getAttributes().hasAttrSomewhere(Kind, &Index))
416 if (
Attrs.hasParamAttr(ArgNo, Kind))
423 if (!
F->getAttributes().hasParamAttr(ArgNo, Kind))
428 case Attribute::ReadNone:
430 case Attribute::ReadOnly:
432 case Attribute::WriteOnly:
440 bool AllowUndefOrPoison)
const {
442 "Argument must be a pointer");
444 (AllowUndefOrPoison ||
paramHasAttr(ArgNo, Attribute::NoUndef)))
458 return F->getAttributes().hasFnAttr(Kind);
463bool CallBase::hasFnAttrOnCalledFunction(
StringRef Kind)
const {
465 return F->getAttributes().hasFnAttr(Kind);
470template <
typename AK>
471Attribute CallBase::getFnAttrOnCalledFunction(AK Kind)
const {
472 if constexpr (std::is_same_v<AK, Attribute::AttrKind>) {
475 assert(Kind != Attribute::Memory &&
"Use getMemoryEffects() instead");
479 return F->getAttributes().getFnAttr(Kind);
487CallBase::getFnAttrOnCalledFunction(
StringRef Kind)
const;
489template <
typename AK>
490Attribute CallBase::getParamAttrOnCalledFunction(
unsigned ArgNo,
495 return F->getAttributes().getParamAttr(ArgNo, Kind);
502CallBase::getParamAttrOnCalledFunction(
unsigned ArgNo,
StringRef Kind)
const;
512 const unsigned BeginIndex) {
514 for (
auto &
B : Bundles)
515 It = std::copy(
B.input_begin(),
B.input_end(), It);
518 auto BI = Bundles.
begin();
519 unsigned CurrentIndex = BeginIndex;
522 assert(BI != Bundles.
end() &&
"Incorrect allocation?");
524 BOI.Tag = ContextImpl->getOrInsertBundleTag(BI->getTag());
525 BOI.Begin = CurrentIndex;
526 BOI.End = CurrentIndex + BI->input_size();
527 CurrentIndex = BOI.End;
531 assert(BI == Bundles.
end() &&
"Incorrect allocation?");
551 "The Idx isn't in the operand bundle");
555 constexpr unsigned NumberScaling = 1024;
561 while (Begin != End) {
562 unsigned ScaledOperandPerBundle =
563 NumberScaling * (std::prev(End)->End - Begin->
Begin) / (End - Begin);
564 Current = Begin + (((
OpIdx - Begin->
Begin) * NumberScaling) /
565 ScaledOperandPerBundle);
567 Current = std::prev(End);
568 assert(Current < End && Current >= Begin &&
569 "the operand bundle doesn't cover every value in the range");
579 "the operand bundle doesn't cover every value in the range");
592 return Create(CB, Bundles, InsertPt);
598 bool CreateNew =
false;
602 if (Bundle.getTagID() ==
ID) {
609 return CreateNew ?
Create(CB, Bundles, InsertPt) : CB;
616 "Trying to remove non-existant operand bundle");
618 Bundles.
reserve(OpBundleCount - 1);
623 for (;
I != OpBundleCount; ++
I)
625 return Create(CB, Bundles, InsertPt);
732 CI &= Fn->getAttributes().getParamAttrs(OpNo).getCaptureInfo();
753 CI &= Fn->getAttributes().getParamAttrs(
I).getCaptureInfo();
768 "NumOperands not set up?");
773 "Calling a function with bad signature!");
775 for (
unsigned i = 0; i != Args.size(); ++i)
778 "Calling a function with a bad signature!");
807 init(Ty, Func, Name);
813 "Wrong number of operands allocated");
828 Args, OpB, CI->
getName(), InsertPt);
831 NewCI->FMF = CI->
FMF;
842 LLVM_DEBUG(
dbgs() <<
"Attempting to update profile weights will result in "
843 "div by 0. Ignoring. Likely the function "
845 <<
" has 0 entry count, and contains call instructions "
846 "with non-zero prof info.");
859 const Twine &NameStr) {
864 "NumOperands not set up?");
869 "Invoking a function with bad signature");
871 for (
unsigned i = 0, e = Args.size(); i != e; i++)
874 "Invoking a function with a bad signature!");
894 "Wrong number of operands allocated");
897 std::copy(
II.bundle_op_info_begin(),
II.bundle_op_info_end(),
904 std::vector<Value *> Args(
II->arg_begin(),
II->arg_end());
907 II->getFunctionType(),
II->getCalledOperand(),
II->getNormalDest(),
908 II->getUnwindDest(), Args, OpB,
II->getName(), InsertPt);
909 NewII->setCallingConv(
II->getCallingConv());
910 NewII->SubclassOptionalData =
II->SubclassOptionalData;
911 NewII->setAttributes(
II->getAttributes());
912 NewII->setDebugLoc(
II->getDebugLoc());
922 LLVM_DEBUG(
dbgs() <<
"Attempting to update profile weights will result in "
923 "div by 0. Ignoring. Likely the function "
925 <<
" has 0 entry count, and contains call instructions "
926 "with non-zero prof info.");
940 const Twine &NameStr) {
944 IndirectDests.
size(),
946 "NumOperands not set up?");
951 "Calling a function with bad signature");
953 for (
unsigned i = 0, e = Args.size(); i != e; i++)
956 "Calling a function with a bad signature!");
962 NumIndirectDests = IndirectDests.
size();
964 for (
unsigned i = 0; i != NumIndirectDests; ++i)
979 "Wrong number of operands allocated");
985 NumIndirectDests = CBI.NumIndirectDests;
999 NewCBI->NumIndirectDests = CBI->NumIndirectDests;
1011 "Wrong number of operands allocated");
1037 AllocMarker, InsertBefore) {
1049 "Wrong number of operands allocated");
1050 setSubclassData<Instruction::OpaqueField>(
1057void CleanupReturnInst::init(
Value *CleanupPad,
BasicBlock *UnwindBB) {
1059 setSubclassData<UnwindDestField>(
true);
1061 Op<0>() = CleanupPad;
1066CleanupReturnInst::CleanupReturnInst(
Value *CleanupPad,
BasicBlock *UnwindBB,
1071 init(CleanupPad, UnwindBB);
1092 AllocMarker, InsertBefore) {
1100CatchSwitchInst::CatchSwitchInst(
Value *ParentPad,
BasicBlock *UnwindDest,
1101 unsigned NumReservedValues,
1102 const Twine &NameStr,
1107 ++NumReservedValues;
1108 init(ParentPad, UnwindDest, NumReservedValues + 1);
1119 for (
unsigned I = 1,
E = ReservedSpace;
I !=
E; ++
I)
1124 unsigned NumReservedValues) {
1125 assert(ParentPad && NumReservedValues);
1127 ReservedSpace = NumReservedValues;
1131 Op<0>() = ParentPad;
1140void CatchSwitchInst::growOperands(
unsigned Size) {
1142 assert(NumOperands >= 1);
1143 if (ReservedSpace >= NumOperands +
Size)
1145 ReservedSpace = (NumOperands +
Size / 2) * 2;
1152 assert(OpNo < ReservedSpace &&
"Growing didn't work!");
1160 for (
Use *CurDst = HI.getCurrent(); CurDst != EndDst; ++CurDst)
1161 *CurDst = *(CurDst + 1);
1172 const Twine &NameStr) {
1182 "Wrong number of operands allocated");
1189 const Twine &NameStr,
1192 init(ParentPad, Args, NameStr);
1202 AllocMarker, InsertBefore) {}
1213 AllocMarker, InsertBefore) {
1220 Op<-1>() = BI.Op<-1>();
1228void CondBrInst::AssertOK() {
1230 "May only branch on boolean predicates!");
1236 AllocMarker, InsertBefore) {
1250 Op<-3>() = BI.Op<-3>();
1251 Op<-2>() = BI.Op<-2>();
1252 Op<-1>() = BI.Op<-1>();
1276 "Passed basic block into allocation size parameter! Use other ctor");
1278 "Allocation array size is not an integer!");
1285 "Insertion position cannot be null when alignment not provided!");
1288 "BB must be in a Function when alignment not provided!");
1290 return DL.getPrefTypeAlign(Ty);
1295 :
AllocaInst(Ty, AddrSpace, nullptr, Name, InsertBefore) {}
1310 assert(!Ty->isVoidTy() &&
"Cannot allocate void!");
1316 return !CI->isOne();
1336void LoadInst::AssertOK() {
1338 "Ptr must have pointer type.");
1343 "Insertion position cannot be null when alignment not provided!");
1346 "BB must be in a Function when alignment not provided!");
1348 return DL.getABITypeAlign(Ty);
1380void StoreInst::AssertOK() {
1383 "Ptr must have pointer type!");
1430 "All operands must be non-null!");
1432 "Ptr must have pointer type!");
1434 "Cmp type and NewVal type must be same!");
1445 AtomicCmpXchg, AllocMarker, InsertBefore) {
1446 Init(Ptr, Cmp, NewVal, Alignment, SuccessOrdering, FailureOrdering, SSID);
1457 "atomicrmw instructions can only be atomic.");
1459 "atomicrmw instructions cannot be unordered.");
1470 "Ptr must have pointer type!");
1472 "AtomicRMW instructions must be atomic!");
1480 Init(
Operation, Ptr, Val, Alignment, Ordering, SSID, Elementwise);
1520 return "fmaximumnum";
1522 return "fminimumnum";
1532 return "<invalid operation>";
1554 const Twine &Name) {
1556 "NumOperands not initialized?");
1565 SourceElementType(GEPI.SourceElementType),
1566 ResultElementType(GEPI.ResultElementType) {
1568 "Wrong number of operands allocated");
1575 if (!Struct->indexValid(Idx))
1577 return Struct->getTypeAtIndex(Idx);
1582 return Array->getElementType();
1584 return Vector->getElementType();
1590 if (Idx >= Struct->getNumElements())
1592 return Struct->getElementType(Idx);
1595 return Array->getElementType();
1597 return Vector->getElementType();
1601template <
typename IndexTy>
1603 if (IdxList.
empty())
1605 for (IndexTy V : IdxList.
slice(1)) {
1632 if (!CI->isZero())
return false;
1689 APInt &ConstantOffset)
const {
1699ExtractElementInst::ExtractElementInst(
Value *Val,
Value *Index,
1703 ExtractElement, AllocMarker, InsertBef) {
1704 assert(isValidOperands(Val, Index) &&
1705 "Invalid extractelement instruction operands!");
1721InsertElementInst::InsertElementInst(
Value *Vec,
Value *Elt,
Value *Index,
1726 "Invalid insertelement instruction operands!");
1734 const Value *Index) {
1741 if (!Index->getType()->isIntegerTy())
1751 assert(V &&
"Cannot create placeholder of nullptr V");
1772 ShuffleVector, AllocMarker, InsertBefore) {
1774 "Invalid shuffle vector instruction operands!");
1790 ShuffleVector, AllocMarker, InsertBefore) {
1792 "Invalid shuffle vector instruction operands!");
1801 int NumMaskElts = ShuffleMask.size();
1803 for (
int i = 0; i != NumMaskElts; ++i) {
1809 assert(MaskElt >= 0 && MaskElt < 2 * NumOpElts &&
"Out-of-range mask");
1810 MaskElt = (MaskElt < NumOpElts) ? MaskElt + NumOpElts : MaskElt - NumOpElts;
1811 NewMask[i] = MaskElt;
1826 for (
int Elem : Mask)
1838 const Value *Mask) {
1846 if (!MaskTy || !MaskTy->getElementType()->isIntegerTy(32) ||
1862 return !CI->uge(V1Size * 2);
1865 for (
Value *
Op : MV->operands()) {
1867 if (CI->uge(V1Size*2))
1879 if (CDS->getElementAsInteger(i) >= V1Size*2)
1893 Result.append(EC.getKnownMinValue(), MaskVal);
1897 assert(!EC.isScalable() &&
1898 "Scalable vector shuffle mask must be undef or zeroinitializer");
1900 unsigned NumElts = EC.getFixedValue();
1902 Result.reserve(NumElts);
1905 for (
unsigned i = 0; i != NumElts; ++i)
1906 Result.push_back(CDS->getElementAsInteger(i));
1909 for (
unsigned i = 0; i != NumElts; ++i) {
1910 Constant *
C = Mask->getAggregateElement(i);
1917 ShuffleMask.assign(Mask.begin(), Mask.end());
1932 for (
int Elem : Mask) {
1942 assert(!Mask.empty() &&
"Shuffle mask must contain elements");
1943 bool UsesLHS =
false;
1944 bool UsesRHS =
false;
1945 for (
int I : Mask) {
1948 assert(
I >= 0 &&
I < (NumOpElts * 2) &&
1949 "Out-of-bounds shuffle mask element");
1950 UsesLHS |= (
I < NumOpElts);
1951 UsesRHS |= (
I >= NumOpElts);
1952 if (UsesLHS && UsesRHS)
1956 return UsesLHS || UsesRHS;
1968 for (
int i = 0, NumMaskElts = Mask.size(); i < NumMaskElts; ++i) {
1971 if (Mask[i] != i && Mask[i] != (NumOpElts + i))
1978 if (Mask.size() !=
static_cast<unsigned>(NumSrcElts))
1986 if (Mask.size() !=
static_cast<unsigned>(NumSrcElts))
1995 for (
int I = 0, E = Mask.size();
I < E; ++
I) {
1998 if (Mask[
I] != (NumSrcElts - 1 -
I) &&
1999 Mask[
I] != (NumSrcElts + NumSrcElts - 1 -
I))
2006 if (Mask.size() !=
static_cast<unsigned>(NumSrcElts))
2010 for (
int I = 0, E = Mask.size();
I < E; ++
I) {
2013 if (Mask[
I] != 0 && Mask[
I] != NumSrcElts)
2020 if (Mask.size() !=
static_cast<unsigned>(NumSrcElts))
2025 for (
int I = 0, E = Mask.size();
I < E; ++
I) {
2028 if (Mask[
I] !=
I && Mask[
I] != (NumSrcElts +
I))
2041 if (Mask.size() !=
static_cast<unsigned>(NumSrcElts))
2044 int Sz = Mask.size();
2049 if (Mask[0] != 0 && Mask[0] != 1)
2054 if ((Mask[1] - Mask[0]) != NumSrcElts)
2059 for (
int I = 2;
I < Sz; ++
I) {
2060 int MaskEltVal = Mask[
I];
2061 if (MaskEltVal == -1)
2063 int MaskEltPrevVal = Mask[
I - 2];
2064 if (MaskEltVal - MaskEltPrevVal != 2)
2072 if (Mask.size() !=
static_cast<unsigned>(NumSrcElts))
2075 int StartIndex = -1;
2076 for (
int I = 0, E = Mask.size();
I != E; ++
I) {
2077 int MaskEltVal = Mask[
I];
2078 if (MaskEltVal == -1)
2081 if (StartIndex == -1) {
2084 if (MaskEltVal <
I || NumSrcElts <= (MaskEltVal -
I))
2087 StartIndex = MaskEltVal -
I;
2092 if (MaskEltVal != (StartIndex +
I))
2096 if (StartIndex == -1)
2105 int NumSrcElts,
int &Index) {
2111 if (NumSrcElts <= (
int)Mask.size())
2116 for (
int i = 0, e = Mask.size(); i != e; ++i) {
2120 int Offset = (M % NumSrcElts) - i;
2121 if (0 <= SubIndex && SubIndex !=
Offset)
2126 if (0 <= SubIndex && SubIndex + (
int)Mask.size() <= NumSrcElts) {
2134 int NumSrcElts,
int &NumSubElts,
2136 int NumMaskElts = Mask.size();
2139 if (NumMaskElts < NumSrcElts)
2150 bool Src0Identity =
true;
2151 bool Src1Identity =
true;
2153 for (
int i = 0; i != NumMaskElts; ++i) {
2159 if (M < NumSrcElts) {
2161 Src0Identity &= (M == i);
2165 Src1Identity &= (M == (i + NumSrcElts));
2167 assert((Src0Elts | Src1Elts | UndefElts).isAllOnes() &&
2168 "unknown shuffle elements");
2170 "2-source shuffle not found");
2176 int Src0Hi = NumMaskElts - Src0Elts.
countl_zero();
2177 int Src1Hi = NumMaskElts - Src1Elts.
countl_zero();
2182 int NumSub1Elts = Src1Hi - Src1Lo;
2185 NumSubElts = NumSub1Elts;
2194 int NumSub0Elts = Src0Hi - Src0Lo;
2197 NumSubElts = NumSub0Elts;
2214 if (NumMaskElts <= NumOpElts)
2223 for (
int i = NumOpElts; i < NumMaskElts; ++i)
2238 if (NumMaskElts >= NumOpElts)
2256 if (NumMaskElts != NumOpElts * 2)
2267 int ReplicationFactor,
int VF) {
2268 assert(Mask.size() == (
unsigned)ReplicationFactor * VF &&
2269 "Unexpected mask size.");
2271 for (
int CurrElt :
seq(VF)) {
2272 ArrayRef<int> CurrSubMask = Mask.take_front(ReplicationFactor);
2273 assert(CurrSubMask.
size() == (
unsigned)ReplicationFactor &&
2274 "Run out of mask?");
2275 Mask = Mask.drop_front(ReplicationFactor);
2276 if (!
all_of(CurrSubMask, [CurrElt](
int MaskElt) {
2281 assert(Mask.empty() &&
"Did not consume the whole mask?");
2287 int &ReplicationFactor,
int &VF) {
2291 Mask.take_while([](
int MaskElt) {
return MaskElt == 0; }).
size();
2292 if (ReplicationFactor == 0 || Mask.size() % ReplicationFactor != 0)
2294 VF = Mask.size() / ReplicationFactor;
2306 for (
int MaskElt : Mask) {
2310 if (MaskElt < Largest)
2312 Largest = std::max(Largest, MaskElt);
2316 for (
int PossibleReplicationFactor :
2318 if (Mask.size() % PossibleReplicationFactor != 0)
2320 int PossibleVF = Mask.size() / PossibleReplicationFactor;
2324 ReplicationFactor = PossibleReplicationFactor;
2340 if (ShuffleMask.size() % VF != 0)
2342 ReplicationFactor = ShuffleMask.size() / VF;
2348 if (VF <= 0 || Mask.size() <
static_cast<unsigned>(VF) ||
2349 Mask.size() % VF != 0)
2351 for (
unsigned K = 0, Sz = Mask.size(); K < Sz; K += VF) {
2356 for (
int Idx : SubMask) {
2392 unsigned NumElts = Mask.size();
2393 if (NumElts % Factor)
2396 unsigned LaneLen = NumElts / Factor;
2400 StartIndexes.
resize(Factor);
2406 for (;
I < Factor;
I++) {
2407 unsigned SavedLaneValue;
2408 unsigned SavedNoUndefs = 0;
2411 for (J = 0; J < LaneLen - 1; J++) {
2413 unsigned Lane = J * Factor +
I;
2414 unsigned NextLane = Lane + Factor;
2415 int LaneValue = Mask[Lane];
2416 int NextLaneValue = Mask[NextLane];
2419 if (LaneValue >= 0 && NextLaneValue >= 0 &&
2420 LaneValue + 1 != NextLaneValue)
2424 if (LaneValue >= 0 && NextLaneValue < 0) {
2425 SavedLaneValue = LaneValue;
2434 if (SavedNoUndefs > 0 && LaneValue < 0) {
2436 if (NextLaneValue >= 0 &&
2437 SavedLaneValue + SavedNoUndefs != (
unsigned)NextLaneValue)
2442 if (J < LaneLen - 1)
2448 StartMask = Mask[
I];
2449 }
else if (Mask[(LaneLen - 1) * Factor +
I] >= 0) {
2451 StartMask = Mask[(LaneLen - 1) * Factor +
I] - J;
2452 }
else if (SavedNoUndefs > 0) {
2454 StartMask = SavedLaneValue - (LaneLen - 1 - SavedNoUndefs);
2461 if (StartMask + LaneLen > NumInputElts)
2464 StartIndexes[
I] = StartMask;
2477 for (
unsigned Idx = 0; Idx < Factor; Idx++) {
2482 for (;
I < Mask.size();
I++)
2483 if (Mask[
I] >= 0 &&
static_cast<unsigned>(Mask[
I]) != Idx +
I * Factor)
2486 if (
I == Mask.size()) {
2500 int NumElts = Mask.size();
2501 assert((NumElts % NumSubElts) == 0 &&
"Illegal shuffle mask");
2504 for (
int i = 0; i != NumElts; i += NumSubElts) {
2505 for (
int j = 0; j != NumSubElts; ++j) {
2506 int M = Mask[i + j];
2509 if (M < i || M >= i + NumSubElts)
2511 int Offset = (NumSubElts - (M - (i + j))) % NumSubElts;
2512 if (0 <= RotateAmt &&
Offset != RotateAmt)
2521 ArrayRef<int> Mask,
unsigned EltSizeInBits,
unsigned MinSubElts,
2522 unsigned MaxSubElts,
unsigned &NumSubElts,
unsigned &RotateAmt) {
2523 for (NumSubElts = MinSubElts; NumSubElts <= MaxSubElts; NumSubElts *= 2) {
2525 if (EltRotateAmt < 0)
2527 RotateAmt = EltRotateAmt * EltSizeInBits;
2539 const Twine &Name) {
2546 assert(!Idxs.
empty() &&
"InsertValueInst must have at least one index");
2549 Val->
getType() &&
"Inserted value must match indexed type!");
2559 Indices(IVI.Indices) {
2574 assert(!Idxs.
empty() &&
"ExtractValueInst must have at least one index");
2576 Indices.append(Idxs.
begin(), Idxs.
end());
2583 Indices(EVI.Indices) {
2595 for (
unsigned Index : Idxs) {
2603 if (Index >= AT->getNumElements())
2605 Agg = AT->getElementType();
2607 if (Index >= ST->getNumElements())
2609 Agg = ST->getElementType(Index);
2633 case UnaryOps::FNeg:
2640void UnaryOperator::AssertOK() {
2647 "Unary operation should return same type as operand!");
2649 "Tried to create a floating-point operation on a "
2650 "non-floating-point type!");
2663 :
Instruction(Ty, iType, AllocMarker, InsertBefore) {
2670void BinaryOperator::AssertOK() {
2672 (void)LHS; (void)RHS;
2673 assert(LHS->getType() == RHS->getType() &&
2674 "Binary operator operand types must match!");
2680 "Arithmetic operation should return same type as operands!");
2682 "Tried to create an integer operation on a non-integer type!");
2687 "Arithmetic operation should return same type as operands!");
2689 "Tried to create a floating-point operation on a "
2690 "non-floating-point type!");
2695 "Arithmetic operation should return same type as operands!");
2697 "Incorrect operand type (not integer) for S/UDIV");
2701 "Arithmetic operation should return same type as operands!");
2703 "Incorrect operand type (not floating point) for FDIV");
2708 "Arithmetic operation should return same type as operands!");
2710 "Incorrect operand type (not integer) for S/UREM");
2714 "Arithmetic operation should return same type as operands!");
2716 "Incorrect operand type (not floating point) for FREM");
2722 "Shift operation should return same type as operands!");
2724 "Tried to create a shift operation on a non-integral type!");
2729 "Logical operation should return same type as operands!");
2731 "Tried to create a logical operation on a non-integral type!");
2742 "Cannot create binary operator with two operands of differing type!");
2744 case BinaryOps::FAdd:
2745 case BinaryOps::FSub:
2746 case BinaryOps::FMul:
2747 case BinaryOps::FDiv:
2748 case BinaryOps::FRem:
2757 Value *Zero = ConstantInt::get(
Op->getType(), 0);
2764 Value *Zero = ConstantInt::get(
Op->getType(), 0);
2765 return BinaryOperator::CreateNSWSub(Zero,
Op, Name, InsertBefore);
2772 Op->getType(), Name, InsertBefore);
2805 default:
return false;
2806 case Instruction::ZExt:
2807 case Instruction::SExt:
2808 case Instruction::Trunc:
2810 case Instruction::BitCast:
2831 case Instruction::Trunc:
2832 case Instruction::ZExt:
2833 case Instruction::SExt:
2834 case Instruction::FPTrunc:
2835 case Instruction::FPExt:
2836 case Instruction::UIToFP:
2837 case Instruction::SIToFP:
2838 case Instruction::FPToUI:
2839 case Instruction::FPToSI:
2840 case Instruction::AddrSpaceCast:
2843 case Instruction::BitCast:
2845 case Instruction::PtrToAddr:
2846 case Instruction::PtrToInt:
2847 return DL.getIntPtrType(SrcTy)->getScalarSizeInBits() ==
2849 case Instruction::IntToPtr:
2850 return DL.getIntPtrType(DestTy)->getScalarSizeInBits() ==
2851 SrcTy->getScalarSizeInBits();
2902 const unsigned numCastOps =
2903 Instruction::CastOpsEnd - Instruction::CastOpsBegin;
2905 static const uint8_t CastResults[numCastOps][numCastOps] = {
2911 { 1, 0, 0,99,99, 0, 0,99,99,99,99, 0, 3, 0},
2912 { 8, 1, 9,99,99, 2,17,99,99,99,99, 2, 3, 0},
2913 { 8, 0, 1,99,99, 0, 2,99,99,99,99, 0, 3, 0},
2914 { 0, 0, 0,99,99, 0, 0,99,99,99,99, 0, 3, 0},
2915 { 0, 0, 0,99,99, 0, 0,99,99,99,99, 0, 3, 0},
2916 { 99,99,99, 0, 0,99,99, 0, 0,99,99,99, 4, 0},
2917 { 99,99,99, 0, 0,99,99, 0, 0,99,99,99, 4, 0},
2918 { 99,99,99, 0, 0,99,99, 0, 0,99,99,99, 4, 0},
2919 { 99,99,99, 2, 2,99,99, 8, 2,99,99,99, 4, 0},
2920 { 1, 0, 0,99,99, 0, 0,99,99,99,99, 7, 3, 0},
2921 { 0, 0, 0,99,99, 0, 0,99,99,99,99, 0, 3, 0},
2922 { 99,99,99,99,99,99,99,99,99,11,11,99,15, 0},
2923 { 5, 5, 5, 0, 0, 5, 5, 0, 0,16,16, 5, 1,14},
2924 { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,13,12},
2932 bool IsFirstBitcast = (firstOp == Instruction::BitCast);
2933 bool IsSecondBitcast = (secondOp == Instruction::BitCast);
2934 bool AreBothBitcasts = IsFirstBitcast && IsSecondBitcast;
2939 if (!AreBothBitcasts)
2942 int ElimCase = CastResults[firstOp-Instruction::CastOpsBegin]
2943 [secondOp-Instruction::CastOpsBegin];
2970 if (SrcTy->isIntegerTy())
2985 if (!
DL || MidSize < DL->getPointerTypeSizeInBits(SrcTy))
2988 return Instruction::BitCast;
2994 unsigned SrcSize = SrcTy->getScalarSizeInBits();
2997 return Instruction::BitCast;
2998 if (SrcSize < DstSize)
3000 if (SrcSize > DstSize)
3006 return Instruction::ZExt;
3011 unsigned MidSize = secondOp == Instruction::PtrToAddr
3012 ?
DL->getAddressSizeInBits(MidTy)
3013 :
DL->getPointerTypeSizeInBits(MidTy);
3014 unsigned SrcSize = SrcTy->getScalarSizeInBits();
3018 if (MidSize < SrcSize && MidSize < DstSize)
3020 if (DstSize < SrcSize)
3021 return Instruction::Trunc;
3022 if (DstSize > SrcSize)
3023 return Instruction::ZExt;
3024 return Instruction::BitCast;
3030 return Instruction::AddrSpaceCast;
3031 return Instruction::BitCast;
3037 SrcTy->isPtrOrPtrVectorTy() &&
3042 "Illegal addrspacecast, bitcast sequence!");
3047 return Instruction::AddrSpaceCast;
3053 SrcTy->isIntOrIntVectorTy() &&
3057 "Illegal inttoptr, bitcast sequence!");
3065 SrcTy->isPtrOrPtrVectorTy() &&
3069 "Illegal bitcast, ptrtoint sequence!");
3074 return Instruction::UIToFP;
3089 case Trunc:
return new TruncInst (S, Ty, Name, InsertBefore);
3090 case ZExt:
return new ZExtInst (S, Ty, Name, InsertBefore);
3091 case SExt:
return new SExtInst (S, Ty, Name, InsertBefore);
3092 case FPTrunc:
return new FPTruncInst (S, Ty, Name, InsertBefore);
3093 case FPExt:
return new FPExtInst (S, Ty, Name, InsertBefore);
3094 case UIToFP:
return new UIToFPInst (S, Ty, Name, InsertBefore);
3095 case SIToFP:
return new SIToFPInst (S, Ty, Name, InsertBefore);
3096 case FPToUI:
return new FPToUIInst (S, Ty, Name, InsertBefore);
3097 case FPToSI:
return new FPToSIInst (S, Ty, Name, InsertBefore);
3098 case PtrToAddr:
return new PtrToAddrInst (S, Ty, Name, InsertBefore);
3099 case PtrToInt:
return new PtrToIntInst (S, Ty, Name, InsertBefore);
3100 case IntToPtr:
return new IntToPtrInst (S, Ty, Name, InsertBefore);
3102 return new BitCastInst(S, Ty, Name, InsertBefore);
3113 return Create(Instruction::BitCast, S, Ty, Name, InsertBefore);
3114 return Create(Instruction::ZExt, S, Ty, Name, InsertBefore);
3120 return Create(Instruction::BitCast, S, Ty, Name, InsertBefore);
3121 return Create(Instruction::SExt, S, Ty, Name, InsertBefore);
3127 return Create(Instruction::BitCast, S, Ty, Name, InsertBefore);
3128 return Create(Instruction::Trunc, S, Ty, Name, InsertBefore);
3135 assert((Ty->isIntOrIntVectorTy() || Ty->isPtrOrPtrVectorTy()) &&
3138 assert((!Ty->isVectorTy() ||
3143 if (Ty->isIntOrIntVectorTy())
3144 return Create(Instruction::PtrToInt, S, Ty, Name, InsertBefore);
3152 assert(Ty->isPtrOrPtrVectorTy() &&
"Invalid cast");
3155 return Create(Instruction::AddrSpaceCast, S, Ty, Name, InsertBefore);
3157 return Create(Instruction::BitCast, S, Ty, Name, InsertBefore);
3164 return Create(Instruction::PtrToInt, S, Ty, Name, InsertBefore);
3166 return Create(Instruction::IntToPtr, S, Ty, Name, InsertBefore);
3168 return Create(Instruction::BitCast, S, Ty, Name, InsertBefore);
3174 assert(
C->getType()->isIntOrIntVectorTy() && Ty->isIntOrIntVectorTy() &&
3175 "Invalid integer cast");
3176 unsigned SrcBits =
C->getType()->getScalarSizeInBits();
3177 unsigned DstBits = Ty->getScalarSizeInBits();
3179 (SrcBits == DstBits ? Instruction::BitCast :
3180 (SrcBits > DstBits ? Instruction::Trunc :
3181 (
isSigned ? Instruction::SExt : Instruction::ZExt)));
3182 return Create(opcode,
C, Ty, Name, InsertBefore);
3187 assert(
C->getType()->isFPOrFPVectorTy() && Ty->isFPOrFPVectorTy() &&
3189 unsigned SrcBits =
C->getType()->getScalarSizeInBits();
3190 unsigned DstBits = Ty->getScalarSizeInBits();
3191 assert((
C->getType() == Ty || SrcBits != DstBits) &&
"Invalid cast");
3193 (SrcBits == DstBits ? Instruction::BitCast :
3194 (SrcBits > DstBits ? Instruction::FPTrunc : Instruction::FPExt));
3195 return Create(opcode,
C, Ty, Name, InsertBefore);
3202 if (SrcTy == DestTy)
3207 if (SrcVecTy->getElementCount() == DestVecTy->getElementCount()) {
3209 SrcTy = SrcVecTy->getElementType();
3210 DestTy = DestVecTy->getElementType();
3217 return SrcPtrTy->getAddressSpace() == DestPtrTy->getAddressSpace();
3221 TypeSize SrcBits = SrcTy->getPrimitiveSizeInBits();
3229 if (SrcBits != DestBits)
3240 return (IntTy->getBitWidth() ==
DL.getPointerTypeSizeInBits(PtrTy) &&
3241 !
DL.isNonIntegralPointerType(PtrTy));
3244 return (IntTy->getBitWidth() ==
DL.getPointerTypeSizeInBits(PtrTy) &&
3245 !
DL.isNonIntegralPointerType(PtrTy));
3258 const Value *Src,
bool SrcIsSigned,
Type *DestTy,
bool DestIsSigned) {
3259 Type *SrcTy = Src->getType();
3262 "Only first class types are castable!");
3264 if (SrcTy == DestTy)
3270 if (SrcVecTy->getElementCount() == DestVecTy->getElementCount()) {
3273 SrcTy = SrcVecTy->getElementType();
3274 DestTy = DestVecTy->getElementType();
3281 SrcTy->getPrimitiveSizeInBits().getFixedValue();
3287 if (SrcTy->isIntegerTy()) {
3288 assert(DestBits == SrcBits &&
"Illegal cast from integer to byte type");
3290 }
else if (SrcTy->isPointerTy()) {
3291 assert(DestBits == SrcBits &&
"Illegal cast from pointer to byte type");
3296 if (SrcTy->isIntegerTy()) {
3297 if (DestBits < SrcBits)
3299 else if (DestBits > SrcBits) {
3307 }
else if (SrcTy->isFloatingPointTy()) {
3312 }
else if (SrcTy->isVectorTy()) {
3313 assert(DestBits == SrcBits &&
3314 "Casting vector to integer of different width");
3317 assert(SrcTy->isPointerTy() &&
3318 "Casting from a value that is not first-class type");
3322 if (SrcTy->isIntegerTy()) {
3327 }
else if (SrcTy->isFloatingPointTy()) {
3328 if (DestBits < SrcBits) {
3330 }
else if (DestBits > SrcBits) {
3335 }
else if (SrcTy->isVectorTy()) {
3336 assert(DestBits == SrcBits &&
3337 "Casting vector to floating point of different width");
3342 assert(DestBits == SrcBits &&
3343 "Illegal cast to vector (wrong type or size)");
3346 if (SrcTy->isPointerTy()) {
3348 return AddrSpaceCast;
3350 }
else if (SrcTy->isIntegerTy()) {
3376 unsigned SrcScalarBitSize = SrcTy->getScalarSizeInBits();
3389 default:
return false;
3390 case Instruction::Trunc:
3392 SrcEC == DstEC && SrcScalarBitSize > DstScalarBitSize;
3393 case Instruction::ZExt:
3395 SrcEC == DstEC && SrcScalarBitSize < DstScalarBitSize;
3396 case Instruction::SExt:
3398 SrcEC == DstEC && SrcScalarBitSize < DstScalarBitSize;
3399 case Instruction::FPTrunc:
3401 SrcEC == DstEC && SrcScalarBitSize > DstScalarBitSize;
3402 case Instruction::FPExt:
3404 SrcEC == DstEC && SrcScalarBitSize < DstScalarBitSize;
3405 case Instruction::UIToFP:
3406 case Instruction::SIToFP:
3409 case Instruction::FPToUI:
3410 case Instruction::FPToSI:
3413 case Instruction::PtrToAddr:
3414 case Instruction::PtrToInt:
3418 case Instruction::IntToPtr:
3422 case Instruction::BitCast: {
3429 (SrcTy->isByteOrByteVectorTy() && DstPtrTy))
3431 if (!SrcPtrTy != !DstPtrTy)
3444 if (SrcIsVec && DstIsVec)
3445 return SrcEC == DstEC;
3453 case Instruction::AddrSpaceCast: {
3465 return SrcEC == DstEC;
3472 :
CastInst(Ty, Trunc, S, Name, InsertBefore) {
3478 :
CastInst(Ty, ZExt, S, Name, InsertBefore) {
3484 :
CastInst(Ty, SExt, S, Name, InsertBefore) {
3490 :
CastInst(Ty, FPTrunc, S, Name, InsertBefore) {
3496 :
CastInst(Ty, FPExt, S, Name, InsertBefore) {
3502 :
CastInst(Ty, UIToFP, S, Name, InsertBefore) {
3508 :
CastInst(Ty, SIToFP, S, Name, InsertBefore) {
3514 :
CastInst(Ty, FPToUI, S, Name, InsertBefore) {
3520 :
CastInst(Ty, FPToSI, S, Name, InsertBefore) {
3526 :
CastInst(Ty, PtrToInt, S, Name, InsertBefore) {
3532 :
CastInst(Ty, PtrToAddr, S, Name, InsertBefore) {
3538 :
CastInst(Ty, IntToPtr, S, Name, InsertBefore) {
3544 :
CastInst(Ty, BitCast, S, Name, InsertBefore) {
3550 :
CastInst(Ty, AddrSpaceCast, S, Name, InsertBefore) {
3569 if (
Op == Instruction::ICmp) {
3605 return IC->isCommutative();
3682 default:
return "unknown";
3871 return LHS.ugt(RHS);
3873 return LHS.uge(RHS);
3875 return LHS.ult(RHS);
3877 return LHS.ule(RHS);
3879 return LHS.sgt(RHS);
3881 return LHS.sge(RHS);
3883 return LHS.slt(RHS);
3885 return LHS.sle(RHS);
3973 switch (predicate) {
3974 default:
return false;
3982 switch (predicate) {
3983 default:
return false;
3992 default:
return false;
4002 default:
return false;
4048 return std::nullopt;
4057 if (
A.Pred ==
B.Pred)
4061 if (
A.HasSameSign &&
4064 if (
B.HasSameSign &&
4076 return ICI->getCmpPredicate();
4077 return Cmp->getPredicate();
4098 ReservedSpace = NumReserved;
4113 AllocMarker, InsertBefore) {
4119 init(
SI.getCondition(),
SI.getDefaultDest(),
SI.getNumOperands());
4120 setNumHungOffUseOperands(
SI.getNumOperands());
4121 Use *OL = getOperandList();
4122 ConstantInt **VL = case_values();
4123 const Use *InOL =
SI.getOperandList();
4124 ConstantInt *
const *InVL =
SI.case_values();
4125 for (
unsigned i = 2,
E =
SI.getNumOperands(); i !=
E; ++i) {
4127 VL[i - 2] = InVL[i - 2];
4129 SubclassOptionalData =
SI.SubclassOptionalData;
4137 if (OpNo + 1 > ReservedSpace)
4140 assert(OpNo < ReservedSpace &&
"Growing didn't work!");
4150 unsigned idx =
I->getCaseIndex();
4159 if (2 + idx + 1 !=
NumOps) {
4160 OL[2 + idx] = OL[
NumOps - 1];
4161 VL[idx] = VL[
NumOps - 2 - 1];
4166 VL[
NumOps - 2 - 1] =
nullptr;
4169 return CaseIt(
this, idx);
4175void SwitchInst::growOperands() {
4190 "not correspond to number of succesors");
4196 this->Weights = std::move(Weights);
4202 assert(SI.getNumSuccessors() == Weights->size() &&
4203 "num of prof branch_weights must accord with num of successors");
4208 (*Weights)[
I->getCaseIndex() + 1] = Weights->back();
4209 Weights->pop_back();
4211 return SI.removeCase(
I);
4215 auto *DestBlock =
I->getCaseSuccessor();
4218 (*Weights)[0] = Weight.value();
4221 SI.setDefaultDest(DestBlock);
4227 SI.addCase(OnVal, Dest);
4229 if (!Weights && W && *W) {
4232 (*Weights)[SI.getNumSuccessors() - 1] = *W;
4233 }
else if (Weights) {
4235 Weights->push_back(W.value_or(0));
4238 assert(SI.getNumSuccessors() == Weights->size() &&
4239 "num of prof branch_weights must accord with num of successors");
4248 return SI.eraseFromParent();
4254 return std::nullopt;
4255 return (*Weights)[idx];
4267 auto &OldW = (*Weights)[idx];
4281 return Weights[idx];
4284 return std::nullopt;
4291void IndirectBrInst::init(
Value *
Address,
unsigned NumDests) {
4293 "Address of indirectbr must be a pointer");
4294 ReservedSpace = 1+NumDests;
4305void IndirectBrInst::growOperands() {
4313IndirectBrInst::IndirectBrInst(
Value *
Address,
unsigned NumCases,
4316 Instruction::IndirectBr, AllocMarker, InsertBefore) {
4325 Use *OL = getOperandList();
4336 if (OpNo+1 > ReservedSpace)
4339 assert(OpNo < ReservedSpace &&
"Growing didn't work!");
4353 OL[idx+1] = OL[
NumOps-1];
4378 return new (AllocMarker) GetElementPtrInst(*
this, AllocMarker);
4393 "Should call FPBinaryOperator::cloneImpl!");
4417 return new ExtractValueInst(*
this);
4421 return new InsertValueInst(*
this);
4447 Result->setWeak(
isWeak());
4528 return new (AllocMarker) CallInst(*
this, AllocMarker);
4531 return new (AllocMarker) CallInst(*
this, AllocMarker);
4559 return new LandingPadInst(*
this);
4564 return new (AllocMarker) ReturnInst(*
this, AllocMarker);
4568 return new (AllocMarker) UncondBrInst(*
this);
4572 return new (AllocMarker) CondBrInst(*
this);
4578 return new IndirectBrInst(*
this);
4586 return new (AllocMarker) InvokeInst(*
this, AllocMarker);
4589 return new (AllocMarker) InvokeInst(*
this, AllocMarker);
4597 return new (AllocMarker) CallBrInst(*
this, AllocMarker);
4600 return new (AllocMarker) CallBrInst(*
this, AllocMarker);
4604 return new (AllocMarker) ResumeInst(*
this);
4609 return new (AllocMarker) CleanupReturnInst(*
this, AllocMarker);
4613 return new (AllocMarker) CatchReturnInst(*
this);
4617 return new CatchSwitchInst(*
this);
4622 return new (AllocMarker) FuncletPadInst(*
this, AllocMarker);
4631 bool NoTrapAfterNoreturn)
const {
4632 if (!TrapUnreachable)
4638 if (NoTrapAfterNoreturn)
4641 if (
Call->isNonContinuableTrap())
4645 if (
getFunction()->hasFnAttribute(Attribute::Naked))
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
Atomic ordering constants.
This file contains the simple types necessary to represent the attributes associated with functions a...
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_SUPPRESS_DEPRECATED_DECLARATIONS_PUSH
#define LLVM_SUPPRESS_DEPRECATED_DECLARATIONS_POP
This file contains the declarations for the subclasses of Constant, which represent the different fla...
static bool isSigned(unsigned Opcode)
Module.h This file contains the declarations for the Module class.
static Align computeLoadStoreDefaultAlign(Type *Ty, InsertPosition Pos)
static bool isImpliedFalseByMatchingCmp(CmpPredicate Pred1, CmpPredicate Pred2)
static Value * createPlaceholderForShuffleVector(Value *V)
static Align computeAllocaDefaultAlign(Type *Ty, InsertPosition Pos)
static cl::opt< bool > DisableI2pP2iOpt("disable-i2p-p2i-opt", cl::init(false), cl::desc("Disables inttoptr/ptrtoint roundtrip optimization"))
static bool hasNonZeroFPOperands(const CmpInst *Cmp)
static int matchShuffleAsBitRotate(ArrayRef< int > Mask, int NumSubElts)
Try to lower a vector shuffle as a bit rotation.
static Type * getIndexedTypeInternal(Type *Ty, ArrayRef< IndexTy > IdxList)
static bool isReplicationMaskWithParams(ArrayRef< int > Mask, int ReplicationFactor, int VF)
static bool isIdentityMaskImpl(ArrayRef< int > Mask, int NumOpElts)
static bool isSingleSourceMaskImpl(ArrayRef< int > Mask, int NumOpElts)
static bool isImpliedTrueByMatchingCmp(CmpPredicate Pred1, CmpPredicate Pred2)
static LLVM_SUPPRESS_DEPRECATED_DECLARATIONS_POP Value * getAISize(LLVMContext &Context, Value *Amt)
static Value * getOpcode(Value &V, Type &Ty, InstrumentationConfig &IConf, InstrumentorIRBuilderTy &IIRB)
const size_t AbstractManglingParser< Derived, Alloc >::NumOps
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
PowerPC Reduce CR logical Operation
This file contains the declarations for profiling metadata utility functions.
const SmallVectorImpl< MachineOperand > & Cond
static unsigned getNumElements(Type *Ty)
This file implements the SmallBitVector class.
This file defines the SmallVector class.
static SymbolRef::Type getType(const Symbol *Sym)
cmpResult
IEEE-754R 5.11: Floating Point Comparison Relations.
LLVM_ABI float convertToFloat() const
Converts this APFloat to host float value.
Class for arbitrary precision integers.
void setBit(unsigned BitPosition)
Set the given bit to 1 whose position is given as "bitPosition".
bool isZero() const
Determine if this value is zero, i.e. all bits are clear.
unsigned countr_zero() const
Count the number of trailing zero bits.
unsigned countl_zero() const
The APInt version of std::countl_zero.
static APInt getZero(unsigned numBits)
Get the '0' value for the specified bit-width.
This class represents a conversion between pointers from one address space to another.
LLVM_ABI AddrSpaceCastInst * cloneImpl() const
Clone an identical AddrSpaceCastInst.
LLVM_ABI AddrSpaceCastInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI std::optional< TypeSize > getAllocationSizeInBits(const DataLayout &DL) const
Get allocation size in bits.
bool isSwiftError() const
Return true if this alloca is used as a swifterror argument to a call.
LLVM_ABI bool isStaticAlloca() const
Return true if this alloca is in the entry block of the function and is a constant size.
Align getAlign() const
Return the alignment of the memory that is being allocated by the instruction.
LLVM_ABI AllocaInst * cloneImpl() const
Type * getAllocatedType() const
Return the type that is being allocated by the instruction.
bool isUsedWithInAlloca() const
Return true if this alloca is used as an inalloca argument to a call.
unsigned getAddressSpace() const
Return the address space for the allocation.
LLVM_ABI std::optional< TypeSize > getAllocationSize(const DataLayout &DL) const
Get allocation size in bytes.
LLVM_ABI bool isArrayAllocation() const
Return true if there is an allocation size parameter to the allocation instruction that is not 1.
void setAlignment(Align Align)
const Value * getArraySize() const
Get the number of elements allocated.
LLVM_ABI AllocaInst(Type *Ty, unsigned AddrSpace, Value *ArraySize, const Twine &Name, InsertPosition InsertBefore)
Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
Get the array size.
bool empty() const
Check if the array is empty.
ArrayRef< T > slice(size_t N, size_t M) const
slice(n, m) - Chop off the first N elements of the array, and keep M elements in the array.
Class to represent array types.
void setSyncScopeID(SyncScope::ID SSID)
Sets the synchronization scope ID of this cmpxchg instruction.
bool isVolatile() const
Return true if this is a cmpxchg from a volatile memory location.
void setFailureOrdering(AtomicOrdering Ordering)
Sets the failure ordering constraint of this cmpxchg instruction.
AtomicOrdering getFailureOrdering() const
Returns the failure ordering constraint of this cmpxchg instruction.
void setSuccessOrdering(AtomicOrdering Ordering)
Sets the success ordering constraint of this cmpxchg instruction.
LLVM_ABI AtomicCmpXchgInst * cloneImpl() const
Align getAlign() const
Return the alignment of the memory that is being allocated by the instruction.
friend class Instruction
Iterator for Instructions in a `BasicBlock.
bool isWeak() const
Return true if this cmpxchg may spuriously fail.
void setAlignment(Align Align)
AtomicOrdering getSuccessOrdering() const
Returns the success ordering constraint of this cmpxchg instruction.
SyncScope::ID getSyncScopeID() const
Returns the synchronization scope ID of this cmpxchg instruction.
LLVM_ABI AtomicCmpXchgInst(Value *Ptr, Value *Cmp, Value *NewVal, Align Alignment, AtomicOrdering SuccessOrdering, AtomicOrdering FailureOrdering, SyncScope::ID SSID, InsertPosition InsertBefore=nullptr)
bool isElementwise() const
Return true if this RMW has elementwise vector semantics.
Align getAlign() const
Return the alignment of the memory that is being allocated by the instruction.
LLVM_ABI AtomicRMWInst * cloneImpl() const
bool isVolatile() const
Return true if this is a RMW on a volatile memory location.
LLVM_ABI AtomicRMWInst(BinOp Operation, Value *Ptr, Value *Val, Align Alignment, AtomicOrdering Ordering, SyncScope::ID SSID, bool Elementwise=false, InsertPosition InsertBefore=nullptr)
BinOp
This enumeration lists the possible modifications atomicrmw can make.
@ USubCond
Subtract only if no unsigned overflow.
@ FMinimum
*p = minimum(old, v) minimum matches the behavior of llvm.minimum.
@ Min
*p = old <signed v ? old : v
@ USubSat
*p = usub.sat(old, v) usub.sat matches the behavior of llvm.usub.sat.
@ FMaximum
*p = maximum(old, v) maximum matches the behavior of llvm.maximum.
@ UIncWrap
Increment one up to a maximum value.
@ Max
*p = old >signed v ? old : v
@ UMin
*p = old <unsigned v ? old : v
@ FMin
*p = minnum(old, v) minnum matches the behavior of llvm.minnum.
@ UMax
*p = old >unsigned v ? old : v
@ FMaximumNum
*p = maximumnum(old, v) maximumnum matches the behavior of llvm.maximumnum.
@ FMax
*p = maxnum(old, v) maxnum matches the behavior of llvm.maxnum.
@ UDecWrap
Decrement one until a minimum value or zero.
@ FMinimumNum
*p = minimumnum(old, v) minimumnum matches the behavior of llvm.minimumnum.
void setSyncScopeID(SyncScope::ID SSID)
Sets the synchronization scope ID of this rmw instruction.
void setOrdering(AtomicOrdering Ordering)
Sets the ordering constraint of this rmw instruction.
void setOperation(BinOp Operation)
friend class Instruction
Iterator for Instructions in a `BasicBlock.
BinOp getOperation() const
SyncScope::ID getSyncScopeID() const
Returns the synchronization scope ID of this rmw instruction.
void setAlignment(Align Align)
void setElementwise(bool V)
Specify whether this RMW has elementwise vector semantics.
static LLVM_ABI StringRef getOperationName(BinOp Op)
AtomicOrdering getOrdering() const
Returns the ordering constraint of this rmw instruction.
LLVM_ABI CaptureInfo getCaptureInfo() const
Functions, function parameters, and return types can have attributes to indicate how they should be t...
LLVM_ABI const ConstantRange & getRange() const
Returns the value of the range attribute.
AttrKind
This enumeration lists the attributes that can be associated with parameters, function results,...
static LLVM_ABI Attribute getWithMemoryEffects(LLVMContext &Context, MemoryEffects ME)
bool isValid() const
Return true if the attribute is any kind of attribute.
LLVM Basic Block Representation.
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this basic block belongs to.
static LLVM_ABI BinaryOperator * CreateNeg(Value *Op, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Helper functions to construct and inspect unary operations (NEG and NOT) via binary operators SUB and...
BinaryOps getOpcode() const
LLVM_ABI bool swapOperands()
Exchange the two operands to this instruction.
static LLVM_ABI BinaryOperator * CreateNot(Value *Op, const Twine &Name="", InsertPosition InsertBefore=nullptr)
friend class Instruction
Iterator for Instructions in a `BasicBlock.
static LLVM_ABI BinaryOperator * Create(BinaryOps Op, Value *S1, Value *S2, const Twine &Name=Twine(), InsertPosition InsertBefore=nullptr)
Construct a binary instruction, given the opcode and the two operands.
LLVM_ABI BinaryOperator(BinaryOps iType, Value *S1, Value *S2, Type *Ty, const Twine &Name, InsertPosition InsertBefore)
static LLVM_ABI BinaryOperator * CreateNSWNeg(Value *Op, const Twine &Name="", InsertPosition InsertBefore=nullptr)
LLVM_ABI BinaryOperator * cloneImpl() const
This class represents a no-op cast from one type to another.
LLVM_ABI BitCastInst * cloneImpl() const
Clone an identical BitCastInst.
LLVM_ABI BitCastInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
LLVM_ABI FPClassTest getParamNoFPClass(unsigned i) const
Extract a test mask for disallowed floating-point value classes for the parameter.
bool isInlineAsm() const
Check if this call is an inline asm statement.
LLVM_ABI BundleOpInfo & getBundleOpInfoForOperand(unsigned OpIdx)
Return the BundleOpInfo for the operand at index OpIdx.
void setCallingConv(CallingConv::ID CC)
LLVM_ABI FPClassTest getRetNoFPClass() const
Extract a test mask for disallowed floating-point value classes for the return value.
bundle_op_iterator bundle_op_info_begin()
Return the start of the list of BundleOpInfo instances associated with this OperandBundleUser.
LLVM_ABI bool paramHasNonNullAttr(unsigned ArgNo, bool AllowUndefOrPoison) const
Return true if this argument has the nonnull attribute on either the CallBase instruction or the call...
LLVM_ABI MemoryEffects getMemoryEffects() const
void addFnAttr(Attribute::AttrKind Kind)
Adds the attribute to the function.
LLVM_ABI bool doesNotAccessMemory() const
Determine if the call does not access memory.
LLVM_ABI void getOperandBundlesAsDefs(SmallVectorImpl< OperandBundleDef > &Defs) const
Return the list of operand bundles attached to this instruction as a vector of OperandBundleDefs.
LLVM_ABI void setOnlyAccessesArgMemory()
OperandBundleUse getOperandBundleAt(unsigned Index) const
Return the operand bundle at a specific index.
OperandBundleUse operandBundleFromBundleOpInfo(const BundleOpInfo &BOI) const
Simple helper function to map a BundleOpInfo to an OperandBundleUse.
LLVM_ABI void setOnlyAccessesInaccessibleMemOrArgMem()
std::optional< OperandBundleUse > getOperandBundle(StringRef Name) const
Return an operand bundle by name, if present.
Function * getCalledFunction() const
Returns the function called, or null if this is an indirect function invocation or the function signa...
LLVM_ABI void setDoesNotAccessMemory()
AttributeSet getParamAttributes(unsigned ArgNo) const
Return the param attributes for this call.
bool hasRetAttr(Attribute::AttrKind Kind) const
Determine whether the return value has the given attribute.
LLVM_ABI bool onlyAccessesInaccessibleMemory() const
Determine if the function may only access memory that is inaccessible from the IR.
unsigned getNumOperandBundles() const
Return the number of operand bundles associated with this User.
CallingConv::ID getCallingConv() const
bundle_op_iterator bundle_op_info_end()
Return the end of the list of BundleOpInfo instances associated with this OperandBundleUser.
LLVM_ABI unsigned getNumSubclassExtraOperandsDynamic() const
Get the number of extra operands for instructions that don't have a fixed number of extra operands.
BundleOpInfo * bundle_op_iterator
LLVM_ABI bool paramHasAttr(unsigned ArgNo, Attribute::AttrKind Kind) const
Determine whether the argument or parameter has the given attribute.
User::op_iterator arg_begin()
Return the iterator pointing to the beginning of the argument list.
LLVM_ABI bool isMustTailCall() const
Tests if this call site must be tail call optimized.
LLVM_ABI bool isIndirectCall() const
Return true if the callsite is an indirect call.
LLVM_ABI bool onlyReadsMemory() const
Determine if the call does not access or only reads memory.
bool isByValArgument(unsigned ArgNo) const
Determine whether this argument is passed by value.
iterator_range< bundle_op_iterator > bundle_op_infos()
Return the range [bundle_op_info_begin, bundle_op_info_end).
LLVM_ABI void setOnlyReadsMemory()
static LLVM_ABI CallBase * addOperandBundle(CallBase *CB, uint32_t ID, OperandBundleDef OB, InsertPosition InsertPt=nullptr)
Create a clone of CB with operand bundle OB added.
LLVM_ABI bool onlyAccessesInaccessibleMemOrArgMem() const
Determine if the function may only access memory that is either inaccessible from the IR or pointed t...
static LLVM_ABI CallBase * removeOperandBundleAt(CallBase *CB, size_t Offset, InsertPosition InsertPtr=nullptr)
LLVM_ABI CaptureInfo getCaptureInfo(unsigned OpNo) const
Return which pointer components this operand may capture.
LLVM_ABI bool hasArgumentWithAdditionalReturnCaptureComponents() const
Returns whether the call has an argument that has an attribute like captures(ret: address,...
CallBase(AttributeList const &A, FunctionType *FT, ArgsTy &&... Args)
Value * getCalledOperand() const
LLVM_ABI void setOnlyWritesMemory()
LLVM_ABI op_iterator populateBundleOperandInfos(ArrayRef< OperandBundleDef > Bundles, const unsigned BeginIndex)
Populate the BundleOpInfo instances and the Use& vector from Bundles.
AttributeList Attrs
parameter attributes for callable
bool hasOperandBundlesOtherThan(ArrayRef< uint32_t > IDs) const
Return true if this operand bundle user contains operand bundles with tags other than those specified...
LLVM_ABI std::optional< ConstantRange > getRange() const
If this return value has a range attribute, return the value range of the argument.
LLVM_ABI bool isReturnNonNull() const
Return true if the return value is known to be not null.
Value * getArgOperand(unsigned i) const
uint64_t getRetDereferenceableBytes() const
Extract the number of dereferenceable bytes for a call or parameter (0=unknown).
User::op_iterator arg_end()
Return the iterator pointing to the end of the argument list.
FunctionType * getFunctionType() const
LLVM_ABI Intrinsic::ID getIntrinsicID() const
Returns the intrinsic ID of the intrinsic called or Intrinsic::not_intrinsic if the called function i...
static unsigned CountBundleInputs(ArrayRef< OperandBundleDef > Bundles)
Return the total number of values used in Bundles.
LLVM_ABI Value * getArgOperandWithAttribute(Attribute::AttrKind Kind) const
If one of the arguments has the specified attribute, returns its operand value.
LLVM_ABI void setOnlyAccessesInaccessibleMemory()
static LLVM_ABI CallBase * Create(CallBase *CB, ArrayRef< OperandBundleDef > Bundles, InsertPosition InsertPt=nullptr)
Create a clone of CB with a different set of operand bundles and insert it before InsertPt.
LLVM_ABI bool onlyWritesMemory() const
Determine if the call does not access or only writes memory.
LLVM_ABI bool hasClobberingOperandBundles() const
Return true if this operand bundle user has operand bundles that may write to the heap.
void setCalledOperand(Value *V)
static LLVM_ABI CallBase * removeOperandBundle(CallBase *CB, uint32_t ID, InsertPosition InsertPt=nullptr)
Create a clone of CB with operand bundle ID removed.
LLVM_ABI bool hasReadingOperandBundles() const
Return true if this operand bundle user has operand bundles that may read from the heap.
LLVM_ABI bool onlyAccessesArgMemory() const
Determine if the call can access memmory only using pointers based on its arguments.
unsigned arg_size() const
AttributeList getAttributes() const
Return the attributes for this call.
LLVM_ABI void setMemoryEffects(MemoryEffects ME)
bool hasOperandBundles() const
Return true if this User has any operand bundles.
LLVM_ABI bool isTailCall() const
Tests if this call site is marked as a tail call.
LLVM_ABI Function * getCaller()
Helper to get the caller (the parent function).
CallBr instruction, tracking function calls that may not return control but instead transfer it to a ...
SmallVector< BasicBlock *, 16 > getIndirectDests() const
void setDefaultDest(BasicBlock *B)
void setIndirectDest(unsigned i, BasicBlock *B)
BasicBlock * getDefaultDest() const
static CallBrInst * Create(FunctionType *Ty, Value *Func, BasicBlock *DefaultDest, ArrayRef< BasicBlock * > IndirectDests, ArrayRef< Value * > Args, const Twine &NameStr, InsertPosition InsertBefore=nullptr)
LLVM_ABI CallBrInst * cloneImpl() const
This class represents a function call, abstracting a target machine's calling convention.
LLVM_ABI void updateProfWeight(uint64_t S, uint64_t T)
Updates profile metadata by scaling it by S / T.
TailCallKind getTailCallKind() const
LLVM_ABI CallInst * cloneImpl() const
static CallInst * Create(FunctionType *Ty, Value *F, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Represents which components of the pointer may be captured in which location.
CaptureComponents getOtherComponents() const
Get components potentially captured through locations other than the return value.
static CaptureInfo none()
Create CaptureInfo that does not capture any components of the pointer.
static CaptureInfo all()
Create CaptureInfo that may capture all components of the pointer.
CaptureComponents getRetComponents() const
Get components potentially captured by the return value.
static LLVM_ABI Instruction::CastOps getCastOpcode(const Value *Val, bool SrcIsSigned, Type *Ty, bool DstIsSigned)
Returns the opcode necessary to cast Val into Ty using usual casting rules.
static LLVM_ABI CastInst * CreatePointerBitCastOrAddrSpaceCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a BitCast or an AddrSpaceCast cast instruction.
Instruction::CastOps getOpcode() const
Return the opcode of this CastInst.
static LLVM_ABI unsigned isEliminableCastPair(Instruction::CastOps firstOpcode, Instruction::CastOps secondOpcode, Type *SrcTy, Type *MidTy, Type *DstTy, const DataLayout *DL)
Determine how a pair of casts can be eliminated, if they can be at all.
static LLVM_ABI CastInst * CreateIntegerCast(Value *S, Type *Ty, bool isSigned, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a ZExt, BitCast, or Trunc for int -> int casts.
static LLVM_ABI CastInst * CreateFPCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create an FPExt, BitCast, or FPTrunc for fp -> fp casts.
CastInst(Type *Ty, unsigned iType, Value *S, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics for subclasses.
static LLVM_ABI bool isBitOrNoopPointerCastable(Type *SrcTy, Type *DestTy, const DataLayout &DL)
Check whether a bitcast, inttoptr, or ptrtoint cast between these types is valid and a no-op.
static LLVM_ABI bool isBitCastable(Type *SrcTy, Type *DestTy)
Check whether a bitcast between these types is valid.
static LLVM_ABI CastInst * CreateTruncOrBitCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a Trunc or BitCast cast instruction.
static LLVM_ABI CastInst * CreatePointerCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a BitCast, AddrSpaceCast or a PtrToInt cast instruction.
static LLVM_ABI CastInst * CreateBitOrPointerCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a BitCast, a PtrToInt, or an IntToPTr cast instruction.
static LLVM_ABI bool isNoopCast(Instruction::CastOps Opcode, Type *SrcTy, Type *DstTy, const DataLayout &DL)
A no-op cast is one that can be effected without changing any bits.
static LLVM_ABI CastInst * CreateZExtOrBitCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a ZExt or BitCast cast instruction.
static LLVM_ABI CastInst * Create(Instruction::CastOps, Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Provides a way to construct any of the CastInst subclasses using an opcode instead of the subclass's ...
LLVM_ABI bool isIntegerCast() const
There are several places where we need to know if a cast instruction only deals with integer source a...
static LLVM_ABI CastInst * CreateSExtOrBitCast(Value *S, Type *Ty, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Create a SExt or BitCast cast instruction.
static LLVM_ABI bool castIsValid(Instruction::CastOps op, Type *SrcTy, Type *DstTy)
This method can be used to determine if a cast from SrcTy to DstTy using Opcode op is valid or not.
LLVM_ABI CatchReturnInst * cloneImpl() const
void setUnwindDest(BasicBlock *UnwindDest)
LLVM_ABI void addHandler(BasicBlock *Dest)
Add an entry to the switch instruction... Note: This action invalidates handler_end().
LLVM_ABI CatchSwitchInst * cloneImpl() const
mapped_iterator< op_iterator, DerefFnTy > handler_iterator
Value * getParentPad() const
void setParentPad(Value *ParentPad)
BasicBlock * getUnwindDest() const
LLVM_ABI void removeHandler(handler_iterator HI)
bool hasUnwindDest() const
LLVM_ABI CleanupReturnInst * cloneImpl() const
This class is the base class for the comparison instructions.
Predicate getStrictPredicate() const
For example, SGE -> SGT, SLE -> SLT, ULE -> ULT, UGE -> UGT.
bool isEquality() const
Determine if this is an equals/not equals predicate.
void setPredicate(Predicate P)
Set the predicate for this instruction to the specified value.
bool isFalseWhenEqual() const
This is just a convenience.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
@ FCMP_OEQ
0 0 0 1 True if ordered and equal
@ FCMP_TRUE
1 1 1 1 Always true (always folded)
@ ICMP_SLT
signed less than
@ ICMP_SLE
signed less or equal
@ FCMP_OLT
0 1 0 0 True if ordered and less than
@ FCMP_ULE
1 1 0 1 True if unordered, less than, or equal
@ FCMP_OGT
0 0 1 0 True if ordered and greater than
@ FCMP_OGE
0 0 1 1 True if ordered and greater than or equal
@ ICMP_UGE
unsigned greater or equal
@ ICMP_UGT
unsigned greater than
@ ICMP_SGT
signed greater than
@ FCMP_ULT
1 1 0 0 True if unordered or less than
@ FCMP_ONE
0 1 1 0 True if ordered and operands are unequal
@ FCMP_UEQ
1 0 0 1 True if unordered or equal
@ ICMP_ULT
unsigned less than
@ FCMP_UGT
1 0 1 0 True if unordered or greater than
@ FCMP_OLE
0 1 0 1 True if ordered and less than or equal
@ FCMP_ORD
0 1 1 1 True if ordered (no nans)
@ ICMP_SGE
signed greater or equal
@ FCMP_UNE
1 1 1 0 True if unordered or not equal
@ ICMP_ULE
unsigned less or equal
@ FCMP_UGE
1 0 1 1 True if unordered, greater than, or equal
@ FCMP_FALSE
0 0 0 0 Always false (always folded)
@ FCMP_UNO
1 0 0 0 True if unordered: isnan(X) | isnan(Y)
LLVM_ABI bool isEquivalence(bool Invert=false) const
Determine if one operand of this compare can always be replaced by the other operand,...
static LLVM_ABI bool isEquality(Predicate pred)
Determine if this is an equals/not equals predicate.
Predicate getSwappedPredicate() const
For example, EQ->EQ, SLE->SGE, ULT->UGT, OEQ->OEQ, ULE->UGE, OLT->OGT, etc.
bool isTrueWhenEqual() const
This is just a convenience.
static LLVM_ABI CmpInst * Create(OtherOps Op, Predicate Pred, Value *S1, Value *S2, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Construct a compare instruction, given the opcode, the predicate and the two operands.
static bool isFPPredicate(Predicate P)
Predicate getNonStrictPredicate() const
For example, SGT -> SGE, SLT -> SLE, ULT -> ULE, UGT -> UGE.
static LLVM_ABI CmpInst * CreateWithCopiedFlags(OtherOps Op, Predicate Pred, Value *S1, Value *S2, const Instruction *FlagsSource, const Twine &Name="", InsertPosition InsertBefore=nullptr)
Construct a compare instruction, given the opcode, the predicate, the two operands and the instructio...
LLVM_ABI CmpInst(Type *ty, Instruction::OtherOps op, Predicate pred, Value *LHS, Value *RHS, const Twine &Name="", InsertPosition InsertBefore=nullptr)
bool isNonStrictPredicate() const
LLVM_ABI void swapOperands()
This is just a convenience that dispatches to the subclasses.
static bool isRelational(Predicate P)
Return true if the predicate is relational (not EQ or NE).
Predicate getInversePredicate() const
For example, EQ -> NE, UGT -> ULE, SLT -> SGE, OEQ -> UNE, UGT -> OLE, OLT -> UGE,...
static LLVM_ABI StringRef getPredicateName(Predicate P)
Predicate getPredicate() const
Return the predicate for this instruction.
bool isStrictPredicate() const
static LLVM_ABI bool isUnordered(Predicate predicate)
Determine if the predicate is an unordered operation.
Predicate getFlippedStrictnessPredicate() const
For predicate of kind "is X or equal to 0" returns the predicate "is X".
static bool isIntPredicate(Predicate P)
static LLVM_ABI bool isOrdered(Predicate predicate)
Determine if the predicate is an ordered operation.
LLVM_ABI bool isCommutative() const
This is just a convenience that dispatches to the subclasses.
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
static LLVM_ABI std::optional< CmpPredicate > getMatching(CmpPredicate A, CmpPredicate B)
Compares two CmpPredicates taking samesign into account and returns the canonicalized CmpPredicate if...
static LLVM_ABI CmpPredicate getInverse(CmpPredicate P)
Get the inverse predicate of a CmpPredicate.
CmpPredicate()
Default constructor.
static LLVM_ABI CmpPredicate get(const CmpInst *Cmp)
Do a ICmpInst::getCmpPredicate() or CmpInst::getPredicate(), as appropriate.
LLVM_ABI CmpInst::Predicate getPreferredSignedPredicate() const
Attempts to return a signed CmpInst::Predicate from the CmpPredicate.
bool hasSameSign() const
Query samesign information, for optimizations.
static LLVM_ABI CmpPredicate getSwapped(CmpPredicate P)
Get the swapped predicate of a CmpPredicate.
Conditional Branch instruction.
LLVM_ABI void swapSuccessors()
Swap the successors of this branch instruction.
LLVM_ABI CondBrInst * cloneImpl() const
Value * getCondition() const
ConstantFP - Floating Point Values [float, double].
const APFloat & getValueAPF() const
This is the shared class of boolean and integer constants.
LLVM_ABI ConstantRange intersectWith(const ConstantRange &CR, PreferredRangeType Type=Smallest) const
Return the range that results from the intersection of this range with another range.
static LLVM_ABI Constant * get(ArrayRef< Constant * > V)
This is an important base class in LLVM.
static LLVM_ABI Constant * getAllOnesValue(Type *Ty)
static LLVM_ABI Constant * getNullValue(Type *Ty)
Constructor to create a '0' constant of arbitrary type.
A parsed version of the target data layout string in and methods for querying it.
static constexpr ElementCount getFixed(ScalarTy MinVal)
This instruction compares its operands according to the predicate given to the constructor.
static LLVM_ABI bool compare(const APFloat &LHS, const APFloat &RHS, FCmpInst::Predicate Pred)
Return result of LHS Pred RHS comparison.
LLVM_ABI FCmpInst * cloneImpl() const
Clone an identical FCmpInst.
FCmpInst(InsertPosition InsertBefore, Predicate pred, Value *LHS, Value *RHS, const Twine &NameStr="")
Constructor with insertion semantics.
Binary operators support fast-math flags, users should not use this class directly,...
This class represents an extension of floating point types.
LLVM_ABI FPExtInst * cloneImpl() const
Clone an identical FPExtInst.
LLVM_ABI FPExtInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI float getFPAccuracy() const
Get the maximum error permitted by this operation in ULPs.
This class represents a cast from floating point to signed integer.
LLVM_ABI FPToSIInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI FPToSIInst * cloneImpl() const
Clone an identical FPToSIInst.
This class represents a cast from floating point to unsigned integer.
LLVM_ABI FPToUIInst * cloneImpl() const
Clone an identical FPToUIInst.
LLVM_ABI FPToUIInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
This class represents a truncation of floating point types.
LLVM_ABI FPTruncInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI FPTruncInst * cloneImpl() const
Clone an identical FPTruncInst.
Unary operators support fast-math flags, users should not use this class directly,...
LLVM_ABI FenceInst(LLVMContext &C, AtomicOrdering Ordering, SyncScope::ID SSID=SyncScope::System, InsertPosition InsertBefore=nullptr)
SyncScope::ID getSyncScopeID() const
Returns the synchronization scope ID of this fence instruction.
void setSyncScopeID(SyncScope::ID SSID)
Sets the synchronization scope ID of this fence instruction.
LLVM_ABI FenceInst * cloneImpl() const
friend class Instruction
Iterator for Instructions in a `BasicBlock.
void setOrdering(AtomicOrdering Ordering)
Sets the ordering constraint of this fence instruction.
AtomicOrdering getOrdering() const
Returns the ordering constraint of this fence instruction.
Class to represent fixed width SIMD vectors.
unsigned getNumElements() const
LLVM_ABI FreezeInst(Value *S, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
LLVM_ABI FreezeInst * cloneImpl() const
Clone an identical FreezeInst.
void setParentPad(Value *ParentPad)
Value * getParentPad() const
Convenience accessors.
LLVM_ABI FuncletPadInst * cloneImpl() const
Class to represent function types.
unsigned getNumParams() const
Return the number of fixed parameters this function type requires.
Type * getParamType(unsigned i) const
Parameter type accessors.
Represents flags for the getelementptr instruction/expression.
static GEPNoWrapFlags inBounds()
GEPNoWrapFlags withoutInBounds() const
an instruction for type-safe pointer arithmetic to access elements of arrays and structs
LLVM_ABI bool isInBounds() const
Determine whether the GEP has the inbounds flag.
LLVM_ABI bool hasNoUnsignedSignedWrap() const
Determine whether the GEP has the nusw flag.
static LLVM_ABI Type * getTypeAtIndex(Type *Ty, Value *Idx)
Return the type of the element at the given index of an indexable type.
LLVM_ABI bool hasAllZeroIndices() const
Return true if all of the indices of this GEP are zeros.
LLVM_ABI bool hasNoUnsignedWrap() const
Determine whether the GEP has the nuw flag.
LLVM_ABI bool hasAllConstantIndices() const
Return true if all of the indices of this GEP are constant integers.
LLVM_ABI void setIsInBounds(bool b=true)
Set or clear the inbounds flag on this GEP instruction.
static LLVM_ABI Type * getIndexedType(Type *Ty, ArrayRef< Value * > IdxList)
Returns the result type of a getelementptr with the given source element type and indexes.
LLVM_ABI bool accumulateConstantOffset(const DataLayout &DL, APInt &Offset) const
Accumulate the constant address offset of this GEP if possible.
LLVM_ABI GetElementPtrInst * cloneImpl() const
LLVM_ABI bool collectOffset(const DataLayout &DL, unsigned BitWidth, SmallMapVector< Value *, APInt, 4 > &VariableOffsets, APInt &ConstantOffset) const
LLVM_ABI void setNoWrapFlags(GEPNoWrapFlags NW)
Set nowrap flags for GEP instruction.
LLVM_ABI GEPNoWrapFlags getNoWrapFlags() const
Get the nowrap flags for the GEP instruction.
Module * getParent()
Get the module that this global value is contained inside of...
This instruction compares its operands according to the predicate given to the constructor.
bool hasSameSign() const
An icmp instruction, which can be marked as "samesign", indicating that the two operands have the sam...
ICmpInst(InsertPosition InsertBefore, Predicate pred, Value *LHS, Value *RHS, const Twine &NameStr="")
Constructor with insertion semantics.
static LLVM_ABI bool compare(const APInt &LHS, const APInt &RHS, ICmpInst::Predicate Pred)
Return result of LHS Pred RHS comparison.
LLVM_ABI ICmpInst * cloneImpl() const
Clone an identical ICmpInst.
Predicate getFlippedSignednessPredicate() const
For example, SLT->ULT, ULT->SLT, SLE->ULE, ULE->SLE, EQ->EQ.
Predicate getSignedPredicate() const
For example, EQ->EQ, SLE->SLE, UGT->SGT, etc.
static CmpPredicate getInverseCmpPredicate(CmpPredicate Pred)
bool isEquality() const
Return true if this predicate is either EQ or NE.
static LLVM_ABI Predicate getFlippedSignednessPredicate(Predicate Pred)
For example, SLT->ULT, ULT->SLT, SLE->ULE, ULE->SLE, EQ->EQ.
static LLVM_ABI std::optional< bool > isImpliedByMatchingCmp(CmpPredicate Pred1, CmpPredicate Pred2)
Determine if Pred1 implies Pred2 is true, false, or if nothing can be inferred about the implication,...
Predicate getUnsignedPredicate() const
For example, EQ->EQ, SLE->ULE, UGT->UGT, etc.
Indirect Branch Instruction.
LLVM_ABI void addDestination(BasicBlock *Dest)
Add a destination.
LLVM_ABI void removeDestination(unsigned i)
This method removes the specified successor from the indirectbr instruction.
LLVM_ABI IndirectBrInst * cloneImpl() const
LLVM_ABI InsertElementInst * cloneImpl() const
static InsertElementInst * Create(Value *Vec, Value *NewElt, Value *Idx, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
static LLVM_ABI bool isValidOperands(const Value *Vec, const Value *NewElt, const Value *Idx)
Return true if an insertelement instruction can be formed with the specified operands.
BasicBlock * getBasicBlock()
This instruction inserts a struct field of array element value into an aggregate value.
LLVM_ABI InsertValueInst * cloneImpl() const
BitfieldElement::Type getSubclassData() const
LLVM_ABI bool hasNoNaNs() const LLVM_READONLY
Determine whether the no-NaNs flag is set.
LLVM_ABI void copyIRFlags(const Value *V, bool IncludeWrapFlags=true)
Convenience method to copy supported exact, fast-math, and (optionally) wrapping flags from V to this...
const DebugLoc & getDebugLoc() const
Return the debug location for this node as a DebugLoc.
LLVM_ABI bool isCommutative() const LLVM_READONLY
Return true if the instruction is commutative:
LLVM_ABI InstListType::iterator eraseFromParent()
This method unlinks 'this' from the containing basic block and deletes it.
LLVM_ABI const Function * getFunction() const
Return the function this instruction belongs to.
LLVM_ABI bool isVolatile() const LLVM_READONLY
Return true if this instruction has a volatile memory access.
unsigned getOpcode() const
Returns a member of one of the enums like Instruction::Add.
Bitfield::Element< uint16_t, 0, 16 > OpaqueField
Instruction(const Instruction &)=delete
friend class BasicBlock
Various leaf nodes.
void setSubclassData(typename BitfieldElement::Type Value)
This class represents a cast from an integer to a pointer.
LLVM_ABI IntToPtrInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI IntToPtrInst * cloneImpl() const
Clone an identical IntToPtrInst.
BasicBlock * getUnwindDest() const
void setNormalDest(BasicBlock *B)
LLVM_ABI InvokeInst * cloneImpl() const
LLVM_ABI LandingPadInst * getLandingPadInst() const
Get the landingpad instruction from the landing pad block (the unwind destination).
void setUnwindDest(BasicBlock *B)
LLVM_ABI void updateProfWeight(uint64_t S, uint64_t T)
Updates profile metadata by scaling it by S / T.
static InvokeInst * Create(FunctionType *Ty, Value *Func, BasicBlock *IfNormal, BasicBlock *IfException, ArrayRef< Value * > Args, const Twine &NameStr, InsertPosition InsertBefore=nullptr)
This is an important class for using LLVM in a threaded context.
LLVMContextImpl *const pImpl
The landingpad instruction holds all of the information necessary to generate correct exception handl...
bool isCleanup() const
Return 'true' if this landingpad instruction is a cleanup.
LLVM_ABI LandingPadInst * cloneImpl() const
static LLVM_ABI LandingPadInst * Create(Type *RetTy, unsigned NumReservedClauses, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructors - NumReservedClauses is a hint for the number of incoming clauses that this landingpad w...
LLVM_ABI void addClause(Constant *ClauseVal)
Add a catch or filter clause to the landing pad.
void setCleanup(bool V)
Indicate that this landingpad instruction is a cleanup.
void setAlignment(Align Align)
bool isVolatile() const
Return true if this is a load from a volatile memory location.
void setAtomic(AtomicOrdering Ordering, SyncScope::ID SSID=SyncScope::System)
Sets the ordering constraint and the synchronization scope ID of this load instruction.
LLVM_ABI LoadInst * cloneImpl() const
AtomicOrdering getOrdering() const
Returns the ordering constraint of this load instruction.
void setVolatile(bool V)
Specify whether this is a volatile load or not.
SyncScope::ID getSyncScopeID() const
Returns the synchronization scope ID of this load instruction.
LLVM_ABI LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, InsertPosition InsertBefore)
Align getAlign() const
Return the alignment of the access that is being performed.
const MDOperand & getOperand(unsigned I) const
static MemoryEffectsBase readOnly()
bool onlyWritesMemory() const
Whether this function only (at most) writes memory.
bool doesNotAccessMemory() const
Whether this function accesses no memory.
static MemoryEffectsBase argMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
static MemoryEffectsBase inaccessibleMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
bool onlyAccessesInaccessibleMem() const
Whether this function only (at most) accesses inaccessible memory.
bool onlyAccessesArgPointees() const
Whether this function only (at most) accesses argument memory.
bool onlyReadsMemory() const
Whether this function only (at most) reads memory.
static MemoryEffectsBase writeOnly()
static MemoryEffectsBase inaccessibleOrArgMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
static MemoryEffectsBase none()
bool onlyAccessesInaccessibleOrArgMem() const
Whether this function only (at most) accesses argument and inaccessible memory.
void allocHungoffUses(unsigned N)
const_block_iterator block_begin() const
LLVM_ABI void removeIncomingValueIf(function_ref< bool(unsigned)> Predicate, bool DeletePHIIfEmpty=true)
Remove all incoming values for which the predicate returns true.
void setIncomingBlock(unsigned i, BasicBlock *BB)
LLVM_ABI Value * removeIncomingValue(unsigned Idx, bool DeletePHIIfEmpty=true)
Remove an incoming value.
LLVM_ABI bool hasConstantOrUndefValue() const
Whether the specified PHI node always merges together the same value, assuming undefs are equal to a ...
void setIncomingValue(unsigned i, Value *V)
const_block_iterator block_end() const
BasicBlock * getIncomingBlock(unsigned i) const
Return incoming basic block number i.
Value * getIncomingValue(unsigned i) const
Return incoming value number x.
LLVM_ABI Value * hasConstantValue() const
If the specified PHI node always merges together the same value, return the value,...
LLVM_ABI PHINode * cloneImpl() const
unsigned getNumIncomingValues() const
Return the number of incoming edges.
Class to represent pointers.
unsigned getAddressSpace() const
Return the address space of the Pointer type.
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
This class represents a cast from a pointer to an address (non-capturing ptrtoint).
PtrToAddrInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
PtrToAddrInst * cloneImpl() const
Clone an identical PtrToAddrInst.
This class represents a cast from a pointer to an integer.
LLVM_ABI PtrToIntInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI PtrToIntInst * cloneImpl() const
Clone an identical PtrToIntInst.
Resume the propagation of an exception.
LLVM_ABI ResumeInst * cloneImpl() const
Return a value (possibly void), from a function.
LLVM_ABI ReturnInst * cloneImpl() const
This class represents a sign extension of integer types.
LLVM_ABI SExtInst * cloneImpl() const
Clone an identical SExtInst.
LLVM_ABI SExtInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
This class represents a cast from signed integer to floating point.
LLVM_ABI SIToFPInst * cloneImpl() const
Clone an identical SIToFPInst.
LLVM_ABI SIToFPInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
Class to represent scalable SIMD vectors.
LLVM_ABI SelectInst * cloneImpl() const
static LLVM_ABI const char * areInvalidOperands(Value *Cond, Value *True, Value *False)
Return a string if the specified operands are invalid for a select operation, otherwise return null.
static SelectInst * Create(Value *C, Value *S1, Value *S2, const Twine &NameStr="", InsertPosition InsertBefore=nullptr, const Instruction *MDFrom=nullptr)
static LLVM_ABI bool isZeroEltSplatMask(ArrayRef< int > Mask, int NumSrcElts)
Return true if this shuffle mask chooses all elements with the same value as the first element of exa...
ArrayRef< int > getShuffleMask() const
static LLVM_ABI bool isSpliceMask(ArrayRef< int > Mask, int NumSrcElts, int &Index)
Return true if this shuffle mask is a splice mask, concatenating the two inputs together and then ext...
int getMaskValue(unsigned Elt) const
Return the shuffle mask value of this instruction for the given element index.
LLVM_ABI ShuffleVectorInst(Value *V1, Value *Mask, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
static LLVM_ABI bool isValidOperands(const Value *V1, const Value *V2, const Value *Mask)
Return true if a shufflevector instruction can be formed with the specified operands.
static LLVM_ABI bool isSelectMask(ArrayRef< int > Mask, int NumSrcElts)
Return true if this shuffle mask chooses elements from its source vectors without lane crossings.
static LLVM_ABI bool isBitRotateMask(ArrayRef< int > Mask, unsigned EltSizeInBits, unsigned MinSubElts, unsigned MaxSubElts, unsigned &NumSubElts, unsigned &RotateAmt)
Checks if the shuffle is a bit rotation of the first operand across multiple subelements,...
VectorType * getType() const
Overload to return most specific vector type.
LLVM_ABI bool isIdentityWithExtract() const
Return true if this shuffle extracts the first N elements of exactly one source vector.
static LLVM_ABI bool isOneUseSingleSourceMask(ArrayRef< int > Mask, int VF)
Return true if this shuffle mask represents "clustered" mask of size VF, i.e.
LLVM_ABI bool isIdentityWithPadding() const
Return true if this shuffle lengthens exactly one source vector with undefs in the high elements.
static LLVM_ABI bool isSingleSourceMask(ArrayRef< int > Mask, int NumSrcElts)
Return true if this shuffle mask chooses elements from exactly one source vector.
LLVM_ABI bool isConcat() const
Return true if this shuffle concatenates its 2 source vectors.
static LLVM_ABI bool isDeInterleaveMaskOfFactor(ArrayRef< int > Mask, unsigned Factor, unsigned &Index)
Check if the mask is a DE-interleave mask of the given factor Factor like: <Index,...
LLVM_ABI ShuffleVectorInst * cloneImpl() const
static LLVM_ABI bool isIdentityMask(ArrayRef< int > Mask, int NumSrcElts)
Return true if this shuffle mask chooses elements from exactly one source vector without lane crossin...
static LLVM_ABI bool isExtractSubvectorMask(ArrayRef< int > Mask, int NumSrcElts, int &Index)
Return true if this shuffle mask is an extract subvector mask.
LLVM_ABI void setShuffleMask(ArrayRef< int > Mask)
friend class Instruction
Iterator for Instructions in a `BasicBlock.
LLVM_ABI bool isInterleave(unsigned Factor)
Return if this shuffle interleaves its two input vectors together.
static LLVM_ABI bool isReverseMask(ArrayRef< int > Mask, int NumSrcElts)
Return true if this shuffle mask swaps the order of elements from exactly one source vector.
static LLVM_ABI bool isTransposeMask(ArrayRef< int > Mask, int NumSrcElts)
Return true if this shuffle mask is a transpose mask.
LLVM_ABI void commute()
Swap the operands and adjust the mask to preserve the semantics of the instruction.
static LLVM_ABI bool isInsertSubvectorMask(ArrayRef< int > Mask, int NumSrcElts, int &NumSubElts, int &Index)
Return true if this shuffle mask is an insert subvector mask.
static LLVM_ABI Constant * convertShuffleMaskForBitcode(ArrayRef< int > Mask, Type *ResultTy)
static LLVM_ABI bool isReplicationMask(ArrayRef< int > Mask, int &ReplicationFactor, int &VF)
Return true if this shuffle mask replicates each of the VF elements in a vector ReplicationFactor tim...
static LLVM_ABI bool isInterleaveMask(ArrayRef< int > Mask, unsigned Factor, unsigned NumInputElts, SmallVectorImpl< unsigned > &StartIndexes)
Return true if the mask interleaves one or more input vectors together.
This is a 'bitvector' (really, a variable-sized bit array), optimized for the case when the array is ...
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.
AtomicOrdering getOrdering() const
Returns the ordering constraint of this store instruction.
void setVolatile(bool V)
Specify whether this is a volatile store or not.
void setAlignment(Align Align)
friend class Instruction
Iterator for Instructions in a `BasicBlock.
LLVM_ABI StoreInst * cloneImpl() const
LLVM_ABI StoreInst(Value *Val, Value *Ptr, InsertPosition InsertBefore)
SyncScope::ID getSyncScopeID() const
Returns the synchronization scope ID of this store instruction.
bool isVolatile() const
Return true if this is a store to a volatile memory location.
void setAtomic(AtomicOrdering Ordering, SyncScope::ID SSID=SyncScope::System)
Sets the ordering constraint and the synchronization scope ID of this store instruction.
Represent a constant reference to a string, i.e.
Class to represent struct types.
LLVM_ABI void setSuccessorWeight(unsigned idx, CaseWeightOpt W)
LLVM_ABI Instruction::InstListType::iterator eraseFromParent()
Delegate the call to the underlying SwitchInst::eraseFromParent() and mark this object to not touch t...
LLVM_ABI void addCase(ConstantInt *OnVal, BasicBlock *Dest, CaseWeightOpt W)
Delegate the call to the underlying SwitchInst::addCase() and set the specified branch weight for the...
LLVM_ABI CaseWeightOpt getSuccessorWeight(unsigned idx)
LLVM_ABI void replaceDefaultDest(SwitchInst::CaseIt I)
Replace the default destination by given case.
std::optional< uint32_t > CaseWeightOpt
LLVM_ABI SwitchInst::CaseIt removeCase(SwitchInst::CaseIt I)
Delegate the call to the underlying SwitchInst::removeCase() and remove correspondent branch weight.
void setValue(ConstantInt *V) const
Sets the new value for current case.
void setSuccessor(BasicBlock *S) const
Sets the new successor for current case.
void allocHungoffUses(unsigned N)
LLVM_ABI SwitchInst * cloneImpl() const
LLVM_ABI void addCase(ConstantInt *OnVal, BasicBlock *Dest)
Add an entry to the switch instruction.
CaseIteratorImpl< CaseHandle > CaseIt
ConstantInt *const * case_values() const
unsigned getNumCases() const
Return the number of 'cases' in this switch instruction, excluding the default case.
LLVM_ABI CaseIt removeCase(CaseIt I)
This method removes the specified case and its successor from the switch instruction.
Target - Wrapper for Target specific information.
This class represents a truncation of integer types.
LLVM_ABI TruncInst * cloneImpl() const
Clone an identical TruncInst.
LLVM_ABI TruncInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
static constexpr TypeSize getFixed(ScalarTy ExactSize)
static constexpr TypeSize get(ScalarTy Quantity, bool Scalable)
The instances of the Type class are immutable: once they are created, they are never changed.
bool isByteTy() const
True if this is an instance of ByteType.
bool isVectorTy() const
True if this is an instance of VectorType.
static LLVM_ABI IntegerType * getInt32Ty(LLVMContext &C)
bool isIntOrIntVectorTy() const
Return true if this is an integer type or a vector of integer types.
bool isPointerTy() const
True if this is an instance of PointerType.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
LLVM_ABI bool isFirstClassType() const
Return true if the type is "first class", meaning it is a valid type for a Value.
Type * getScalarType() const
If this is a vector type, return the element type, otherwise return 'this'.
LLVM_ABI TypeSize getPrimitiveSizeInBits() const LLVM_READONLY
Return the basic size of this type if it is a primitive type.
bool isByteOrByteVectorTy() const
Return true if this is a byte type or a vector of byte types.
bool isAggregateType() const
Return true if the type is an aggregate type.
LLVMContext & getContext() const
Return the LLVMContext in which this type was uniqued.
LLVM_ABI unsigned getScalarSizeInBits() const LLVM_READONLY
If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
static LLVM_ABI IntegerType * getInt1Ty(LLVMContext &C)
bool isFloatingPointTy() const
Return true if this is one of the floating-point types.
bool isPtrOrPtrVectorTy() const
Return true if this is a pointer type or a vector of pointer types.
bool isIntegerTy() const
True if this is an instance of IntegerType.
bool isTokenTy() const
Return true if this is 'token'.
bool isFPOrFPVectorTy() const
Return true if this is a FP type or a vector of FP.
This class represents a cast unsigned integer to floating point.
LLVM_ABI UIToFPInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI UIToFPInst * cloneImpl() const
Clone an identical UIToFPInst.
UnaryInstruction(Type *Ty, unsigned iType, Value *V, InsertPosition InsertBefore=nullptr)
static LLVM_ABI UnaryOperator * Create(UnaryOps Op, Value *S, const Twine &Name=Twine(), InsertPosition InsertBefore=nullptr)
Construct a unary instruction, given the opcode and an operand.
LLVM_ABI UnaryOperator(UnaryOps iType, Value *S, Type *Ty, const Twine &Name, InsertPosition InsertBefore)
LLVM_ABI UnaryOperator * cloneImpl() const
UnaryOps getOpcode() const
Unconditional Branch instruction.
LLVM_ABI UncondBrInst * cloneImpl() const
LLVM_ABI UnreachableInst(LLVMContext &C, InsertPosition InsertBefore=nullptr)
LLVM_ABI bool shouldLowerToTrap(bool TrapUnreachable, bool NoTrapAfterNoreturn) const
friend class Instruction
Iterator for Instructions in a `BasicBlock.
LLVM_ABI UnreachableInst * cloneImpl() const
A Use represents the edge between a Value definition and its users.
LLVM_ABI void set(Value *Val)
const Use * getOperandList() const
LLVM_ABI void allocHungoffUses(unsigned N, bool WithExtraValues=false)
Allocate the array of Uses, followed by a pointer (with bottom bit set) to the User.
const Use & getOperandUse(unsigned i) const
void setNumHungOffUseOperands(unsigned NumOps)
Subclasses with hung off uses need to manage the operand count themselves.
LLVM_ABI void growHungoffUses(unsigned N, bool WithExtraValues=false)
Grow the number of hung off uses.
Value * getOperand(unsigned i) const
unsigned getNumOperands() const
VAArgInst(Value *List, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
LLVM_ABI VAArgInst * cloneImpl() const
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
unsigned char SubclassOptionalData
Hold subclass data that can be dropped.
LLVM_ABI void setName(const Twine &Name)
Change the name of the value.
LLVM_ABI void replaceAllUsesWith(Value *V)
Change all uses of this to point to a new Value.
LLVMContext & getContext() const
All values hold a context through their type.
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
Base class of all SIMD vector types.
ElementCount getElementCount() const
Return an ElementCount instance to represent the (possibly scalable) number of elements in the vector...
static LLVM_ABI VectorType * get(Type *ElementType, ElementCount EC)
This static method is the primary way to construct an VectorType.
This class represents zero extension of integer types.
LLVM_ABI ZExtInst(Value *S, Type *Ty, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Constructor with insert-before-instruction semantics.
LLVM_ABI ZExtInst * cloneImpl() const
Clone an identical ZExtInst.
constexpr ScalarTy getFixedValue() const
constexpr ScalarTy getKnownMinValue() const
Returns the minimum value this quantity can represent.
An efficient, type-erasing, non-owning reference to a callable.
const ilist_detail::compute_node_options< Instruction, Options... >::type::parent_ty * getParent() const
Instruction * getPrevNode()
typename base_list_type::iterator iterator
This class implements an extremely fast bulk output stream that can only output to a stream.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ C
The default llvm calling convention, compatible with C.
bool match(Val *V, const Pattern &P)
cstfp_pred_ty< is_non_zero_not_denormal_fp > m_NonZeroNotDenormalFP()
Match a floating-point non-zero that is not a denormal.
initializer< Ty > init(const Ty &Val)
@ Switch
The "resume-switch" lowering, where there are separate resume and destroy functions that are shared b...
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > extract(Y &&MD)
Extract a Value from Metadata.
NodeAddr< UseNode * > Use
Context & getContext() const
This is an optimization pass for GlobalISel generic memory operations.
auto seq_inclusive(T Begin, T End)
Iterate over an integral type from Begin to End inclusive.
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
auto size(R &&Range, std::enable_if_t< std::is_base_of< std::random_access_iterator_tag, typename std::iterator_traits< decltype(Range.begin())>::iterator_category >::value, void > *=nullptr)
Get the size of a range.
unsigned getPointerAddressSpace(const Type *T)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
FunctionAddr VTableAddr uintptr_t uintptr_t Int32Ty
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
LLVM_ABI MDNode * getBranchWeightMDNode(const Instruction &I)
Get the branch weights metadata node.
MemoryEffectsBase< IRMemLocation > MemoryEffects
Summary of how a function affects memory in the program.
constexpr auto equal_to(T &&Arg)
Functor variant of std::equal_to that can be used as a UnaryPredicate in functional algorithms like a...
std::enable_if_t< std::is_unsigned_v< T >, std::optional< T > > checkedMulUnsigned(T LHS, T RHS)
Multiply two unsigned integers LHS and RHS.
auto dyn_cast_or_null(const Y &Val)
auto reverse(ContainerTy &&C)
LLVM_ABI MDNode * getValidBranchWeightMDNode(const Instruction &I)
Get the valid branch weights metadata node.
constexpr bool isPowerOf2_32(uint32_t Value)
Return true if the argument is a power of two > 0.
decltype(auto) get(const PointerIntPair< PointerTy, IntBits, IntType, PtrTraits, Info > &Pair)
FPClassTest
Floating-point class tests, supported by 'is_fpclass' intrinsic.
LLVM_ABI bool NullPointerIsDefined(const Function *F, unsigned AS=0)
Check whether null pointer dereferencing is considered undefined behavior for a given function or an ...
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
bool isPointerTy(const Type *T)
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...
constexpr int PoisonMaskElem
LLVM_ABI unsigned getNumBranchWeights(const MDNode &ProfileData)
AtomicOrdering
Atomic ordering for LLVM's memory model.
LLVM_ABI void extractFromBranchWeightMD32(const MDNode *ProfileData, SmallVectorImpl< uint32_t > &Weights)
Faster version of extractBranchWeights() that skips checks and must only be called with "branch_weigh...
OperandBundleDefT< Value * > OperandBundleDef
@ Mul
Product of integers.
@ FSub
Subtraction of floats.
@ Xor
Bitwise or logical XOR of integers.
@ Sub
Subtraction of integers.
DWARFExpression::Operation Op
raw_ostream & operator<<(raw_ostream &OS, const APFixedPoint &FX)
OutputIt copy(R &&Range, OutputIt Out)
constexpr unsigned BitWidth
LLVM_ABI bool extractBranchWeights(const MDNode *ProfileData, SmallVectorImpl< uint32_t > &Weights)
Extract branch weights from MD_prof metadata.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
bool capturesAnything(CaptureComponents CC)
bool all_equal(std::initializer_list< T > Values)
Returns true if all Values in the initializer lists are equal or the list.
auto seq(T Begin, T End)
Iterate over an integral type from Begin up to - but not including - End.
@ Default
The result value is uniform if and only if all operands are uniform.
LLVM_ABI void scaleProfData(Instruction &I, uint64_t S, uint64_t T)
Scaling the profile data attached to 'I' using the ratio of S/T.
This struct is a compact representation of a valid (non-zero power of two) alignment.
Summary of memprof metadata on allocations.
Used to keep track of an operand bundle.
uint32_t End
The index in the Use& vector where operands for this operand bundle ends.
uint32_t Begin
The index in the Use& vector where operands for this operand bundle starts.
static LLVM_ABI std::optional< bool > eq(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_EQ result.
static LLVM_ABI std::optional< bool > ne(const KnownBits &LHS, const KnownBits &RHS)
Determine if these known bits always give the same ICMP_NE result.
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.
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 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.
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.
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.
A MapVector that performs no allocations if smaller than a certain size.
Indicates this User has operands co-allocated.
Indicates this User has operands and a descriptor co-allocated .