171568a9eSLeonard Chan // The VTable is not in a comdat but the inline methods are. 271568a9eSLeonard Chan // This doesn’t affect the vtable or the stubs we emit. 371568a9eSLeonard Chan 4*cf8ff75bSLeonard Chan // RUN: %clang_cc1 %s -triple=aarch64 -O1 -S -o - -emit-llvm -fexperimental-relative-c++-abi-vtables | FileCheck %s 5*cf8ff75bSLeonard Chan // RUN: %clang_cc1 %s -triple=x86_64 -O1 -S -o - -emit-llvm -fexperimental-relative-c++-abi-vtables | FileCheck %s 671568a9eSLeonard Chan 771568a9eSLeonard Chan // CHECK: $_ZTI1A.rtti_proxy = comdat any 871568a9eSLeonard Chan 971568a9eSLeonard Chan // The vtable has a key function (A::foo()) so it does not have a comdat 10*cf8ff75bSLeonard Chan // CHECK: @_ZTV1A.local = private unnamed_addr constant { [4 x i32] } { [4 x i32] [i32 0, i32 trunc (i64 sub (i64 ptrtoint ({ i8*, i8* }** @_ZTI1A.rtti_proxy to i64), i64 ptrtoint (i32* getelementptr inbounds ({ [4 x i32] }, { [4 x i32] }* @_ZTV1A.local, i32 0, i32 0, i32 2) to i64)) to i32), i32 trunc (i64 sub (i64 ptrtoint (void (%class.A*)* dso_local_equivalent @_ZN1A3fooEv to i64), i64 ptrtoint (i32* getelementptr inbounds ({ [4 x i32] }, { [4 x i32] }* @_ZTV1A.local, i32 0, i32 0, i32 2) to i64)) to i32), i32 trunc (i64 sub (i64 ptrtoint (void (%class.A*)* dso_local_equivalent @_ZN1A3barEv to i64), i64 ptrtoint (i32* getelementptr inbounds ({ [4 x i32] }, { [4 x i32] }* @_ZTV1A.local, i32 0, i32 0, i32 2) to i64)) to i32)] }, align 4 1171568a9eSLeonard Chan // CHECK: @_ZTV1A = unnamed_addr alias { [4 x i32] }, { [4 x i32] }* @_ZTV1A.local 1271568a9eSLeonard Chan 1371568a9eSLeonard Chan class A { 1471568a9eSLeonard Chan public: 1571568a9eSLeonard Chan virtual void foo(); // Key func 1671568a9eSLeonard Chan inline virtual void bar() {} 1771568a9eSLeonard Chan }; 1871568a9eSLeonard Chan 1971568a9eSLeonard Chan void A::foo() {} 20