From d63fed48fa958ca7d9a432dab1010c272c19f215 Mon Sep 17 00:00:00 2001 From: Anders Carlsson Date: Wed, 24 Mar 2010 00:41:37 +0000 Subject: [PATCH] Flip the switch and use the new vtable layout code for thunks by default. Add a thunks.cpp test. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@99367 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGVtable.cpp | 7 --- test/CodeGenCXX/thunks.cpp | 116 +++++++++++++++++++++++++++++++++++++ 2 files changed, 116 insertions(+), 7 deletions(-) create mode 100644 test/CodeGenCXX/thunks.cpp diff --git a/lib/CodeGen/CGVtable.cpp b/lib/CodeGen/CGVtable.cpp index 2e4cb61b1f..47509616c5 100644 --- a/lib/CodeGen/CGVtable.cpp +++ b/lib/CodeGen/CGVtable.cpp @@ -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(GD.getDecl())->getCanonicalDecl(); diff --git a/test/CodeGenCXX/thunks.cpp b/test/CodeGenCXX/thunks.cpp new file mode 100644 index 0000000000..2389839921 --- /dev/null +++ b/test/CodeGenCXX/thunks.cpp @@ -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(); +} -- 2.40.0