clang 23.0.0git
CodeGenABITypes.h
Go to the documentation of this file.
1//==---- CodeGenABITypes.h - Convert Clang types to LLVM types for ABI -----==//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// CodeGenABITypes is a simple interface for getting LLVM types for
10// the parameters and the return value of a function given the Clang
11// types.
12//
13// The class is implemented as a public wrapper around the private
14// CodeGenTypes class in lib/CodeGen.
15//
16// It allows other clients, like LLDB, to determine the LLVM types that are
17// actually used in function calls, which makes it possible to then determine
18// the actual ABI locations (e.g. registers, stack locations, etc.) that
19// these parameters are stored in.
20//
21//===----------------------------------------------------------------------===//
22
23#ifndef LLVM_CLANG_CODEGEN_CODEGENABITYPES_H
24#define LLVM_CLANG_CODEGEN_CODEGENABITYPES_H
25
27#include "clang/AST/Type.h"
28#include "clang/Basic/ABI.h"
30#include "llvm/IR/BasicBlock.h"
31
32namespace llvm {
33class AttrBuilder;
34class Constant;
35class ConstantInt;
36class Function;
37class FunctionType;
38class Type;
39}
40
41namespace clang {
44class CXXRecordDecl;
45class CXXMethodDecl;
46class GlobalDecl;
48class ObjCMethodDecl;
50
51namespace CodeGen {
52class CGFunctionInfo;
53class CodeGenModule;
54
55/// Additional implicit arguments to add to a constructor argument list.
57 /// Implicit arguments to add before the explicit arguments, but after the
58 /// `*this` argument (which always comes first).
60
61 /// Implicit arguments to add after the explicit arguments.
63};
64
66 const ObjCMethodDecl *MD,
67 QualType receiverType);
68
71
74
76 const CXXRecordDecl *RD,
77 const FunctionProtoType *FTP,
78 const CXXMethodDecl *MD);
79
80const CGFunctionInfo &
84 RequiredArgs args);
85
87 CodeGenModule &CGM, CanQualType returnType, ArrayRef<CanQualType> argTypes,
90 RequiredArgs args);
91
92// An overload with an empty `paramInfos`
93inline const CGFunctionInfo &
95 ArrayRef<CanQualType> argTypes,
97 return arrangeFreeFunctionCall(CGM, returnType, argTypes, info, {}, args);
98}
99
100/// Returns the implicit arguments to add to a complete, non-delegating C++
101/// constructor call.
102ImplicitCXXConstructorArgs
103getImplicitCXXConstructorArgs(CodeGenModule &CGM, const CXXConstructorDecl *D);
104
105llvm::Value *
106getCXXDestructorImplicitParam(CodeGenModule &CGM, llvm::BasicBlock *InsertBlock,
107 llvm::BasicBlock::iterator InsertPoint,
109 bool ForVirtualBase, bool Delegating);
110
111/// Returns null if the function type is incomplete and can't be lowered.
112llvm::FunctionType *convertFreeFunctionType(CodeGenModule &CGM,
113 const FunctionDecl *FD);
114
115llvm::Type *convertTypeForMemory(CodeGenModule &CGM, QualType T);
116
117/// Given a non-bitfield struct field, return its index within the elements of
118/// the struct's converted type. The returned index refers to a field number in
119/// the complete object type which is returned by convertTypeForMemory. FD must
120/// be a field in RD directly (i.e. not an inherited field).
121unsigned getLLVMFieldNumber(CodeGenModule &CGM,
122 const RecordDecl *RD, const FieldDecl *FD);
123
124/// Return a declaration discriminator for the given global decl.
125uint16_t getPointerAuthDeclDiscriminator(CodeGenModule &CGM, GlobalDecl GD);
126
127/// Return a type discriminator for the given function type.
128uint16_t getPointerAuthTypeDiscriminator(CodeGenModule &CGM,
130
131/// Return a signed constant pointer.
132llvm::Constant *getConstantSignedPointer(CodeGenModule &CGM,
133 llvm::Constant *Pointer, unsigned Key,
134 llvm::Constant *StorageAddress,
135 llvm::ConstantInt *OtherDiscriminator);
136
137/// Given the language and code-generation options that Clang was configured
138/// with, set the default LLVM IR attributes for a function definition.
139/// The attributes set here are mostly global target-configuration and
140/// pipeline-configuration options like the target CPU, variant stack
141/// rules, whether to optimize for size, and so on. This is useful for
142/// frontends (such as Swift) that generally intend to interoperate with
143/// C code and rely on Clang's target configuration logic.
144///
145/// As a general rule, this function assumes that meaningful attributes
146/// haven't already been added to the builder. It won't intentionally
147/// displace any existing attributes, but it also won't check to avoid
148/// overwriting them. Callers should generally apply customizations after
149/// making this call.
150///
151/// This function assumes that the caller is not defining a function that
152/// requires special no-builtin treatment.
153void addDefaultFunctionDefinitionAttributes(CodeGenModule &CGM,
154 llvm::AttrBuilder &attrs);
155
156/// Returns the default constructor for a C struct with non-trivially copyable
157/// fields, generating it if necessary. The returned function uses the `cdecl`
158/// calling convention, returns void, and takes a single argument that is a
159/// pointer to the address of the struct.
160llvm::Function *getNonTrivialCStructDefaultConstructor(CodeGenModule &GCM,
161 CharUnits DstAlignment,
162 bool IsVolatile,
163 QualType QT);
164
165/// Returns the copy constructor for a C struct with non-trivially copyable
166/// fields, generating it if necessary. The returned function uses the `cdecl`
167/// calling convention, returns void, and takes two arguments: pointers to the
168/// addresses of the destination and source structs, respectively.
169llvm::Function *getNonTrivialCStructCopyConstructor(CodeGenModule &CGM,
170 CharUnits DstAlignment,
171 CharUnits SrcAlignment,
172 bool IsVolatile,
173 QualType QT);
174
175/// Returns the move constructor for a C struct with non-trivially copyable
176/// fields, generating it if necessary. The returned function uses the `cdecl`
177/// calling convention, returns void, and takes two arguments: pointers to the
178/// addresses of the destination and source structs, respectively.
179llvm::Function *getNonTrivialCStructMoveConstructor(CodeGenModule &CGM,
180 CharUnits DstAlignment,
181 CharUnits SrcAlignment,
182 bool IsVolatile,
183 QualType QT);
184
185/// Returns the copy assignment operator for a C struct with non-trivially
186/// copyable fields, generating it if necessary. The returned function uses the
187/// `cdecl` calling convention, returns void, and takes two arguments: pointers
188/// to the addresses of the destination and source structs, respectively.
190 CodeGenModule &CGM, CharUnits DstAlignment, CharUnits SrcAlignment,
191 bool IsVolatile, QualType QT);
192
193/// Return the move assignment operator for a C struct with non-trivially
194/// copyable fields, generating it if necessary. The returned function uses the
195/// `cdecl` calling convention, returns void, and takes two arguments: pointers
196/// to the addresses of the destination and source structs, respectively.
198 CodeGenModule &CGM, CharUnits DstAlignment, CharUnits SrcAlignment,
199 bool IsVolatile, QualType QT);
200
201/// Returns the destructor for a C struct with non-trivially copyable fields,
202/// generating it if necessary. The returned function uses the `cdecl` calling
203/// convention, returns void, and takes a single argument that is a pointer to
204/// the address of the struct.
205llvm::Function *getNonTrivialCStructDestructor(CodeGenModule &CGM,
206 CharUnits DstAlignment,
207 bool IsVolatile, QualType QT);
208
209/// Get a pointer to a protocol object for the given declaration, emitting it if
210/// it hasn't already been emitted in this translation unit. Note that the ABI
211/// for emitting a protocol reference in code (e.g. for a protocol expression)
212/// in most runtimes is not as simple as just materializing a pointer to this
213/// object.
214llvm::Constant *emitObjCProtocolObject(CodeGenModule &CGM,
215 const ObjCProtocolDecl *p);
216
217/// Get the appropriate callee for an ObjC direct method. Returns the thunk
218/// if the receiver may be null (or class may be unrealized) and precondition
219/// thunks are enabled, otherwise returns the true implementation.
220///
221/// This allows external compilers (e.g., Swift) to reuse Clang's thunk
222/// generation logic when calling ObjC direct methods, ensuring consistent
223/// nil-check behavior.
225 const ObjCMethodDecl *OMD,
226 const ObjCContainerDecl *CD,
227 bool ReceiverCanBeNull,
228 bool ClassObjectCanBeUnrealized);
229
230} // end namespace CodeGen
231} // end namespace clang
232
233#endif
Enums/classes describing ABI related information about constructors, destructors and thunks.
C Language Family Type Representation.
Represents a C++ constructor within a class.
Definition DeclCXX.h:2624
Represents a C++ destructor within a class.
Definition DeclCXX.h:2889
Represents a static or instance method of a struct/union/class.
Definition DeclCXX.h:2136
Represents a C++ struct/union/class.
Definition DeclCXX.h:258
Represents a canonical, potentially-qualified type.
CharUnits - This is an opaque type for sizes expressed in character units.
Definition CharUnits.h:38
CGFunctionInfo - Class to encapsulate the information about a function definition.
This class organizes the cross-function state that is used while generating LLVM code.
A class for recording the number of arguments that a function signature requires.
Represents a member of a struct/union/class.
Definition Decl.h:3175
Represents a function declaration or definition.
Definition Decl.h:2015
Represents a prototype with parameter type info, e.g.
Definition TypeBase.h:5357
A class which abstracts out some details necessary for making a call.
Definition TypeBase.h:4664
FunctionType - C99 6.7.5.3 - Function Declarators.
Definition TypeBase.h:4553
GlobalDecl - represents a global declaration.
Definition GlobalDecl.h:57
ObjCContainerDecl - Represents a container for method declarations.
Definition DeclObjC.h:948
ObjCMethodDecl - Represents an instance or class method declaration.
Definition DeclObjC.h:140
Represents an Objective-C protocol declaration.
Definition DeclObjC.h:2084
A (possibly-)qualified type.
Definition TypeBase.h:937
Represents a struct/union/class.
Definition Decl.h:4342
The base class of the type hierarchy.
Definition TypeBase.h:1866
llvm::Value * getCXXDestructorImplicitParam(CodeGenModule &CGM, llvm::BasicBlock *InsertBlock, llvm::BasicBlock::iterator InsertPoint, const CXXDestructorDecl *D, CXXDtorType Type, bool ForVirtualBase, bool Delegating)
const CGFunctionInfo & arrangeFreeFunctionType(CodeGenModule &CGM, CanQual< FunctionProtoType > Ty)
const CGFunctionInfo & arrangeFreeFunctionCall(CodeGenModule &CGM, CanQualType returnType, ArrayRef< CanQualType > argTypes, FunctionType::ExtInfo info, ArrayRef< FunctionProtoType::ExtParameterInfo > paramInfos, RequiredArgs args)
llvm::Type * convertTypeForMemory(CodeGenModule &CGM, QualType T)
const CGFunctionInfo & arrangeObjCMessageSendSignature(CodeGenModule &CGM, const ObjCMethodDecl *MD, QualType receiverType)
llvm::Function * getNonTrivialCStructCopyConstructor(CodeGenModule &CGM, CharUnits DstAlignment, CharUnits SrcAlignment, bool IsVolatile, QualType QT)
Returns the copy constructor for a C struct with non-trivially copyable fields, generating it if nece...
unsigned getLLVMFieldNumber(CodeGenModule &CGM, const RecordDecl *RD, const FieldDecl *FD)
Given a non-bitfield struct field, return its index within the elements of the struct's converted typ...
llvm::Function * getNonTrivialCStructMoveConstructor(CodeGenModule &CGM, CharUnits DstAlignment, CharUnits SrcAlignment, bool IsVolatile, QualType QT)
Returns the move constructor for a C struct with non-trivially copyable fields, generating it if nece...
void addDefaultFunctionDefinitionAttributes(CodeGenModule &CGM, llvm::AttrBuilder &attrs)
Given the language and code-generation options that Clang was configured with, set the default LLVM I...
const CGFunctionInfo & arrangeCXXMethodType(CodeGenModule &CGM, const CXXRecordDecl *RD, const FunctionProtoType *FTP, const CXXMethodDecl *MD)
llvm::Function * getNonTrivialCStructCopyAssignmentOperator(CodeGenModule &CGM, CharUnits DstAlignment, CharUnits SrcAlignment, bool IsVolatile, QualType QT)
Returns the copy assignment operator for a C struct with non-trivially copyable fields,...
llvm::Function * getObjCDirectMethodCallee(CodeGenModule &CGM, const ObjCMethodDecl *OMD, const ObjCContainerDecl *CD, bool ReceiverCanBeNull, bool ClassObjectCanBeUnrealized)
Get the appropriate callee for an ObjC direct method.
llvm::FunctionType * convertFreeFunctionType(CodeGenModule &CGM, const FunctionDecl *FD)
Returns null if the function type is incomplete and can't be lowered.
llvm::Function * getNonTrivialCStructMoveAssignmentOperator(CodeGenModule &CGM, CharUnits DstAlignment, CharUnits SrcAlignment, bool IsVolatile, QualType QT)
Return the move assignment operator for a C struct with non-trivially copyable fields,...
llvm::Constant * emitObjCProtocolObject(CodeGenModule &CGM, const ObjCProtocolDecl *p)
Get a pointer to a protocol object for the given declaration, emitting it if it hasn't already been e...
uint16_t getPointerAuthDeclDiscriminator(CodeGenModule &CGM, GlobalDecl GD)
Return a declaration discriminator for the given global decl.
llvm::Function * getNonTrivialCStructDestructor(CodeGenModule &CGM, CharUnits DstAlignment, bool IsVolatile, QualType QT)
Returns the destructor for a C struct with non-trivially copyable fields, generating it if necessary.
const CGFunctionInfo & arrangeCXXMethodCall(CodeGenModule &CGM, CanQualType returnType, ArrayRef< CanQualType > argTypes, FunctionType::ExtInfo info, ArrayRef< FunctionProtoType::ExtParameterInfo > paramInfos, RequiredArgs args)
ImplicitCXXConstructorArgs getImplicitCXXConstructorArgs(CodeGenModule &CGM, const CXXConstructorDecl *D)
Returns the implicit arguments to add to a complete, non-delegating C++ constructor call.
llvm::Constant * getConstantSignedPointer(CodeGenModule &CGM, llvm::Constant *Pointer, unsigned Key, llvm::Constant *StorageAddress, llvm::ConstantInt *OtherDiscriminator)
Return a signed constant pointer.
llvm::Function * getNonTrivialCStructDefaultConstructor(CodeGenModule &GCM, CharUnits DstAlignment, bool IsVolatile, QualType QT)
Returns the default constructor for a C struct with non-trivially copyable fields,...
uint16_t getPointerAuthTypeDiscriminator(CodeGenModule &CGM, QualType FunctionType)
Return a type discriminator for the given function type.
The JSON file list parser is used to communicate input to InstallAPI.
CanQual< Type > CanQualType
Represents a canonical, potentially-qualified type.
CXXDtorType
C++ destructor types.
Definition ABI.h:34
Diagnostic wrappers for TextAPI types for error reporting.
Definition Dominators.h:30
Additional implicit arguments to add to a constructor argument list.
SmallVector< llvm::Value *, 1 > Prefix
Implicit arguments to add before the explicit arguments, but after the *this argument (which always c...
SmallVector< llvm::Value *, 1 > Suffix
Implicit arguments to add after the explicit arguments.