clang 20.0.0git
Public Member Functions | List of all members
clang::CodeGen::CodeGenTypes Class Reference

This class organizes the cross-module state that is used while lowering AST types to LLVM types. More...

#include "/home/buildbot/as-worker-4/publish-doxygen-docs/llvm-project/clang/lib/CodeGen/CodeGenTypes.h"

Public Member Functions

 CodeGenTypes (CodeGenModule &cgm)
 
 ~CodeGenTypes ()
 
const llvm::DataLayout & getDataLayout () const
 
CodeGenModulegetCGM () const
 
ASTContextgetContext () const
 
const TargetInfogetTarget () const
 
CGCXXABIgetCXXABI () const
 
llvm::LLVMContext & getLLVMContext ()
 
const CodeGenOptionsgetCodeGenOpts () const
 
unsigned ClangCallConvToLLVMCallConv (CallingConv CC)
 Convert clang calling convention to LLVM callilng convention.
 
CanQualType DeriveThisType (const CXXRecordDecl *RD, const CXXMethodDecl *MD)
 Derives the 'this' type for codegen purposes, i.e.
 
llvm::Type * ConvertType (QualType T)
 ConvertType - Convert type T into a llvm::Type.
 
llvm::Type * ConvertTypeForMem (QualType T)
 ConvertTypeForMem - Convert type T into a llvm::Type.
 
bool typeRequiresSplitIntoByteArray (QualType ASTTy, llvm::Type *LLVMTy=nullptr)
 Check whether the given type needs to be laid out in memory using an opaque byte-array type because its load/store type does not have the correct alloc size in the LLVM data layout.
 
llvm::Type * convertTypeForLoadStore (QualType T, llvm::Type *LLVMTy=nullptr)
 Given that T is a scalar type, return the IR type that should be used for load and store operations.
 
llvm::FunctionType * GetFunctionType (const CGFunctionInfo &Info)
 GetFunctionType - Get the LLVM function type for.
 
llvm::FunctionType * GetFunctionType (GlobalDecl GD)
 
