LLVM 20.0.0git
Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
llvm::VectorType Class Reference

Base class of all SIMD vector types. More...

#include "llvm/IR/DerivedTypes.h"

Inheritance diagram for llvm::VectorType:
Inheritance graph
[legend]

Public Member Functions

 VectorType (const VectorType &)=delete
 
VectorTypeoperator= (const VectorType &)=delete
 
TypegetElementType () const
 
ElementCount getElementCount () const
 Return an ElementCount instance to represent the (possibly scalable) number of elements in the vector.
 
- 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
 
LLVMContextgetContext () 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 fltSemanticsgetFltSemantics () 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 () const
 Return true if this is a type whose size is a known multiple of vscale.
 
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 isOpaquePointerTy () const
 True if this is an instance of an opaque 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 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.
 
TypegetScalarType () 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
 
TypegetContainedType (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
 
TypegetFunctionParamType (unsigned i) const
 
unsigned getFunctionNumParams () const
 
bool isFunctionVarArg () const
 
StringRef getStructName () const
 
unsigned getStructNumElements () const
 
TypegetStructElementType (unsigned N) const
 
uint64_t getArrayNumElements () const
 
TypegetArrayElementType () const
 
StringRef getTargetExtName () const
 
TypegetNonOpaquePointerElementType () const
 Only use this method in code that is not reachable with opaque pointers, or part of deprecated methods that will be removed as part of the opaque pointers transition.
 
TypegetWithNewType (Type *EltTy) const
 Given vector type, change the element type, whilst keeping the old number of elements.
 
TypegetWithNewBitWidth (unsigned NewBitWidth) const
 Given an integer or vector type, change the lane bitwidth to NewBitwidth, whilst keeping the old number of lanes.
 
TypegetExtendedType () 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.
 
PointerTypegetPointerTo (unsigned AddrSpace=0) const
 Return a pointer to the current type.
 

Static Public Member Functions

static VectorTypeget (Type *ElementType, ElementCount EC)
 This static method is the primary way to construct an VectorType.
 
static VectorTypeget (Type *ElementType, unsigned NumElements, bool Scalable)
 
static VectorTypeget (Type *ElementType, const VectorType *Other)
 
static VectorTypegetInteger (VectorType *VTy)
 This static method gets a VectorType with the same number of elements as the input type, and the element type is an integer type of the same width as the input element type.
 
static VectorTypegetExtendedElementVectorType (VectorType *VTy)
 This static method is like getInteger except that the element types are twice as wide as the elements in the input type.
 
static VectorTypegetTruncatedElementVectorType (VectorType *VTy)
 
static VectorTypegetSubdividedVectorType (VectorType *VTy, int NumSubdivs)
 
static VectorTypegetHalfElementsVectorType (VectorType *VTy)
 This static method returns a VectorType with half as many elements as the input type and the same element type.
 
static VectorTypegetDoubleElementsVectorType (VectorType *VTy)
 This static method returns a VectorType with twice as many elements as the input type and the same element type.
 
static bool isValidElementType (Type *ElemTy)
 Return true if the specified type is valid as a element type.
 
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 TypegetPrimitiveType (LLVMContext &C, TypeID IDNumber)
 Return a type based on an identifier.
 
static TypegetVoidTy (LLVMContext &C)
 
static TypegetLabelTy (LLVMContext &C)
 
static TypegetHalfTy (LLVMContext &C)
 
static TypegetBFloatTy (LLVMContext &C)
 
static TypegetFloatTy (LLVMContext &C)
 
static TypegetDoubleTy (LLVMContext &C)
 
static TypegetMetadataTy (LLVMContext &C)
 
static TypegetX86_FP80Ty (LLVMContext &C)
 
static TypegetFP128Ty (LLVMContext &C)
 
static TypegetPPC_FP128Ty (LLVMContext &C)
 
static TypegetX86_AMXTy (LLVMContext &C)
 
static TypegetTokenTy (LLVMContext &C)
 
static IntegerTypegetIntNTy (LLVMContext &C, unsigned N)
 
static IntegerTypegetInt1Ty (LLVMContext &C)
 
static IntegerTypegetInt8Ty (LLVMContext &C)
 
static IntegerTypegetInt16Ty (LLVMContext &C)
 
static IntegerTypegetInt32Ty (LLVMContext &C)
 
static IntegerTypegetInt64Ty (LLVMContext &C)
 
static IntegerTypegetInt128Ty (LLVMContext &C)
 
template<typename ScalarTy >
static TypegetScalarTy (LLVMContext &C)
 
static TypegetFloatingPointTy (LLVMContext &C, const fltSemantics &S)
 
static TypegetWasm_ExternrefTy (LLVMContext &C)
 
static TypegetWasm_FuncrefTy (LLVMContext &C)
 

Protected Member Functions

 VectorType (Type *ElType, unsigned EQ, Type::TypeID TID)
 
- Protected Member Functions inherited from llvm::Type
 Type (LLVMContext &C, TypeID tid)
 
 ~Type ()=default
 
unsigned getSubclassData () const
 
void setSubclassData (unsigned val)
 

Protected Attributes

const unsigned ElementQuantity
 The element quantity of this vector.
 
- Protected Attributes inherited from llvm::Type
unsigned NumContainedTys = 0
 Keeps track of how many Type*'s there are in the ContainedTys list.
 
Type *constContainedTys = nullptr
 A pointer to the array of Types contained by this Type.
 

Additional Inherited Members

- Public Types inherited from llvm::Type
enum  TypeID {
  HalfTyID = 0 , BFloatTyID , FloatTyID , DoubleTyID ,
  X86_FP80TyID , FP128TyID , PPC_FP128TyID , VoidTyID ,
  LabelTyID , MetadataTyID , X86_AMXTyID , TokenTyID ,
  IntegerTyID , FunctionTyID , PointerTyID , StructTyID ,
  ArrayTyID , FixedVectorTyID , ScalableVectorTyID , TypedPointerTyID ,
  TargetExtTyID
}
 Definitions of all of the base types for the Type system. More...
 
using subtype_iterator = Type *const *
 
using subtype_reverse_iterator = std::reverse_iterator< subtype_iterator >
 

Detailed Description

Base class of all SIMD vector types.

Definition at line 403 of file DerivedTypes.h.

Constructor & Destructor Documentation

◆ VectorType() [1/2]

VectorType::VectorType ( Type ElType,
unsigned  EQ,
Type::TypeID  TID 
)
protected

Definition at line 657 of file Type.cpp.

References llvm::Type::ContainedTys, and llvm::Type::NumContainedTys.

◆ VectorType() [2/2]

llvm::VectorType::VectorType ( const VectorType )
delete

Member Function Documentation

◆ classof()

static bool llvm::VectorType::classof ( const Type T)
inlinestatic

Methods for support type inquiry through isa, cast, and dyn_cast.

Definition at line 532 of file DerivedTypes.h.

References llvm::Type::FixedVectorTyID, and llvm::Type::ScalableVectorTyID.

◆ get() [1/3]

static VectorType * llvm::VectorType::get ( Type ElementType,
const VectorType Other 
)
inlinestatic

Definition at line 447 of file DerivedTypes.h.

References get(), and llvm::Other.

◆ get() [2/3]

VectorType * VectorType::get ( Type ElementType,
ElementCount  EC 
)
static

This static method is the primary way to construct an VectorType.

Definition at line 664 of file Type.cpp.

References llvm::ScalableVectorType::get(), and llvm::FixedVectorType::get().

Referenced by llvm::applyWrappers(), buildNew(), llvm::LoopVectorizationCostModel::calculateRegisterUsage(), canonicalizeBitCastExtElt(), llvm::ShuffleVectorInst::convertShuffleMaskForBitcode(), createBitOrPointerCast(), llvm::IRBuilderBase::CreateStepVector(), llvm::IRBuilderBase::CreateVectorSplat(), DecodeFixedType(), llvm::InstCombinerImpl::EvaluateInDifferentType(), llvm::VPWidenRecipe::execute(), llvm::VPWidenCastRecipe::execute(), llvm::VPWidenCallRecipe::execute(), llvm::VPWidenPointerInductionRecipe::execute(), llvm::VPFirstOrderRecurrencePHIRecipe::execute(), llvm::VPReductionPHIRecipe::execute(), llvm::VPInterleaveRecipe::execute(), llvm::VPReplicateRecipe::execute(), llvm::VPWidenLoadRecipe::execute(), llvm::VPWidenLoadEVLRecipe::execute(), llvm::VPScalarIVStepsRecipe::execute(), llvm::InstCombinerImpl::foldICmpBitCast(), llvm::InstSimplifyFolder::FoldShuffleVector(), get(), llvm::VPTransformState::get(), llvm::IRBuilderBase::getAllOnesMask(), getDoubleElementsVectorType(), getExtendedElementVectorType(), llvm::BasicTTIImplBase< T >::getExtendedReductionCost(), llvm::GetElementPtrInst::getGEPReturnType(), getHalfElementsVectorType(), llvm::DataLayout::getIndexType(), llvm::LoopVectorizationCostModel::getInstructionCost(), getInteger(), llvm::AMDGPU::getInterestingMemoryOperands(), llvm::AArch64TTIImpl::getInterleavedMemoryOpCost(), llvm::RISCVTTIImpl::getInterleavedMemoryOpCost(), llvm::DataLayout::getIntPtrType(), llvm::BasicTTIImplBase< T >::getIntrinsicInstrCost(), llvm::AArch64TTIImpl::getIntrinsicInstrCost(), llvm::RISCVTTIImpl::getIntrinsicInstrCost(), llvm::BasicTTIImplBase< T >::getMulAccReductionCost(), llvm::ConstantDataVector::getRaw(), getReducedType(), llvm::LoopVectorizationCostModel::getReductionPatternCost(), llvm::AArch64TTIImpl::getShuffleCost(), llvm::RISCVTTIImpl::getShuffleCost(), llvm::ConstantExpr::getShuffleVector(), llvm::ConstantVector::getSplat(), getStepVector(), getTruncatedElementVectorType(), llvm::RISCVTTIImpl::getVectorInstrCost(), instCombineSVECondLast(), llvm::LoopVectorizationCostModel::isLegalGatherOrScatter(), llvm::LoopVectorizationCostModel::isScalarWithPredication(), llvm::AArch64TargetLowering::lowerDeinterleaveIntrinsicToLoad(), llvm::AArch64TargetLowering::lowerInterleavedLoad(), llvm::AArch64TargetLowering::lowerInterleavedStore(), llvm::AArch64TargetLowering::lowerInterleaveIntrinsicToStore(), llvm::CmpInst::makeCmpResultType(), llvm::fuzzerop::matchFirstLengthWAnyType(), MaybeVectorizeType(), llvm::SPIRV::parseBuiltinCallArgumentBaseType(), llvm::LoopVectorizationCostModel::setVectorizedCallDecision(), llvm::ToVectorTy(), llvm::InstCombinerImpl::visitFCmpInst(), llvm::InstCombinerImpl::visitGetElementPtrInst(), llvm::InstCombinerImpl::visitInsertElementInst(), and llvm::InstCombinerImpl::visitTrunc().

◆ get() [3/3]

static VectorType * llvm::VectorType::get ( Type ElementType,
unsigned  NumElements,
bool  Scalable 
)
inlinestatic

Definition at line 441 of file DerivedTypes.h.

References llvm::ElementCount::get(), and get().

◆ getDoubleElementsVectorType()

static VectorType * llvm::VectorType::getDoubleElementsVectorType ( VectorType VTy)
inlinestatic

This static method returns a VectorType with twice as many elements as the input type and the same element type.

Definition at line 517 of file DerivedTypes.h.

References assert(), get(), getElementCount(), and getElementType().

Referenced by llvm::FixedVectorType::getDoubleElementsVectorType(), llvm::ScalableVectorType::getDoubleElementsVectorType(), llvm::X86TTIImpl::getShuffleCost(), getSubdividedVectorType(), and interleaveVectors().

◆ getElementCount()

ElementCount VectorType::getElementCount ( ) const
inline

◆ getElementType()

Type * llvm::VectorType::getElementType ( ) const
inline

Definition at line 436 of file DerivedTypes.h.

Referenced by CheckAndCreateOffsetAdd(), llvm::ConstantFoldCastInstruction(), llvm::AArch64TargetLowering::createComplexDeinterleavingIR(), createTblShuffleForSExt(), createTblShuffleForZExt(), emitGlobalConstantVector(), llvm::VPReductionRecipe::execute(), llvm::findScalarElement(), foldConstantInsEltIntoShuffle(), foldSelectShuffleWith1Binop(), llvm::Constant::getAllOnesValue(), llvm::AArch64TTIImpl::getArithmeticReductionCost(), llvm::RISCVTTIImpl::getArithmeticReductionCost(), llvm::ARMTTIImpl::getArithmeticReductionCost(), getDoubleElementsVectorType(), llvm::EVT::getEVT(), getExtendedElementVectorType(), llvm::BasicTTIImplBase< T >::getExtractWithExtendCost(), llvm::AArch64TTIImpl::getExtractWithExtendCost(), getHalfElementsVectorType(), getInteger(), llvm::X86TTIImpl::getInterleavedMemoryOpCostAVX512(), llvm::HexagonTTIImpl::getMemoryOpCost(), llvm::BasicTTIImplBase< T >::getMinMaxReductionCost(), llvm::ARMTTIImpl::getMinMaxReductionCost(), llvm::RISCVTTIImpl::getMinMaxReductionCost(), llvm::AArch64TargetLowering::getNumInterleavedAccesses(), llvm::SPIRVGlobalRegistry::getOrCreateConsIntVector(), llvm::SPIRVGlobalRegistry::getOrCreateConstVector(), llvm::BasicTTIImplBase< T >::getOrderedReductionCost(), llvm::AArch64TTIImpl::getScalarizationOverhead(), llvm::X86TTIImpl::getScalarizationOverhead(), llvm::AArch64TTIImpl::getShuffleCost(), llvm::GCNTTIImpl::getShuffleCost(), llvm::RISCVTTIImpl::getShuffleCost(), llvm::X86TTIImpl::getShuffleCost(), getSVEContainerIRType(), llvm::BasicTTIImplBase< T >::getTreeReductionCost(), getTruncatedElementVectorType(), llvm::DataLayout::getTypeSizeInBits(), llvm::SelectionDAGBuilder::getValueImpl(), llvm::MVT::getVT(), llvm::BasicTTIImplBase< T >::improveShuffleKindFromMask(), isBFloat2(), isHalf2(), llvm::ARMTargetLowering::isLegalInterleavedAccessType(), llvm::AArch64TargetLowering::isLegalInterleavedAccessType(), isSupportedAccessType(), llvm::AArch64TargetLowering::lowerDeinterleaveIntrinsicToLoad(), lowerFunnelShifts(), llvm::AArch64TargetLowering::lowerInterleavedLoad(), llvm::ARMTargetLowering::lowerInterleavedLoad(), llvm::AArch64TargetLowering::lowerInterleaveIntrinsicToStore(), matchIntrinsicType(), promoteAllocaUserToVector(), llvm::X86TargetLowering::shouldSinkOperands(), llvm::Interpreter::visitInsertElementInst(), and llvm::Interpreter::visitShuffleVectorInst().

◆ getExtendedElementVectorType()

static VectorType * llvm::VectorType::getExtendedElementVectorType ( VectorType VTy)
inlinestatic

This static method is like getInteger except that the element types are twice as wide as the elements in the input type.

Definition at line 463 of file DerivedTypes.h.

References assert(), get(), getElementCount(), getElementType(), and llvm::Type::isIntOrIntVectorTy().

Referenced by DecodeFixedType(), llvm::X86TTIImpl::getArithmeticInstrCost(), llvm::FixedVectorType::getExtendedElementVectorType(), llvm::ScalableVectorType::getExtendedElementVectorType(), and matchIntrinsicType().

◆ getHalfElementsVectorType()

static VectorType * llvm::VectorType::getHalfElementsVectorType ( VectorType VTy)
inlinestatic

◆ getInteger()

static VectorType * llvm::VectorType::getInteger ( VectorType VTy)
inlinestatic

This static method gets a VectorType with the same number of elements as the input type, and the element type is an integer type of the same width as the input element type.

Definition at line 454 of file DerivedTypes.h.

References assert(), llvm::IntegerType::get(), get(), llvm::Type::getContext(), getElementCount(), getElementType(), and llvm::Type::getPrimitiveSizeInBits().

Referenced by DecodeFixedType(), llvm::FixedVectorType::getInteger(), llvm::ScalableVectorType::getInteger(), llvm::Constant::isElementWiseEqual(), matchIntrinsicType(), and llvm::AArch64TargetLowering::optimizeExtendOrTruncateConversion().

◆ getSubdividedVectorType()

static VectorType * llvm::VectorType::getSubdividedVectorType ( VectorType VTy,
int  NumSubdivs 
)
inlinestatic

◆ getTruncatedElementVectorType()

static VectorType * llvm::VectorType::getTruncatedElementVectorType ( VectorType VTy)
inlinestatic

◆ isValidElementType()

bool VectorType::isValidElementType ( Type ElemTy)
static

◆ operator=()

VectorType & llvm::VectorType::operator= ( const VectorType )
delete

Member Data Documentation

◆ ElementQuantity

const unsigned llvm::VectorType::ElementQuantity
protected

The element quantity of this vector.

The meaning of this value depends on the type of vector:

  • For FixedVectorType = <ElementQuantity x ty>, there are exactly ElementQuantity elements in this vector.
  • For ScalableVectorType = <vscale x ElementQuantity x ty>, there are vscale * ElementQuantity elements in this vector, where vscale is a runtime-constant integer greater than 0.

Definition at line 428 of file DerivedTypes.h.

Referenced by getElementCount(), llvm::ScalableVectorType::getMinNumElements(), and llvm::FixedVectorType::getNumElements().


The documentation for this class was generated from the following files: