[ELF] Allow sections after a non-SHF_ALLOC section to be covered by PT_LOAD
authorFangrui Song <i@maskray.me>
Thu, 6 Aug 2020 15:26:43 +0000 (08:26 -0700)
committerFangrui Song <i@maskray.me>
Thu, 6 Aug 2020 15:27:15 +0000 (08:27 -0700)
commita6db64ef4a9906c96ef5652739ac15aefaa7827c
tree3961f3d25bcd1e0cbc93a56e9837e3baa4fd2f57
parent63cdc9a49f1fdd7df80dc964bf647f89982a2569
[ELF] Allow sections after a non-SHF_ALLOC section to be covered by PT_LOAD

GNU ld allows sections after a non-SHF_ALLOC section to be covered by PT_LOAD
(PR37607) and assigns addresses to non-SHF_ALLOC output sections (similar to
SHF_ALLOC NOBITS sections. The location counter is not advanced).

This patch tries to fix PR37607 (remove a special case in
`Writer<ELFT>::createPhdrs`). To make the created PT_LOAD meaningful, we cannot
reset dot to 0 for a middle non-SHF_ALLOC output section. This results in
removal of two special cases in LinkerScript::assignOffsets. Non-SHF_ALLOC
non-orphan sections can have non-zero addresses like in GNU ld.

The zero address rule for non-SHF_ALLOC sections is weakened to apply to orphan
only. This results in a special case in createSection and findOrphanPos, respectively.

Reviewed By: jhenderson

Differential Revision: https://reviews.llvm.org/D85100
lld/ELF/LinkerScript.cpp
lld/ELF/Writer.cpp
lld/test/ELF/linkerscript/compress-debug-sections-custom.s
lld/test/ELF/linkerscript/sections.s
lld/test/ELF/linkerscript/symbols-non-alloc.test
lldb/test/Shell/SymbolFile/DWARF/Inputs/debug-line-basic.script