diff options
Diffstat (limited to 'lib/CodeGen/CGVTables.h')
| -rw-r--r-- | lib/CodeGen/CGVTables.h | 40 | 
1 files changed, 14 insertions, 26 deletions
| diff --git a/lib/CodeGen/CGVTables.h b/lib/CodeGen/CGVTables.h index bd3bdb13583d5..e8cd55eed80a6 100644 --- a/lib/CodeGen/CGVTables.h +++ b/lib/CodeGen/CGVTables.h @@ -31,10 +31,10 @@ namespace CodeGen {  class CodeGenVTables {    CodeGenModule &CGM; -  VTableContext VTContext; - -  /// VTables - All the vtables which have been defined. -  llvm::DenseMap<const CXXRecordDecl *, llvm::GlobalVariable *> VTables; +  // FIXME: Consider moving ItaniumVTContext and MicrosoftVTContext into +  // respective CXXABI classes? +  ItaniumVTableContext ItaniumVTContext; +  OwningPtr<MicrosoftVTableContext> MicrosoftVTContext;    /// VTableAddressPointsMapTy - Address points for a single vtable.    typedef llvm::DenseMap<BaseSubobject, uint64_t> VTableAddressPointsMapTy; @@ -52,16 +52,14 @@ class CodeGenVTables {    /// indices.    SecondaryVirtualPointerIndicesMapTy SecondaryVirtualPointerIndices; -  /// EmitThunk - Emit a single thunk. -  void EmitThunk(GlobalDecl GD, const ThunkInfo &Thunk,  -                 bool UseAvailableExternallyLinkage); +  /// emitThunk - Emit a single thunk. +  void emitThunk(GlobalDecl GD, const ThunkInfo &Thunk, bool ForVTable); -  /// MaybeEmitThunkAvailableExternally - Try to emit the given thunk with -  /// available_externally linkage to allow for inlining of thunks. -  /// This will be done iff optimizations are enabled and the member function -  /// doesn't contain any incomplete types. -  void MaybeEmitThunkAvailableExternally(GlobalDecl GD, const ThunkInfo &Thunk); +  /// maybeEmitThunkForVTable - Emit the given thunk for the vtable if needed by +  /// the ABI. +  void maybeEmitThunkForVTable(GlobalDecl GD, const ThunkInfo &Thunk); +public:    /// CreateVTableInitializer - Create a vtable initializer for the given record    /// decl.    /// \param Components - The vtable components; this is really an array of @@ -72,15 +70,13 @@ class CodeGenVTables {                                  const VTableLayout::VTableThunkTy *VTableThunks,                                            unsigned NumVTableThunks); -public:    CodeGenVTables(CodeGenModule &CGM); -  VTableContext &getVTableContext() { return VTContext; } +  ItaniumVTableContext &getItaniumVTableContext() { return ItaniumVTContext; } -  /// needsVTTParameter - Return whether the given global decl needs a VTT -  /// parameter, which it does if it's a base constructor or destructor with -  /// virtual bases. -  static bool needsVTTParameter(GlobalDecl GD); +  MicrosoftVTableContext &getMicrosoftVTableContext() { +    return *MicrosoftVTContext.get(); +  }    /// getSubVTTIndex - Return the index of the sub-VTT for the base class of the    /// given record decl. @@ -95,14 +91,6 @@ public:    /// class decl.    uint64_t getAddressPoint(BaseSubobject Base, const CXXRecordDecl *RD); -  /// GetAddrOfVTable - Get the address of the vtable for the given record decl. -  llvm::GlobalVariable *GetAddrOfVTable(const CXXRecordDecl *RD); - -  /// EmitVTableDefinition - Emit the definition of the given vtable. -  void EmitVTableDefinition(llvm::GlobalVariable *VTable, -                            llvm::GlobalVariable::LinkageTypes Linkage, -                            const CXXRecordDecl *RD); -      /// GenerateConstructionVTable - Generate a construction vtable for the given     /// base subobject.    llvm::GlobalVariable * | 
