Index: ELF/InputSection.cpp =================================================================== --- ELF/InputSection.cpp +++ ELF/InputSection.cpp @@ -1149,43 +1149,32 @@ return Comp(Value, *First) ? First : First + 1; } -// Do binary search to get a section piece at a given input offset. -static SectionPiece *findSectionPiece(MergeInputSection *Sec, uint64_t Offset) { - if (Sec->Data.size() <= Offset) - fatal(toString(Sec) + ": entry is past the end of the section"); +SectionPiece *MergeInputSection::getSectionPiece(uint64_t Offset) { + if (this->Data.size() <= Offset) + fatal(toString(this) + ": offset is outside the section"); - // Find the element this offset points to. + // Find a piece starting at a given offset. + auto It = OffsetMap.find(Offset); + if (It != OffsetMap.end()) + return &Pieces[It->second]; + + // If Offset is not at beginning of a section piece, it is not in the map. + // In that case we need to do a binary search of the original section piece vector. auto I = fastUpperBound( - Sec->Pieces.begin(), Sec->Pieces.end(), Offset, + Pieces.begin(), Pieces.end(), Offset, [](const uint64_t &A, const SectionPiece &B) { return A < B.InputOff; }); --I; return &*I; } -SectionPiece *MergeInputSection::getSectionPiece(uint64_t Offset) { - // Find a piece starting at a given offset. - auto It = OffsetMap.find(Offset); - if (It != OffsetMap.end()) - return &Pieces[It->second]; - - // If Offset is not at beginning of a section piece, it is not in the map. - // In that case we need to search from the original section piece vector. - return findSectionPiece(this, Offset); -} - // Returns the offset in an output section for a given input offset. // Because contents of a mergeable section is not contiguous in output, // it is not just an addition to a base output offset. uint64_t MergeInputSection::getParentOffset(uint64_t Offset) const { - // Find a string starting at a given offset. - auto It = OffsetMap.find(Offset); - if (It != OffsetMap.end()) - return Pieces[It->second].OutputOff; - // If Offset is not at beginning of a section piece, it is not in the map. // In that case we need to search from the original section piece vector. const SectionPiece &Piece = - *findSectionPiece(const_cast(this), Offset); + *(const_cast(this)->getSectionPiece (Offset)); uint64_t Addend = Offset - Piece.InputOff; return Piece.OutputOff + Addend; } Index: test/ELF/merge-string-error.s =================================================================== --- test/ELF/merge-string-error.s +++ test/ELF/merge-string-error.s @@ -8,4 +8,4 @@ .data .long .rodata.str1.1 + 4 -// CHECK: merge-string-error.s.tmp.o:(.rodata.str1.1): entry is past the end of the section +// CHECK: merge-string-error.s.tmp.o:(.rodata.str1.1): offset is outside the section Index: test/ELF/relocation-before-merge-start.s =================================================================== --- /dev/null +++ test/ELF/relocation-before-merge-start.s @@ -0,0 +1,9 @@ +// REQUIRES: x86 +// RUN: llvm-mc %s -o %t.o -filetype=obj -triple=x86_64-pc-linux +// RUN: not ld.lld %t.o -o /dev/null -shared 2>&1 | FileCheck %s +// CHECK: relocation-before-merge-start.s.tmp.o:(.foo): offset is outside the section + +.data +.long .foo - 1 +.section .foo,"aM",@progbits,4 +.quad 0 Index: test/ELF/relocation-past-merge-end.s =================================================================== --- test/ELF/relocation-past-merge-end.s +++ test/ELF/relocation-past-merge-end.s @@ -1,7 +1,7 @@ // REQUIRES: x86 // RUN: llvm-mc %s -o %t.o -filetype=obj -triple=x86_64-pc-linux // RUN: not ld.lld %t.o -o /dev/null -shared 2>&1 | FileCheck %s -// CHECK: relocation-past-merge-end.s.tmp.o:(.foo): entry is past the end of the section +// CHECK: relocation-past-merge-end.s.tmp.o:(.foo): offset is outside the section .data .long .foo + 10