Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / CodeGenCXX / apple-kext-indirect-call.cpp
blob31afa0c669107a432a7c74be8e484ecbe2a27eaa
1 // RUN: %clang_cc1 -triple x86_64-apple-darwin10 -fapple-kext -emit-llvm -o - %s | FileCheck %s
3 // CHECK: @_ZTV5TemplIiE = internal unnamed_addr constant { [5 x ptr] } { [5 x ptr] [ptr null, ptr @_ZTI5TemplIiE, ptr @_ZN5TemplIiE1fEv, ptr @_ZN5TemplIiE1gEv, ptr null] }
5 struct Base {
6 virtual void abc(void) const;
7 };
9 void Base::abc(void) const {}
11 void FUNC(Base* p) {
12 p->Base::abc();
15 // CHECK: getelementptr inbounds (ptr, ptr @_ZTV4Base, i64 2)
16 // CHECK-NOT: call void @_ZNK4Base3abcEv
18 template<class T>
19 struct Templ {
20 virtual void f() {}
21 virtual void g() {}
23 template<class T>
24 struct SubTempl : public Templ<T> {
25 virtual void f() {} // override
26 virtual void g() {} // override
29 void f(SubTempl<int>* t) {
30 // Qualified calls go through the (qualified) vtable in apple-kext mode.
31 // Since t's this pointer points to SubTempl's vtable, the call needs
32 // to load Templ<int>'s vtable. Hence, Templ<int>::g needs to be
33 // instantiated in this TU, for it's referenced by the vtable.
34 // (This happens only in apple-kext mode; elsewhere virtual calls can always
35 // use the vtable pointer off this instead of having to load the vtable
36 // symbol.)
37 t->Templ::f();
40 // CHECK: getelementptr inbounds (ptr, ptr @_ZTV5TemplIiE, i64 2)
41 // CHECK: define internal void @_ZN5TemplIiE1fEv(ptr {{[^,]*}} %this)
42 // CHECK: define internal void @_ZN5TemplIiE1gEv(ptr {{[^,]*}} %this)