]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commit - bfd/ChangeLog
PR25384, PowerPC64 ELFv1 copy relocs against function symbols
authorAlan Modra <amodra@gmail.com>
Tue, 14 Jan 2020 10:15:53 +0000 (20:45 +1030)
committerAlan Modra <amodra@gmail.com>
Wed, 15 Jan 2020 01:59:21 +0000 (12:29 +1030)
commite1c6cf618cbeebbafd34afc5ee921fcbf7061bfa
tree0b4df69086860715c0142805e45013a0ce383555
parentff47f4f06d296b672337e2c7363a745cd2725f58
PR25384, PowerPC64 ELFv1 copy relocs against function symbols

Function symbols of course don't normally want .dynbss copies but
with some old versions of gcc they are needed to copy the function
descriptor.  This patch restricts the cases where they are useful to
compilers using dot-symbols, and enables the warning regardless of
whether a PLT entry is emitted in the executable.  PLTs in shared
libraries are affected by a .dynbss copy in the executable.

bfd/
PR 25384
* elf64-ppc.c (ELIMINATE_COPY_RELOCS): Update comment.
(ppc64_elf_adjust_dynamic_symbol): Don't allow .dynbss copies
of function symbols unless dot symbols are present.  Do warn
whenever one is created, regardles of whether a PLT entry is
also emitted for the function symbol.
ld/
* testsuite/ld-powerpc/ambiguousv1b.d: Adjust expected output.
* testsuite/ld-powerpc/funref.s: Align func_tab.
* testsuite/ld-powerpc/funref2.s: Likewise.
* testsuite/ld-powerpc/funv1.s: Add dot symbols.
bfd/ChangeLog
bfd/elf64-ppc.c
ld/ChangeLog
ld/testsuite/ld-powerpc/ambiguousv1b.d
ld/testsuite/ld-powerpc/funref.s
ld/testsuite/ld-powerpc/funref2.s
ld/testsuite/ld-powerpc/funv1.s