10b57cec5SDimitry Andric //==--- CodeGenABITypes.cpp - Convert Clang types to LLVM types for ABI ----==//
20b57cec5SDimitry Andric //
30b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
50b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60b57cec5SDimitry Andric //
70b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
80b57cec5SDimitry Andric //
90b57cec5SDimitry Andric // CodeGenABITypes is a simple interface for getting LLVM types for
100b57cec5SDimitry Andric // the parameters and the return value of a function given the Clang
110b57cec5SDimitry Andric // types.
120b57cec5SDimitry Andric //
130b57cec5SDimitry Andric // The class is implemented as a public wrapper around the private
140b57cec5SDimitry Andric // CodeGenTypes class in lib/CodeGen.
150b57cec5SDimitry Andric //
160b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
170b57cec5SDimitry Andric 
180b57cec5SDimitry Andric #include "clang/CodeGen/CodeGenABITypes.h"
195ffd83dbSDimitry Andric #include "CGCXXABI.h"
200b57cec5SDimitry Andric #include "CGRecordLayout.h"
215ffd83dbSDimitry Andric #include "CodeGenFunction.h"
220b57cec5SDimitry Andric #include "CodeGenModule.h"
230b57cec5SDimitry Andric #include "clang/CodeGen/CGFunctionInfo.h"
240b57cec5SDimitry Andric #include "clang/Lex/HeaderSearchOptions.h"
250b57cec5SDimitry Andric #include "clang/Lex/PreprocessorOptions.h"
260b57cec5SDimitry Andric 
270b57cec5SDimitry Andric using namespace clang;
280b57cec5SDimitry Andric using namespace CodeGen;
290b57cec5SDimitry Andric 
addDefaultFunctionDefinitionAttributes(CodeGenModule & CGM,llvm::AttrBuilder & attrs)305ffd83dbSDimitry Andric void CodeGen::addDefaultFunctionDefinitionAttributes(CodeGenModule &CGM,
315ffd83dbSDimitry Andric                                                      llvm::AttrBuilder &attrs) {
325ffd83dbSDimitry Andric   CGM.addDefaultFunctionDefinitionAttributes(attrs);
335ffd83dbSDimitry Andric }
345ffd83dbSDimitry Andric 
350b57cec5SDimitry Andric const CGFunctionInfo &
arrangeObjCMessageSendSignature(CodeGenModule & CGM,const ObjCMethodDecl * MD,QualType receiverType)360b57cec5SDimitry Andric CodeGen::arrangeObjCMessageSendSignature(CodeGenModule &CGM,
370b57cec5SDimitry Andric                                          const ObjCMethodDecl *MD,
380b57cec5SDimitry Andric                                          QualType receiverType) {
390b57cec5SDimitry Andric   return CGM.getTypes().arrangeObjCMessageSendSignature(MD, receiverType);
400b57cec5SDimitry Andric }
410b57cec5SDimitry Andric 
420b57cec5SDimitry Andric const CGFunctionInfo &
arrangeFreeFunctionType(CodeGenModule & CGM,CanQual<FunctionProtoType> Ty)430b57cec5SDimitry Andric CodeGen::arrangeFreeFunctionType(CodeGenModule &CGM,
440b57cec5SDimitry Andric                                  CanQual<FunctionProtoType> Ty) {
450b57cec5SDimitry Andric   return CGM.getTypes().arrangeFreeFunctionType(Ty);
460b57cec5SDimitry Andric }
470b57cec5SDimitry Andric 
480b57cec5SDimitry Andric const CGFunctionInfo &
arrangeFreeFunctionType(CodeGenModule & CGM,CanQual<FunctionNoProtoType> Ty)490b57cec5SDimitry Andric CodeGen::arrangeFreeFunctionType(CodeGenModule &CGM,
500b57cec5SDimitry Andric                                  CanQual<FunctionNoProtoType> Ty) {
510b57cec5SDimitry Andric   return CGM.getTypes().arrangeFreeFunctionType(Ty);
520b57cec5SDimitry Andric }
530b57cec5SDimitry Andric 
540b57cec5SDimitry Andric const CGFunctionInfo &
arrangeCXXMethodType(CodeGenModule & CGM,const CXXRecordDecl * RD,const FunctionProtoType * FTP,const CXXMethodDecl * MD)550b57cec5SDimitry Andric CodeGen::arrangeCXXMethodType(CodeGenModule &CGM,
560b57cec5SDimitry Andric                               const CXXRecordDecl *RD,
570b57cec5SDimitry Andric                               const FunctionProtoType *FTP,
580b57cec5SDimitry Andric                               const CXXMethodDecl *MD) {
590b57cec5SDimitry Andric   return CGM.getTypes().arrangeCXXMethodType(RD, FTP, MD);
600b57cec5SDimitry Andric }
610b57cec5SDimitry Andric 
620b57cec5SDimitry Andric const CGFunctionInfo &
arrangeFreeFunctionCall(CodeGenModule & CGM,CanQualType returnType,ArrayRef<CanQualType> argTypes,FunctionType::ExtInfo info,RequiredArgs args)630b57cec5SDimitry Andric CodeGen::arrangeFreeFunctionCall(CodeGenModule &CGM,
640b57cec5SDimitry Andric                                  CanQualType returnType,
650b57cec5SDimitry Andric                                  ArrayRef<CanQualType> argTypes,
660b57cec5SDimitry Andric                                  FunctionType::ExtInfo info,
670b57cec5SDimitry Andric                                  RequiredArgs args) {
688a4dda33SDimitry Andric   return CGM.getTypes().arrangeLLVMFunctionInfo(returnType, FnInfoOpts::None,
698a4dda33SDimitry Andric                                                 argTypes, info, {}, args);
700b57cec5SDimitry Andric }
710b57cec5SDimitry Andric 
725ffd83dbSDimitry Andric ImplicitCXXConstructorArgs
getImplicitCXXConstructorArgs(CodeGenModule & CGM,const CXXConstructorDecl * D)735ffd83dbSDimitry Andric CodeGen::getImplicitCXXConstructorArgs(CodeGenModule &CGM,
745ffd83dbSDimitry Andric                                        const CXXConstructorDecl *D) {
755ffd83dbSDimitry Andric   // We have to create a dummy CodeGenFunction here to pass to
765ffd83dbSDimitry Andric   // getImplicitConstructorArgs(). In some cases (base and delegating
775ffd83dbSDimitry Andric   // constructor calls), getImplicitConstructorArgs() can reach into the
785ffd83dbSDimitry Andric   // CodeGenFunction to find parameters of the calling constructor to pass on to
795ffd83dbSDimitry Andric   // the called constructor, but that can't happen here because we're asking for
805ffd83dbSDimitry Andric   // the args for a complete, non-delegating constructor call.
815ffd83dbSDimitry Andric   CodeGenFunction CGF(CGM, /* suppressNewContext= */ true);
825ffd83dbSDimitry Andric   CGCXXABI::AddedStructorArgs addedArgs =
835ffd83dbSDimitry Andric       CGM.getCXXABI().getImplicitConstructorArgs(CGF, D, Ctor_Complete,
845ffd83dbSDimitry Andric                                                  /* ForVirtualBase= */ false,
855ffd83dbSDimitry Andric                                                  /* Delegating= */ false);
865ffd83dbSDimitry Andric   ImplicitCXXConstructorArgs implicitArgs;
875ffd83dbSDimitry Andric   for (const auto &arg : addedArgs.Prefix) {
885ffd83dbSDimitry Andric     implicitArgs.Prefix.push_back(arg.Value);
895ffd83dbSDimitry Andric   }
905ffd83dbSDimitry Andric   for (const auto &arg : addedArgs.Suffix) {
915ffd83dbSDimitry Andric     implicitArgs.Suffix.push_back(arg.Value);
925ffd83dbSDimitry Andric   }
935ffd83dbSDimitry Andric   return implicitArgs;
945ffd83dbSDimitry Andric }
955ffd83dbSDimitry Andric 
960b57cec5SDimitry Andric llvm::FunctionType *
convertFreeFunctionType(CodeGenModule & CGM,const FunctionDecl * FD)970b57cec5SDimitry Andric CodeGen::convertFreeFunctionType(CodeGenModule &CGM, const FunctionDecl *FD) {
980b57cec5SDimitry Andric   assert(FD != nullptr && "Expected a non-null function declaration!");
990b57cec5SDimitry Andric   llvm::Type *T = CGM.getTypes().ConvertType(FD->getType());
1000b57cec5SDimitry Andric 
1010b57cec5SDimitry Andric   if (auto FT = dyn_cast<llvm::FunctionType>(T))
1020b57cec5SDimitry Andric     return FT;
1030b57cec5SDimitry Andric 
1040b57cec5SDimitry Andric   return nullptr;
1050b57cec5SDimitry Andric }
1060b57cec5SDimitry Andric 
1070b57cec5SDimitry Andric llvm::Type *
convertTypeForMemory(CodeGenModule & CGM,QualType T)1080b57cec5SDimitry Andric CodeGen::convertTypeForMemory(CodeGenModule &CGM, QualType T) {
1090b57cec5SDimitry Andric   return CGM.getTypes().ConvertTypeForMem(T);
1100b57cec5SDimitry Andric }
1110b57cec5SDimitry Andric 
getLLVMFieldNumber(CodeGenModule & CGM,const RecordDecl * RD,const FieldDecl * FD)1120b57cec5SDimitry Andric unsigned CodeGen::getLLVMFieldNumber(CodeGenModule &CGM,
1130b57cec5SDimitry Andric                                      const RecordDecl *RD,
1140b57cec5SDimitry Andric                                      const FieldDecl *FD) {
1150b57cec5SDimitry Andric   return CGM.getTypes().getCGRecordLayout(RD).getLLVMFieldNo(FD);
1160b57cec5SDimitry Andric }
1175ffd83dbSDimitry Andric 
getCXXDestructorImplicitParam(CodeGenModule & CGM,llvm::BasicBlock * InsertBlock,llvm::BasicBlock::iterator InsertPoint,const CXXDestructorDecl * D,CXXDtorType Type,bool ForVirtualBase,bool Delegating)1185ffd83dbSDimitry Andric llvm::Value *CodeGen::getCXXDestructorImplicitParam(
1195ffd83dbSDimitry Andric     CodeGenModule &CGM, llvm::BasicBlock *InsertBlock,
1205ffd83dbSDimitry Andric     llvm::BasicBlock::iterator InsertPoint, const CXXDestructorDecl *D,
1215ffd83dbSDimitry Andric     CXXDtorType Type, bool ForVirtualBase, bool Delegating) {
1225ffd83dbSDimitry Andric   CodeGenFunction CGF(CGM, /*suppressNewContext=*/true);
1235ffd83dbSDimitry Andric   CGF.CurCodeDecl = D;
1245ffd83dbSDimitry Andric   CGF.CurFuncDecl = D;
1255ffd83dbSDimitry Andric   CGF.CurFn = InsertBlock->getParent();
1265ffd83dbSDimitry Andric   CGF.Builder.SetInsertPoint(InsertBlock, InsertPoint);
1275ffd83dbSDimitry Andric   return CGM.getCXXABI().getCXXDestructorImplicitParam(
1285ffd83dbSDimitry Andric       CGF, D, Type, ForVirtualBase, Delegating);
1295ffd83dbSDimitry Andric }
130