mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-09 17:43:40 +08:00
74541ad4c0
* elf-bfd.h (struct elf_link_hash_table): Reorder. Add text_index_section and data_index_section. (struct elf_backend_data): Add elf_backend_init_index_section. (_bfd_elf_init_1_index_section): Declare. (_bfd_elf_init_2_index_sections): Declare. * elfxx-target.h (elf_backend_init_index_section): Define. (elfNN_bed): Init new field. * elflink.c (_bfd_elf_link_omit_section_dynsym): Keep first tls section and text_index_section plus data_index_section. (_bfd_elf_link_renumber_dynsyms): Clear dynindx on omitted sections. (_bfd_elf_init_1_index_section): New function. (_bfd_elf_init_2_index_sections): New function. (bfd_elf_size_dynsym_hash_dynstr): Call elf_backend_init_index_section. (elf_link_input_bfd): When emitting relocs, use text_index_section and data_index_section for removed sections. * elf-m10300.c (elf_backend_omit_section_dynsym): Define. * elf32-i386.c: Likewise. * elf32-m32r.c: Likewise. * elf32-sh.c: Likewise. * elf32-xstormy16.c: Likewise. * elf32-xtensa.c: Likewise. * elf64-alpha.c: Likewise. * elf64-hppa.c: Likewise. * elf64-mmix.c: Likewise. * elf64-sh64.c: Likewise. * elfxx-ia64.c: Likewise. * elf32-arm.c (elf32_arm_final_link_relocate): Use text_index_section and data_index_section sym for relocs against sections with no dynamic section sym. (elf_backend_init_index_section): Define. * elf32-cris.c: Similarly. * elf32-hppa.c: Similarly. * elf32-i370.c: Similarly. * elf32-m68k.c: Similarly. * elf32-mips.c: Similarly. * elf32-ppc.c: Similarly. * elf32-s390.c: Similarly. * elf32-sparc.c: Similarly. * elf32-vax.c: Similarly. * elf64-mips.c: Similarly. * elf64-ppc.c: Similarly. * elf64-s390.c: Similarly. * elf64-sparc.c: Similarly. * elf64-x86-64.c: Similarly. * elfn32-mips.c: Similarly. * elfxx-mips.c: Similarly. * elfxx-sparc.c: Similarly. * linker.c (fix_syms): Base symbols in removed sections on previous section in preference to using absolute section. ld/ * ldlang.c (strip_excluded_output_sections): Do strip sections that define syms, but don't ignore them. * ld.texinfo (Output Section Discarding): Revise. * emultempl/armcoff.em (gld${EMULATION_NAME}_finish): Always call finish_default. ld/testsuite/ Update for section sym changes.
80 lines
2.1 KiB
Makefile
80 lines
2.1 KiB
Makefile
#source: tlspic1.s
|
|
#source: tlspic2.s
|
|
#as: -little
|
|
#ld: -shared -EL
|
|
#readelf: -Ssrl
|
|
#target: sh*-*-linux* sh*-*-netbsd*
|
|
|
|
There are [0-9]+ section headers, starting at offset 0x[0-9a-f]+:
|
|
|
|
Section Headers:
|
|
\[Nr\] Name +Type +Addr +Off +Size +ES Flg Lk Inf Al
|
|
\[ 0\] +NULL +0+ 0+ 0+ 0+ +0 +0 +0
|
|
\[ 1\] \.hash .*
|
|
\[ 2\] \.dynsym .*
|
|
\[ 3\] \.dynstr .*
|
|
\[ 4\] \.rela\.dyn .*
|
|
\[ 5\] \.rela\.plt .*
|
|
\[ 6\] \.plt .*
|
|
\[ 7\] \.text +PROGBITS .*
|
|
\[ 8\] \.tdata +PROGBITS .* 0+18 00 WAT 0 0 4
|
|
\[ 9\] \.tbss +NOBITS .* 0+08 00 WAT 0 0 1
|
|
#...
|
|
\[[0-9a-f]+\] \.got +PROGBITS .*
|
|
#...
|
|
\[[0-9a-f]+\] \.shstrtab .*
|
|
\[[0-9a-f]+\] \.symtab .*
|
|
\[[0-9a-f]+\] \.strtab .*
|
|
Key to Flags:
|
|
.*
|
|
.*
|
|
.*
|
|
|
|
Elf file type is DYN \(Shared object file\)
|
|
Entry point 0x[0-9a-f]+
|
|
There are 4 program headers, starting at offset [0-9]+
|
|
|
|
Program Headers:
|
|
Type +Offset +VirtAddr +PhysAddr +FileSiz +MemSiz +Flg Align
|
|
LOAD.*
|
|
LOAD.*
|
|
DYNAMIC.*
|
|
TLS .* 0x0+18 0x0+20 R +0x4
|
|
|
|
Section to Segment mapping:
|
|
Segment Sections\.\.\.
|
|
00 +\.hash \.dynsym \.dynstr \.rela\.dyn \.rela\.plt \.plt \.text *
|
|
01 +\.tdata \.dynamic \.got *
|
|
02 +\.dynamic *
|
|
03 +\.tdata \.tbss *
|
|
|
|
Relocation section '\.rela\.dyn' at offset 0x[0-9a-f]+ contains 10 entries:
|
|
Offset +Info +Type +Sym\.Value +Sym\. Name \+ Addend
|
|
[0-9a-f ]+R_SH_TLS_DTPMOD32 +0+00
|
|
[0-9a-f ]+R_SH_TLS_TPOFF32 +0+0c
|
|
[0-9a-f ]+R_SH_TLS_DTPMOD32 +0+00
|
|
[0-9a-f ]+R_SH_TLS_DTPMOD32 +0+00
|
|
[0-9a-f ]+R_SH_TLS_TPOFF32 +0+1c
|
|
[0-9a-f ]+R_SH_TLS_DTPMOD32 +0+00
|
|
[0-9a-f ]+R_SH_TLS_TPOFF32 +0+14
|
|
[0-9a-f ]+R_SH_TLS_DTPMOD32 +0+ +sg1 \+ 0
|
|
[0-9a-f ]+R_SH_TLS_DTPOFF32 +0+ +sg1 \+ 0
|
|
[0-9a-f ]+R_SH_TLS_TPOFF32 +0+04 +sg2 \+ 0
|
|
|
|
Relocation section '\.rela\.plt' at offset 0x[0-9a-f]+ contains 1 entries:
|
|
Offset +Info +Type +Sym\.Value +Sym\. Name \+ Addend
|
|
[0-9a-f ]+R_SH_JMP_SLOT[0-9a-f ]+__tls_get_addr \+ [0-9a-f]+
|
|
|
|
Symbol table '\.dynsym' contains [0-9]+ entries:
|
|
+Num: +Value +Size Type +Bind +Vis +Ndx Name
|
|
.* NOTYPE +LOCAL +DEFAULT UND *
|
|
.* NOTYPE GLOBAL DEFAULT UND __tls_get_addr
|
|
.* TLS +GLOBAL DEFAULT +8 sg1
|
|
#...
|
|
.* FUNC +GLOBAL DEFAULT +7 fn1
|
|
#...
|
|
.* TLS +GLOBAL DEFAULT +8 sg2
|
|
#...
|
|
|
|
#pass
|