summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CodeGenModule.cpp
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2009-11-26 02:52:12 +0000
committerEli Friedman <eli.friedman@gmail.com>2009-11-26 02:52:12 +0000
commit8a5f75ed5d998b207d5c2008287cfa34157d8ad7 (patch)
treeadd180f1551470a2a4015e25da0b59f957a885b9 /clang/lib/CodeGen/CodeGenModule.cpp
parentabe274a8b06650e486c0f3e197ea1d0fbcb651e6 (diff)
downloadbcm5719-llvm-8a5f75ed5d998b207d5c2008287cfa34157d8ad7.tar.gz
bcm5719-llvm-8a5f75ed5d998b207d5c2008287cfa34157d8ad7.zip
Use new getLinkage() method to correctly compute whether a variable has
internal linkage. Fixes PR5433. llvm-svn: 89931
Diffstat (limited to 'clang/lib/CodeGen/CodeGenModule.cpp')
-rw-r--r--clang/lib/CodeGen/CodeGenModule.cpp7
1 files changed, 3 insertions, 4 deletions
diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp
index 7cd9e9f81be..6aff0e7476b 100644
--- a/clang/lib/CodeGen/CodeGenModule.cpp
+++ b/clang/lib/CodeGen/CodeGenModule.cpp
@@ -549,7 +549,7 @@ bool CodeGenModule::MayDeferGeneration(const ValueDecl *Global) {
// cannot be.
if (VD->isInAnonymousNamespace())
return true;
- if (VD->getStorageClass() == VarDecl::Static) {
+ if (VD->getLinkage() == VarDecl::InternalLinkage) {
// Initializer has side effects?
if (VD->getInit() && VD->getInit()->HasSideEffects(Context))
return false;
@@ -982,9 +982,8 @@ GetLinkageForVariable(ASTContext &Context, const VarDecl *VD) {
return CodeGenModule::GVA_TemplateInstantiation;
}
}
-
- // Static variables get internal linkage.
- if (VD->getStorageClass() == VarDecl::Static)
+
+ if (VD->getLinkage() == VarDecl::InternalLinkage)
return CodeGenModule::GVA_Internal;
return CodeGenModule::GVA_StrongExternal;
OpenPOWER on IntegriCloud