* elf32-i386.c (elf_i386_relocate_section): Fill in proper addend
for R_386_TLS_TPOFF32 relocs against symndx 0.
This commit is contained in:
parent
b2dd631140
commit
c366c25e10
@ -1,3 +1,8 @@
|
|||||||
|
2002-08-08 Jakub Jelinek <jakub@redhat.com>
|
||||||
|
|
||||||
|
* elf32-i386.c (elf_i386_relocate_section): Fill in proper addend
|
||||||
|
for R_386_TLS_TPOFF32 relocs against symndx 0.
|
||||||
|
|
||||||
2002-08-07 H.J. Lu <hjl@gnu.org>
|
2002-08-07 H.J. Lu <hjl@gnu.org>
|
||||||
|
|
||||||
* elflink.h (NAME(bfd_elf,size_dynamic_sections)): Check symbol
|
* elflink.h (NAME(bfd_elf,size_dynamic_sections)): Check symbol
|
||||||
|
@ -2567,13 +2567,17 @@ elf_i386_relocate_section (output_bfd, info, input_bfd, input_section,
|
|||||||
outrel.r_offset = (htab->sgot->output_section->vma
|
outrel.r_offset = (htab->sgot->output_section->vma
|
||||||
+ htab->sgot->output_offset + off);
|
+ htab->sgot->output_offset + off);
|
||||||
|
|
||||||
bfd_put_32 (output_bfd, 0,
|
|
||||||
htab->sgot->contents + off);
|
|
||||||
indx = h && h->dynindx != -1 ? h->dynindx : 0;
|
indx = h && h->dynindx != -1 ? h->dynindx : 0;
|
||||||
if (r_type == R_386_TLS_GD)
|
if (r_type == R_386_TLS_GD)
|
||||||
dr_type = R_386_TLS_DTPMOD32;
|
dr_type = R_386_TLS_DTPMOD32;
|
||||||
else
|
else
|
||||||
dr_type = R_386_TLS_TPOFF32;
|
dr_type = R_386_TLS_TPOFF32;
|
||||||
|
if (dr_type == R_386_TLS_TPOFF32 && indx == 0)
|
||||||
|
bfd_put_32 (output_bfd, relocation - dtpoff_base (info),
|
||||||
|
htab->sgot->contents + off);
|
||||||
|
else
|
||||||
|
bfd_put_32 (output_bfd, 0,
|
||||||
|
htab->sgot->contents + off);
|
||||||
outrel.r_info = ELF32_R_INFO (indx, dr_type);
|
outrel.r_info = ELF32_R_INFO (indx, dr_type);
|
||||||
loc = (Elf32_External_Rel *) htab->srelgot->contents;
|
loc = (Elf32_External_Rel *) htab->srelgot->contents;
|
||||||
loc += htab->srelgot->reloc_count++;
|
loc += htab->srelgot->reloc_count++;
|
||||||
|
Loading…
Reference in New Issue
Block a user