]> granicus.if.org Git - clang/commitdiff
Don't let typeinfo name symbols be 'internal hidden', it can lead to linker conflicts
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>
Mon, 11 Oct 2010 03:25:53 +0000 (03:25 +0000)
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>
Mon, 11 Oct 2010 03:25:53 +0000 (03:25 +0000)
with similarly named classes in anonymous namespaces.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@116185 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGRTTI.cpp
test/CodeGenCXX/rtti-linkage.cpp

index 60df613f65e8b99c8f12caccb1b489f61b0bc06d..e98d0e8ceadc3deb353bd8c24e73b4c2865e6bfb 100644 (file)
@@ -85,7 +85,7 @@ public:
       OGV->replaceAllUsesWith(NewPtr);
       OGV->eraseFromParent();
     }
-    if (Hidden)
+    if (Hidden && Linkage != llvm::GlobalValue::InternalLinkage)
       GV->setVisibility(llvm::GlobalVariable::HiddenVisibility);
     return llvm::ConstantExpr::getBitCast(GV, Int8PtrTy);
   }
index efa336dda4ec75ce2d3ec1c9d1ac93a133cb46fa..211f57634c6e6493ddc5aaaff77338b7f5992088 100644 (file)
@@ -1,11 +1,12 @@
 // RUN: %clang_cc1 %s -I%S -triple=x86_64-apple-darwin10 -fhidden-weak-vtables -emit-llvm -o - | sort | FileCheck %s
+// RUN: %clang_cc1 %s -I%S -triple=x86_64-apple-darwin10 -fvisibility hidden -fhidden-weak-vtables -emit-llvm -o - | FileCheck -check-prefix=CHECK-WITH-HIDDEN %s
 
 // FIXME: Fails on Win32, dunno why.
 // XFAIL: win32
 
 #include <typeinfo>
 
-
+// CHECK-WITH-HIDDEN: _ZTSFN12_GLOBAL__N_11DEvE = internal constant
 
 // CHECK: _ZTIN12_GLOBAL__N_11DE to