14#ifndef LLVM_ANALYSIS_TARGETTRANSFORMINFOIMPL_H
15#define LLVM_ANALYSIS_TARGETTRANSFORMINFOIMPL_H
81 return SI.getNumCases();
163 virtual std::pair<const Value *, unsigned>
165 return std::make_pair(
nullptr, -1);
175 assert(
F &&
"A concrete function must be provided to this routine.");
182 if (
F->isIntrinsic())
185 if (
F->hasLocalLinkage() || !
F->hasName())
192 if (Name ==
"copysign" || Name ==
"copysignf" || Name ==
"copysignl" ||
193 Name ==
"fabs" || Name ==
"fabsf" || Name ==
"fabsl" ||
194 Name ==
"fmin" || Name ==
"fminf" || Name ==
"fminl" ||
195 Name ==
"fmax" || Name ==
"fmaxf" || Name ==
"fmaxl" ||
196 Name ==
"sin" || Name ==
"sinf" || Name ==
"sinl" ||
197 Name ==
"cos" || Name ==
"cosf" || Name ==
"cosl" ||
198 Name ==
"tan" || Name ==
"tanf" || Name ==
"tanl" ||
199 Name ==
"asin" || Name ==
"asinf" || Name ==
"asinl" ||
200 Name ==
"acos" || Name ==
"acosf" || Name ==
"acosl" ||
201 Name ==
"atan" || Name ==
"atanf" || Name ==
"atanl" ||
202 Name ==
"atan2" || Name ==
"atan2f" || Name ==
"atan2l"||
203 Name ==
"sinh" || Name ==
"sinhf" || Name ==
"sinhl" ||
204 Name ==
"cosh" || Name ==
"coshf" || Name ==
"coshl" ||
205 Name ==
"tanh" || Name ==
"tanhf" || Name ==
"tanhl" ||
206 Name ==
"sqrt" || Name ==
"sqrtf" || Name ==
"sqrtl" ||
207 Name ==
"exp10" || Name ==
"exp10l" || Name ==
"exp10f")
211 if (Name ==
"pow" || Name ==
"powf" || Name ==
"powl" || Name ==
"exp2" ||
212 Name ==
"exp2l" || Name ==
"exp2f" || Name ==
"floor" ||
213 Name ==
"floorf" || Name ==
"ceil" || Name ==
"round" ||
214 Name ==
"ffs" || Name ==
"ffsl" || Name ==
"abs" || Name ==
"labs" ||
239 virtual std::optional<Instruction *>
244 virtual std::optional<Value *>
247 bool &KnownBitsComputed)
const {
255 SimplifyAndSetOp)
const {
273 int64_t BaseOffset,
bool HasBaseReg,
274 int64_t Scale,
unsigned AddrSpace,
276 int64_t ScalableOffset = 0)
const {
279 return !BaseGV && BaseOffset == 0 && (Scale == 0 || Scale == 1);
324 unsigned DataSize =
DL.getTypeStoreSize(DataType);
331 unsigned DataSize =
DL.getTypeStoreSize(DataType);
349 Align Alignment)
const {
354 Align Alignment)
const {
359 Align Alignment)
const {
379 unsigned AddrSpace)
const {
384 Type *DataType)
const {
402 bool HasBaseReg, int64_t Scale,
403 unsigned AddrSpace)
const {
406 Scale, AddrSpace,
nullptr,
418 virtual bool useAA()
const {
return false; }
439 unsigned ScalarOpdIdx)
const {
511 unsigned *
Fast)
const {
567 Type *Ty =
nullptr)
const {
574 return "Generic::Unknown Register Class";
576 return "Generic::ScalarRC";
578 return "Generic::VectorRC";
589 virtual std::optional<unsigned>
getMaxVScale()
const {
return std::nullopt; }
604 virtual unsigned getMaximumVF(
unsigned ElemWidth,
unsigned Opcode)
const {
612 const Instruction &
I,
bool &AllowPromotionWithoutCommonHeader)
const {
613 AllowPromotionWithoutCommonHeader =
false;
618 virtual std::optional<unsigned>
629 virtual std::optional<unsigned>
645 unsigned NumStridedMemAccesses,
646 unsigned NumPrefetches,
647 bool HasCall)
const {
655 unsigned Opcode,
Type *InputTypeA,
Type *InputTypeB,
Type *AccumType,
670 auto IsWidenableCondition = [](
const Value *V) {
672 if (
II->getIntrinsicID() == Intrinsic::experimental_widenable_condition)
681 case Instruction::FDiv:
682 case Instruction::FRem:
683 case Instruction::SDiv:
684 case Instruction::SRem:
685 case Instruction::UDiv:
686 case Instruction::URem:
689 case Instruction::And:
690 case Instruction::Or:
691 if (
any_of(Args, IsWidenableCondition))
698 if (Ty->getScalarType()->isFloatingPointTy())
726 case Instruction::IntToPtr: {
727 unsigned SrcSize = Src->getScalarSizeInBits();
728 if (
DL.isLegalInteger(SrcSize) &&
729 SrcSize <=
DL.getPointerTypeSizeInBits(Dst))
733 case Instruction::PtrToAddr: {
734 unsigned DstSize = Dst->getScalarSizeInBits();
735 assert(DstSize ==
DL.getAddressSizeInBits(Src));
736 if (
DL.isLegalInteger(DstSize))
740 case Instruction::PtrToInt: {
741 unsigned DstSize = Dst->getScalarSizeInBits();
742 if (
DL.isLegalInteger(DstSize) &&
743 DstSize >=
DL.getPointerTypeSizeInBits(Src))
747 case Instruction::BitCast:
748 if (Dst == Src || (Dst->isPointerTy() && Src->isPointerTy()))
752 case Instruction::Trunc: {
789 unsigned Index,
const Value *Op0,
790 const Value *Op1)
const {
801 ArrayRef<std::tuple<Value *, User *, int>> ScalarUserAndIdx)
const {
807 unsigned Index)
const {
814 unsigned Index)
const {
820 const APInt &DemandedDstElts,
831 if (Opcode == Instruction::InsertValue &&
861 bool VariableMask,
Align Alignment,
868 unsigned Opcode,
Type *DataTy,
bool VariableMask,
Align Alignment,
875 bool VariableMask,
Align Alignment,
884 bool UseMaskForCond,
bool UseMaskForGaps)
const {
891 switch (ICA.
getID()) {
894 case Intrinsic::allow_runtime_check:
895 case Intrinsic::allow_ubsan_check:
896 case Intrinsic::annotation:
897 case Intrinsic::assume:
898 case Intrinsic::sideeffect:
899 case Intrinsic::pseudoprobe:
900 case Intrinsic::arithmetic_fence:
901 case Intrinsic::dbg_assign:
902 case Intrinsic::dbg_declare:
903 case Intrinsic::dbg_value:
904 case Intrinsic::dbg_label:
905 case Intrinsic::invariant_start:
906 case Intrinsic::invariant_end:
907 case Intrinsic::launder_invariant_group:
908 case Intrinsic::strip_invariant_group:
909 case Intrinsic::is_constant:
910 case Intrinsic::lifetime_start:
911 case Intrinsic::lifetime_end:
912 case Intrinsic::experimental_noalias_scope_decl:
913 case Intrinsic::objectsize:
914 case Intrinsic::ptr_annotation:
915 case Intrinsic::var_annotation:
916 case Intrinsic::experimental_gc_result:
917 case Intrinsic::experimental_gc_relocate:
918 case Intrinsic::coro_alloc:
919 case Intrinsic::coro_begin:
920 case Intrinsic::coro_begin_custom_abi:
921 case Intrinsic::coro_free:
922 case Intrinsic::coro_end:
923 case Intrinsic::coro_frame:
924 case Intrinsic::coro_size:
925 case Intrinsic::coro_align:
926 case Intrinsic::coro_suspend:
927 case Intrinsic::coro_subfn_addr:
928 case Intrinsic::threadlocal_address:
929 case Intrinsic::experimental_widenable_condition:
930 case Intrinsic::ssa_copy:
955 std::optional<FastMathFlags> FMF,
968 VectorType *Ty, std::optional<FastMathFlags> FMF,
1000 bool CanCreate =
true)
const {
1006 unsigned SrcAddrSpace,
unsigned DestAddrSpace,
1008 std::optional<uint32_t> AtomicElementSize)
const {
1009 return AtomicElementSize ?
Type::getIntNTy(Context, *AtomicElementSize * 8)
1015 unsigned RemainingBytes,
unsigned SrcAddrSpace,
unsigned DestAddrSpace,
1017 std::optional<uint32_t> AtomicCpySize)
const {
1018 unsigned OpSizeInBytes = AtomicCpySize.value_or(1);
1020 for (
unsigned i = 0; i != RemainingBytes; i += OpSizeInBytes)
1026 return (Caller->getFnAttribute(
"target-cpu") ==
1027 Callee->getFnAttribute(
"target-cpu")) &&
1028 (Caller->getFnAttribute(
"target-features") ==
1029 Callee->getFnAttribute(
"target-features"));
1033 unsigned DefaultCallPenalty)
const {
1034 return DefaultCallPenalty;
1040 return (Caller->getFnAttribute(
"target-cpu") ==
1041 Callee->getFnAttribute(
"target-cpu")) &&
1042 (Caller->getFnAttribute(
"target-features") ==
1043 Callee->getFnAttribute(
"target-features"));
1064 unsigned AddrSpace)
const {
1070 unsigned AddrSpace)
const {
1084 unsigned ChainSizeInBytes,
1090 unsigned ChainSizeInBytes,
1181 unsigned MaxRequiredSize =
1182 VT->getElementType()->getPrimitiveSizeInBits().getFixedValue();
1184 unsigned MinRequiredSize = 0;
1185 for (
unsigned i = 0, e = VT->getNumElements(); i < e; ++i) {
1186 if (
auto *IntElement =
1188 bool signedElement = IntElement->getValue().isNegative();
1190 unsigned ElementMinRequiredSize =
1191 IntElement->getValue().getSignificantBits() - 1;
1195 MinRequiredSize = std::max(MinRequiredSize, ElementMinRequiredSize);
1198 return MaxRequiredSize;
1201 return MinRequiredSize;
1205 isSigned = CI->getValue().isNegative();
1206 return CI->getValue().getSignificantBits() - 1;
1211 return Cast->getSrcTy()->getScalarSizeInBits() - 1;
1216 return Cast->getSrcTy()->getScalarSizeInBits();
1236 int64_t MergeDistance)
const {
1250template <
typename T>
1262 assert(PointeeType &&
Ptr &&
"can't get GEPCost of nullptr");
1264 bool HasBaseReg = (BaseGV ==
nullptr);
1266 auto PtrSizeBits =
DL.getPointerTypeSizeInBits(
Ptr->getType());
1267 APInt BaseOffset(PtrSizeBits, 0);
1271 Type *TargetType =
nullptr;
1279 TargetType = GTI.getIndexedType();
1286 if (
StructType *STy = GTI.getStructTypeOrNull()) {
1288 assert(ConstIdx &&
"Unexpected GEP index");
1290 BaseOffset +=
DL.getStructLayout(STy)->getElementOffset(
Field);
1296 int64_t ElementSize =
1297 GTI.getSequentialElementStride(
DL).getFixedValue();
1306 Scale = ElementSize;
1321 AccessType = TargetType;
1328 Ptr->getType()->getPointerAddressSpace()))
1352 for (
const Value *V : Ptrs) {
1356 if (
Info.isSameBase() && V !=
Base) {
1357 if (
GEP->hasAllConstantIndices())
1361 {TTI::OK_AnyValue, TTI::OP_None}, {TTI::OK_AnyValue, TTI::OP_None},
1366 GEP->getSourceElementType(),
GEP->getPointerOperand(), Indices,
1378 auto *TargetTTI =
static_cast<const T *
>(
this);
1383 if (
const Function *
F = CB->getCalledFunction()) {
1384 if (!TargetTTI->isLoweredToCall(
F))
1393 Type *Ty = U->getType();
1399 case Instruction::Call: {
1403 return TargetTTI->getIntrinsicInstrCost(CostAttrs,
CostKind);
1405 case Instruction::Br:
1406 case Instruction::Ret:
1407 case Instruction::PHI:
1408 case Instruction::Switch:
1409 return TargetTTI->getCFInstrCost(Opcode,
CostKind,
I);
1410 case Instruction::Freeze:
1412 case Instruction::ExtractValue:
1413 case Instruction::InsertValue:
1414 return TargetTTI->getInsertExtractValueCost(Opcode,
CostKind);
1415 case Instruction::Alloca:
1419 case Instruction::GetElementPtr: {
1421 Type *AccessType =
nullptr;
1424 if (
GEP->hasOneUser() &&
I)
1425 AccessType =
I->user_back()->getAccessType();
1427 return TargetTTI->getGEPCost(
GEP->getSourceElementType(),
1431 case Instruction::Add:
1432 case Instruction::FAdd:
1433 case Instruction::Sub:
1434 case Instruction::FSub:
1435 case Instruction::Mul:
1436 case Instruction::FMul:
1437 case Instruction::UDiv:
1438 case Instruction::SDiv:
1439 case Instruction::FDiv:
1440 case Instruction::URem:
1441 case Instruction::SRem:
1442 case Instruction::FRem:
1443 case Instruction::Shl:
1444 case Instruction::LShr:
1445 case Instruction::AShr:
1446 case Instruction::And:
1447 case Instruction::Or:
1448 case Instruction::Xor:
1449 case Instruction::FNeg: {
1452 if (Opcode != Instruction::FNeg)
1454 return TargetTTI->getArithmeticInstrCost(Opcode, Ty,
CostKind, Op1Info,
1457 case Instruction::IntToPtr:
1458 case Instruction::PtrToAddr:
1459 case Instruction::PtrToInt:
1460 case Instruction::SIToFP:
1461 case Instruction::UIToFP:
1462 case Instruction::FPToUI:
1463 case Instruction::FPToSI:
1464 case Instruction::Trunc:
1465 case Instruction::FPTrunc:
1466 case Instruction::BitCast:
1467 case Instruction::FPExt:
1468 case Instruction::SExt:
1469 case Instruction::ZExt:
1470 case Instruction::AddrSpaceCast: {
1472 return TargetTTI->getCastInstrCost(
1475 case Instruction::Store: {
1479 return TargetTTI->getMemoryOpCost(Opcode, ValTy,
SI->getAlign(),
1483 case Instruction::Load: {
1488 Type *LoadType = U->getType();
1499 LoadType = TI->getDestTy();
1501 return TargetTTI->getMemoryOpCost(Opcode, LoadType, LI->getAlign(),
1503 {TTI::OK_AnyValue, TTI::OP_None},
I);
1505 case Instruction::Select: {
1506 const Value *Op0, *Op1;
1517 return TargetTTI->getArithmeticInstrCost(
1524 return TargetTTI->getCmpSelInstrCost(Opcode, U->getType(), CondTy,
1528 case Instruction::ICmp:
1529 case Instruction::FCmp: {
1534 return TargetTTI->getCmpSelInstrCost(Opcode, ValTy, U->getType(),
1539 case Instruction::InsertElement: {
1545 if (CI->getValue().getActiveBits() <= 32)
1546 Idx = CI->getZExtValue();
1547 return TargetTTI->getVectorInstrCost(*IE, Ty,
CostKind, Idx);
1549 case Instruction::ShuffleVector: {
1557 int NumSubElts, SubIndex;
1560 if (
all_of(Mask, [](
int M) {
return M < 0; }))
1564 if (Shuffle->changesLength()) {
1566 if (Shuffle->increasesLength() && Shuffle->isIdentityWithPadding())
1569 if (Shuffle->isExtractSubvectorMask(SubIndex))
1571 VecSrcTy, Mask,
CostKind, SubIndex,
1574 if (Shuffle->isInsertSubvectorMask(NumSubElts, SubIndex))
1575 return TargetTTI->getShuffleCost(
1581 int ReplicationFactor, VF;
1582 if (Shuffle->isReplicationMask(ReplicationFactor, VF)) {
1586 DemandedDstElts.
setBit(
I.index());
1588 return TargetTTI->getReplicationShuffleCost(
1589 VecSrcTy->getElementType(), ReplicationFactor, VF,
1594 NumSubElts = VecSrcTy->getElementCount().getKnownMinValue();
1600 if (Shuffle->increasesLength()) {
1601 for (
int &M : AdjustMask)
1602 M = M >= NumSubElts ? (M + (Mask.size() - NumSubElts)) : M;
1604 return TargetTTI->getShuffleCost(
1621 std::iota(ExtractMask.
begin(), ExtractMask.
end(), 0);
1622 return ShuffleCost + TargetTTI->getShuffleCost(
1624 ExtractMask,
CostKind, 0, VecTy, {}, Shuffle);
1627 if (Shuffle->isIdentity())
1630 if (Shuffle->isReverse())
1631 return TargetTTI->getShuffleCost(
TTI::SK_Reverse, VecTy, VecSrcTy, Mask,
1635 if (Shuffle->isTranspose())
1640 if (Shuffle->isZeroEltSplat())
1645 if (Shuffle->isSingleSource())
1647 VecSrcTy, Mask,
CostKind, 0,
nullptr,
1650 if (Shuffle->isInsertSubvectorMask(NumSubElts, SubIndex))
1651 return TargetTTI->getShuffleCost(
1656 if (Shuffle->isSelect())
1657 return TargetTTI->getShuffleCost(
TTI::SK_Select, VecTy, VecSrcTy, Mask,
1661 if (Shuffle->isSplice(SubIndex))
1662 return TargetTTI->getShuffleCost(
TTI::SK_Splice, VecTy, VecSrcTy, Mask,
1670 case Instruction::ExtractElement: {
1676 if (CI->getValue().getActiveBits() <= 32)
1677 Idx = CI->getZExtValue();
1679 return TargetTTI->getVectorInstrCost(*EEI, DstTy,
CostKind, Idx);
1688 auto *TargetTTI =
static_cast<const T *
>(
this);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
Analysis containing CSE Info
static cl::opt< OutputCostKind > CostKind("cost-kind", cl::desc("Target cost kind"), cl::init(OutputCostKind::RecipThroughput), cl::values(clEnumValN(OutputCostKind::RecipThroughput, "throughput", "Reciprocal throughput"), clEnumValN(OutputCostKind::Latency, "latency", "Instruction latency"), clEnumValN(OutputCostKind::CodeSize, "code-size", "Code size"), clEnumValN(OutputCostKind::SizeAndLatency, "size-latency", "Code size and latency"), clEnumValN(OutputCostKind::All, "all", "Print all cost kinds")))
static bool isSigned(unsigned int Opcode)
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
mir Rename Register Operands
uint64_t IntrinsicInst * II
OptimizedStructLayoutField Field
static cl::opt< RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode > Mode("regalloc-enable-advisor", cl::Hidden, cl::init(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default), cl::desc("Enable regalloc advisor mode"), cl::values(clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Default, "default", "Default"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Release, "release", "precompiled"), clEnumValN(RegAllocEvictionAdvisorAnalysisLegacy::AdvisorMode::Development, "development", "for training")))
static SymbolRef::Type getType(const Symbol *Sym)
Class for arbitrary precision integers.
void setBit(unsigned BitPosition)
Set the given bit to 1 whose position is given as "bitPosition".
unsigned getBitWidth() const
Return the number of bits in the APInt.
LLVM_ABI APInt sextOrTrunc(unsigned width) const
Sign extend or truncate to width.
static APInt getZero(unsigned numBits)
Get the '0' value for the specified bit-width.
int64_t getSExtValue() const
Get sign extended value.
an instruction to allocate memory on the stack
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Class to represent array types.
A cache of @llvm.assume calls within a function.
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
Conditional or Unconditional Branch instruction.
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
This is the shared class of boolean and integer constants.
uint64_t getZExtValue() const
Return the constant as a 64-bit unsigned integer value after it has been zero extended as appropriate...
const APInt & getValue() const
Return the constant as an APInt value reference.
This is an important base class in LLVM.
A parsed version of the target data layout string in and methods for querying it.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
static constexpr ElementCount get(ScalarTy MinVal, bool Scalable)
Convenience struct for specifying and reasoning about fast-math flags.
static LLVM_ABI FixedVectorType * get(Type *ElementType, unsigned NumElts)
The core instruction combiner logic.
static InstructionCost getInvalid(CostType Val=0)
Intrinsic::ID getID() const
A wrapper class for inspecting calls to intrinsic functions.
This is an important class for using LLVM in a threaded context.
An instruction for reading from memory.
Represents a single loop in the control flow graph.
unsigned getOpcode() const
Return the opcode for this Instruction or ConstantExpr.
Analysis providing profile information.
The RecurrenceDescriptor is used to identify recurrences variables in a loop.
This node represents a polynomial recurrence on the trip count of the specified loop.
const SCEV * getStepRecurrence(ScalarEvolution &SE) const
Constructs and returns the recurrence indicating how much this expression steps by.
This class represents a constant integer value.
const APInt & getAPInt() const
This class represents an analyzed expression in the program.
The main scalar evolution driver.
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...
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.
StackOffset holds a fixed and a scalable offset in bytes.
static StackOffset getScalable(int64_t Scalable)
static StackOffset getFixed(int64_t Fixed)
An instruction for storing to memory.
StringRef - Represent a constant reference to a string, i.e.
Class to represent struct types.
Provides information about what library functions are available for the current target.
This class represents a truncation of integer types.
static constexpr TypeSize getFixed(ScalarTy ExactSize)
The instances of the Type class are immutable: once they are created, they are never changed.
bool isVectorTy() const
True if this is an instance of VectorType.
LLVM_ABI bool isScalableTy(SmallPtrSetImpl< const Type * > &Visited) const
Return true if this is a type whose size is a known multiple of vscale.
LLVM_ABI unsigned getPointerAddressSpace() const
Get the address space of this pointer or pointer vector type.
static LLVM_ABI IntegerType * getInt8Ty(LLVMContext &C)
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 * getIntNTy(LLVMContext &C, unsigned N)
This is the common base class for vector predication intrinsics.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
Base class of all SIMD vector types.
constexpr ScalarTy getFixedValue() const
constexpr bool isScalable() const
Returns whether the quantity is scaled by a runtime quantity (vscale).
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ C
The default llvm calling convention, compatible with C.
This namespace contains an enum with a value for every intrinsic/builtin function known by LLVM.
class_match< Constant > m_Constant()
Match an arbitrary Constant and ignore it.
bool match(Val *V, const Pattern &P)
ThreeOps_match< Cond, LHS, RHS, Instruction::Select > m_Select(const Cond &C, const LHS &L, const RHS &R)
Matches SelectInst.
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
class_match< Value > m_Value()
Match an arbitrary value and ignore it.
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
match_combine_or< LTy, RTy > m_CombineOr(const LTy &L, const RTy &R)
Combine two pattern matchers matching L || R.
This is an optimization pass for GlobalISel generic memory operations.
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 enumerate(FirstRange &&First, RestRanges &&...Rest)
Given two or more input ranges, returns a new range whose values are tuples (A, B,...
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
FunctionAddr VTableAddr uintptr_t uintptr_t DataSize
LLVM_ABI Value * getSplatValue(const Value *V)
Get splat value if the input is a splat vector or return nullptr.
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
constexpr bool isPowerOf2_32(uint32_t Value)
Return true if the argument is a power of two > 0.
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
RecurKind
These are the kinds of recurrences that we support.
constexpr unsigned BitWidth
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
gep_type_iterator gep_type_begin(const User *GEP)
@ DataWithoutLaneMask
Same as Data, but avoids using the get.active.lane.mask intrinsic to calculate the mask and instead i...
This struct is a compact representation of a valid (non-zero power of two) alignment.
Attributes of a target dependent hardware loop.
Information about a load/store intrinsic defined by the target.