Overlapping program headers/segments
Jan Beulich
jbeulich@suse.com
Mon Sep 25 06:14:03 GMT 2023
On 24.09.2023 20:32, Max Larsson via Binutils wrote:
> What I have done so far, is to put the .rodata section in its own segment via defining a target
> specific method for 'elf_backend_modify_segment'. How to do it, I copied/looked/adapted from
> elfxx-mips.c:_bfd_mips_elf_modify_segment_map That works as expected.
>
> But The result is that the program headers overlap. Like this:
>
> Program Headers:
> Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align
> LOAD 0x000000 0x10000000 0x10000000 0x02034 0x02034 R E 0x10000
> LOAD 0x020000 0x10010000 0x10010000 0x000f0 0x000f0 RW 0x10000
> DYNAMIC 0x020028 0x10010028 0x10010028 0x000b8 0x000b8 RW 0x4
> LOAD 0x012000 0x10002000 0x10002000 0x00031 0x00031 R 0x10000
> Section to Segment mapping:
> Segment Sections...
> 00 .hash .dynsym .dynstr .rela.dyn .rela.got2 .rela.plt .text .plt
> 01 .init_array .fini_array .got2 .dynamic .got
> 02 .dynamic
> 03 .rodata
>
> You see, if you take the Virt-/PhysAddr and add the MemSize from the first
> program header the result is 0x10002034, which is greater than the Virt-/PhysAddr
> of the last program header 0x10002000.
>
> So my question why do I get such a result, and how can I avoid it?
You didn't provide the linker script, which may have the observed effect together
with your code change: If it puts .text and .rodata together, then the overlap is
to be expected (as would frequently happen for NOTE segments and .note sections),
I think.
Jan
More information about the Binutils
mailing list