13#ifndef LLVM_LIB_TARGET_NVPTX_NVPTXUTILITIES_H
14#define LLVM_LIB_TARGET_NVPTX_NVPTXUTILITIES_H
77 return Ty->isAggregateType() || Ty->isVectorTy() ||
78 Ty->getScalarSizeInBits() >= 128 || Ty->isHalfTy() || Ty->isBFloatTy();
86 static const auto PackedTypes = {MVT::v4i8, MVT::v2f16, MVT::v2bf16,
87 MVT::v2i16, MVT::v2f32, MVT::v2i32};
103 std::string ValidName;
104 ValidName.reserve(Name.size() + 4);
109 ValidName.push_back(
C);
111 ValidName.append({
'_',
'$',
'_'});
127 return "AcquireRelease";
129 return "SequentiallyConsistent";
133 return "RelaxedMMIO";
157 return "DefaultDevice";
169 bool UseParamSubqualifiers =
false) {
180 return "shared::cluster";
182 return UseParamSubqualifiers ?
"param::entry" :
"param";
184 return UseParamSubqualifiers ?
"param::func" :
"param";
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
This file defines the SmallVector class.
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
A parsed version of the target data layout string in and methods for querying it.
Represent a constant reference to a string, i.e.
Primary interface to the complete machine description for the target machine.
The instances of the Type class are immutable: once they are created, they are never changed.
This class implements an extremely fast bulk output stream that can only output to a stream.
@ C
The default llvm calling convention, compatible with C.
const char * addressSpaceToString(AddressSpace A, bool UseParamSubqualifiers=false)
raw_ostream & operator<<(raw_ostream &O, Ordering Order)
unsigned int OrderingUnderlyingType
std::string ScopeToString(Scope S)
std::string OrderingToString(Ordering Order)
unsigned int ScopeUnderlyingType
bool isPackedVectorTy(EVT VT)
bool isPackedElementTy(EVT ET)
unsigned int AddressSpaceUnderlyingType
std::string getValidPTXIdentifier(StringRef Name)
This is an optimization pass for GlobalISel generic memory operations.
bool shouldEmitPTXNoReturn(const Value *V, const TargetMachine &TM)
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.
Align getPTXPromotedParamTypeAlign(const Function *F, Type *ArgTy, const DataLayout &DL)
Since function arguments are passed via .param space, we may want to increase their alignment in a wa...
constexpr auto equal_to(T &&Arg)
Functor variant of std::equal_to that can be used as a UnaryPredicate in functional algorithms like a...
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
auto formatv(bool Validate, const char *Fmt, Ts &&...Vals)
unsigned promoteScalarArgumentSize(unsigned size)
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
bool shouldPassAsArray(Type *Ty)
bool isAlnum(char C)
Checks whether character C is either a decimal digit or an uppercase or lowercase letter as classifie...
Align getPTXParamAlign(const Function *F, Type *Ty, unsigned AttrIdx, const DataLayout &DL)
Get the alignment for a function parameter or return value.
Align getDeviceByValParamAlign(const Function *F, Type *ArgTy, Align InitialAlign, const DataLayout &DL)
Function * getMaybeBitcastedCallee(const CallBase *CB)
This struct is a compact representation of a valid (non-zero power of two) alignment.
EVT getVectorElementType() const
Given a vector type, return the type of each element.