diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2009-12-11 20:48:18 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2009-12-11 20:48:18 +0000 |
commit | 470fb73d4e09e1dfe62cb545d7fe0e567ac6e8d6 (patch) | |
tree | 2b4d7590303da23ad512cf7c430932a55d883254 /lib | |
parent | 6f9f25dfc7bf9cc1ab1282d6d7e9cf7916d8a09c (diff) |
Fix linkage of type info and vtable for classes without linkage.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@91152 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/CodeGen/CGRTTI.cpp | 4 | ||||
-rw-r--r-- | lib/CodeGen/CGVtable.cpp | 2 |
2 files changed, 3 insertions, 3 deletions
diff --git a/lib/CodeGen/CGRTTI.cpp b/lib/CodeGen/CGRTTI.cpp index a574703935..a15ba4f215 100644 --- a/lib/CodeGen/CGRTTI.cpp +++ b/lib/CodeGen/CGRTTI.cpp @@ -230,7 +230,7 @@ public: return llvm::ConstantExpr::getBitCast(GV, Int8PtrTy); // If we're in an anonymous namespace, then we always want internal linkage. - if (RD->isInAnonymousNamespace()) + if (RD->isInAnonymousNamespace() || !RD->hasLinkage()) Linkage = llvm::GlobalVariable::InternalLinkage; bool Hidden = CGM.getDeclVisibilityMode(RD) == LangOptions::Hidden; @@ -295,7 +295,7 @@ public: return DecideExtern(PT->getPointeeType()); if (const RecordType *RT = Ty->getAs<RecordType>()) if (const CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(RT->getDecl())) - return !RD->isInAnonymousNamespace(); + return !RD->isInAnonymousNamespace() && RD->hasLinkage(); return true; } diff --git a/lib/CodeGen/CGVtable.cpp b/lib/CodeGen/CGVtable.cpp index 752f69c7c2..868a341440 100644 --- a/lib/CodeGen/CGVtable.cpp +++ b/lib/CodeGen/CGVtable.cpp @@ -1458,7 +1458,7 @@ void CGVtableInfo::MaybeEmitVtable(GlobalDecl GD) { } llvm::GlobalVariable::LinkageTypes Linkage; - if (RD->isInAnonymousNamespace()) + if (RD->isInAnonymousNamespace() || !RD->hasLinkage()) Linkage = llvm::GlobalVariable::InternalLinkage; else if (KeyFunction && !MD->isInlined()) Linkage = llvm::GlobalVariable::ExternalLinkage; |