From 9850436d9e423d66d67d27135896582b2725782e Mon Sep 17 00:00:00 2001 From: Alan Modra Date: Fri, 28 Feb 2014 14:38:27 +1030 Subject: [PATCH] Fix check_relocs/gc_sweep_hook mismatch PR ld/16643 * elflink.c (elf_gc_sweep): Call gc_sweep_hook for exactly the same conditions we called check_relocs. --- bfd/ChangeLog | 6 ++++++ bfd/elflink.c | 4 +++- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 472bc89391..75a638c54d 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,9 @@ +2014-02-28 Alan Modra + + PR ld/16643 + * elflink.c (elf_gc_sweep): Call gc_sweep_hook for exactly + the same conditions we called check_relocs. + 2014-02-27 Yuri Gribov * bfd-in.h: Add export of bfd_elf32_arm_use_long_plt. diff --git a/bfd/elflink.c b/bfd/elflink.c index 28ccf535a7..47e4802438 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -11992,7 +11992,9 @@ elf_gc_sweep (bfd *abfd, struct bfd_link_info *info) info we collected before. */ if (gc_sweep_hook && (o->flags & SEC_RELOC) != 0 - && o->reloc_count > 0 + && o->reloc_count != 0 + && !((info->strip == strip_all || info->strip == strip_debugger) + && (o->flags & SEC_DEBUGGING) != 0) && !bfd_is_abs_section (o->output_section)) { Elf_Internal_Rela *internal_relocs;