From: Fariborz Jahanian Date: Thu, 16 Jun 2011 14:49:42 +0000 (+0000) Subject: Set the visibility to 'hidden' when previous X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=119f19b46b79cbe48f1992911588a728dfa5ad2e;p=clang Set the visibility to 'hidden' when previous declaration of global var is __private_extern__. // rdar://9609649 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@133157 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp index 78c57b4e3f..c15ef9b089 100644 --- a/lib/CodeGen/CodeGenModule.cpp +++ b/lib/CodeGen/CodeGenModule.cpp @@ -206,8 +206,17 @@ void CodeGenModule::setGlobalVisibility(llvm::GlobalValue *GV, // Set visibility for definitions. NamedDecl::LinkageInfo LV = D->getLinkageAndVisibility(); - if (LV.visibilityExplicit() || !GV->hasAvailableExternallyLinkage()) - GV->setVisibility(GetLLVMVisibility(LV.visibility())); + if (LV.visibilityExplicit() || !GV->hasAvailableExternallyLinkage()) { + Visibility Vis = LV.visibility(); + if (Vis == DefaultVisibility) + if (const VarDecl *VD = dyn_cast(D)) + if (const VarDecl *Old = VD->getPreviousDeclaration()) { + Visibility OldVis = Old->getLinkageAndVisibility().visibility(); + if (OldVis == HiddenVisibility) + Vis = HiddenVisibility; + } + GV->setVisibility(GetLLVMVisibility(Vis)); + } } /// Set the symbol visibility of type information (vtable and RTTI) diff --git a/test/CodeGen/private-extern-redef.c b/test/CodeGen/private-extern-redef.c new file mode 100644 index 0000000000..580ce9bd4a --- /dev/null +++ b/test/CodeGen/private-extern-redef.c @@ -0,0 +1,39 @@ +// RUN: %clang_cc1 -triple x86_64-darwin-apple -emit-llvm -o - %s | FileCheck %s +// rdar://9609649 + +__private_extern__ const int I; +__private_extern__ const int J = 927; + +__private_extern__ const int K; +const int K = 37; + +const int L = 10; +__private_extern__ const int L; + +__private_extern__ int M; +int M = 20; + +__private_extern__ int N; +int N; + +__private_extern__ int O; +int O=1; + +__private_extern__ int P; +extern int P; + +void bar(int); + +void foo() { + bar(I); +} + +// CHECK: @J = hidden constant +// CHECK: @K = hidden constant +// CHECK: @L = constant +// CHECK: @M = hidden global +// CHECK: @O = hidden global +// CHECK: @I = external hidden +// CHECK: @N = common hidden global +// CHECK-NOT: @P +