From ea10ab668f8b6cdaa17723b37af32f1a7cb36e46 Mon Sep 17 00:00:00 2001 From: Daniel Dunbar Date: Tue, 7 Apr 2009 22:36:33 +0000 Subject: Visibility attributes should only be set on definition. llvm-svn: 68561 --- clang/lib/CodeGen/CodeGenModule.cpp | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'clang/lib/CodeGen/CodeGenModule.cpp') diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index 1dd2c4d67f0..508d7ce2b6f 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -272,10 +272,12 @@ void CodeGenModule::SetGlobalValueAttributes(const Decl *D, // FIXME: Figure out the relative priority of the attribute, // -fvisibility, and private_extern. - if (const VisibilityAttr *attr = D->getAttr()) - setGlobalVisibility(GV, attr->getVisibility()); - else - setGlobalOptionVisibility(GV, getLangOptions().getVisibilityMode()); + if (ForDefinition) { + if (const VisibilityAttr *attr = D->getAttr()) + setGlobalVisibility(GV, attr->getVisibility()); + else + setGlobalOptionVisibility(GV, getLangOptions().getVisibilityMode()); + } if (const SectionAttr *SA = D->getAttr()) GV->setSection(SA->getName()); -- cgit v1.2.3