osg*_*sgx 6 linux glibc elf thread-local-storage
int i;
int main() {
return i;
}
Run Code Online (Sandbox Code Playgroud)
-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
Run Code Online (Sandbox Code Playgroud)
有人可以解释一下,为什么第二个和第四个程序头确实相交(它们以相同的偏移量 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) )。
| 归档时间: |
|
| 查看次数: |
7031 次 |
| 最近记录: |