* elf64-sparc.c (sparc64_elf_relocate_section): Clear the location
of a GOT reloc.
This commit is contained in:
parent
e1e0340bc8
commit
ea5fbc6753
2 changed files with 12 additions and 1 deletions
|
@ -1,5 +1,8 @@
|
||||||
2000-10-16 Geoffrey Keating <geoffk@shoggoth.cygnus.com>
|
2000-10-16 Geoffrey Keating <geoffk@shoggoth.cygnus.com>
|
||||||
|
|
||||||
|
* elf64-sparc.c (sparc64_elf_relocate_section): Clear the location
|
||||||
|
of a GOT reloc.
|
||||||
|
|
||||||
* elf32-ppc.c (SYMBOL_REFERENCES_LOCAL): New macro.
|
* elf32-ppc.c (SYMBOL_REFERENCES_LOCAL): New macro.
|
||||||
(SYMBOL_CALLS_LOCAL): New macro.
|
(SYMBOL_CALLS_LOCAL): New macro.
|
||||||
(ppc_elf_adjust_dynamic_symbol): Use SYMBOL_CALLS_LOCAL.
|
(ppc_elf_adjust_dynamic_symbol): Use SYMBOL_CALLS_LOCAL.
|
||||||
|
|
|
@ -2358,7 +2358,6 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section,
|
||||||
off &= ~1;
|
off &= ~1;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bfd_put_64 (output_bfd, relocation, sgot->contents + off);
|
|
||||||
local_got_offsets[r_symndx] |= 1;
|
local_got_offsets[r_symndx] |= 1;
|
||||||
|
|
||||||
if (info->shared)
|
if (info->shared)
|
||||||
|
@ -2366,6 +2365,13 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section,
|
||||||
asection *srelgot;
|
asection *srelgot;
|
||||||
Elf_Internal_Rela outrel;
|
Elf_Internal_Rela outrel;
|
||||||
|
|
||||||
|
/* The Solaris 2.7 64-bit linker adds the contents
|
||||||
|
of the location to the value of the reloc.
|
||||||
|
Note this is different behaviour to the
|
||||||
|
32-bit linker, which both adds the contents
|
||||||
|
and ignores the addend. So clear the location. */
|
||||||
|
bfd_put_64 (output_bfd, 0, sgot->contents + off);
|
||||||
|
|
||||||
/* We need to generate a R_SPARC_RELATIVE reloc
|
/* We need to generate a R_SPARC_RELATIVE reloc
|
||||||
for the dynamic linker. */
|
for the dynamic linker. */
|
||||||
srelgot = bfd_get_section_by_name(dynobj, ".rela.got");
|
srelgot = bfd_get_section_by_name(dynobj, ".rela.got");
|
||||||
|
@ -2382,6 +2388,8 @@ sparc64_elf_relocate_section (output_bfd, info, input_bfd, input_section,
|
||||||
+ srelgot->reloc_count));
|
+ srelgot->reloc_count));
|
||||||
++srelgot->reloc_count;
|
++srelgot->reloc_count;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
bfd_put_64 (output_bfd, relocation, sgot->contents + off);
|
||||||
}
|
}
|
||||||
relocation = sgot->output_offset + off - got_base;
|
relocation = sgot->output_offset + off - got_base;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue