linux – ELF文件TLS和LOAD程序部分

linux – ELF文件TLS和LOAD程序部分,第1张

概述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 Heade
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 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?
.tbss在哪里?

解决方法 首先.tdata部分 – 是TLS数据的“初始图像”.它是TLS变量的初始值,将在每个线程中使用(也在主线程中).在crt(我假设)中,将TLS初始图像复制到主线程的TLS中. pthread_create中的代码相同.

未加载PT_TLS,因为PT_LOAD确实并且PT_LOAD已包含此PT_TLS.我认为PT_TLS用于初始图像 – 因为它比整个线程本地数据(tbss tdata> size(PT_TLS))短.

总结

以上是内存溢出为你收集整理的linux – ELF文件TLS和LOAD程序部分全部内容,希望文章能够帮你解决linux – ELF文件TLS和LOAD程序部分所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1023765.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存