summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGCXX.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2010-03-05 01:21:10 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2010-03-05 01:21:10 +0000
commit4c489c7030e9310d7d9dfe073c399b7076c37e71 (patch)
treecb6fcbce1db4deabbc46ddf125f59bd2545e139a /clang/lib/CodeGen/CGCXX.cpp
parent6dbf5cc64c3338c81752024e456a2ac86c3d20e2 (diff)
downloadbcm5719-llvm-4c489c7030e9310d7d9dfe073c399b7076c37e71.tar.gz
bcm5719-llvm-4c489c7030e9310d7d9dfe073c399b7076c37e71.zip
Don't produce an alias for a destructor if the target is weak.
This fixes bootstrap on ELF systems :-) llvm-svn: 97773
Diffstat (limited to 'clang/lib/CodeGen/CGCXX.cpp')
-rw-r--r--clang/lib/CodeGen/CGCXX.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/clang/lib/CodeGen/CGCXX.cpp b/clang/lib/CodeGen/CGCXX.cpp
index 4889fc08f48..cd5d64697d1 100644
--- a/clang/lib/CodeGen/CGCXX.cpp
+++ b/clang/lib/CodeGen/CGCXX.cpp
@@ -109,6 +109,16 @@ bool CodeGenModule::TryEmitBaseDestructorAsAlias(const CXXDestructorDecl *D) {
GlobalDecl(BaseD, Dtor_Base));
}
+static bool isWeakForLinker(llvm::GlobalValue::LinkageTypes Linkage) {
+ return (Linkage == llvm::GlobalValue::AvailableExternallyLinkage ||
+ Linkage == llvm::GlobalValue::WeakAnyLinkage ||
+ Linkage == llvm::GlobalValue::WeakODRLinkage ||
+ Linkage == llvm::GlobalValue::LinkOnceAnyLinkage ||
+ Linkage == llvm::GlobalValue::LinkOnceODRLinkage ||
+ Linkage == llvm::GlobalValue::CommonLinkage ||
+ Linkage == llvm::GlobalValue::ExternalWeakLinkage);
+}
+
/// Try to emit a definition as a global alias for another definition.
bool CodeGenModule::TryEmitDefinitionAsAlias(GlobalDecl AliasDecl,
GlobalDecl TargetDecl) {
@@ -142,6 +152,12 @@ bool CodeGenModule::TryEmitDefinitionAsAlias(GlobalDecl AliasDecl,
return true;
}
+ llvm::GlobalValue::LinkageTypes TargetLinkage
+ = getFunctionLinkage(cast<FunctionDecl>(TargetDecl.getDecl()));
+
+ if (isWeakForLinker(TargetLinkage))
+ return true;
+
// Derive the type for the alias.
const llvm::PointerType *AliasType
= getTypes().GetFunctionType(AliasDecl)->getPointerTo();
OpenPOWER on IntegriCloud