diff options
| author | Bill Wendling <isanbard@gmail.com> | 2012-08-17 18:33:14 +0000 | 
|---|---|---|
| committer | Bill Wendling <isanbard@gmail.com> | 2012-08-17 18:33:14 +0000 | 
| commit | 34bc34ecae660ea50ad9852e619efb23d8863a8c (patch) | |
| tree | ff7161d99e438d318de97e4db1a8cd9fa8e00048 /llvm/lib/CodeGen/AsmPrinter | |
| parent | 9a16735e2292236b3d795f8b2e3042b75bafae1a (diff) | |
| download | bcm5719-llvm-34bc34ecae660ea50ad9852e619efb23d8863a8c.tar.gz bcm5719-llvm-34bc34ecae660ea50ad9852e619efb23d8863a8c.zip | |
Change the `linker_private_weak_def_auto' linkage to `linkonce_odr_auto_hide' to
make it more consistent with its intended semantics.
The `linker_private_weak_def_auto' linkage type was meant to automatically hide
globals which never had their addresses taken. It has nothing to do with the
`linker_private' linkage type, which outputs the symbols with a `l' (ell) prefix
among other things.
The intended semantic is more like the `linkonce_odr' linkage type.
Change the name of the linkage type to `linkonce_odr_auto_hide'. And therefore
changing the semantics so that it produces the correct output for the linker.
Note: The old linkage name `linker_private_weak_def_auto' will still parse but
is not a synonym for `linkonce_odr_auto_hide'. This should be removed in 4.0.
<rdar://problem/11754934>
llvm-svn: 162114
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 4 | 
1 files changed, 2 insertions, 2 deletions
| diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index d9be7a1a58f..375bd7eb88d 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -213,16 +213,16 @@ void AsmPrinter::EmitLinkage(unsigned Linkage, MCSymbol *GVSym) const {    case GlobalValue::CommonLinkage:    case GlobalValue::LinkOnceAnyLinkage:    case GlobalValue::LinkOnceODRLinkage: +  case GlobalValue::LinkOnceODRAutoHideLinkage:    case GlobalValue::WeakAnyLinkage:    case GlobalValue::WeakODRLinkage:    case GlobalValue::LinkerPrivateWeakLinkage: -  case GlobalValue::LinkerPrivateWeakDefAutoLinkage:      if (MAI->getWeakDefDirective() != 0) {        // .globl _foo        OutStreamer.EmitSymbolAttribute(GVSym, MCSA_Global);        if ((GlobalValue::LinkageTypes)Linkage != -          GlobalValue::LinkerPrivateWeakDefAutoLinkage) +          GlobalValue::LinkOnceODRAutoHideLinkage)          // .weak_definition _foo          OutStreamer.EmitSymbolAttribute(GVSym, MCSA_WeakDefinition);        else | 

