Thanks to visit codestin.com
Credit goes to llvm.org

LLVM 22.0.0git
llvm::IntegerType Class Reference

Class to represent integer types. More...

#include "llvm/IR/DerivedTypes.h"

Inheritance diagram for llvm::IntegerType:
[legend]

Public Types

enum  { MIN_INT_BITS = 1 , MAX_INT_BITS = (1<<23) }
 This enum is just used to hold constants we need for IntegerType. More...
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>

Public Member Functions

IntegerTypegetExtendedType () const
 Returns type twice as wide the input type.
unsigned getBitWidth () const
 Get the number of bits in this IntegerType.
uint64_t getBitMask () const
 Return a bitmask with ones set for all of the bits that can be set by an unsigned version of this type.
uint64_t getSignBit () const
 Return a uint64_t with just the most significant bit set (the sign bit, if the value is treated as a signed number).
LLVM_ABI APInt getMask () const
 For example, this is 0xFF for an 8 bit integer, 0xFFFF for i16, etc.
Public Member Functions inherited from llvm::Type
LLVM_ABI void print (raw_ostream &O, bool IsForDebug=false, bool NoDetails=false) const
 Print the current type.
LLVM_ABI 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, 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.
LLVM_ABI 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.
LLVM_ABI bool isScalableTargetExtTy () const
 Return true if this is a target extension type with a scalable layout.
LLVM_ABI bool isScalableTy (SmallPtrSetImpl< const Type * > &Visited) const
 Return true if this is a type whose size is a known multiple of vscale.
LLVM_ABI bool isScalableTy () const
LLVM_ABI 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.
LLVM_ABI bool containsNonGlobalTargetExtType () const
LLVM_ABI 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.
LLVM_ABI 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 isTokenLikeTy () const
 Returns true if this is 'token' or a token-like target type.s.
bool isIntegerTy () const
 True if this is an instance of IntegerType.
LLVM_ABI 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.
LLVM_ABI bool isRISCVVectorTupleTy () const
LLVM_ABI bool canLosslesslyBitCastTo (Type *Ty) const
 Return true if this type could be converted with a lossless BitCast to type 'Ty'.
LLVM_ABI bool isEmptyTy () const
 Return true if this type is empty, that is, it has no elements or all of its elements are empty.
LLVM_ABI 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.
LLVM_ABI TypeSize getPrimitiveSizeInBits () const LLVM_READONLY
 Return the basic size of this type if it is a primitive type.
LLVM_ABI unsigned getScalarSizeInBits () const LLVM_READONLY
 If this is a vector type, return the getPrimitiveSizeInBits value for the element type.
LLVM_ABI int getFPMantissaWidth () const
 Return the width of the mantissa of this type.
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.
LLVM_ABI unsigned getIntegerBitWidth () const
LLVM_ABI TypegetFunctionParamType (unsigned i) const
LLVM_ABI unsigned getFunctionNumParams () const
LLVM_ABI bool isFunctionVarArg () const
LLVM_ABI StringRef getStructName () const
LLVM_ABI unsigned getStructNumElements () const
LLVM_ABI TypegetStructElementType (unsigned N) const
LLVM_ABI uint64_t getArrayNumElements () const
TypegetArrayElementType () const
LLVM_ABI StringRef getTargetExtName () const
LLVM_ABI TypegetWithNewType (Type *EltTy) const
 Given vector type, change the element type, whilst keeping the old number of elements.
LLVM_ABI TypegetWithNewBitWidth (unsigned NewBitWidth) const
 Given an integer or vector type, change the lane bitwidth to NewBitwidth, whilst keeping the old number of lanes.
LLVM_ABI TypegetExtendedType () const
 Given scalar/vector integer type, returns a type with elements twice as wide as in the original type.
LLVM_ABI unsigned getPointerAddressSpace () const
 Get the address space of this pointer or pointer vector type.
LLVM_ABI LLVM_DEPRECATED ("Use PointerType::get instead", "PointerType::get") PointerType *getPointerTo(unsigned AddrSpace=0) const
 Return a pointer to the current type.

Static Public Member Functions

static LLVM_ABI IntegerTypeget (LLVMContext &C, unsigned NumBits)
 This static method is the primary way of constructing an IntegerType.
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 LLVM_ABI TypegetPrimitiveType (LLVMContext &C, TypeID IDNumber)
 Return a type based on an identifier.
static LLVM_ABI TypegetVoidTy (LLVMContext &C)
static LLVM_ABI TypegetLabelTy (LLVMContext &C)
static LLVM_ABI TypegetHalfTy (LLVMContext &C)
static LLVM_ABI TypegetBFloatTy (LLVMContext &C)
static LLVM_ABI TypegetFloatTy (LLVMContext &C)
static LLVM_ABI TypegetDoubleTy (LLVMContext &C)
static LLVM_ABI TypegetMetadataTy (LLVMContext &C)
static LLVM_ABI TypegetX86_FP80Ty (LLVMContext &C)
static LLVM_ABI TypegetFP128Ty (LLVMContext &C)
static LLVM_ABI TypegetPPC_FP128Ty (LLVMContext &C)
static LLVM_ABI TypegetX86_AMXTy (LLVMContext &C)
static LLVM_ABI TypegetTokenTy (LLVMContext &C)
static LLVM_ABI IntegerTypegetIntNTy (LLVMContext &C, unsigned N)
static LLVM_ABI IntegerTypegetInt1Ty (LLVMContext &C)
static LLVM_ABI IntegerTypegetInt8Ty (LLVMContext &C)
static LLVM_ABI IntegerTypegetInt16Ty (LLVMContext &C)
static LLVM_ABI IntegerTypegetInt32Ty (LLVMContext &C)
static LLVM_ABI IntegerTypegetInt64Ty (LLVMContext &C)
static LLVM_ABI IntegerTypegetInt128Ty (LLVMContext &C)
template<typename ScalarTy>
static TypegetScalarTy (LLVMContext &C)
static LLVM_ABI TypegetFloatingPointTy (LLVMContext &C, const fltSemantics &S)
static LLVM_ABI TypegetWasm_ExternrefTy (LLVMContext &C)
static LLVM_ABI TypegetWasm_FuncrefTy (LLVMContext &C)

Protected Member Functions

 IntegerType (LLVMContext &C, unsigned NumBits)
Protected Member Functions inherited from llvm::Type
 Type (LLVMContext &C, TypeID tid)
 ~Type ()=default
unsigned getSubclassData () const
void setSubclassData (unsigned val)

Friends

class LLVMContextImpl

Additional Inherited Members

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.

Detailed Description

Class to represent integer types.

Note that this class is also used to represent the built-in integer types: Int1Ty, Int8Ty, Int16Ty, Int32Ty and Int64Ty. Integer representation type

Definition at line 42 of file DerivedTypes.h.

Member Enumeration Documentation

◆ anonymous enum

anonymous enum

This enum is just used to hold constants we need for IntegerType.

Enumerator
MIN_INT_BITS 

Minimum number of bits that can be specified.

MAX_INT_BITS 

Maximum number of bits that can be specified.

Note that bit width is stored in the Type classes SubclassData field which has 24 bits. SelectionDAG type legalization can require a power of 2 IntegerType, so limit to the largest representable power of 2, 8388608.

Definition at line 52 of file DerivedTypes.h.

Constructor & Destructor Documentation

◆ IntegerType()

llvm::IntegerType::IntegerType ( LLVMContext & C,
unsigned NumBits )
inlineexplicitprotected

Member Function Documentation

◆ classof()

bool llvm::IntegerType::classof ( const Type * T)
inlinestatic

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

Definition at line 94 of file DerivedTypes.h.

References llvm::Type::IntegerTyID, T, and llvm::Type::Type().

◆ get()

IntegerType * IntegerType::get ( LLVMContext & C,
unsigned NumBits )
static

This static method is the primary way of constructing an IntegerType.

If an IntegerType with the same NumBits value was previously instantiated, that instance will be returned. Otherwise a new one will be created. Only one instance with a given NumBits value is ever created. Get or create an IntegerType instance.

Definition at line 319 of file Type.cpp.

