diff options
author | Joel Brobecker <brobecker@gnat.com> | 2007-02-09 20:11:47 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2007-02-09 20:11:47 +0000 |
commit | e9a34859e32becc4ddabfd098b25f12cff59544a (patch) | |
tree | 072c8b93b65c7f181b2c397bcd7b19fbae6ed17d /gdb/exec.c | |
parent | dd406f0ad67fae75aea71883c3790651e4d5bc76 (diff) | |
download | gdb-e9a34859e32becc4ddabfd098b25f12cff59544a.tar.gz |
* exec.c (add_to_section_table): Do not discard empty sections.
Diffstat (limited to 'gdb/exec.c')
-rw-r--r-- | gdb/exec.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/gdb/exec.c b/gdb/exec.c index fde35eb92eb..e2d6b995c90 100644 --- a/gdb/exec.c +++ b/gdb/exec.c @@ -345,11 +345,15 @@ add_to_section_table (bfd *abfd, struct bfd_section *asect, struct section_table **table_pp = (struct section_table **) table_pp_char; flagword aflag; + /* Check the section flags, but do not discard zero-length sections, since + some symbols may still be attached to this section. For instance, we + encountered on sparc-solaris 2.10 a shared library with an empty .bss + section to which a symbol named "_end" was attached. The address + of this symbol still needs to be relocated. */ aflag = bfd_get_section_flags (abfd, asect); if (!(aflag & SEC_ALLOC)) return; - if (0 == bfd_section_size (abfd, asect)) - return; + (*table_pp)->bfd = abfd; (*table_pp)->the_bfd_section = asect; (*table_pp)->addr = bfd_section_vma (abfd, asect); |