diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2011-01-11 21:44:37 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2011-01-11 21:44:37 +0000 |
commit | b1e879c80f02e9c4bbbba124bf2c6379ca9c8246 (patch) | |
tree | 6a4d7c92d38e1caac0fe03f7f2ec96035a8de80b /clang/lib/CodeGen/CGRTTI.cpp | |
parent | 447cb38fbe08f4ca701ab14439804e9d1a8bc33e (diff) | |
download | bcm5719-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.cpp | 6 |
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); } |