Referenced by BinomialCoefficient(), llvm::MachineIRBuilder::buildConstant(), buildIntrinsicArgTypes(), llvm::buildNDRange(), llvm::MachineIRBuilder::buildVScale(), CanShareConstantPoolEntry(), llvm::VNCoercion::coerceAvailableValueToLoadType(), collectInsertionElements(), llvm::slpvectorizer::BoUpSLP::computeMinimumValueSizes(), llvm::ConstantFoldBinaryInstruction(), llvm::ConstantFoldCastInstruction(), llvm::ConstantFoldCompareInstruction(), llvm::ConstantFoldSelectInstruction(), llvm::ConstantFoldShuffleVectorInstruction(), llvm::ConstantFoldUnaryInstruction(), createAccessTag(), createAtomicLibcall(), llvm::DIBuilder::createBitFieldMemberType(), llvm::DIBuilder::createBitFieldMemberType(), llvm::MatrixBuilder::CreateIndex(), llvm::DIBuilder::createInheritance(), llvm::createMemLibcall(), llvm::MDBuilder::createRange(), llvm::orc::ReOptimizeLayer::createReoptimizeCall(), DecodeFixedType(), llvm::AtomicInfo::EmitAtomicCompareExchangeLibcall(), llvm::AtomicInfo::EmitAtomicLoadOp(), emitGlobalConstantVector(), llvm::VPScalarIVStepsRecipe::execute(), llvm::GIMatchTableExecutor::executeMatchTable(), expandVPWidenIntOrFpInduction(), llvm::FastISel::fastEmit_ri_(), fixI8UseChain(), foldConsecutiveLoads(), foldLoadsRecursive(), llvm::SCEVExpander::generateOverflowCheck(), llvm::ConstantInt::get(), llvm::X86TTIImpl::getArithmeticReductionCost(), llvm::AtomicInfo::getAtomicSizeValue(), llvm::RISCVTTIImpl::getCastInstrCost(), llvm::BasicTTIImplBase< BasicTTIImpl >::getExtendedReductionCost(), llvm::Type::getFloatingPointTy(), llvm::DataLayout::getIndexType(), llvm::DataLayout::getIndexType(), llvm::LoopVectorizationCostModel::getInstructionCost(), llvm::VectorType::getInteger(), llvm::DataLayout::getIntPtrType(), llvm::DataLayout::getIntPtrType(), llvm::VNCoercion::getMemInstValueForLoad(), llvm::X86TTIImpl::getMemoryOpCost(), llvm::SPIRVGlobalRegistry::getOrCreateSPIRVBoolType(), llvm::SPIRVGlobalRegistry::getOrCreateSPIRVBoolType(), llvm::SPIRVGlobalRegistry::getOrCreateSPIRVIntegerType(), llvm::SPIRVGlobalRegistry::getOrCreateSPIRVIntegerType(), getPreStartForExtend(), llvm::slpvectorizer::BoUpSLP::getReductionType(), llvm::slpvectorizer::BoUpSLP::getRootNodeTypeWithNoCast(), llvm::RISCVTTIImpl::getShuffleCost(), llvm::ScalarEvolution::getSignExtendExprImpl(), llvm::TargetLibraryInfo::getSizeTType(), llvm::slpvectorizer::BoUpSLP::getSpillCost(), llvm::VNCoercion::getStoreValueForLoadHelper(), llvm::slpvectorizer::BoUpSLP::getTreeCost(), llvm::BasicTTIImplBase< BasicTTIImpl >::getTreeReductionCost(), llvm::VectorType::getTruncatedElementVectorType(), llvm::EVT::getTypeForEVT(), llvm::getTypeForLLT(), llvm::ScalarEvolution::getUDivExpr(), llvm::ScalarEvolution::getURemExpr(), llvm::RISCVTTIImpl::getVectorInstrCost(), llvm::ScalarEvolution::getZeroExtendExprImpl(), insertSpills(), llvm::AMDGPU::instrumentAddressImpl(), isAddRecSExtable(), isAddSExtable(), IsIncrementNSW(), IsIncrementNUW(), isLoadCombineCandidateImpl(), isMulSExtable(), llvm::SPIRVLegalizerInfo::legalizeCustom(), llvm::LegalizerHelper::libcall(), LLVMIntTypeInContext(), lookThroughAnd(), llvm::lowerUnaryVectorIntrinsicAsLoop(), matchIntrinsicType(), optimizeMemCmpConstantSize(), optimizeVectorInductionWidthForTCAndVFUF(), llvm::TargetLowering::ParseConstraints(), llvm::LoopStructure::parseLoopStructure(), processUGT_ADDCST_ADD(), llvm::VPlanTransforms::replicateByVF(), llvm::ScalarEvolution::LoopGuards::rewrite(), rewriteGEPAsOffset(), llvm::InstCombinerImpl::SimplifyAnyMemTransfer(), simplifyX86pmulh(), llvm::VPlanTransforms::truncateToMinimalBitwidths(), tryToFPToSat(), llvm::InstCombinerImpl::visitSwitchInst(), and llvm::ScalarEvolution::willNotOverflow().

◆ getBitMask()

uint64_t llvm::IntegerType::getBitMask ( ) const
inline

Return a bitmask with ones set for all of the bits that can be set by an unsigned version of this type.

This is 0xFF for i8, 0xFFFF for i16, etc.

Definition at line 78 of file DerivedTypes.h.

References getBitWidth().

◆ getBitWidth()

◆ getExtendedType()

IntegerType * llvm::IntegerType::getExtendedType ( ) const
inline

Returns type twice as wide the input type.

Definition at line 69 of file DerivedTypes.h.

References llvm::Type::getContext(), llvm::Type::getIntNTy(), llvm::Type::getScalarSizeInBits(), and IntegerType().

◆ getMask()

APInt IntegerType::getMask ( ) const

For example, this is 0xFF for an 8 bit integer, 0xFFFF for i16, etc.

Returns
a bit mask with ones set for all the bits of this type. Get a bit mask for this type.

Definition at line 343 of file Type.cpp.

Referenced by isIndvarOverflowCheckKnownFalse().

◆ getSignBit()

uint64_t llvm::IntegerType::getSignBit ( ) const
inline

Return a uint64_t with just the most significant bit set (the sign bit, if the value is treated as a signed number).

Definition at line 84 of file DerivedTypes.h.

References getBitWidth().

◆ LLVMContextImpl

friend class LLVMContextImpl
friend

Definition at line 43 of file DerivedTypes.h.

References LLVMContextImpl.

Referenced by LLVMContextImpl.


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