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

TargetExtType &

operator= (const TargetExtType &)=delete

StringRef

getName () const

Return the name for this target extension type.

ArrayRef< Type * >

type_params () const

Return the type parameters for this particular target extension type.

type_param_iterator

type_param_begin () const

type_param_iterator

type_param_end () const

Type *

getTypeParameter (unsigned i) const

unsigned

getNumTypeParameters () const

ArrayRef< unsigned >

int_params () const

Return the integer parameters for this particular target extension type.

unsigned

getIntParameter (unsigned i) const

unsigned

getNumIntParameters () const

bool

hasProperty (Property Prop) const

Returns true if the target extension type contains the given property.

Type *

getLayoutType () const

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

dump () const

LLVMContext &

getContext () const

Return the LLVMContext in which this type was uniqued.

TypeID

getTypeID () const

Return the type id for the type.

bool

isVoidTy () const

Return true if this is 'void'.

bool

isHalfTy () const

Return true if this is 'half', a 16-bit IEEE fp type.

bool

isBFloatTy () const

Return true if this is 'bfloat', a 16-bit bfloat type.

bool

is16bitFPTy () const

Return true if this is a 16-bit float type.

bool

isFloatTy () const

Return true if this is 'float', a 32-bit IEEE fp type.

bool

isDoubleTy () const

Return true if this is 'double', a 64-bit IEEE fp type.

bool

isX86_FP80Ty () const

Return true if this is x86 long double.

bool

isFP128Ty () const

Return true if this is 'fp128'.

bool

isPPC_FP128Ty () const

Return true if this is powerpc long double.

bool

isIEEELikeFPTy () const

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.

bool

isFloatingPointTy () const

Return true if this is one of the floating-point types.

bool

isMultiUnitFPType () const

Returns true if this is a floating-point type that is an unevaluated sum of multiple floating-point units.

const fltSemantics &

getFltSemantics () const

bool

isX86_AMXTy () const

Return true if this is X86 AMX.

bool

isTargetExtTy () const

Return true if this is a target extension type.

bool

isScalableTargetExtTy () const

Return true if this is a target extension type with a scalable layout.

bool

isScalableTy (SmallPtrSetImpl< const Type * > &Visited) const

Return true if this is a type whose size is a known multiple of vscale.

bool

isScalableTy () const

bool

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.

bool

containsNonGlobalTargetExtType () const

bool

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.

bool

containsNonLocalTargetExtType () const

bool

isFPOrFPVectorTy () const

Return true if this is a FP type or a vector of FP.

bool

isLabelTy () const

Return true if this is 'label'.

bool

isMetadataTy () const

Return true if this is 'metadata'.

bool

isTokenTy () const

Return true if this is 'token'.

bool

isIntegerTy () const

True if this is an instance of IntegerType.

bool

isIntegerTy (unsigned Bitwidth) const

Return true if this is an IntegerType of the given width.

bool

isIntOrIntVectorTy () const

Return true if this is an integer type or a vector of integer types.

bool

isIntOrIntVectorTy (unsigned BitWidth) const

Return true if this is an integer type or a vector of integer types of the given width.

bool

isIntOrPtrTy () const

Return true if this is an integer type or a pointer type.

bool

isFunctionTy () const

True if this is an instance of FunctionType.

bool

isStructTy () const

True if this is an instance of StructType.

bool

isArrayTy () const

True if this is an instance of ArrayType.

bool

isPointerTy () const

True if this is an instance of PointerType.

bool

isPtrOrPtrVectorTy () const

Return true if this is a pointer type or a vector of pointer types.

bool

isVectorTy () const

True if this is an instance of VectorType.

bool

isRISCVVectorTupleTy () const

bool

canLosslesslyBitCastTo (Type *Ty) const

Return true if this type could be converted with a lossless BitCast to type 'Ty'.

bool

isEmptyTy () const

Return true if this type is empty, that is, it has no elements or all of its elements are empty.

bool

isFirstClassType () const

Return true if the type is "first class", meaning it is a valid type for a Value.

bool

isSingleValueType () const

Return true if the type is a valid type for a register in codegen.

bool

isAggregateType () const

Return true if the type is an aggregate type.

bool

isSized (SmallPtrSetImpl< Type * > *Visited=nullptr) const

Return true if it makes sense to take the size of this type.

TypeSize

getPrimitiveSizeInBits () const LLVM_READONLY

Return the basic size of this type if it is a primitive type.

unsigned

getScalarSizeInBits () const LLVM_READONLY

If this is a vector type, return the getPrimitiveSizeInBits value for the element type.

int

getFPMantissaWidth () const

Return the width of the mantissa of this type.

bool

isIEEE () const

Return whether the type is IEEE compatible, as defined by the eponymous method in APFloat.

Type *

getScalarType () const

If this is a vector type, return the element type, otherwise return 'this'.

subtype_iterator

subtype_begin () const

subtype_iterator

subtype_end () const

ArrayRef< Type * >

subtypes () const

subtype_reverse_iterator

subtype_rbegin () const

subtype_reverse_iterator

subtype_rend () const

Type *

getContainedType (unsigned i) const

This method is used to implement the type iterator (defined at the end of the file).

unsigned

getNumContainedTypes () const

Return the number of types in the derived type.

unsigned

getIntegerBitWidth () const

Type *

getFunctionParamType (unsigned i) const

unsigned

getFunctionNumParams () const

bool

isFunctionVarArg () const

StringRef

getStructName () const

unsigned

getStructNumElements () const

Type *

getStructElementType (unsigned N) const

uint64_t

getArrayNumElements () const

Type *

getArrayElementType () const

StringRef

getTargetExtName () const

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 *

getExtendedType () const

Given scalar/vector integer type, returns a type with elements twice as wide as in the original type.

unsigned

getPointerAddressSpace () const

Get the address space of this pointer or pointer vector type.

PointerType *

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

classof (const Type *T)

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 *

getVoidTy (LLVMContext &C)

static Type *

getLabelTy (LLVMContext &C)

static Type *

getHalfTy (LLVMContext &C)

static Type *

getBFloatTy (LLVMContext &C)

static Type *

getFloatTy (LLVMContext &C)

static Type *

getDoubleTy (LLVMContext &C)

static Type *

getMetadataTy (LLVMContext &C)

static Type *

getX86_FP80Ty (LLVMContext &C)

static Type *

getFP128Ty (LLVMContext &C)

static Type *

getPPC_FP128Ty (LLVMContext &C)

static Type *

getX86_AMXTy (LLVMContext &C)

static Type *

getTokenTy (LLVMContext &C)

static IntegerType *

getIntNTy (LLVMContext &C, unsigned N)

static IntegerType *

getInt1Ty (LLVMContext &C)

static IntegerType *

getInt8Ty (LLVMContext &C)

static IntegerType *

getInt16Ty (LLVMContext &C)

static IntegerType *

getInt32Ty (LLVMContext &C)

static IntegerType *

getInt64Ty (LLVMContext &C)

static IntegerType *

getInt128Ty (LLVMContext &C)

template

static Type *

getScalarTy (LLVMContext &C)

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.