From: Rafael Espindola Date: Fri, 16 Jan 2015 21:41:44 +0000 (+0000) Subject: Also put vtables in a comdat when rtti is disabled. X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=4af2cdb7324916a71dbcfdaa7faa8db625d1d1d3;p=platform%2Fupstream%2Fllvm.git Also put vtables in a comdat when rtti is disabled. llvm-svn: 226325 --- diff --git a/clang/lib/CodeGen/MicrosoftCXXABI.cpp b/clang/lib/CodeGen/MicrosoftCXXABI.cpp index 1402b52..c7e66e9 100644 --- a/clang/lib/CodeGen/MicrosoftCXXABI.cpp +++ b/clang/lib/CodeGen/MicrosoftCXXABI.cpp @@ -1420,6 +1420,10 @@ llvm::GlobalVariable *MicrosoftCXXABI::getAddrOfVTable(const CXXRecordDecl *RD, } else { llvm_unreachable("unexpected linkage for vftable!"); } + } else { + if (llvm::GlobalValue::isWeakForLinker(VFTableLinkage)) + VTable->setComdat( + CGM.getModule().getOrInsertComdat(VTable->getName())); } VFTable->setLinkage(VFTableLinkage); CGM.setGlobalVisibility(VFTable, RD); diff --git a/clang/test/CodeGenCXX/microsoft-no-rtti-data.cpp b/clang/test/CodeGenCXX/microsoft-no-rtti-data.cpp index fded4c9..68fdf05 100644 --- a/clang/test/CodeGenCXX/microsoft-no-rtti-data.cpp +++ b/clang/test/CodeGenCXX/microsoft-no-rtti-data.cpp @@ -2,7 +2,7 @@ // vftable shouldn't have RTTI data in it. // CHECK-NOT: @"\01??_R4S@@6B@" -// CHECK: @"\01??_7S@@6B@" = linkonce_odr unnamed_addr constant [1 x i8*] [i8* bitcast ({{.*}} @"\01??_GS@@UAEPAXI@Z" to i8*)] +// CHECK: @"\01??_7S@@6B@" = linkonce_odr unnamed_addr constant [1 x i8*] [i8* bitcast ({{.*}} @"\01??_GS@@UAEPAXI@Z" to i8*)], comdat struct type_info; namespace std { using ::type_info; }