diff options
| author | Roman Divacky <rdivacky@freebsd.org> | 2010-09-08 18:08:40 +0000 |
|---|---|---|
| committer | Roman Divacky <rdivacky@freebsd.org> | 2010-09-08 18:08:40 +0000 |
| commit | 2ef1a589c5fabb452255bf85751cbb215c5f0e8b (patch) | |
| tree | fc6f99d84ec7d75bc42716a410bacf14dcd6357c /llvm | |
| parent | 8e89e41fafaa372175b7f5b1676b2a20916b88d7 (diff) | |
| download | bcm5719-llvm-2ef1a589c5fabb452255bf85751cbb215c5f0e8b.tar.gz bcm5719-llvm-2ef1a589c5fabb452255bf85751cbb215c5f0e8b.zip | |
ELF_STB_Local is 0 so setting and checking it must be done specially
llvm-svn: 113375
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/MC/ELFObjectWriter.cpp | 4 | ||||
| -rw-r--r-- | llvm/lib/MC/MCELFStreamer.cpp | 4 |
2 files changed, 5 insertions, 3 deletions
diff --git a/llvm/lib/MC/ELFObjectWriter.cpp b/llvm/lib/MC/ELFObjectWriter.cpp index ed4f972be59..5713f470260 100644 --- a/llvm/lib/MC/ELFObjectWriter.cpp +++ b/llvm/lib/MC/ELFObjectWriter.cpp @@ -439,7 +439,7 @@ void ELFObjectWriterImpl::WriteSymbolTable(MCDataFragment *F, assert((Data.getFlags() & ELF_STB_Global) && "External symbol requires STB_GLOBAL flag"); WriteSymbol(F, MSD, Layout); - if (Data.getFlags() & ELF_STB_Local) + if ((Data.getFlags() & (0xf << ELF_STB_Shift)) == ELF_STB_Local) LastLocalSymbolIndex++; } @@ -448,7 +448,7 @@ void ELFObjectWriterImpl::WriteSymbolTable(MCDataFragment *F, MCSymbolData &Data = *MSD.SymbolData; Data.setFlags(Data.getFlags() | ELF_STB_Global); WriteSymbol(F, MSD, Layout); - if (Data.getFlags() & ELF_STB_Local) + if ((Data.getFlags() & (0xf << ELF_STB_Shift)) == ELF_STB_Local) LastLocalSymbolIndex++; } } diff --git a/llvm/lib/MC/MCELFStreamer.cpp b/llvm/lib/MC/MCELFStreamer.cpp index 570c3917ab4..583052d0638 100644 --- a/llvm/lib/MC/MCELFStreamer.cpp +++ b/llvm/lib/MC/MCELFStreamer.cpp @@ -196,7 +196,9 @@ void MCELFStreamer::EmitSymbolAttribute(MCSymbol *Symbol, break; case MCSA_Local: - SD.setFlags(SD.getFlags() | ELF_STB_Local); + // ELF_STB_Local is 0, so zero the ELF_STB area + // SD.getFlags() | ELF_STB_Local is a NOP + SD.setFlags(SD.getFlags() & ~(0xf << ELF_STB_Shift)); break; case MCSA_ELF_TypeFunction: |

