summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGRTTI.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2011-01-11 21:44:37 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2011-01-11 21:44:37 +0000
commitb1e879c80f02e9c4bbbba124bf2c6379ca9c8246 (patch)
tree6a4d7c92d38e1caac0fe03f7f2ec96035a8de80b /clang/lib/CodeGen/CGRTTI.cpp
parent447cb38fbe08f4ca701ab14439804e9d1a8bc33e (diff)
downloadbcm5719-llvm-b1e879c80f02e9c4bbbba124bf2c6379ca9c8246.tar.gz
bcm5719-llvm-b1e879c80f02e9c4bbbba124bf2c6379ca9c8246.zip
Set unnamed_addr for type infos that we are confortable marking as hidden. I
think it is safe to mark all type infos with unnamed_addr, but I am not sure. llvm-svn: 123275
Diffstat (limited to 'clang/lib/CodeGen/CGRTTI.cpp')
-rw-r--r--clang/lib/CodeGen/CGRTTI.cpp6
1 files changed, 5 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGRTTI.cpp b/clang/lib/CodeGen/CGRTTI.cpp
index 444062bbfff..839ff909407 100644
--- a/clang/lib/CodeGen/CGRTTI.cpp
+++ b/clang/lib/CodeGen/CGRTTI.cpp
@@ -640,8 +640,12 @@ llvm::Constant *RTTIBuilder::BuildTypeInfo(QualType Ty, bool Force) {
/*ForRTTI*/ true, /*ForDefinition*/ true);
else if (Hidden ||
(CGM.getCodeGenOpts().HiddenWeakVTables &&
- Linkage == llvm::GlobalValue::WeakODRLinkage))
+ Linkage == llvm::GlobalValue::WeakODRLinkage)) {
GV->setVisibility(llvm::GlobalValue::HiddenVisibility);
+
+ // FIXME: Should we set this for all type infos?
+ GV->setUnnamedAddr(true);
+ }
return llvm::ConstantExpr::getBitCast(GV, Int8PtrTy);
}
OpenPOWER on IntegriCloud