From: Anders Carlsson Date: Tue, 20 Apr 2010 18:05:10 +0000 (+0000) Subject: Back out r101911 and see if it makes the bots happy. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3e79c30807c516e8d32e4ed08408b30605df5997;p=clang Back out r101911 and see if it makes the bots happy. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@101921 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGClass.cpp b/lib/CodeGen/CGClass.cpp index b2991ade43..a21af413fd 100644 --- a/lib/CodeGen/CGClass.cpp +++ b/lib/CodeGen/CGClass.cpp @@ -1549,7 +1549,6 @@ CodeGenFunction::GetVirtualBaseClassOffset(llvm::Value *This, void CodeGenFunction::InitializeVTablePointer(BaseSubobject Base, const CXXRecordDecl *NearestVBase, - uint64_t BaseOffsetFromNearestVBase, llvm::Constant *VTable, const CXXRecordDecl *VTableClass) { const CXXRecordDecl *RD = Base.getBase(); @@ -1577,31 +1576,21 @@ CodeGenFunction::InitializeVTablePointer(BaseSubobject Base, Builder.CreateConstInBoundsGEP2_64(VTable, 0, AddressPoint); } - llvm::Value *VTableField = LoadCXXThis(); - // Compute where to store the address point. - uint64_t NonVirtualOffset = BaseOffsetFromNearestVBase; - - llvm::Value *VirtualOffset = 0; - if (NearestVBase) { - if (!CodeGenVTables::needsVTTParameter(CurGD)) { - // Just get the vbase offset in the complete class. - const ASTRecordLayout &Layout = - getContext().getASTRecordLayout(VTableClass); - - NonVirtualOffset += Layout.getVBaseClassOffset(NearestVBase); - } else { - // We need to use the virtual base offset offset because the virtual base - // might have a different offset in the most derived class. - VirtualOffset = GetVirtualBaseClassOffset(VTableField, - VTableClass, NearestVBase); - } - } + llvm::Value *VTableField; + + if (CodeGenVTables::needsVTTParameter(CurGD) && NearestVBase) { + // We need to use the virtual base offset offset because the virtual base + // might have a different offset in the most derived class. + VTableField = GetAddressOfBaseClass(LoadCXXThis(), VTableClass, RD, + /*NullCheckValue=*/false); + } else { + const llvm::Type *Int8PtrTy = llvm::Type::getInt8PtrTy(CGM.getLLVMContext()); - if (NonVirtualOffset || VirtualOffset) + VTableField = Builder.CreateBitCast(LoadCXXThis(), Int8PtrTy); VTableField = - ApplyNonVirtualAndVirtualOffset(*this, VTableField, - NonVirtualOffset, VirtualOffset); + Builder.CreateConstInBoundsGEP1_64(VTableField, Base.getBaseOffset() / 8); + } // Finally, store the address point. const llvm::Type *AddressPointPtrTy = @@ -1613,7 +1602,6 @@ CodeGenFunction::InitializeVTablePointer(BaseSubobject Base, void CodeGenFunction::InitializeVTablePointers(BaseSubobject Base, const CXXRecordDecl *NearestVBase, - uint64_t BaseOffsetFromNearestVBase, bool BaseIsNonVirtualPrimaryBase, llvm::Constant *VTable, const CXXRecordDecl *VTableClass, @@ -1622,8 +1610,7 @@ CodeGenFunction::InitializeVTablePointers(BaseSubobject Base, // been set. if (!BaseIsNonVirtualPrimaryBase) { // Initialize the vtable pointer for this base. - InitializeVTablePointer(Base, NearestVBase, BaseOffsetFromNearestVBase, - VTable, VTableClass); + InitializeVTablePointer(Base, NearestVBase, VTable, VTableClass); } const CXXRecordDecl *RD = Base.getBase(); @@ -1660,7 +1647,6 @@ CodeGenFunction::InitializeVTablePointers(BaseSubobject Base, InitializeVTablePointers(BaseSubobject(BaseDecl, BaseOffset), I->isVirtual() ? BaseDecl : NearestVBase, - I->isVirtual() ? 0 : BaseOffsetFromNearestVBase, BaseDeclIsNonVirtualPrimaryBase, VTable, VTableClass, VBases); } @@ -1677,7 +1663,6 @@ void CodeGenFunction::InitializeVTablePointers(const CXXRecordDecl *RD) { // Initialize the vtable pointers for this class and all of its bases. VisitedVirtualBasesSetTy VBases; InitializeVTablePointers(BaseSubobject(RD, 0), /*NearestVBase=*/0, - /*BaseOffsetFromNearestVBase=*/0, /*BaseIsNonVirtualPrimaryBase=*/false, VTable, RD, VBases); } diff --git a/lib/CodeGen/CodeGenFunction.h b/lib/CodeGen/CodeGenFunction.h index 12e37e42d7..c43e0006e6 100644 --- a/lib/CodeGen/CodeGenFunction.h +++ b/lib/CodeGen/CodeGenFunction.h @@ -536,14 +536,12 @@ public: /// void InitializeVTablePointer(BaseSubobject Base, const CXXRecordDecl *NearestVBase, - uint64_t BaseOffsetFromNearestVBase, llvm::Constant *VTable, const CXXRecordDecl *VTableClass); typedef llvm::SmallPtrSet VisitedVirtualBasesSetTy; void InitializeVTablePointers(BaseSubobject Base, const CXXRecordDecl *NearestVBase, - uint64_t BaseOffsetFromNearestVBase, bool BaseIsNonVirtualPrimaryBase, llvm::Constant *VTable, const CXXRecordDecl *VTableClass, diff --git a/test/CodeGenCXX/vtable-pointer-initialization.cpp b/test/CodeGenCXX/vtable-pointer-initialization.cpp index ca8fb9be88..75620ab8e6 100644 --- a/test/CodeGenCXX/vtable-pointer-initialization.cpp +++ b/test/CodeGenCXX/vtable-pointer-initialization.cpp @@ -55,23 +55,3 @@ void f() { B b; } // CHECK: store i8** getelementptr inbounds ([3 x i8*]* @_ZTV1B, i64 0, i64 2) // CHECK: call void @_ZN5FieldC1Ev // CHECK: ret void - -namespace Test1 { - -// Test that we don't assert when initializing the vtable pointers in C. -struct A { - virtual void a(); - int i; -}; - -struct B : virtual A { - virtual void b(); -}; - -struct C : A, virtual B { - virtual void c(); - C(); -}; - -C::C() { } -}