MCELF: Count the section orders properly. Patch by Roman Divacky.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@111517 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Benjamin Kramer 2010-08-19 13:44:49 +00:00
parent 6e97e1d4be
commit 44cbde85ba

View File

@ -932,11 +932,16 @@ void ELFObjectWriterImpl::WriteObject(const MCAssembler &Asm,
// ... then all of the sections ... // ... then all of the sections ...
DenseMap<const MCSection*, uint64_t> SectionOffsetMap; DenseMap<const MCSection*, uint64_t> SectionOffsetMap;
DenseMap<const MCSection*, uint8_t> SectionIndexMap;
unsigned Index = 1;
for (MCAssembler::const_iterator it = Asm.begin(), for (MCAssembler::const_iterator it = Asm.begin(),
ie = Asm.end(); it != ie; ++it) { ie = Asm.end(); it != ie; ++it) {
// Remember the offset into the file for this section. // Remember the offset into the file for this section.
SectionOffsetMap[&it->getSection()] = FileOff; SectionOffsetMap[&it->getSection()] = FileOff;
SectionIndexMap[&it->getSection()] = Index++;
const MCSectionData &SD = *it; const MCSectionData &SD = *it;
FileOff += Layout.getSectionFileSize(&SD); FileOff += Layout.getSectionFileSize(&SD);
@ -968,15 +973,11 @@ void ELFObjectWriterImpl::WriteObject(const MCAssembler &Asm,
case ELF::SHT_RELA: { case ELF::SHT_RELA: {
const MCSection *SymtabSection; const MCSection *SymtabSection;
const MCSection *InfoSection; const MCSection *InfoSection;
const MCSectionData *SymtabSD;
const MCSectionData *InfoSD;
SymtabSection = Asm.getContext().getELFSection(".symtab", ELF::SHT_SYMTAB, 0, SymtabSection = Asm.getContext().getELFSection(".symtab", ELF::SHT_SYMTAB, 0,
SectionKind::getReadOnly(), SectionKind::getReadOnly(),
false); false);
SymtabSD = &Asm.getSectionData(*SymtabSection); sh_link = SectionIndexMap[SymtabSection];
// we have to count the empty section in too
sh_link = SymtabSD->getLayoutOrder() + 1;
// Remove ".rel" and ".rela" prefixes. // Remove ".rel" and ".rela" prefixes.
unsigned SecNameLen = (Section.getType() == ELF::SHT_REL) ? 4 : 5; unsigned SecNameLen = (Section.getType() == ELF::SHT_REL) ? 4 : 5;
@ -986,8 +987,7 @@ void ELFObjectWriterImpl::WriteObject(const MCAssembler &Asm,
ELF::SHT_PROGBITS, 0, ELF::SHT_PROGBITS, 0,
SectionKind::getReadOnly(), SectionKind::getReadOnly(),
false); false);
InfoSD = &Asm.getSectionData(*InfoSection); sh_info = SectionIndexMap[InfoSection];
sh_info = InfoSD->getLayoutOrder() + 1;
break; break;
} }