int i; int main() { return i; }
After -static compilation of readelf -l , the elf program headers are displayed:
Elf file type is EXEC (Executable file) Entry point 0xxxxx30 There are 6 program headers, starting at offset 52 Program Headers: Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align LOAD 0x000000 0x08048000 0x08048000 0x79868 0x79868 RE 0x1000 > LOAD 0x079f94 0x080c2f94 0x080c2f94 0x0078c 0x02254 RW 0x1000 << NOTE 0x0000f4 0x080480f4 0x080480f4 0x00020 0x00020 R 0x4 > TLS 0x079f94 0x080c2f94 0x080c2f94 0x00010 0x0002c R 0x4 << GNU_STACK 0x000000 0x00000000 0x00000000 0x00000 0x00000 RW 0x4 PAX_FLAGS 0x000000 0x00000000 0x00000000 0x00000 0x00000 0x4 Section to Segment mapping: Segment Sections... 00 .note.ABI-tag .init .text __libc_freeres_fn .fini .rodata __libc_subfreeres __libc_atexit .eh_frame .gcc_except_table 01 .tdata .ctors .dtors .jcr .data.rel.ro .got .got.plt .data .bss __libc_freeres_ptrs 02 .note.ABI-tag 03 .tdata .tbss
Can someone explain why the 2 and 4 program headers intersect (they start at the same offset 0x079f94 and VirtAddr 0x080c2f94).
In addition, the .tdata segment segment .tdata transmitted twice.
How will PT_TLS and PT_LOAD be loaded for the first stream (the program itself)? Where is .tbss in memory?
linux glibc elf thread-local-storage
osgx
source share