diff options
author | Reid Kleckner <reid@kleckner.net> | 2014-09-23 16:20:01 +0000 |
---|---|---|
committer | Reid Kleckner <reid@kleckner.net> | 2014-09-23 16:20:01 +0000 |
commit | 739aa12b79bcf96f20a106285a939496d3ac15ba (patch) | |
tree | da1a582ad5b6871c350e6c5698a79b4440eea92e /clang/lib/CodeGen | |
parent | c07dc68852832a73c21ed55e02bccd4cd28713f1 (diff) | |
download | bcm5719-llvm-739aa12b79bcf96f20a106285a939496d3ac15ba.tar.gz bcm5719-llvm-739aa12b79bcf96f20a106285a939496d3ac15ba.zip |
Revert "Don't use comdats for initializers on platforms that don't support it"
On further investigation, COMDATs should work with .ctors, and the issue
I was hitting probably reproduces with .init_array.
This reverts commit r218287.
llvm-svn: 218313
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r-- | clang/lib/CodeGen/CGDeclCXX.cpp | 2 | ||||
-rw-r--r-- | clang/lib/CodeGen/CodeGenModule.h | 1 | ||||
-rw-r--r-- | clang/lib/CodeGen/ItaniumCXXABI.cpp | 3 | ||||
-rw-r--r-- | clang/lib/CodeGen/TargetInfo.cpp | 8 |
4 files changed, 2 insertions, 12 deletions
diff --git a/clang/lib/CodeGen/CGDeclCXX.cpp b/clang/lib/CodeGen/CGDeclCXX.cpp index 7b8d3d57a97..91ae6a8c2fa 100644 --- a/clang/lib/CodeGen/CGDeclCXX.cpp +++ b/clang/lib/CodeGen/CGDeclCXX.cpp @@ -302,7 +302,7 @@ CodeGenModule::EmitCXXGlobalVarDeclInitFunc(const VarDecl *D, CodeGenFunction(*this).GenerateCXXGlobalVarDeclInitFunc(Fn, D, Addr, PerformInit); - llvm::GlobalVariable *Key = supportsCOMDATInitializers() ? Addr : nullptr; + llvm::GlobalVariable *Key = supportsCOMDAT() ? Addr : nullptr; if (D->getTLSKind()) { // FIXME: Should we support init_priority for thread_local? diff --git a/clang/lib/CodeGen/CodeGenModule.h b/clang/lib/CodeGen/CodeGenModule.h index d62d68a408a..afd5b5d404f 100644 --- a/clang/lib/CodeGen/CodeGenModule.h +++ b/clang/lib/CodeGen/CodeGenModule.h @@ -601,7 +601,6 @@ public: const TargetInfo &getTarget() const { return Target; } const llvm::Triple &getTriple() const; bool supportsCOMDAT() const; - bool supportsCOMDATInitializers() const; CGCXXABI &getCXXABI() const { return *ABI; } llvm::LLVMContext &getLLVMContext() { return VMContext; } diff --git a/clang/lib/CodeGen/ItaniumCXXABI.cpp b/clang/lib/CodeGen/ItaniumCXXABI.cpp index 6d73a4b184c..84bfb6aa505 100644 --- a/clang/lib/CodeGen/ItaniumCXXABI.cpp +++ b/clang/lib/CodeGen/ItaniumCXXABI.cpp @@ -1668,8 +1668,7 @@ void ItaniumCXXABI::EmitGuardedInit(CodeGenFunction &CGF, // The ABI says: It is suggested that it be emitted in the same COMDAT group // as the associated data object - if (!D.isLocalVarDecl() && var->isWeakForLinker() && - CGM.supportsCOMDATInitializers()) { + if (!D.isLocalVarDecl() && var->isWeakForLinker() && CGM.supportsCOMDAT()) { llvm::Comdat *C = CGM.getModule().getOrInsertComdat(var->getName()); guard->setComdat(C); var->setComdat(C); diff --git a/clang/lib/CodeGen/TargetInfo.cpp b/clang/lib/CodeGen/TargetInfo.cpp index de129e57cbb..17552a50692 100644 --- a/clang/lib/CodeGen/TargetInfo.cpp +++ b/clang/lib/CodeGen/TargetInfo.cpp @@ -6877,14 +6877,6 @@ bool CodeGenModule::supportsCOMDAT() const { return !getTriple().isOSBinFormatMachO(); } -bool CodeGenModule::supportsCOMDATInitializers() const { - // We can only put initializers in comdat groups on ELF with .init_array and - // COFF with .CRT$XCU. - return supportsCOMDAT() && - ((getTriple().isOSBinFormatELF() && getCodeGenOpts().UseInitArray) || - (getTriple().isWindowsMSVCEnvironment())); -} - const TargetCodeGenInfo &CodeGenModule::getTargetCodeGenInfo() { if (TheTargetCodeGenInfo) return *TheTargetCodeGenInfo; |