blob: 1a0ae80952a6269aadf31d08f277cd75d4f62bdb [file] [log] [blame]
John McCall358d0562011-03-27 09:00:25 +00001//===--- CGVTables.h - Emit LLVM Code for C++ vtables -----------*- C++ -*-===//
Anders Carlsson2bb27f52009-10-11 22:13:54 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This contains code dealing with C++ code generation of virtual tables.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef CLANG_CODEGEN_CGVTABLE_H
15#define CLANG_CODEGEN_CGVTABLE_H
16
17#include "llvm/ADT/DenseMap.h"
Anders Carlsson0911ae82009-12-06 00:23:49 +000018#include "llvm/GlobalVariable.h"
Peter Collingbourne0ff0b372011-01-13 18:57:25 +000019#include "clang/Basic/ABI.h"
Peter Collingbourne66c3a832011-09-26 01:56:16 +000020#include "clang/AST/BaseSubobject.h"
Ken Dyck16ffcac2011-03-24 01:21:01 +000021#include "clang/AST/CharUnits.h"
Peter Collingbourneee781d52011-06-14 04:02:39 +000022#include "clang/AST/GlobalDecl.h"
Anders Carlsson2bb27f52009-10-11 22:13:54 +000023
24namespace clang {
Anders Carlsson2bb27f52009-10-11 22:13:54 +000025 class CXXRecordDecl;
Benjamin Kramer334af992009-11-26 13:09:03 +000026
Anders Carlsson2bb27f52009-10-11 22:13:54 +000027namespace CodeGen {
28 class CodeGenModule;
Anders Carlssonc7785402009-11-26 02:32:05 +000029
Anders Carlssona864caf2010-03-23 04:11:45 +000030class CodeGenVTables {
Anders Carlsson2bb27f52009-10-11 22:13:54 +000031 CodeGenModule &CGM;
Benjamin Kramer334af992009-11-26 13:09:03 +000032
Anders Carlsson11e51402010-04-17 20:15:18 +000033 /// MethodVTableIndices - Contains the index (relative to the vtable address
Anders Carlsson2bb27f52009-10-11 22:13:54 +000034 /// point) where the function pointer for a virtual function is stored.
Anders Carlsson11e51402010-04-17 20:15:18 +000035 typedef llvm::DenseMap<GlobalDecl, int64_t> MethodVTableIndicesTy;
36 MethodVTableIndicesTy MethodVTableIndices;
Benjamin Kramer334af992009-11-26 13:09:03 +000037
Anders Carlsson2bb27f52009-10-11 22:13:54 +000038 typedef std::pair<const CXXRecordDecl *,
39 const CXXRecordDecl *> ClassPairTy;
Benjamin Kramer334af992009-11-26 13:09:03 +000040
Anders Carlsson4cbe83c2010-03-11 07:15:17 +000041 /// VirtualBaseClassOffsetOffsets - Contains the vtable offset (relative to
Ken Dyck3a09bc52011-04-07 01:22:42 +000042 /// the address point) in chars where the offsets for virtual bases of a class
Anders Carlsson4cbe83c2010-03-11 07:15:17 +000043 /// are stored.
Ken Dyck3a09bc52011-04-07 01:22:42 +000044 typedef llvm::DenseMap<ClassPairTy, CharUnits>
Anders Carlsson4cbe83c2010-03-11 07:15:17 +000045 VirtualBaseClassOffsetOffsetsMapTy;
46 VirtualBaseClassOffsetOffsetsMapTy VirtualBaseClassOffsetOffsets;
Mike Stumpd846d082009-11-10 07:44:33 +000047
Anders Carlsson11e51402010-04-17 20:15:18 +000048 /// VTables - All the vtables which have been defined.
49 llvm::DenseMap<const CXXRecordDecl *, llvm::GlobalVariable *> VTables;
Anders Carlssonf942ee02009-11-27 20:47:55 +000050
51 /// NumVirtualFunctionPointers - Contains the number of virtual function
52 /// pointers in the vtable for a given record decl.
53 llvm::DenseMap<const CXXRecordDecl *, uint64_t> NumVirtualFunctionPointers;
54
Chris Lattner01cf8db2011-07-20 06:58:45 +000055 typedef SmallVector<ThunkInfo, 1> ThunkInfoVectorTy;
Anders Carlsson5c5abad2010-03-23 16:36:50 +000056 typedef llvm::DenseMap<const CXXMethodDecl *, ThunkInfoVectorTy> ThunksMapTy;
57
58 /// Thunks - Contains all thunks that a given method decl will need.
59 ThunksMapTy Thunks;
John McCall6a7f9f52010-06-02 21:22:02 +000060
61 // The layout entry and a bool indicating whether we've actually emitted
62 // the vtable.
63 typedef llvm::PointerIntPair<uint64_t *, 1, bool> VTableLayoutData;
64 typedef llvm::DenseMap<const CXXRecordDecl *, VTableLayoutData>
65 VTableLayoutMapTy;
Anders Carlssone90954d2010-03-24 16:42:11 +000066
67 /// VTableLayoutMap - Stores the vtable layout for all record decls.
68 /// The layout is stored as an array of 64-bit integers, where the first
69 /// integer is the number of vtable entries in the layout, and the subsequent
70 /// integers are the vtable components.
71 VTableLayoutMapTy VTableLayoutMap;
72
Anders Carlsson8bdbb5b2010-05-03 00:55:11 +000073 typedef std::pair<const CXXRecordDecl *, BaseSubobject> BaseSubobjectPairTy;
74 typedef llvm::DenseMap<BaseSubobjectPairTy, uint64_t> AddressPointsMapTy;
Anders Carlssond03325c2010-03-25 00:51:13 +000075
Anders Carlssona208b392010-03-26 03:56:54 +000076 /// Address points - Address points for all vtables.
Anders Carlssond03325c2010-03-25 00:51:13 +000077 AddressPointsMapTy AddressPoints;
Anders Carlssona208b392010-03-26 03:56:54 +000078
79 /// VTableAddressPointsMapTy - Address points for a single vtable.
80 typedef llvm::DenseMap<BaseSubobject, uint64_t> VTableAddressPointsMapTy;
81
Chris Lattner01cf8db2011-07-20 06:58:45 +000082 typedef SmallVector<std::pair<uint64_t, ThunkInfo>, 1>
Anders Carlssona4147142010-03-25 15:26:28 +000083 VTableThunksTy;
84
85 typedef llvm::DenseMap<const CXXRecordDecl *, VTableThunksTy>
86 VTableThunksMapTy;
87
88 /// VTableThunksMap - Contains thunks needed by vtables.
89 VTableThunksMapTy VTableThunksMap;
90
Anders Carlssone90954d2010-03-24 16:42:11 +000091 uint64_t getNumVTableComponents(const CXXRecordDecl *RD) const {
92 assert(VTableLayoutMap.count(RD) && "No vtable layout for this class!");
93
John McCall6a7f9f52010-06-02 21:22:02 +000094 return VTableLayoutMap.lookup(RD).getPointer()[0];
Anders Carlssone90954d2010-03-24 16:42:11 +000095 }
96
Anders Carlssona627ac7e2010-03-29 03:38:52 +000097 const uint64_t *getVTableComponentsData(const CXXRecordDecl *RD) const {
98 assert(VTableLayoutMap.count(RD) && "No vtable layout for this class!");
99
John McCall6a7f9f52010-06-02 21:22:02 +0000100 uint64_t *Components = VTableLayoutMap.lookup(RD).getPointer();
Anders Carlssona627ac7e2010-03-29 03:38:52 +0000101 return &Components[1];
102 }
103
Anders Carlsson8bdbb5b2010-05-03 00:55:11 +0000104 typedef llvm::DenseMap<BaseSubobjectPairTy, uint64_t> SubVTTIndiciesMapTy;
Anders Carlssonf1a994c2010-03-26 04:23:58 +0000105
106 /// SubVTTIndicies - Contains indices into the various sub-VTTs.
107 SubVTTIndiciesMapTy SubVTTIndicies;
108
Anders Carlsson8bdbb5b2010-05-03 00:55:11 +0000109 typedef llvm::DenseMap<BaseSubobjectPairTy, uint64_t>
Anders Carlssonf1a994c2010-03-26 04:23:58 +0000110 SecondaryVirtualPointerIndicesMapTy;
111
112 /// SecondaryVirtualPointerIndices - Contains the secondary virtual pointer
113 /// indices.
114 SecondaryVirtualPointerIndicesMapTy SecondaryVirtualPointerIndices;
Anders Carlssone36a6b32010-01-02 01:01:18 +0000115
Anders Carlssonf942ee02009-11-27 20:47:55 +0000116 /// getNumVirtualFunctionPointers - Return the number of virtual function
117 /// pointers in the vtable for a given record decl.
118 uint64_t getNumVirtualFunctionPointers(const CXXRecordDecl *RD);
119
Anders Carlsson11e51402010-04-17 20:15:18 +0000120 void ComputeMethodVTableIndices(const CXXRecordDecl *RD);
Anders Carlssonfe5f7d92009-12-06 01:09:21 +0000121
Anders Carlsson5c5abad2010-03-23 16:36:50 +0000122 /// EmitThunk - Emit a single thunk.
Anders Carlsson8b021832011-02-06 18:31:40 +0000123 void EmitThunk(GlobalDecl GD, const ThunkInfo &Thunk,
124 bool UseAvailableExternallyLinkage);
125
126 /// MaybeEmitThunkAvailableExternally - Try to emit the given thunk with
127 /// available_externally linkage to allow for inlining of thunks.
128 /// This will be done iff optimizations are enabled and the member function
129 /// doesn't contain any incomplete types.
130 void MaybeEmitThunkAvailableExternally(GlobalDecl GD, const ThunkInfo &Thunk);
131
Anders Carlssone90954d2010-03-24 16:42:11 +0000132 /// ComputeVTableRelatedInformation - Compute and store all vtable related
133 /// information (vtable layout, vbase offset offsets, thunks etc) for the
134 /// given record decl.
John McCall6a7f9f52010-06-02 21:22:02 +0000135 void ComputeVTableRelatedInformation(const CXXRecordDecl *RD,
136 bool VTableRequired);
Anders Carlssone90954d2010-03-24 16:42:11 +0000137
Anders Carlssona4147142010-03-25 15:26:28 +0000138 /// CreateVTableInitializer - Create a vtable initializer for the given record
139 /// decl.
140 /// \param Components - The vtable components; this is really an array of
141 /// VTableComponents.
142 llvm::Constant *CreateVTableInitializer(const CXXRecordDecl *RD,
143 const uint64_t *Components,
144 unsigned NumComponents,
145 const VTableThunksTy &VTableThunks);
Anders Carlssona208b392010-03-26 03:56:54 +0000146
Anders Carlsson2bb27f52009-10-11 22:13:54 +0000147public:
Anders Carlssona864caf2010-03-23 04:11:45 +0000148 CodeGenVTables(CodeGenModule &CGM)
Anders Carlsson2bb27f52009-10-11 22:13:54 +0000149 : CGM(CGM) { }
150
Argyrios Kyrtzidis0c34b132010-10-11 03:25:57 +0000151 /// \brief True if the VTable of this record must be emitted in the
152 /// translation unit.
153 bool ShouldEmitVTableInThisTU(const CXXRecordDecl *RD);
Rafael Espindola683fe4f2010-04-19 00:44:22 +0000154
Anders Carlssone36a6b32010-01-02 01:01:18 +0000155 /// needsVTTParameter - Return whether the given global decl needs a VTT
156 /// parameter, which it does if it's a base constructor or destructor with
157 /// virtual bases.
158 static bool needsVTTParameter(GlobalDecl GD);
159
160 /// getSubVTTIndex - Return the index of the sub-VTT for the base class of the
161 /// given record decl.
Anders Carlsson859b3062010-05-02 23:53:25 +0000162 uint64_t getSubVTTIndex(const CXXRecordDecl *RD, BaseSubobject Base);
Anders Carlssone36a6b32010-01-02 01:01:18 +0000163
Anders Carlssonf1a994c2010-03-26 04:23:58 +0000164 /// getSecondaryVirtualPointerIndex - Return the index in the VTT where the
165 /// virtual pointer for the given subobject is located.
166 uint64_t getSecondaryVirtualPointerIndex(const CXXRecordDecl *RD,
167 BaseSubobject Base);
168
Anders Carlsson11e51402010-04-17 20:15:18 +0000169 /// getMethodVTableIndex - Return the index (relative to the vtable address
Benjamin Kramer334af992009-11-26 13:09:03 +0000170 /// point) where the function pointer for the given virtual function is
Anders Carlsson2bb27f52009-10-11 22:13:54 +0000171 /// stored.
Anders Carlsson11e51402010-04-17 20:15:18 +0000172 uint64_t getMethodVTableIndex(GlobalDecl GD);
Benjamin Kramer334af992009-11-26 13:09:03 +0000173
Ken Dyckbb4e9772011-04-07 12:37:09 +0000174 /// getVirtualBaseOffsetOffset - Return the offset in chars (relative to the
Anders Carlsson4cbe83c2010-03-11 07:15:17 +0000175 /// vtable address point) where the offset of the virtual base that contains
176 /// the given base is stored, otherwise, if no virtual base contains the given
Mike Stump28431212009-10-13 22:54:56 +0000177 /// class, return 0. Base must be a virtual base class or an unambigious
178 /// base.
Ken Dyckbb4e9772011-04-07 12:37:09 +0000179 CharUnits getVirtualBaseOffsetOffset(const CXXRecordDecl *RD,
180 const CXXRecordDecl *VBase);
Mike Stumpd846d082009-11-10 07:44:33 +0000181
Anders Carlssonf6f24c62010-03-29 02:08:26 +0000182 /// getAddressPoint - Get the address point of the given subobject in the
183 /// class decl.
184 uint64_t getAddressPoint(BaseSubobject Base, const CXXRecordDecl *RD);
185
Anders Carlsson67fbf982010-03-24 05:32:05 +0000186 /// GetAddrOfVTable - Get the address of the vtable for the given record decl.
Anders Carlssona086edc2010-03-30 03:35:35 +0000187 llvm::GlobalVariable *GetAddrOfVTable(const CXXRecordDecl *RD);
Anders Carlssonb35ea552010-03-24 03:57:14 +0000188
Anders Carlssona627ac7e2010-03-29 03:38:52 +0000189 /// EmitVTableDefinition - Emit the definition of the given vtable.
190 void EmitVTableDefinition(llvm::GlobalVariable *VTable,
191 llvm::GlobalVariable::LinkageTypes Linkage,
192 const CXXRecordDecl *RD);
193
Anders Carlsson0534b022010-03-25 00:35:49 +0000194 /// GenerateConstructionVTable - Generate a construction vtable for the given
195 /// base subobject.
196 llvm::GlobalVariable *
197 GenerateConstructionVTable(const CXXRecordDecl *RD, const BaseSubobject &Base,
198 bool BaseIsVirtual,
John McCall358d0562011-03-27 09:00:25 +0000199 llvm::GlobalVariable::LinkageTypes Linkage,
Anders Carlssona208b392010-03-26 03:56:54 +0000200 VTableAddressPointsMapTy& AddressPoints);
Anders Carlsson883fc722011-01-29 19:16:51 +0000201
202
203 /// GetAddrOfVTable - Get the address of the VTT for the given record decl.
204 llvm::GlobalVariable *GetAddrOfVTT(const CXXRecordDecl *RD);
205
206 /// EmitVTTDefinition - Emit the definition of the given vtable.
207 void EmitVTTDefinition(llvm::GlobalVariable *VTT,
208 llvm::GlobalVariable::LinkageTypes Linkage,
209 const CXXRecordDecl *RD);
Rafael Espindolae7113ca2010-03-10 02:19:29 +0000210
Douglas Gregor88d292c2010-05-13 16:44:06 +0000211 /// EmitThunks - Emit the associated thunks for the given global decl.
212 void EmitThunks(GlobalDecl GD);
213
Anders Carlsson55e89f82010-03-23 18:18:41 +0000214 /// GenerateClassData - Generate all the class data required to be generated
Rafael Espindolae7113ca2010-03-10 02:19:29 +0000215 /// upon definition of a KeyFunction. This includes the vtable, the
216 /// rtti data structure and the VTT.
217 ///
218 /// \param Linkage - The desired linkage of the vtable, the RTTI and the VTT.
219 void GenerateClassData(llvm::GlobalVariable::LinkageTypes Linkage,
220 const CXXRecordDecl *RD);
Anders Carlsson2bb27f52009-10-11 22:13:54 +0000221};
Benjamin Kramer334af992009-11-26 13:09:03 +0000222
Anders Carlsson5f9a8812010-01-14 02:29:07 +0000223} // end namespace CodeGen
224} // end namespace clang
Anders Carlsson2bb27f52009-10-11 22:13:54 +0000225#endif