From 7f4fcc6f9bdd7c77866c527be6cbc1f3b75800e4 Mon Sep 17 00:00:00 2001 From: Matthias Klose Date: Wed, 27 Feb 2019 21:30:21 +0000 Subject: [PATCH] pr24276 Skip symbol defined by linker when checking copy reloc on protected symbol. bfd/ PR ld/24276 * elf64-x86-64.c (elf_x86_64_check_relocs): Skip symbol defined by linker when checking copy reloc on protected symbol. ld/ PR ld/24276 * testsuite/ld-i386/i386.exp: Run PR ld/24276 test. * testsuite/ld-x86-64/x86-64.exp: Likewise. * testsuite/ld-i386/pr24276.dso: New file. * testsuite/ld-i386/pr24276.warn: Likewise. * testsuite/ld-x86-64/pr24276.dso: Likewise. * testsuite/ld-x86-64/pr24276.warn: Likewise. Gbp-Pq: Name pr24276.diff --- bfd/elf64-x86-64.c | 2 ++ ld/testsuite/ld-i386/i386.exp | 9 +++++++++ ld/testsuite/ld-i386/pr24276.dso | 9 +++++++++ ld/testsuite/ld-i386/pr24276.warn | 1 + ld/testsuite/ld-x86-64/pr24276.dso | 9 +++++++++ ld/testsuite/ld-x86-64/pr24276.warn | 1 + ld/testsuite/ld-x86-64/x86-64.exp | 9 +++++++++ 7 files changed, 40 insertions(+) create mode 100644 ld/testsuite/ld-i386/pr24276.dso create mode 100644 ld/testsuite/ld-i386/pr24276.warn create mode 100644 ld/testsuite/ld-x86-64/pr24276.dso create mode 100644 ld/testsuite/ld-x86-64/pr24276.warn diff --git a/bfd/elf64-x86-64.c b/bfd/elf64-x86-64.c index e265cf324..dec3287d6 100644 --- a/bfd/elf64-x86-64.c +++ b/bfd/elf64-x86-64.c @@ -2238,6 +2238,8 @@ check_pic: bfd_boolean no_copyreloc_p = (info->nocopyreloc || (h != NULL + && !h->root.linker_def + && !h->root.ldscript_def && eh->def_protected && elf_has_no_copy_on_protected (h->root.u.def.section->owner))); if ((sec->flags & SEC_ALLOC) != 0 diff --git a/ld/testsuite/ld-i386/i386.exp b/ld/testsuite/ld-i386/i386.exp index 56c95367e..e56d15f51 100644 --- a/ld/testsuite/ld-i386/i386.exp +++ b/ld/testsuite/ld-i386/i386.exp @@ -785,6 +785,15 @@ if { [isnative] {{objdump {-dw} pr19319.dd}} \ "pr19319" \ ] \ + [list \ + "Build pr24276.so" \ + "-shared -nostdlib -nostartfiles \ + -Ltmpdir $srcdir/$subdir/pr24276.dso" \ + "-Wa,-mx86-used-note=yes" \ + { pr19319b.S } \ + {{warning_output pr24276.warn}} \ + "pr24276.so" \ + ] \ [list \ "Build property 1" \ "" \ diff --git a/ld/testsuite/ld-i386/pr24276.dso b/ld/testsuite/ld-i386/pr24276.dso new file mode 100644 index 000000000..9add115e1 --- /dev/null +++ b/ld/testsuite/ld-i386/pr24276.dso @@ -0,0 +1,9 @@ +INPUT(pr19319.so) +SECTIONS { + my_section : { + __start_my_section = .; + *(my_section); + __stop_my_section = .; + + } +} diff --git a/ld/testsuite/ld-i386/pr24276.warn b/ld/testsuite/ld-i386/pr24276.warn new file mode 100644 index 000000000..5fcfa343c --- /dev/null +++ b/ld/testsuite/ld-i386/pr24276.warn @@ -0,0 +1 @@ +.*contains output sections.* diff --git a/ld/testsuite/ld-x86-64/pr24276.dso b/ld/testsuite/ld-x86-64/pr24276.dso new file mode 100644 index 000000000..9add115e1 --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr24276.dso @@ -0,0 +1,9 @@ +INPUT(pr19319.so) +SECTIONS { + my_section : { + __start_my_section = .; + *(my_section); + __stop_my_section = .; + + } +} diff --git a/ld/testsuite/ld-x86-64/pr24276.warn b/ld/testsuite/ld-x86-64/pr24276.warn new file mode 100644 index 000000000..5fcfa343c --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr24276.warn @@ -0,0 +1 @@ +.*contains output sections.* diff --git a/ld/testsuite/ld-x86-64/x86-64.exp b/ld/testsuite/ld-x86-64/x86-64.exp index ac41d8ea4..cdd549b14 100644 --- a/ld/testsuite/ld-x86-64/x86-64.exp +++ b/ld/testsuite/ld-x86-64/x86-64.exp @@ -923,6 +923,15 @@ if { [isnative] && [which $CC] != 0 } { {{objdump {-dw} pr19319.dd}} \ "pr19319" \ ] \ + [list \ + "Build pr24276.so" \ + "-shared -nostdlib -nostartfiles \ + -Ltmpdir $srcdir/$subdir/pr24276.dso" \ + "-Wa,-mx86-used-note=yes" \ + { pr19319b.S } \ + {{warning_output pr24276.warn}} \ + "pr24276.so" \ + ] \ [list \ "Build property 1" \ "" \ -- 2.30.2