Flip the switch and use the new vtable layout code for thunks by default. Add a thunks.cpp test.

llvm-svn: 99367
This commit is contained in:
Anders Carlsson 2010-03-24 00:41:37 +00:00
parent 6c2d178957
commit 68fdb871dc
2 changed files with 116 additions and 7 deletions

View File

@ -3881,13 +3881,6 @@ void CodeGenVTables::EmitThunk(GlobalDecl GD, const ThunkInfo &Thunk)
void CodeGenVTables::EmitThunks(GlobalDecl GD)
{
// FIXME: We use the -fdump-vtable-layouts flag to trigger the new thunk
// building code for now.
if (!CGM.getLangOptions().DumpVtableLayouts) {
CGM.BuildThunksForVirtual(GD);
return;
}
const CXXMethodDecl *MD =
cast<CXXMethodDecl>(GD.getDecl())->getCanonicalDecl();

View File

@ -0,0 +1,116 @@
// RUN: %clang_cc1 %s -triple=x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s
namespace Test1 {
// Check that we emit a non-virtual thunk for C::f.
struct A {
virtual void f();
};
struct B {
virtual void f();
};
struct C : A, B {
virtual void c();
virtual void f();
};
// CHECK: define weak void @_ZThn8_N5Test11C1fEv(
void C::f() { }
}
namespace Test2 {
// Check that we emit a thunk for B::f since it's overriding a virtual base.
struct A {
virtual void f();
};
struct B : virtual A {
virtual void b();
virtual void f();
};
// CHECK: define weak void @_ZTv0_n24_N5Test21B1fEv(
void B::f() { }
}
namespace Test3 {
// Check that we emit a covariant thunk for B::f.
struct V1 { };
struct V2 : virtual V1 { };
struct A {
virtual V1 *f();
};
struct B : A {
virtual void b();
virtual V2 *f();
};
// CHECK: define weak %{{.*}}* @_ZTch0_v0_n24_N5Test31B1fEv(
V2 *B::f() { return 0; }
}
namespace Test4 {
// Check that the thunk for 'C::f' has the same visibility as the function itself.
struct A {
virtual void f();
};
struct B {
virtual void f();
};
struct __attribute__((visibility("protected"))) C : A, B {
virtual void c();
virtual void f();
};
// CHECK: define weak protected void @_ZThn8_N5Test41C1fEv(
void C::f() { }
}
// Check that the thunk gets internal linkage.
namespace {
struct A {
virtual void f();
};
struct B {
virtual void f();
};
struct C : A, B {
virtual void c();
virtual void f();
};
// CHECK: define internal void @_ZThn8_N12_GLOBAL__N_11C1fEv(
void C::f() { }
}
// Force C::f to be used.
void f() {
C c;
c.f();
}