]> granicus.if.org Git - clang/commitdiff
Be sure to set visibility for ZTI symbols for classes from the class.
authorMike Stump <mrs@apple.com>
Wed, 18 Nov 2009 03:21:29 +0000 (03:21 +0000)
committerMike Stump <mrs@apple.com>
Wed, 18 Nov 2009 03:21:29 +0000 (03:21 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@89186 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGRtti.cpp
test/CodeGenCXX/rtti.cpp

index 4a9779a9b22b21c0fd109e81526239bc90946993..01767466e8b515beb5b3c6dc06536ba53184947a 100644 (file)
@@ -145,7 +145,7 @@ public:
 
   llvm::Constant *finish(std::vector<llvm::Constant *> &info,
                          llvm::GlobalVariable *GV,
-                         llvm::StringRef Name) {
+                         llvm::StringRef Name, bool Extern) {
     llvm::GlobalVariable::LinkageTypes linktype;
     linktype = llvm::GlobalValue::LinkOnceODRLinkage;
 
@@ -165,7 +165,8 @@ public:
       OGV->replaceAllUsesWith(NewPtr);
       OGV->eraseFromParent();
     }
-    GV->setVisibility(llvm::GlobalVariable::HiddenVisibility);
+    if (!Extern)
+      GV->setVisibility(llvm::GlobalVariable::HiddenVisibility);
     return llvm::ConstantExpr::getBitCast(GV, Int8PtrTy);
   }
 
@@ -230,7 +231,9 @@ public:
       }
     }
 
-    return finish(info, GV, Out.str());
+    bool Extern = CGM.getDeclVisibilityMode(RD) != LangOptions::Hidden;
+
+    return finish(info, GV, Out.str(), Extern);
   }
 
   /// - BuildFlags - Build a __flags value for __pbase_type_info.
@@ -291,7 +294,7 @@ public:
     if (PtrMem)
       info.push_back(BuildType2(BTy));
 
-    return finish(info, GV, Out.str());
+    return finish(info, GV, Out.str(), false);
   }
 
   llvm::Constant *BuildSimpleType(QualType Ty, const char *vtbl) {
@@ -312,7 +315,7 @@ public:
     info.push_back(C);
     info.push_back(BuildName(Ty));
 
-    return finish(info, GV, Out.str());
+    return finish(info, GV, Out.str(), false);
   }
 
   llvm::Constant *BuildType(QualType Ty) {
index f496d7af2fc5d6c418469cd7be9174493893a17a..a1ff1ff68729ecc14b7aa895aa3a8546fdb05492 100644 (file)
@@ -41,7 +41,12 @@ class test1_D : public test1_B7 {
 // CHECK-NEXT: .space 4
 // CHECK-NEXT: .quad  __ZTIi
 
-// CHECK:    __ZTIM7test3_Ai:
+// CHECK:      .globl __ZTS7test3_A
+// CHECK-NEXT: .weak_definition __ZTS7test3_A
+// CHECK:     __ZTS7test3_A:
+// CHECK-NEXT: .asciz  "7test3_A"
+
+// CHECK:     __ZTIM7test3_Ai:
 // CHECK-NEXT: .quad  (__ZTVN10__cxxabiv129__pointer_to_member_type_infoE) + 16
 // CHECK-NEXT: .quad  __ZTSM7test3_Ai
 // CHECK-NEXT: .space 4