|
LLVM
3.7.0
|
StructType - Class to represent struct types. More...
#include <DerivedTypes.h>
Public Types | |
| typedef Type::subtype_iterator | element_iterator |
Public Types inherited from llvm::Type | |
| enum | TypeID { VoidTyID = 0, HalfTyID, FloatTyID, DoubleTyID, X86_FP80TyID, FP128TyID, PPC_FP128TyID, LabelTyID, MetadataTyID, X86_MMXTyID, IntegerTyID, FunctionTyID, StructTyID, ArrayTyID, PointerTyID, VectorTyID } |
| Definitions of all of the base types for the Type system. More... | |
| typedef Type *const * | subtype_iterator |
| typedef std::reverse_iterator < subtype_iterator > | subtype_reverse_iterator |
Public Member Functions | |
| bool | isPacked () const |
| bool | isLiteral () const |
| isLiteral - Return true if this type is uniqued by structural equivalence, false if it is a struct definition. More... | |
| bool | isOpaque () const |
| isOpaque - Return true if this is a type with an identity that has no body specified yet. More... | |
| bool | isSized (SmallPtrSetImpl< const Type * > *Visited=nullptr) const |
| isSized - Return true if this is a sized type. More... | |
| bool | hasName () const |
| hasName - Return true if this is a named struct that has a non-empty name. More... | |
| StringRef | getName () const |
| getName - Return the name for this struct type if it has an identity. More... | |
| void | setName (StringRef Name) |
| setName - Change the name of this type to the specified name, or to a name with a suffix if there is a collision. More... | |
| void | setBody (ArrayRef< Type * > Elements, bool isPacked=false) |
| setBody - Specify a body for an opaque identified type. More... | |
| void | setBody (Type *elt1,...) LLVM_END_WITH_NULL |
| element_iterator | element_begin () const |
| element_iterator | element_end () const |
| ArrayRef< Type * > const | elements () const |
| bool | isLayoutIdentical (StructType *Other) const |
| isLayoutIdentical - Return true if this is layout identical to the specified struct. More... | |
| unsigned | getNumElements () const |
| Random access to the elements. More... | |
| Type * | getElementType (unsigned N) const |
Public Member Functions inherited from llvm::CompositeType | |
| Type * | getTypeAtIndex (const Value *V) |
| getTypeAtIndex - Given an index value into the type, return the type of the element. More... | |
| Type * | getTypeAtIndex (unsigned Idx) |
| bool | indexValid (const Value *V) const |
| bool | indexValid (unsigned Idx) const |
Public Member Functions inherited from llvm::Type | |
| void | print (raw_ostream &O) const |
| void | dump () const |
| LLVMContext & | getContext () const |
| getContext - Return the LLVMContext in which this type was uniqued. More... | |
| TypeID | getTypeID () const |
| getTypeID - Return the type id for the type. More... | |
| bool | isVoidTy () const |
| isVoidTy - Return true if this is 'void'. More... | |
| bool | isHalfTy () const |
| isHalfTy - Return true if this is 'half', a 16-bit IEEE fp type. More... | |
| bool | isFloatTy () const |
| isFloatTy - Return true if this is 'float', a 32-bit IEEE fp type. More... | |
| bool | isDoubleTy () const |
| isDoubleTy - Return true if this is 'double', a 64-bit IEEE fp type. More... | |
| bool | isX86_FP80Ty () const |
| isX86_FP80Ty - Return true if this is x86 long double. More... | |
| bool | isFP128Ty () const |
| isFP128Ty - Return true if this is 'fp128'. More... | |
| bool | isPPC_FP128Ty () const |
| isPPC_FP128Ty - Return true if this is powerpc long double. More... | |
| bool | isFloatingPointTy () const |
| isFloatingPointTy - Return true if this is one of the six floating point types More... | |
| const fltSemantics & | getFltSemantics () const |
| bool | isX86_MMXTy () const |
| isX86_MMXTy - Return true if this is X86 MMX. More... | |
| bool | isFPOrFPVectorTy () const |
| isFPOrFPVectorTy - Return true if this is a FP type or a vector of FP. More... | |
| bool | isLabelTy () const |
| isLabelTy - Return true if this is 'label'. More... | |
| bool | isMetadataTy () const |
| isMetadataTy - Return true if this is 'metadata'. More... | |
| bool | isIntegerTy () const |
| isIntegerTy - True if this is an instance of IntegerType. More... | |
| bool | isIntegerTy (unsigned Bitwidth) const |
| isIntegerTy - Return true if this is an IntegerType of the given width. More... | |
| bool | isIntOrIntVectorTy () const |
| isIntOrIntVectorTy - Return true if this is an integer type or a vector of integer types. More... | |
| bool | isFunctionTy () const |
| isFunctionTy - True if this is an instance of FunctionType. More... | |
| bool | isStructTy () const |
| isStructTy - True if this is an instance of StructType. More... | |
| bool | isArrayTy () const |
| isArrayTy - True if this is an instance of ArrayType. More... | |
| bool | isPointerTy () const |
| isPointerTy - True if this is an instance of PointerType. More... | |
| bool | isPtrOrPtrVectorTy () const |
| isPtrOrPtrVectorTy - Return true if this is a pointer type or a vector of pointer types. More... | |
| bool | isVectorTy () const |
| isVectorTy - True if this is an instance of VectorType. More... | |
| bool | canLosslesslyBitCastTo (Type *Ty) const |
| canLosslesslyBitCastTo - Return true if this type could be converted with a lossless BitCast to type 'Ty'. More... | |
| bool | isEmptyTy () const |
| isEmptyTy - Return true if this type is empty, that is, it has no elements or all its elements are empty. More... | |
| bool | isFirstClassType () const |
| isFirstClassType - Return true if the type is "first class", meaning it is a valid type for a Value. More... | |
| bool | isSingleValueType () const |
| isSingleValueType - Return true if the type is a valid type for a register in codegen. More... | |
| bool | isAggregateType () const |
| isAggregateType - Return true if the type is an aggregate type. More... | |
| bool | isSized (SmallPtrSetImpl< const Type * > *Visited=nullptr) const |
| isSized - Return true if it makes sense to take the size of this type. More... | |
| unsigned | getPrimitiveSizeInBits () const LLVM_READONLY |
| getPrimitiveSizeInBits - Return the basic size of this type if it is a primitive type. More... | |
| unsigned | getScalarSizeInBits () const LLVM_READONLY |
| getScalarSizeInBits - If this is a vector type, return the getPrimitiveSizeInBits value for the element type. More... | |
| int | getFPMantissaWidth () const |
| getFPMantissaWidth - Return the width of the mantissa of this type. More... | |
| const Type * | getScalarType () const LLVM_READONLY |
| getScalarType - If this is a vector type, return the element type, otherwise return 'this'. More... | |
| Type * | getScalarType () LLVM_READONLY |
| getScalarType - If this is a vector type, return the element type, otherwise return this. More... | |
| 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 |
| getContainedType - This method is used to implement the type iterator (defined at the end of the file). More... | |
| unsigned | getNumContainedTypes () const |
| getNumContainedTypes - Return the number of types in the derived type. More... | |
| 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 |
| Type * | getSequentialElementType () const |
| uint64_t | getArrayNumElements () const |
| Type * | getArrayElementType () const |
| unsigned | getVectorNumElements () const |
| Type * | getVectorElementType () const |
| Type * | getPointerElementType () const |
| unsigned | getPointerAddressSpace () const |
| Get the address space of this pointer or pointer vector type. More... | |
| PointerType * | getPointerTo (unsigned AddrSpace=0) |
| getPointerTo - Return a pointer to the current type. More... | |
Additional Inherited Members | |
Protected Member Functions inherited from llvm::CompositeType | |
| CompositeType (LLVMContext &C, TypeID tid) | |
Protected Member Functions inherited from llvm::Type | |
| Type (LLVMContext &C, TypeID tid) | |
| ~Type ()=default | |
| void | setTypeID (TypeID ID) |
| unsigned | getSubclassData () const |
| void | setSubclassData (unsigned val) |
Protected Attributes inherited from llvm::Type | |
| unsigned | NumContainedTys |
| NumContainedTys - Keeps track of how many Type*'s there are in the ContainedTys list. More... | |
| Type *const * | ContainedTys |
| ContainedTys - A pointer to the array of Types contained by this Type. More... | |
StructType - Class to represent struct types.
There are two different kinds of struct types: Literal structs and Identified structs.
Literal struct types (e.g. { i32, i32 }) are uniqued structurally, and must always have a body when created. You can get one of these by using one of the StructType::get() forms.
Identified structs (e.g. foo or %42) may optionally have a name and are not uniqued. The names for identified structs are managed at the LLVMContext level, so there can only be a single identified struct with a given name in a particular LLVMContext. Identified structs may also optionally be opaque (have no body specified). You get one of these by using one of the StructType::create() forms.
Independent of what kind of struct you have, the body of a struct type are laid out in memory consequtively with the elements directly one after the other (if the struct is packed) or (if not packed) with padding between the elements as defined by DataLayout (which is required to match what the code generator for a target expects).
Definition at line 191 of file DerivedTypes.h.
Definition at line 278 of file DerivedTypes.h.
Methods for support type inquiry through isa, cast, and dyn_cast.
Definition at line 297 of file DerivedTypes.h.
References llvm::Type::getTypeID(), and llvm::Type::StructTyID.
|
static |
StructType::create - This creates an identified struct.
Definition at line 490 of file Type.cpp.
References llvm::StringRef::empty(), llvm::LLVMContext::pImpl, setName(), llvm::AArch64DB::ST, and llvm::LLVMContextImpl::TypeAllocator.
Referenced by create(), and LLVMStructCreateNamed().
|
static |
|
static |
Definition at line 531 of file Type.cpp.
References create(), llvm::ArrayRef< T >::empty(), and llvm::Type::getContext().
|
static |
Definition at line 538 of file Type.cpp.
References create(), llvm::ArrayRef< T >::empty(), and llvm::Type::getContext().
|
static |
Definition at line 516 of file Type.cpp.
References create(), setBody(), and llvm::AArch64DB::ST.
|
static |
|
static |
Definition at line 544 of file Type.cpp.
References create(), llvm::Type::getContext(), llvm::SmallVectorTemplateBase< T, isPodLike< T >::value >::push_back(), and llvm::MipsISD::Ret.
|
inline |
Definition at line 279 of file DerivedTypes.h.
References llvm::Type::ContainedTys.
Referenced by getTypePartition(), isLayoutIdentical(), isLeakCheckerRoot(), isSized(), LLVMGetStructElementTypes(), and WriteTypeTable().
|
inline |
Definition at line 280 of file DerivedTypes.h.
References llvm::Type::ContainedTys, and llvm::Type::NumContainedTys.
Referenced by getTypePartition(), isLayoutIdentical(), isLeakCheckerRoot(), isSized(), LLVMGetStructElementTypes(), and WriteTypeTable().
Definition at line 281 of file DerivedTypes.h.
References llvm::makeArrayRef().
|
static |
StructType::get - This static method is the primary way to create a literal StructType.
Definition at line 404 of file Type.cpp.
References llvm::LLVMContextImpl::AnonStructTypes, llvm::DenseSet< ValueT, ValueInfoT >::end(), llvm::DenseSet< ValueT, ValueInfoT >::find_as(), I, llvm::DenseSet< ValueT, ValueInfoT >::insert(), llvm::LLVMContext::pImpl, setBody(), llvm::Type::setSubclassData(), llvm::AArch64DB::ST, and llvm::LLVMContextImpl::TypeAllocator.
Referenced by appendToGlobalArray(), createStubLandingPad(), DecodeFixedType(), get(), llvm::ConstantExpr::getAlignOf(), llvm::ConstantStruct::getTypeForElements(), insertSinCosCall(), LLVMStructTypeInContext(), and LowerFSINCOS().
|
static |
StructType::get - Create an empty structure type.
Definition at line 497 of file Type.cpp.
References isPacked(), and llvm::None.
|
static |
StructType::get - This static method is a convenience method for creating structure types by specifying the elements as arguments.
Note that this method always returns a non-packed struct, and requires at least one element type.
Definition at line 501 of file Type.cpp.
References get(), llvm::Type::getContext(), llvm::SmallVectorTemplateBase< T, isPodLike< T >::value >::push_back(), and llvm::MipsISD::Ret.
Definition at line 291 of file DerivedTypes.h.
References llvm::Type::ContainedTys, N, and llvm::Type::NumContainedTys.
Referenced by BuildSubAggregate(), llvm::ConstantStruct::ConstantStruct(), getNaturalGEPRecursively(), llvm::AArch64TTIImpl::getOrCreateResultFromMemIntrinsic(), getTypePartition(), HasPadding(), llvm::Type::isEmptyTy(), and PerformHeapAllocSRoA().
| StringRef StructType::getName | ( | ) | const |
getName - Return the name for this struct type if it has an identity.
This may return an empty string for an unnamed struct type. Do not call this on an literal type.
Definition at line 583 of file Type.cpp.
References isLiteral().
Referenced by llvm::isImageOrSamplerVal(), LLVMGetStructName(), setName(), StripTypeNames(), and WriteTypeTable().
|
inline |
Random access to the elements.
Definition at line 290 of file DerivedTypes.h.
References llvm::Type::NumContainedTys.
Referenced by appendToGlobalArray(), BuildSubAggregate(), llvm::ConstantStruct::ConstantStruct(), llvm::ConstantStruct::get(), llvm::AArch64TTIImpl::getOrCreateResultFromMemIntrinsic(), llvm::DataLayout::getStructLayout(), HasPadding(), llvm::Type::isEmptyTy(), isLayoutIdentical(), PerformHeapAllocSRoA(), TryToOptimizeStoreOfMallocToGlobal(), and llvm::InlineAsm::Verify().
|
inline |
hasName - Return true if this is a named struct that has a non-empty name.
Definition at line 256 of file DerivedTypes.h.
Referenced by LLVMGetStructName().
| bool StructType::isLayoutIdentical | ( | StructType * | Other | ) | const |
isLayoutIdentical - Return true if this is layout identical to the specified struct.
Definition at line 610 of file Type.cpp.
References element_begin(), element_end(), llvm::lltok::equal, getNumElements(), and isPacked().
|
inline |
isLiteral - Return true if this type is uniqued by structural equivalence, false if it is a struct definition.
Definition at line 246 of file DerivedTypes.h.
References llvm::Type::getSubclassData().
Referenced by getName(), llvm::isImageOrSamplerVal(), false::operator<<(), llvm::Type::print(), StripTypeNames(), and WriteTypeTable().
|
inline |
isOpaque - Return true if this is a type with an identity that has no body specified yet.
These prints as 'opaque' in .ll files.
Definition at line 250 of file DerivedTypes.h.
References llvm::Type::getSubclassData().
Referenced by llvm::Linker::IdentifiedStructTypeSet::addNonOpaque(), llvm::Linker::IdentifiedStructTypeSet::addOpaque(), llvm::ConstantStruct::ConstantStruct(), llvm::ConstantStruct::get(), llvm::Linker::IdentifiedStructTypeSet::hasType(), isLeakCheckerRoot(), isSized(), setBody(), llvm::Linker::IdentifiedStructTypeSet::switchToNonOpaque(), and WriteTypeTable().
|
inline |
Definition at line 242 of file DerivedTypes.h.
References llvm::Type::getSubclassData().
Referenced by get(), getTypePartition(), isLayoutIdentical(), and WriteTypeTable().
| bool StructType::isSized | ( | SmallPtrSetImpl< const Type * > * | Visited = nullptr | ) | const |
isSized - Return true if this is a sized type.
Definition at line 559 of file Type.cpp.
References element_begin(), element_end(), llvm::Type::getSubclassData(), I, llvm::SmallPtrSetImpl< PtrType >::insert(), isOpaque(), and llvm::Type::setSubclassData().
isValidElementType - Return true if the specified type is valid as a element type.
Definition at line 603 of file Type.cpp.
References llvm::Type::isFunctionTy(), llvm::Type::isLabelTy(), llvm::Type::isMetadataTy(), and llvm::Type::isVoidTy().
setBody - Specify a body for an opaque identified type.
Definition at line 424 of file Type.cpp.
References llvm::BumpPtrAllocatorImpl< AllocatorT, SlabSize, SizeThreshold >::Allocate(), llvm::Type::ContainedTys, llvm::ArrayRef< T >::data(), llvm::Type::getContext(), llvm::Type::getSubclassData(), isOpaque(), llvm::Type::NumContainedTys, llvm::LLVMContext::pImpl, llvm::Type::setSubclassData(), llvm::ArrayRef< T >::size(), and llvm::LLVMContextImpl::TypeAllocator.
| void StructType::setBody | ( | Type * | elt1, |
| ... | |||
| ) |
Definition at line 590 of file Type.cpp.
References llvm::SmallVectorTemplateBase< T, isPodLike< T >::value >::push_back(), and setBody().
| void StructType::setName | ( | StringRef | Name | ) |
setName - Change the name of this type to the specified name, or to a name with a suffix if there is a collision.
Do not call this on an literal type.
Definition at line 439 of file Type.cpp.
References llvm::StringRef::empty(), llvm::StringMap< ValueTy, AllocatorTy >::getAllocator(), llvm::Type::getContext(), getName(), llvm::LLVMContextImpl::NamedStructTypes, llvm::LLVMContextImpl::NamedStructTypesUniqueID, llvm::COFF::NameSize, llvm::LLVMContext::pImpl, llvm::SmallVectorTemplateBase< T, isPodLike >::push_back(), llvm::StringMap< ValueTy, AllocatorTy >::remove(), llvm::SmallVectorImpl< T >::resize(), llvm::raw_svector_ostream::resync(), llvm::StringRef::size(), and llvm::raw_svector_ostream::str().
Referenced by create(), and StripTypeNames().
1.8.6