diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2015-02-07 05:28:06 -0800 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2015-02-07 05:28:06 -0800 |
commit | 1952c5cd7d3d24b9647b396731bc4808a2d63d9c (patch) | |
tree | c9c5da57723dffe43b0808aa2a0f297015904f4e | |
parent | 11228d29d5146828325a7f14596b9d87f7a2edf7 (diff) | |
download | gdb-1952c5cd7d3d24b9647b396731bc4808a2d63d9c.zip gdb-1952c5cd7d3d24b9647b396731bc4808a2d63d9c.tar.gz gdb-1952c5cd7d3d24b9647b396731bc4808a2d63d9c.tar.bz2 |
Issue relocation in RO section warning for -z text
This patch changes linker to issue a warning for relocation in readonly
section for -z text.
bfd/
PR ld/17935
* elf32-i386.c (elf_i386_readonly_dynrelocs): Also issue a
warning for relocation in readonly section for -z text.
(elf_i386_size_dynamic_sections): Likewise.
* elf64-x86-64.c (elf_x86_64_readonly_dynrelocs): Likewise.
(elf_x86_64_size_dynamic_sections): Likewise.
ld/testsuite/
PR ld/17935
* ld-i386/i386.exp: Run pr17935-1 and pr17935-2.
* ld-x86-64/x86-64.exp: Likewise.
* ld-i386/pr17935-1.d: New file.
* ld-i386/pr17935-1.s: Likewise.
* ld-i386/pr17935-2.d: Likewise.
* ld-i386/pr17935-2.s: Likewise.
* ld-x86-64/pr17935-1.d: Likewise.
* ld-x86-64/pr17935-1.s: Likewise.
* ld-x86-64/pr17935-2.d: Likewise.
* ld-x86-64/pr17935-2.s: Likewise.
-rw-r--r-- | bfd/ChangeLog | 9 | ||||
-rw-r--r-- | bfd/elf32-i386.c | 10 | ||||
-rw-r--r-- | bfd/elf64-x86-64.c | 10 | ||||
-rw-r--r-- | ld/testsuite/ChangeLog | 15 | ||||
-rw-r--r-- | ld/testsuite/ld-i386/i386.exp | 2 | ||||
-rw-r--r-- | ld/testsuite/ld-i386/pr17935-1.d | 3 | ||||
-rw-r--r-- | ld/testsuite/ld-i386/pr17935-1.s | 7 | ||||
-rw-r--r-- | ld/testsuite/ld-i386/pr17935-2.d | 3 | ||||
-rw-r--r-- | ld/testsuite/ld-i386/pr17935-2.s | 6 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/pr17935-1.d | 3 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/pr17935-1.s | 7 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/pr17935-2.d | 3 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/pr17935-2.s | 6 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/x86-64.exp | 2 |
14 files changed, 78 insertions, 8 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 1220455..9732bea 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,12 @@ +2015-02-07 H.J. Lu <hongjiu.lu@intel.com> + + PR ld/17935 + * elf32-i386.c (elf_i386_readonly_dynrelocs): Also issue a + warning for relocation in readonly section for -z text. + (elf_i386_size_dynamic_sections): Likewise. + * elf64-x86-64.c (elf_x86_64_readonly_dynrelocs): Likewise. + (elf_x86_64_size_dynamic_sections): Likewise. + 2015-02-06 H.J. Lu <hongjiu.lu@intel.com> PR ld/12365 diff --git a/bfd/elf32-i386.c b/bfd/elf32-i386.c index 439538e..dd4dbdc 100644 --- a/bfd/elf32-i386.c +++ b/bfd/elf32-i386.c @@ -2600,8 +2600,9 @@ elf_i386_readonly_dynrelocs (struct elf_link_hash_entry *h, void *inf) info->flags |= DF_TEXTREL; - if (info->warn_shared_textrel && info->shared) - info->callbacks->einfo (_("%P: %B: warning: relocation against `%s' in readonly section `%A'.\n"), + if ((info->warn_shared_textrel && info->shared) + || info->error_textrel) + info->callbacks->einfo (_("%P: %B: warning: relocation against `%s' in readonly section `%A'\n"), p->sec->owner, h->root.root.string, p->sec); @@ -2842,8 +2843,9 @@ elf_i386_size_dynamic_sections (bfd *output_bfd, struct bfd_link_info *info) && (info->flags & DF_TEXTREL) == 0) { info->flags |= DF_TEXTREL; - if (info->warn_shared_textrel && info->shared) - info->callbacks->einfo (_("%P: %B: warning: relocation in readonly section `%A'.\n"), + if ((info->warn_shared_textrel && info->shared) + || info->error_textrel) + info->callbacks->einfo (_("%P: %B: warning: relocation in readonly section `%A'\n"), p->sec->owner, p->sec); } } diff --git a/bfd/elf64-x86-64.c b/bfd/elf64-x86-64.c index 80136bf..5fd727b 100644 --- a/bfd/elf64-x86-64.c +++ b/bfd/elf64-x86-64.c @@ -2850,8 +2850,9 @@ elf_x86_64_readonly_dynrelocs (struct elf_link_hash_entry *h, info->flags |= DF_TEXTREL; - if (info->warn_shared_textrel && info->shared) - info->callbacks->einfo (_("%P: %B: warning: relocation against `%s' in readonly section `%A'.\n"), + if ((info->warn_shared_textrel && info->shared) + || info->error_textrel) + info->callbacks->einfo (_("%P: %B: warning: relocation against `%s' in readonly section `%A'\n"), p->sec->owner, h->root.root.string, p->sec); @@ -3090,8 +3091,9 @@ elf_x86_64_size_dynamic_sections (bfd *output_bfd, && (info->flags & DF_TEXTREL) == 0) { info->flags |= DF_TEXTREL; - if (info->warn_shared_textrel && info->shared) - info->callbacks->einfo (_("%P: %B: warning: relocation in readonly section `%A'.\n"), + if ((info->warn_shared_textrel && info->shared) + || info->error_textrel) + info->callbacks->einfo (_("%P: %B: warning: relocation in readonly section `%A'\n"), p->sec->owner, p->sec); } } diff --git a/ld/testsuite/ChangeLog b/ld/testsuite/ChangeLog index 075016b..3f085c2 100644 --- a/ld/testsuite/ChangeLog +++ b/ld/testsuite/ChangeLog @@ -1,3 +1,18 @@ +2015-02-07 H.J. Lu <hongjiu.lu@intel.com> + + PR ld/17935 + * ld-i386/i386.exp: Run pr17935-1 and pr17935-2. + * ld-x86-64/x86-64.exp: Likewise. + + * ld-i386/pr17935-1.d: New file. + * ld-i386/pr17935-1.s: Likewise. + * ld-i386/pr17935-2.d: Likewise. + * ld-i386/pr17935-2.s: Likewise. + * ld-x86-64/pr17935-1.d: Likewise. + * ld-x86-64/pr17935-1.s: Likewise. + * ld-x86-64/pr17935-2.d: Likewise. + * ld-x86-64/pr17935-2.s: Likewise. + 2015-02-06 H.J. Lu <hongjiu.lu@intel.com> PR ld/12365 diff --git a/ld/testsuite/ld-i386/i386.exp b/ld/testsuite/ld-i386/i386.exp index 6f98b4f..f5922b4 100644 --- a/ld/testsuite/ld-i386/i386.exp +++ b/ld/testsuite/ld-i386/i386.exp @@ -263,6 +263,8 @@ run_dump_test "pr12627" run_dump_test "pr13302" run_dump_test "pr14215" run_dump_test "pr17057" +run_dump_test "pr17935-1" +run_dump_test "pr17935-2" # Must be Linux native with the C compiler if { [isnative] diff --git a/ld/testsuite/ld-i386/pr17935-1.d b/ld/testsuite/ld-i386/pr17935-1.d new file mode 100644 index 0000000..5303ea2 --- /dev/null +++ b/ld/testsuite/ld-i386/pr17935-1.d @@ -0,0 +1,3 @@ +# as: --32 +# ld: -m elf_i386 -shared -z text +# error: warning: relocation against `foo' in readonly section `.text' diff --git a/ld/testsuite/ld-i386/pr17935-1.s b/ld/testsuite/ld-i386/pr17935-1.s new file mode 100644 index 0000000..38eef2e --- /dev/null +++ b/ld/testsuite/ld-i386/pr17935-1.s @@ -0,0 +1,7 @@ + .text + .globl foo +foo: + .byte 0 + .globl bar +bar: + .dc.a foo diff --git a/ld/testsuite/ld-i386/pr17935-2.d b/ld/testsuite/ld-i386/pr17935-2.d new file mode 100644 index 0000000..c1080f4 --- /dev/null +++ b/ld/testsuite/ld-i386/pr17935-2.d @@ -0,0 +1,3 @@ +# as: --32 +# ld: -m elf_i386 -shared -z text +# error: warning: relocation in readonly section `.text' diff --git a/ld/testsuite/ld-i386/pr17935-2.s b/ld/testsuite/ld-i386/pr17935-2.s new file mode 100644 index 0000000..3ae5369 --- /dev/null +++ b/ld/testsuite/ld-i386/pr17935-2.s @@ -0,0 +1,6 @@ + .text +foo: + .byte 0 + .globl bar +bar: + .dc.a foo diff --git a/ld/testsuite/ld-x86-64/pr17935-1.d b/ld/testsuite/ld-x86-64/pr17935-1.d new file mode 100644 index 0000000..5734eab --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr17935-1.d @@ -0,0 +1,3 @@ +# as: --64 +# ld: -m elf_x86_64 -shared -z text +# error: warning: relocation against `foo' in readonly section `.text' diff --git a/ld/testsuite/ld-x86-64/pr17935-1.s b/ld/testsuite/ld-x86-64/pr17935-1.s new file mode 100644 index 0000000..38eef2e --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr17935-1.s @@ -0,0 +1,7 @@ + .text + .globl foo +foo: + .byte 0 + .globl bar +bar: + .dc.a foo diff --git a/ld/testsuite/ld-x86-64/pr17935-2.d b/ld/testsuite/ld-x86-64/pr17935-2.d new file mode 100644 index 0000000..81df652 --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr17935-2.d @@ -0,0 +1,3 @@ +# as: --64 +# ld: -m elf_x86_64 -shared -z text +# error: warning: relocation in readonly section `.text' diff --git a/ld/testsuite/ld-x86-64/pr17935-2.s b/ld/testsuite/ld-x86-64/pr17935-2.s new file mode 100644 index 0000000..3ae5369 --- /dev/null +++ b/ld/testsuite/ld-x86-64/pr17935-2.s @@ -0,0 +1,6 @@ + .text +foo: + .byte 0 + .globl bar +bar: + .dc.a foo diff --git a/ld/testsuite/ld-x86-64/x86-64.exp b/ld/testsuite/ld-x86-64/x86-64.exp index bfa89c3..9bb08bd 100644 --- a/ld/testsuite/ld-x86-64/x86-64.exp +++ b/ld/testsuite/ld-x86-64/x86-64.exp @@ -311,6 +311,8 @@ run_dump_test "mov1a" run_dump_test "mov1b" run_dump_test "mov1c" run_dump_test "mov1d" +run_dump_test "pr17935-1" +run_dump_test "pr17935-2" # Must be native with the C compiler if { [isnative] && [which $CC] != 0 } { |