bool isFuncTypeConvertible (const FunctionType *FT)
 isFuncTypeConvertible - Utility to check whether a function type can be converted to an LLVM type (i.e.
 
bool isFuncParamTypeConvertible (QualType Ty)
 isFuncParamTypeConvertible - Return true if the specified type in a function parameter or result position can be converted to an IR type at this point.
 
bool inheritingCtorHasParams (const InheritedConstructor &Inherited, CXXCtorType Type)
 Determine if a C++ inheriting constructor should have parameters matching those of its inherited constructor.
 
llvm::Type * GetFunctionTypeForVTable (GlobalDecl GD)
 GetFunctionTypeForVTable - Get the LLVM function type for use in a vtable, given a CXXMethodDecl.
 
const CGRecordLayoutgetCGRecordLayout (const RecordDecl *)
 getCGRecordLayout - Return record layout info for the given record decl.
 
void UpdateCompletedType (const TagDecl *TD)
 UpdateCompletedType - When we find the full definition for a TagDecl, replace the 'opaque' type we previously made for it if applicable.
 
void RefreshTypeCacheForClass (const CXXRecordDecl *RD)
 Remove stale types from the type cache when an inheritance model gets assigned to a class.
 
const CGFunctionInfoarrangeGlobalDeclaration (GlobalDecl GD)
 
const CGFunctionInfoarrangeCall (const CGFunctionInfo &declFI, const CallArgList &args)
 Given a function info for a declaration, return the function info for a call with the given arguments.
 
const CGFunctionInfoarrangeFunctionDeclaration (const FunctionDecl *FD)
 Free functions are functions that are compatible with an ordinary C function pointer type.
 
const CGFunctionInfoarrangeFreeFunctionCall (const CallArgList &Args, const FunctionType *Ty, bool ChainCall)
 Figure out the rules for calling a function with the given formal type using the given arguments.
 
const CGFunctionInfoarrangeFreeFunctionType (CanQual< FunctionProtoType > Ty)
 Arrange the argument and result information for a value of the given freestanding function type.
 
const CGFunctionInfoarrangeFreeFunctionType (CanQual< FunctionNoProtoType > Ty)
 Arrange the argument and result information for a value of the given unprototyped freestanding function type.
 
const CGFunctionInfoarrangeNullaryFunction ()
 A nullary function is a freestanding function of type 'void ()'.
 
const CGFunctionInfoarrangeBuiltinFunctionDeclaration (QualType resultType, const FunctionArgList &args)
 A builtin function is a freestanding function using the default C conventions.
 
const CGFunctionInfoarrangeBuiltinFunctionDeclaration (CanQualType resultType, ArrayRef< CanQualType > argTypes)
 
const CGFunctionInfoarrangeBuiltinFunctionCall (QualType resultType, const CallArgList &args)
 
const CGFunctionInfoarrangeObjCMethodDeclaration (const ObjCMethodDecl *MD)
 Objective-C methods are C functions with some implicit parameters.
 
const CGFunctionInfoarrangeObjCMessageSendSignature (const ObjCMethodDecl *MD, QualType receiverType)
 Arrange the argument and result information for the function type through which to perform a send to the given Objective-C method, using the given receiver type.
 
const CGFunctionInfoarrangeUnprototypedObjCMessageSend (QualType returnType, const CallArgList &args)
 
const CGFunctionInfoarrangeBlockFunctionDeclaration (const FunctionProtoType *type, const FunctionArgList &args)
 Block invocation functions are C functions with an implicit parameter.
 
const CGFunctionInfoarrangeBlockFunctionCall (const CallArgList &args, const FunctionType *type)
 A block function is essentially a free function with an extra implicit argument.
 
const CGFunctionInfoarrangeCXXMethodDeclaration (const CXXMethodDecl *MD)
 C++ methods have some special rules and also have implicit parameters.
 
const CGFunctionInfoarrangeCXXStructorDeclaration (GlobalDecl GD)
 
const CGFunctionInfoarrangeCXXConstructorCall (const CallArgList &Args, const CXXConstructorDecl *D, CXXCtorType CtorKind, unsigned ExtraPrefixArgs, unsigned ExtraSuffixArgs, bool PassProtoArgs=true)
 Arrange a call to a C++ method, passing the given arguments.
 
const CGFunctionInfoarrangeCXXMethodCall (const CallArgList &args, const FunctionProtoType *type, RequiredArgs required, unsigned numPrefixArgs)
 Arrange a call to a C++ method, passing the given arguments.
 
const CGFunctionInfoarrangeUnprototypedMustTailThunk (const CXXMethodDecl *MD)
 Arrange a thunk that takes 'this' as the first parameter followed by varargs.
 
const CGFunctionInfoarrangeMSCtorClosure (const CXXConstructorDecl *CD, CXXCtorType CT)
 
const CGFunctionInfoarrangeCXXMethodType (const CXXRecordDecl *RD, const FunctionProtoType *FTP, const CXXMethodDecl *MD)
 Arrange the argument and result information for a call to an unknown C++ non-static member function of the given abstract type.
 
const CGFunctionInfoarrangeLLVMFunctionInfo (CanQualType returnType, FnInfoOpts opts, ArrayRef< CanQualType > argTypes, FunctionType::ExtInfo info, ArrayRef< FunctionProtoType::ExtParameterInfo > paramInfos, RequiredArgs args)
 "Arrange" the LLVM information for a call or type with the given signature.
 
std::unique_ptr< CGRecordLayoutComputeRecordLayout (const RecordDecl *D, llvm::StructType *Ty)
 Compute a new LLVM record layout object for the given record.
 
void addRecordTypeName (const RecordDecl *RD, llvm::StructType *Ty, StringRef suffix)
 addRecordTypeName - Compute a name from the given record decl with an optional suffix and name the given LLVM type using it.
 
llvm::StructType * ConvertRecordDeclType (const RecordDecl *TD)
 ConvertRecordDeclType - Lay out a tagged decl type like struct or union.
 
void getExpandedTypes (QualType Ty, SmallVectorImpl< llvm::Type * >::iterator &TI)
 getExpandedTypes - Expand the type
 
bool isZeroInitializable (QualType T)
 IsZeroInitializable - Return whether a type can be zero-initialized (in the C++ sense) with an LLVM zeroinitializer.
 
bool isPointerZeroInitializable (QualType T)
 Check if the pointer type can be zero-initialized (in the C++ sense) with an LLVM zeroinitializer.
 
bool isZeroInitializable (const RecordDecl *RD)
 IsZeroInitializable - Return whether a record type can be zero-initialized (in the C++ sense) with an LLVM zeroinitializer.
 
bool isLongDoubleReferenced () const
 
bool isRecordLayoutComplete (const Type *Ty) const
 isRecordLayoutComplete - Return true if the specified type is already completely laid out.
 
unsigned getTargetAddressSpace (QualType T) const
 

Detailed Description

This class organizes the cross-module state that is used while lowering AST types to LLVM types.

Definition at line 54 of file CodeGenTypes.h.

Constructor & Destructor Documentation

◆ CodeGenTypes()

CodeGenTypes::CodeGenTypes ( CodeGenModule cgm)

Definition at line 33 of file CodeGenTypes.cpp.

◆ ~CodeGenTypes()

CodeGenTypes::~CodeGenTypes ( )

Definition at line 40 of file CodeGenTypes.cpp.

References E.

Member Function Documentation

◆ addRecordTypeName()

void CodeGenTypes::addRecordTypeName ( const RecordDecl RD,
llvm::StructType *  Ty,
StringRef  suffix 
)

◆ arrangeBlockFunctionCall()

const CGFunctionInfo & CodeGenTypes::arrangeBlockFunctionCall ( const CallArgList args,
const FunctionType type 
)

A block function is essentially a free function with an extra implicit argument.

Definition at line 648 of file CGCall.cpp.

References arrangeFreeFunctionLikeCall().

◆ arrangeBlockFunctionDeclaration()

const CGFunctionInfo & CodeGenTypes::arrangeBlockFunctionDeclaration ( const FunctionProtoType type,
const FunctionArgList args 
)

◆ arrangeBuiltinFunctionCall()

const CGFunctionInfo & CodeGenTypes::arrangeBuiltinFunctionCall ( QualType  resultType,
const CallArgList args 
)

◆ arrangeBuiltinFunctionDeclaration() [1/2]

const CGFunctionInfo & CodeGenTypes::arrangeBuiltinFunctionDeclaration ( CanQualType  resultType,
ArrayRef< CanQualType argTypes 
)

◆ arrangeBuiltinFunctionDeclaration() [2/2]

const CGFunctionInfo & CodeGenTypes::arrangeBuiltinFunctionDeclaration ( QualType  resultType,
const FunctionArgList args 
)

◆ arrangeCall()

const CGFunctionInfo & CodeGenTypes::arrangeCall ( const CGFunctionInfo declFI,
const CallArgList args 
)

◆ arrangeCXXConstructorCall()

const CGFunctionInfo & CodeGenTypes::arrangeCXXConstructorCall ( const CallArgList args,
const CXXConstructorDecl D,
CXXCtorType  CtorKind,
unsigned  ExtraPrefixArgs,
unsigned  ExtraSuffixArgs,
bool  PassProtoArgs = true 
)

Arrange a call to a C++ method, passing the given arguments.

ExtraPrefixArgs is the number of ABI-specific args passed after the this parameter. ExtraSuffixArgs is the number of ABI-specific args passed at the end of args. PassProtoArgs indicates whether args has args for the parameters in the given CXXConstructorDecl.

Definition at line 419 of file CGCall.cpp.

References addExtParameterInfosForCall(), clang::CodeGen::RequiredArgs::All, arrangeLLVMFunctionInfo(), D, clang::CodeGen::RequiredArgs::forPrototypePlus(), clang::ASTContext::getCanonicalParamType(), clang::CodeGen::CodeGenModule::getContext(), getCXXABI(), GetFormalType(), clang::CanQual< T >::getTypePtr(), clang::CodeGen::CGCXXABI::hasMostDerivedReturn(), clang::CodeGen::CGCXXABI::HasThisReturn(), clang::CodeGen::IsInstanceMethod, clang::Required, clang::ASTContext::VoidPtrTy, and clang::ASTContext::VoidTy.

Referenced by canEmitDelegateCallArgs().

◆ arrangeCXXMethodCall()

const CGFunctionInfo & CodeGenTypes::arrangeCXXMethodCall ( const CallArgList args,
const FunctionProtoType proto,
RequiredArgs  required,
unsigned  numPrefixArgs 
)

Arrange a call to a C++ method, passing the given arguments.

numPrefixArgs is the number of ABI-specific prefix arguments we have. It does not count this.

Definition at line 701 of file CGCall.cpp.

References arrangeLLVMFunctionInfo(), getArgTypesForCall(), clang::FunctionType::getExtInfo(), getExtParameterInfosForCall(), clang::FunctionType::getReturnType(), GetReturnType(), and clang::CodeGen::IsInstanceMethod.

◆ arrangeCXXMethodDeclaration()

const CGFunctionInfo & CodeGenTypes::arrangeCXXMethodDeclaration ( const CXXMethodDecl MD)

C++ methods have some special rules and also have implicit parameters.

Arrange the argument and result information for a declaration or definition of the given C++ non-static member function.

The member function must be an ordinary function, i.e. not a constructor or destructor.

Definition at line 307 of file CGCall.cpp.

References arrangeCXXMethodType(), arrangeFreeFunctionType(), clang::CanQual< T >::getAs(), getCXXABI(), GetFormalType(), clang::CodeGen::CGCXXABI::getThisArgumentTypeForMethod(), clang::CXXMethodDecl::isImplicitObjectMemberFunction(), and setCUDAKernelCallingConvention().

Referenced by arrangeFunctionDeclaration(), and clang::CodeGen::CodeGenModule::GetAddrOfGlobal().

◆ arrangeCXXMethodType()

const CGFunctionInfo & CodeGenTypes::arrangeCXXMethodType ( const CXXRecordDecl RD,
const FunctionProtoType FTP,
const CXXMethodDecl MD 
)

Arrange the argument and result information for a call to an unknown C++ non-static member function of the given abstract type.

(A null RD means we don't have any meaningful "this" argument type, so fall back to a generic pointer type). The member function must be an ordinary function, i.e. not a constructor or destructor.

Definition at line 279 of file CGCall.cpp.

References DeriveThisType(), clang::CanQual< T >::getAs(), and clang::Type::getCanonicalTypeUnqualified().

Referenced by arrangeCXXMethodDeclaration(), and clang::CodeGen::arrangeCXXMethodType().

◆ arrangeCXXStructorDeclaration()

const CGFunctionInfo & CodeGenTypes::arrangeCXXStructorDeclaration ( GlobalDecl  GD)

◆ arrangeFreeFunctionCall()

const CGFunctionInfo & CodeGenTypes::arrangeFreeFunctionCall ( const CallArgList args,
const FunctionType fnType,
bool  chainCall 
)

Figure out the rules for calling a function with the given formal type using the given arguments.

The arguments are necessary because the function might be unprototyped, in which case it's target-dependent in crazy ways.

Definition at line 638 of file CGCall.cpp.

References arrangeFreeFunctionLikeCall().

Referenced by EmitNewDeleteCall().

◆ arrangeFreeFunctionType() [1/2]

const CGFunctionInfo & CodeGenTypes::arrangeFreeFunctionType ( CanQual< FunctionNoProtoType Ty)

Arrange the argument and result information for a value of the given unprototyped freestanding function type.

Definition at line 117 of file CGCall.cpp.

References arrangeLLVMFunctionInfo(), clang::CanQual< T >::getUnqualifiedType(), and clang::CodeGen::None.

◆ arrangeFreeFunctionType() [2/2]

const CGFunctionInfo & CodeGenTypes::arrangeFreeFunctionType ( CanQual< FunctionProtoType Ty)

Arrange the argument and result information for a value of the given freestanding function type.

Definition at line 206 of file CGCall.cpp.

Referenced by arrangeCXXMethodDeclaration(), clang::CodeGen::arrangeFreeFunctionType(), and arrangeFunctionDeclaration().

◆ arrangeFunctionDeclaration()

const CGFunctionInfo & CodeGenTypes::arrangeFunctionDeclaration ( const FunctionDecl FD)

Free functions are functions that are compatible with an ordinary C function pointer type.

Arrange the argument and result information for the declaration or definition of the given function.

Definition at line 462 of file CGCall.cpp.

References clang::CodeGen::RequiredArgs::All, arrangeCXXMethodDeclaration(), arrangeFreeFunctionType(), arrangeLLVMFunctionInfo(), clang::CanQual< T >::castAs(), clang::CanQual< T >::getAs(), clang::Type::getCanonicalTypeUnqualified(), clang::ValueDecl::getType(), clang::CodeGen::None, and setCUDAKernelCallingConvention().

Referenced by arrangeGlobalDeclaration().

◆ arrangeGlobalDeclaration()

const CGFunctionInfo & CodeGenTypes::arrangeGlobalDeclaration ( GlobalDecl  GD)

◆ arrangeLLVMFunctionInfo()

const CGFunctionInfo & CodeGenTypes::arrangeLLVMFunctionInfo ( CanQualType  resultType,
FnInfoOpts  opts,
ArrayRef< CanQualType argTypes,
FunctionType::ExtInfo  info,
ArrayRef< FunctionProtoType::ExtParameterInfo paramInfos,
RequiredArgs  required 
)

"Arrange" the LLVM information for a call or type with the given signature.

Arrange the argument and result information for an abstract value of a given function type.

This is largely an internal method; other clients should use one of the above routines, which ultimately defer to this.

Parameters
argTypes- must all actually be canonical as params

This is the method which all of the above functions ultimately defer to.

Definition at line 765 of file CGCall.cpp.

References clang::CodeGen::CGFunctionInfo::arguments(), clang::CodeGen::ABIArgInfo::canHaveCoerceToType(), clang::CC_Swift, clang::CC_SwiftAsync, ClangCallConvToLLVMCallConv(), clang::CodeGen::swiftcall::computeABIInfo(), clang::CodeGen::ABIInfo::computeInfo(), clang::CodeGen::computeSPIRKernelABIInfo(), ConvertType(), clang::CodeGen::CGFunctionInfo::create(), clang::CodeGen::CodeGenModule::getABIInfo(), clang::FunctionType::ExtInfo::getCC(), clang::CodeGen::ABIArgInfo::getCoerceToType(), clang::CodeGen::CGFunctionInfo::getReturnInfo(), clang::CodeGen::CGFunctionInfo::getReturnType(), clang::CodeGen::IsChainCall, clang::CodeGen::IsDelegateCall, clang::isInstanceMethod(), clang::CodeGen::IsInstanceMethod, clang::CodeGen::CGFunctionInfo::Profile(), clang::CodeGen::ABIArgInfo::setCoerceToType(), and clang::T.

Referenced by arrangeBlockFunctionDeclaration(), arrangeBuiltinFunctionCall(), arrangeBuiltinFunctionDeclaration(), arrangeCall(), arrangeCXXConstructorCall(), arrangeCXXMethodCall(), arrangeCXXStructorDeclaration(), clang::CodeGen::arrangeFreeFunctionCall(), arrangeFreeFunctionLikeCall(), arrangeFreeFunctionType(), arrangeFunctionDeclaration(), arrangeLLVMFunctionInfo(), arrangeMSCtorClosure(), arrangeNullaryFunction(), arrangeObjCMessageSendSignature(), arrangeUnprototypedMustTailThunk(), and arrangeUnprototypedObjCMessageSend().

◆ arrangeMSCtorClosure()

const CGFunctionInfo & CodeGenTypes::arrangeMSCtorClosure ( const CXXConstructorDecl CD,
CXXCtorType  CT 
)

◆ arrangeNullaryFunction()

const CGFunctionInfo & CodeGenTypes::arrangeNullaryFunction ( )

A nullary function is a freestanding function of type 'void ()'.

This method works for both calls and declarations.

Definition at line 721 of file CGCall.cpp.

References clang::CodeGen::RequiredArgs::All, arrangeLLVMFunctionInfo(), getContext(), and clang::CodeGen::None.

Referenced by createGlobalInitOrCleanupFn(), and clang::CodeGen::CGOpenMPRuntime::emitThreadPrivateVarDefinition().

◆ arrangeObjCMessageSendSignature()

const CGFunctionInfo & CodeGenTypes::arrangeObjCMessageSendSignature ( const ObjCMethodDecl MD,
QualType  receiverType 
)

◆ arrangeObjCMethodDeclaration()

const CGFunctionInfo & CodeGenTypes::arrangeObjCMethodDeclaration ( const ObjCMethodDecl MD)

Objective-C methods are C functions with some implicit parameters.

Arrange the argument and result information for the declaration or definition of an Objective-C method.

Definition at line 486 of file CGCall.cpp.

References arrangeObjCMessageSendSignature(), clang::ObjCMethodDecl::getSelfDecl(), and clang::ValueDecl::getType().

◆ arrangeUnprototypedMustTailThunk()

const CGFunctionInfo & CodeGenTypes::arrangeUnprototypedMustTailThunk ( const CXXMethodDecl MD)

Arrange a thunk that takes 'this' as the first parameter followed by varargs.

Return a void pointer, regardless of the actual return type. The body of the thunk will end in a musttail call to a function of the correct type, and the caller will bitcast the function to the correct prototype.

Definition at line 559 of file CGCall.cpp.

References arrangeLLVMFunctionInfo(), DeriveThisType(), GetFormalType(), clang::CXXMethodDecl::getParent(), clang::CXXMethodDecl::isVirtual(), clang::CodeGen::None, and clang::ASTContext::VoidTy.

◆ arrangeUnprototypedObjCMessageSend()

const CGFunctionInfo & CodeGenTypes::arrangeUnprototypedObjCMessageSend ( QualType  returnType,
const CallArgList args 
)

◆ ClangCallConvToLLVMCallConv()

unsigned CodeGenTypes::ClangCallConvToLLVMCallConv ( CallingConv  CC)

◆ ComputeRecordLayout()

std::unique_ptr< CGRecordLayout > CodeGenTypes::ComputeRecordLayout ( const RecordDecl D,
llvm::StructType *  Ty 
)

◆ ConvertRecordDeclType()

llvm::StructType * CodeGenTypes::ConvertRecordDeclType ( const RecordDecl TD)

◆ ConvertType()

llvm::Type * CodeGenTypes::ConvertType ( QualType  T)

ConvertType - Convert type T into a llvm::Type.

ConvertType - Convert the specified type to its LLVM form.

Definition at line 347 of file CodeGenTypes.cpp.

References clang::C, clang::CodeGen::CGHLSLRuntime::convertHLSLSpecificType(), clang::CodeGen::CGCXXABI::ConvertMemberPointerType(), clang::CodeGen::CGOpenCLRuntime::convertOpenCLSpecificType(), ConvertRecordDeclType(), ConvertType(), ConvertTypeForMem(), clang::ASTContext::BuiltinVectorTypeInfo::EC, clang::ASTContext::BuiltinVectorTypeInfo::ElementType, clang::QualType::getAddressSpace(), clang::ASTContext::getBuiltinVectorTypeInfo(), clang::ASTContext::getCanonicalType(), clang::CodeGen::TargetCodeGenInfo::getCUDADeviceBuiltinSurfaceDeviceType(), clang::CodeGen::TargetCodeGenInfo::getCUDADeviceBuiltinTextureDeviceType(), getCXXABI(), clang::ArrayType::getElementType(), clang::MatrixType::getElementType(), clang::ASTContext::getFloatTypeSemantics(), clang::CodeGen::CodeGenModule::getHLSLRuntime(), clang::ArrayType::getIndexTypeCVRQualifiers(), clang::EnumDecl::getIntegerType(), getKind(), clang::ASTContext::getLangOpts(), getLLVMContext(), clang::ConstantMatrixType::getNumColumns(), clang::ConstantMatrixType::getNumRows(), clang::CodeGen::CodeGenModule::getOpenCLRuntime(), clang::CodeGen::CGOpenCLRuntime::getPipeType(), clang::Type::getPointeeType(), clang::PointerType::getPointeeType(), clang::ReferenceType::getPointeeType(), clang::ASTContext::getTargetAddressSpace(), getTargetAddressSpace(), clang::CodeGen::CodeGenModule::getTargetCodeGenInfo(), clang::ASTContext::getTargetInfo(), clang::Type::getTypeClass(), getTypeForFormat(), clang::ASTContext::getTypeSize(), clang::ConstantArrayType::getZExtSize(), clang::CodeGen::CodeGenTypeCache::Int8Ty, clang::TagDecl::isCompleteDefinition(), clang::Type::isCUDADeviceBuiltinSurfaceType(), clang::Type::isCUDADeviceBuiltinTextureType(), clang::EnumDecl::isFixed(), clang::ASTContext::BuiltinVectorTypeInfo::NumVectors, clang::T, and clang::TargetInfo::useFP16ConversionIntrinsics().

Referenced by clang::CodeGen::swiftcall::SwiftAggLowering::addTypedData(), addX86InterruptAttrs(), arrangeLLVMFunctionInfo(), buildBlockDescriptor(), buildGlobalBlock(), clang::CodeGen::DefaultABIInfo::classifyArgumentType(), computeBlockInfo(), clang::CodeGen::convertFreeFunctionType(), clang::CodeGen::CGCXXABI::ConvertMemberPointerType(), ConvertType(), convertTypeForLoadStore(), ConvertTypeForMem(), clang::CodeGen::CGOpenMPRuntime::emitKmpRoutineEntryT(), clang::CodeGen::CodeGenModule::GetAddrOfConstantCFString(), clang::CodeGen::CodeGenModule::GetAddrOfFunction(), getAllocatorVal(), clang::CodeGen::CodeGenModule::getBlockDescriptorType(), clang::CodeGen::CGCXXABI::GetBogusMemberPointer(), getExpandedTypes(), getGuardAcquireFn(), clang::CodeGen::CodeGenModule::GetNonVirtualBaseClassOffset(), clang::CodeGen::ConstantEmitter::tryEmitPrivate(), typeRequiresSplitIntoByteArray(), and UpdateCompletedType().

◆ convertTypeForLoadStore()

llvm::Type * CodeGenTypes::convertTypeForLoadStore ( QualType  T,
llvm::Type *  LLVMTy = nullptr 
)

Given that T is a scalar type, return the IR type that should be used for load and store operations.

For example, this might be i8 for _Bool or i96 for _BitInt(65). The store size of the load/store type (as reported by LLVM's data layout) is always the same as the alloc size of the memory representation type returned by ConvertTypeForMem.

As an optimization, if you already know the scalar value type for T (as would be returned by ConvertType), you can pass it as the second argument so that it does not need to be recomputed in common cases where the value type and load/store type are the same.

Definition at line 159 of file CodeGenTypes.cpp.

References ConvertType(), ConvertTypeForMem(), getLLVMContext(), clang::CharUnits::getQuantity(), clang::ASTContext::getTypeSize(), clang::ASTContext::getTypeSizeInChars(), clang::Type::isBitIntType(), clang::Type::isExtVectorBoolType(), and clang::T.

Referenced by clang::CodeGen::ConstantEmitter::emitForMemory().

◆ ConvertTypeForMem()

llvm::Type * CodeGenTypes::ConvertTypeForMem ( QualType  T)

ConvertTypeForMem - Convert type T into a llvm::Type.

This differs from ConvertType in that it is used to convert to the memory representation for a type. For example, the scalar representation for _Bool is i1, but the memory representation is usually i8 or i32, depending on the target.

This differs from ConvertType in that it is used to convert to the memory representation for a type. For example, the scalar representation for _Bool is i1, but the memory representation is usually i8 or i32, depending on the target.

We generally assume that the alloc size of this type under the LLVM data layout is the same as the size of the AST type. The alignment does not have to match: Clang should always use explicit alignments and packed structs as necessary to produce the layout it needs. But the size does need to be exactly right or else things like struct layout will break.

Definition at line 101 of file CodeGenTypes.cpp.

References ConvertType(), clang::ASTContext::getCanonicalType(), clang::MatrixType::getElementType(), getLLVMContext(), clang::ConstantMatrixType::getNumColumns(), clang::ConstantMatrixType::getNumRows(), clang::CharUnits::getQuantity(), clang::CanQual< T >::getTypePtr(), clang::ASTContext::getTypeSize(), clang::ASTContext::getTypeSizeInChars(), clang::CodeGen::CodeGenTypeCache::Int8Ty, clang::Type::isBitIntType(), clang::Type::isConstantMatrixType(), clang::Type::isExtVectorBoolType(), clang::T, and typeRequiresSplitIntoByteArray().

Referenced by computeBlockInfo(), ConvertType(), convertTypeForLoadStore(), clang::CodeGen::convertTypeForMemory(), emitConstantObjCStringLiteral(), clang::CodeGen::ConstantEmitter::emitForMemory(), EmitGlobalVarDeclLValue(), clang::CodeGen::CodeGenModule::EmitOMPAllocateDecl(), clang::CodeGen::CGOpenMPRuntime::emitUserDefinedMapper(), clang::CodeGen::CGOpenMPRuntime::getAddrOfDeclareTargetVar(), clang::CodeGen::CodeGenModule::GetAddrOfGlobalTemporary(), clang::CodeGen::CodeGenModule::GetAddrOfGlobalVar(), clang::CodeGen::CodeGenModule::GetAddrOfMSGuidDecl(), clang::CodeGen::CodeGenModule::getOrCreateStaticVarDecl(), clang::CodeGen::CodeGenModule::GetWeakRefReference(), and clang::CodeGen::CGOpenMPRuntime::registerTargetGlobalVariable().

◆ DeriveThisType()

CanQualType CodeGenTypes::DeriveThisType ( const CXXRecordDecl RD,
const CXXMethodDecl MD 
)

Derives the 'this' type for codegen purposes, i.e.

ignoring method CVR qualification.

ignoring method CVR qualification. Either or both of RD and MD may be null. A null RD indicates that there is no meaningful 'this' type, and a null MD can occur when calling a method pointer.

Definition at line 87 of file CGCall.cpp.

References clang::CanQual< Type >::CreateUnsafe(), clang::Qualifiers::getAddressSpace(), clang::ASTContext::getAddrSpaceQualType(), clang::Type::getCanonicalTypeInternal(), clang::CXXMethodDecl::getMethodQualifiers(), clang::ASTContext::getPointerType(), clang::ASTContext::getTagDeclType(), and clang::ASTContext::VoidTy.

Referenced by arrangeCXXMethodType(), arrangeCXXStructorDeclaration(), arrangeMSCtorClosure(), arrangeUnprototypedMustTailThunk(), and commonEmitCXXMemberOrOperatorCall().

◆ getCGM()

CodeGenModule & clang::CodeGen::CodeGenTypes::getCGM ( ) const
inline

Definition at line 102 of file CodeGenTypes.h.

Referenced by getCXXABI().

◆ getCGRecordLayout()

const CGRecordLayout & CodeGenTypes::getCGRecordLayout ( const RecordDecl RD)

◆ getCodeGenOpts()

const CodeGenOptions & CodeGenTypes::getCodeGenOpts ( ) const

◆ getContext()

ASTContext & clang::CodeGen::CodeGenTypes::getContext ( ) const
inline

◆ getCXXABI()

CGCXXABI & CodeGenTypes::getCXXABI ( ) const

◆ getDataLayout()

const llvm::DataLayout & clang::CodeGen::CodeGenTypes::getDataLayout ( ) const
inline

◆ getExpandedTypes()

void CodeGenTypes::getExpandedTypes ( QualType  Ty,
SmallVectorImpl< llvm::Type * >::iterator &  TI 
)

getExpandedTypes - Expand the type

Definition at line 1013 of file CGCall.cpp.

References ConvertType(), getExpandedTypes(), and getTypeExpansion().

Referenced by getExpandedTypes(), and GetFunctionType().

◆ GetFunctionType() [1/2]

llvm::FunctionType * CodeGenTypes::GetFunctionType ( const CGFunctionInfo Info)

GetFunctionType - Get the LLVM function type for.

  • Info.

Definition at line 1606 of file CGCall.cpp.

References clang::CodeGen::CGFunctionInfo::arg_begin(), clang::CodeGen::ABIArgInfo::CoerceAndExpand, clang::CodeGen::ABIArgInfo::Direct, clang::CodeGen::ABIArgInfo::Expand, clang::CodeGen::ABIArgInfo::Extend, clang::CodeGen::ABIArgInfo::getCanBeFlattened(), clang::CodeGen::ABIArgInfo::getCoerceAndExpandTypeSequence(), clang::CodeGen::ABIArgInfo::getCoerceToType(), getContext(), clang::CodeGen::CodeGenModule::getDataLayout(), getExpandedTypes(), clang::CodeGen::ABIArgInfo::getInAllocaSRet(), clang::CodeGen::ABIArgInfo::getIndirectAddrSpace(), clang::CodeGen::ABIArgInfo::getKind(), getLLVMContext(), clang::CodeGen::CGFunctionInfo::getNumRequiredArgs(), clang::CodeGen::ABIArgInfo::getPaddingType(), clang::CodeGen::CGFunctionInfo::getReturnInfo(), clang::CodeGen::CGFunctionInfo::getReturnType(), getTargetAddressSpace(), clang::CodeGen::CodeGenModule::getTypes(), clang::CodeGen::ABIArgInfo::getUnpaddedCoerceAndExpandType(), clang::CodeGen::ABIArgInfo::Ignore, clang::CodeGen::ABIArgInfo::InAlloca, clang::CodeGen::ABIArgInfo::Indirect, clang::CodeGen::ABIArgInfo::IndirectAliased, clang::CodeGen::CGFunctionInfoArgInfo::info, clang::CodeGen::ABIArgInfo::isDirect(), clang::CodeGen::CGFunctionInfo::isVariadic(), and clang::CodeGen::CGFunctionInfoArgInfo::type.

Referenced by emitAtomicLibcall(), emitCombinerOrInitializer(), emitCopyprivateCopyFunction(), emitDestructorsFunction(), clang::CodeGen::CodeGenModule::EmitGlobal(), EmitHipStdParUnsupportedBuiltin(), emitOutlinedFunctionPrologue(), emitProxyTaskFunction(), emitReduceCombFunction(), emitReduceFiniFunction(), emitReduceInitFunction(), clang::CodeGen::CGOpenMPRuntime::emitReductionFunction(), emitTaskDupFunction(), emitTaskPrivateMappingFunction(), clang::CodeGen::CGOpenMPRuntime::emitThreadPrivateVarDefinition(), clang::CodeGen::CGOpenMPRuntime::emitUserDefinedMapper(), generateByrefCopyHelper(), generateByrefDisposeHelper(), clang::CodeGen::CodeGenModule::getAddrAndTypeOfCXXStructor(), clang::CodeGen::CodeGenModule::GetAddrOfGlobal(), getClangCallTerminateFn(), GetFunctionType(), GetFunctionTypeForVTable(), and clang::CodeGen::CodeGenModule::TryEmitBaseDestructorAsAlias().

◆ GetFunctionType() [2/2]

llvm::FunctionType * CodeGenTypes::GetFunctionType ( GlobalDecl  GD)

Definition at line 1600 of file CGCall.cpp.

References arrangeGlobalDeclaration(), and GetFunctionType().

◆ GetFunctionTypeForVTable()

llvm::Type * CodeGenTypes::GetFunctionTypeForVTable ( GlobalDecl  GD)

GetFunctionTypeForVTable - Get the LLVM function type for use in a vtable, given a CXXMethodDecl.

If the method to has an incomplete return type, and/or incomplete argument types, this will return the opaque type.

Definition at line 1733 of file CGCall.cpp.

References clang::Type::castAs(), clang::GlobalDecl::getDecl(), GetFunctionType(), getLLVMContext(), clang::ValueDecl::getType(), and isFuncTypeConvertible().

◆ getLLVMContext()

llvm::LLVMContext & clang::CodeGen::CodeGenTypes::getLLVMContext ( )
inline

◆ getTarget()

const TargetInfo & clang::CodeGen::CodeGenTypes::getTarget ( ) const
inline

◆ getTargetAddressSpace()

unsigned CodeGenTypes::getTargetAddressSpace ( QualType  T) const

◆ inheritingCtorHasParams()

bool CodeGenTypes::inheritingCtorHasParams ( const InheritedConstructor Inherited,
CXXCtorType  Type 
)

Determine if a C++ inheriting constructor should have parameters matching those of its inherited constructor.

Definition at line 325 of file CGCall.cpp.

References clang::ConstructorUsingShadowDecl::constructsVirtualBase(), clang::Ctor_Complete, and clang::InheritedConstructor::getShadowDecl().

Referenced by arrangeCXXStructorDeclaration().

◆ isFuncParamTypeConvertible()

bool CodeGenTypes::isFuncParamTypeConvertible ( QualType  Ty)

isFuncParamTypeConvertible - Return true if the specified type in a function parameter or result position can be converted to an IR type at this point.

This boils down to being whether it is complete.

Definition at line 189 of file CodeGenTypes.cpp.

References clang::Type::getAs(), getCXXABI(), clang::Type::isIncompleteType(), and clang::CodeGen::CGCXXABI::isMemberPointerConvertible().

Referenced by isFuncTypeConvertible().

◆ isFuncTypeConvertible()

bool CodeGenTypes::isFuncTypeConvertible ( const FunctionType FT)

isFuncTypeConvertible - Utility to check whether a function type can be converted to an LLVM type (i.e.

Code to verify a given function type is complete, i.e.

doesn't depend on an incomplete tag type).

the return type and all of the parameter types are complete. Also check to see if we are in a RS_StructPointer context, and if so whether any struct types have been pended. If so, we don't want to ask the ABI lowering code to handle a type that cannot be converted to an IR type.

Definition at line 209 of file CodeGenTypes.cpp.

References clang::FunctionType::getReturnType(), and isFuncParamTypeConvertible().

Referenced by GetFunctionTypeForVTable().

◆ isLongDoubleReferenced()

bool clang::CodeGen::CodeGenTypes::isLongDoubleReferenced ( ) const
inline

Definition at line 312 of file CodeGenTypes.h.

◆ isPointerZeroInitializable()

bool CodeGenTypes::isPointerZeroInitializable ( QualType  T)

Check if the pointer type can be zero-initialized (in the C++ sense) with an LLVM zeroinitializer.

Definition at line 857 of file CodeGenTypes.cpp.

References clang::Type::isAnyPointerType(), clang::Type::isBlockPointerType(), isZeroInitializable(), and clang::T.

Referenced by isSimpleZero().

◆ isRecordLayoutComplete()

bool CodeGenTypes::isRecordLayoutComplete ( const Type Ty) const

isRecordLayoutComplete - Return true if the specified type is already completely laid out.

Definition at line 180 of file CodeGenTypes.cpp.

◆ isZeroInitializable() [1/2]

bool CodeGenTypes::isZeroInitializable ( const RecordDecl RD)

IsZeroInitializable - Return whether a record type can be zero-initialized (in the C++ sense) with an LLVM zeroinitializer.

Definition at line 890 of file CodeGenTypes.cpp.

References getCGRecordLayout(), and clang::CodeGen::CGRecordLayout::isZeroInitializable().

◆ isZeroInitializable() [2/2]

bool CodeGenTypes::isZeroInitializable ( QualType  T)

◆ RefreshTypeCacheForClass()

void CodeGenTypes::RefreshTypeCacheForClass ( const CXXRecordDecl RD)

Remove stale types from the type cache when an inheritance model gets assigned to a class.

Definition at line 259 of file CodeGenTypes.cpp.

References clang::ASTContext::getCanonicalType(), clang::ASTContext::getRecordType(), and clang::T.

Referenced by clang::CodeGen::CodeGenModule::RefreshTypeCacheForClass().

◆ typeRequiresSplitIntoByteArray()

bool CodeGenTypes::typeRequiresSplitIntoByteArray ( QualType  ASTTy,
llvm::Type *  LLVMTy = nullptr 
)

Check whether the given type needs to be laid out in memory using an opaque byte-array type because its load/store type does not have the correct alloc size in the LLVM data layout.

If this is false, the load/store type (convertTypeForLoadStore) and memory representation type (ConvertTypeForMem) will be the same type.

Definition at line 148 of file CodeGenTypes.cpp.

References ConvertType(), clang::CharUnits::fromQuantity(), getDataLayout(), getTypeAllocSize(), and clang::ASTContext::getTypeSizeInChars().

Referenced by ConvertTypeForMem(), and clang::CodeGen::ConstantEmitter::emitForMemory().

◆ UpdateCompletedType()

void CodeGenTypes::UpdateCompletedType ( const TagDecl TD)

UpdateCompletedType - When we find the full definition for a TagDecl, replace the 'opaque' type we previously made for it if applicable.

Definition at line 223 of file CodeGenTypes.cpp.

References ConvertRecordDeclType(), ConvertType(), clang::CodeGen::CodeGenModule::getModuleDebugInfo(), clang::ASTContext::getTagDeclType(), clang::QualType::getTypePtr(), and clang::TagDecl::isDependentType().

Referenced by clang::CodeGen::CodeGenModule::UpdateCompletedType().


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