diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2010-08-16 21:17:09 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2010-08-16 21:17:09 +0000 |
commit | a44fa2473a5f2a13730d44e0aea8897b5656b555 (patch) | |
tree | 461298526268e9d305107a7c76d81e88aac4e675 /lib/MC/ELFObjectWriter.cpp | |
parent | 321473d51dacec12d338a5574d4c942889b682c1 (diff) |
Fixes for generation of ELF relocations. Patch by Roman Divacky.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@111183 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/MC/ELFObjectWriter.cpp')
-rw-r--r-- | lib/MC/ELFObjectWriter.cpp | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/lib/MC/ELFObjectWriter.cpp b/lib/MC/ELFObjectWriter.cpp index e692747de9..5f7ef1217d 100644 --- a/lib/MC/ELFObjectWriter.cpp +++ b/lib/MC/ELFObjectWriter.cpp @@ -451,9 +451,23 @@ void ELFObjectWriterImpl::WriteSymbolTable(MCDataFragment *F, } // Write out a symbol table entry for each section. - for (unsigned Index = 1; Index < Asm.size(); ++Index) + // leaving out the just added .symtab which is at + // the very end + unsigned Index = 1; + for (MCAssembler::const_iterator it = Asm.begin(), + ie = Asm.end(); it != ie; ++it, ++Index) { + const MCSectionData &SD = *it; + const MCSectionELF &Section = + static_cast<const MCSectionELF&>(SD.getSection()); + // Leave out relocations so we don't have indexes within + // the relocations messed up + if (Section.getType() == ELF::SHT_RELA) + continue; + if (Index == Asm.size()) + continue; WriteSymbolEntry(F, 0, ELF::STT_SECTION, 0, 0, ELF::STV_DEFAULT, Index); - LastLocalSymbolIndex += Asm.size() - 1; + LastLocalSymbolIndex++; + } for (unsigned i = 0, e = ExternalSymbolData.size(); i != e; ++i) { ELFSymbolData &MSD = ExternalSymbolData[i]; @@ -620,12 +634,10 @@ uint64_t ELFObjectWriterImpl::getSymbolIndexInSymbolTable(MCAssembler &Asm, return i + /* empty symbol */ 1; for (unsigned i = 0, e = External.size(); i != e; ++i) if (&External[i].SymbolData->getSymbol() == S) - return i + Local.size() + Asm.size() + /* empty symbol */ 1 + - /* .rela.text + .rela.eh_frame */ + 2; + return i + Local.size() + Asm.size() + /* empty symbol */ 1; for (unsigned i = 0, e = Undefined.size(); i != e; ++i) if (&Undefined[i].SymbolData->getSymbol() == S) - return i + Local.size() + External.size() + Asm.size() + /* empty symbol */ 1 + - /* .rela.text + .rela.eh_frame */ + 2; + return i + Local.size() + External.size() + Asm.size() + /* empty symbol */ 1; llvm_unreachable("Cannot find symbol which should exist!"); } |