linux – ELF文件TLS和LOAD程序部分
发布时间:2020-12-14 00:33:28 所属栏目:Linux 来源:网络整理
导读:int i;int main() { return i; } -static编译后readelf -l显示来自elf的程序头: Elf file type is EXEC (Executable file)Entry point 0xxxxx30There are 6 program headers,starting at offset 52Program Headers: Type Offset VirtAddr PhysAddr FileSiz
int i; int main() { return i; } -static编译后readelf -l显示来自elf的程序头: 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 R E 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 有人可以解释,为什么第2和第4个程序头确实相交(它们以相同的偏移量0x079f94和VirtAddr 0x080c2f94开始). 此外,段部分.tdata被引用两次. 如何为第一个线程(程序本身)加载PT_TLS和PT_LOAD? 解决方法
首先.tdata部分 – 是TLS数据的“初始图像”.它是TLS变量的初始值,将在每个线程中使用(也在主线程中).在crt(我假设)中,将TLS初始图像复制到主线程的TLS中. pthread_create中的代码相同.
未加载PT_TLS,因为PT_LOAD确实并且PT_LOAD已包含此PT_TLS.我认为PT_TLS用于初始图像 – 因为它比整个线程本地数据(tbss tdata> size(PT_TLS))短. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |