diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2018-03-14 04:23:24 -0700 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2018-03-14 04:23:40 -0700 |
commit | 9e223787a474c672c5f1cfd4574857241ae4eafa (patch) | |
tree | df0b15bd36ada60535ed0795da1df927a8189221 /bfd/elflink.c | |
parent | bf48520113c4265017769d374f6b1a7ce3fc8e41 (diff) | |
download | gdb-9e223787a474c672c5f1cfd4574857241ae4eafa.zip gdb-9e223787a474c672c5f1cfd4574857241ae4eafa.tar.gz gdb-9e223787a474c672c5f1cfd4574857241ae4eafa.tar.bz2 |
GC: Also check the local debug definition section
Extend
commit b7c871edcd83ccdc5fcd8148a7f433efd6b52255
Author: H.J. Lu <hjl.tools@gmail.com>
Date: Wed May 17 07:57:15 2017 -0700
Mark debug sections referenced by kept debug sections
to handle the local debug definition section.
bfd/
PR ld/20882
* elflink.c (elf_gc_mark_debug_section): Also check the local
debug definition section.
ld/
PR ld/20882
* testsuite/ld-gc/pr20882.d: Also dump and check .debug_abbrev
section.
* testsuite/ld-gc/pr20882b.s: Add .debug_abbrev section.
Diffstat (limited to 'bfd/elflink.c')
-rw-r--r-- | bfd/elflink.c | 25 |
1 files changed, 18 insertions, 7 deletions
diff --git a/bfd/elflink.c b/bfd/elflink.c index 092edae..6a3d516 100644 --- a/bfd/elflink.c +++ b/bfd/elflink.c @@ -12802,20 +12802,31 @@ _bfd_elf_gc_mark_hook (asection *sec, return NULL; } -/* Return the global debug definition section. */ +/* Return the debug definition section. */ static asection * elf_gc_mark_debug_section (asection *sec ATTRIBUTE_UNUSED, struct bfd_link_info *info ATTRIBUTE_UNUSED, Elf_Internal_Rela *rel ATTRIBUTE_UNUSED, struct elf_link_hash_entry *h, - Elf_Internal_Sym *sym ATTRIBUTE_UNUSED) + Elf_Internal_Sym *sym) { - if (h != NULL - && (h->root.type == bfd_link_hash_defined - || h->root.type == bfd_link_hash_defweak) - && (h->root.u.def.section->flags & SEC_DEBUGGING) != 0) - return h->root.u.def.section; + if (h != NULL) + { + /* Return the global debug definition section. */ + if ((h->root.type == bfd_link_hash_defined + || h->root.type == bfd_link_hash_defweak) + && (h->root.u.def.section->flags & SEC_DEBUGGING) != 0) + return h->root.u.def.section; + } + else + { + /* Return the local debug definition section. */ + asection *isec = bfd_section_from_elf_index (sec->owner, + sym->st_shndx); + if ((isec->flags & SEC_DEBUGGING) != 0) + return isec; + } return NULL; } |