LLVM: llvm::TargetExtType Class Reference (original) (raw)
Class to represent target extensions types, which are generally unintrospectable from target-independent optimizations. More...
Public Member Functions
TargetExtType (const TargetExtType &)=delete
operator= (const TargetExtType &)=delete
Return the name for this target extension type.
type_params () const
Return the type parameters for this particular target extension type.
Type *
getTypeParameter (unsigned i) const
int_params () const
Return the integer parameters for this particular target extension type.
getIntParameter (unsigned i) const
hasProperty (Property Prop) const
Returns true if the target extension type contains the given property.
Type *
Returns an underlying layout type for the target extension type.
Public Member Functions inherited from llvm::Type
void
print (raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
Print the current type.
void
getContext () const
Return the LLVMContext in which this type was uniqued.
Return the type id for the type.
Return true if this is 'void'.
Return true if this is 'half', a 16-bit IEEE fp type.
isBFloatTy () const
Return true if this is 'bfloat', a 16-bit bfloat type.
is16bitFPTy () const
Return true if this is a 16-bit float type.
Return true if this is 'float', a 32-bit IEEE fp type.
isDoubleTy () const
Return true if this is 'double', a 64-bit IEEE fp type.
Return true if this is x86 long double.
Return true if this is 'fp128'.
Return true if this is powerpc long double.
Return true if this is a well-behaved IEEE-like type, which has a IEEE compatible layout as defined by APFloat::isIEEE(), and does not have non-IEEE values, such as x86_fp80's unnormal values.
Return true if this is one of the floating-point types.
Returns true if this is a floating-point type that is an unevaluated sum of multiple floating-point units.
isX86_AMXTy () const
Return true if this is X86 AMX.
Return true if this is a target extension type.
isScalableTargetExtTy () const
Return true if this is a target extension type with a scalable layout.
isScalableTy (SmallPtrSetImpl< const Type * > &Visited) const
Return true if this is a type whose size is a known multiple of vscale.
containsNonGlobalTargetExtType (SmallPtrSetImpl< const Type * > &Visited) const
Return true if this type is or contains a target extension type that disallows being used as a global.
containsNonGlobalTargetExtType () const
containsNonLocalTargetExtType (SmallPtrSetImpl< const Type * > &Visited) const
Return true if this type is or contains a target extension type that disallows being used as a local.
containsNonLocalTargetExtType () const
Return true if this is a FP type or a vector of FP.
Return true if this is 'label'.
Return true if this is 'metadata'.
Return true if this is 'token'.
isIntegerTy () const
True if this is an instance of IntegerType.
isIntegerTy (unsigned Bitwidth) const
Return true if this is an IntegerType of the given width.
Return true if this is an integer type or a vector of integer types.
isIntOrIntVectorTy (unsigned BitWidth) const
Return true if this is an integer type or a vector of integer types of the given width.
Return true if this is an integer type or a pointer type.
True if this is an instance of FunctionType.
isStructTy () const
True if this is an instance of StructType.
True if this is an instance of ArrayType.
isPointerTy () const
True if this is an instance of PointerType.
Return true if this is a pointer type or a vector of pointer types.
isVectorTy () const
True if this is an instance of VectorType.
canLosslesslyBitCastTo (Type *Ty) const
Return true if this type could be converted with a lossless BitCast to type 'Ty'.
Return true if this type is empty, that is, it has no elements or all of its elements are empty.
Return true if the type is "first class", meaning it is a valid type for a Value.
Return true if the type is a valid type for a register in codegen.
Return true if the type is an aggregate type.
isSized (SmallPtrSetImpl< Type * > *Visited=nullptr) const
Return true if it makes sense to take the size of this type.
getPrimitiveSizeInBits () const LLVM_READONLY
Return the basic size of this type if it is a primitive type.
getScalarSizeInBits () const LLVM_READONLY
If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
int
Return the width of the mantissa of this type.
Return whether the type is IEEE compatible, as defined by the eponymous method in APFloat.
Type *
If this is a vector type, return the element type, otherwise return 'this'.
subtype_end () const
Type *
getContainedType (unsigned i) const
This method is used to implement the type iterator (defined at the end of the file).
Return the number of types in the derived type.
Type *
getFunctionParamType (unsigned i) const
Type *
getStructElementType (unsigned N) const
Type *
Type *
getWithNewType (Type *EltTy) const
Given vector type, change the element type, whilst keeping the old number of elements.
Type *
getWithNewBitWidth (unsigned NewBitWidth) const
Given an integer or vector type, change the lane bitwidth to NewBitwidth, whilst keeping the old number of lanes.
Type *
Given scalar/vector integer type, returns a type with elements twice as wide as in the original type.
getPointerAddressSpace () const
Get the address space of this pointer or pointer vector type.
getPointerTo (unsigned AddrSpace=0) const
Return a pointer to the current type.
Static Public Member Functions
static TargetExtType *
get (LLVMContext &Context, StringRef Name, ArrayRef< Type * > Types={}, ArrayRef< unsigned > Ints={})
Return a target extension type having the specified name and optional type and integer parameters.
static Expected< TargetExtType * >
getOrError (LLVMContext &Context, StringRef Name, ArrayRef< Type * > Types={}, ArrayRef< unsigned > Ints={})
Return a target extension type having the specified name and optional type and integer parameters, or an appropriate Error if it fails the parameters check.
static Expected< TargetExtType * >
checkParams (TargetExtType *TTy)
Check that a newly created target extension type has the expected number of type parameters and integer parameters, returning the type itself if OK or an appropriate Error if not.
static bool
Methods for support type inquiry through isa, cast, and dyn_cast.
Static Public Member Functions inherited from llvm::Type
static Type *
getPrimitiveType (LLVMContext &C, TypeID IDNumber)
Return a type based on an identifier.
static Type *
static Type *
static Type *
static Type *
static Type *
static Type *
static Type *
getMetadataTy (LLVMContext &C)
static Type *
getX86_FP80Ty (LLVMContext &C)
static Type *
static Type *
getPPC_FP128Ty (LLVMContext &C)
static Type *
static Type *
static IntegerType *
getIntNTy (LLVMContext &C, unsigned N)
static IntegerType *
static IntegerType *
static IntegerType *
static IntegerType *
static IntegerType *
static IntegerType *
template
static Type *
static Type *
getFloatingPointTy (LLVMContext &C, const fltSemantics &S)
static Type *
getWasm_ExternrefTy (LLVMContext &C)
static Type *
getWasm_FuncrefTy (LLVMContext &C)
Class to represent target extensions types, which are generally unintrospectable from target-independent optimizations.
Target extension types have a string name, and optionally have type and/or integer parameters. The exact meaning of any parameters is dependent on the target.
Definition at line 744 of file DerivedTypes.h.