summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2002-10-07 17:25:08 +0000
committerNick Clifton <nickc@redhat.com>2002-10-07 17:25:08 +0000
commitf309035a880c33487eb89d299e839afb213c7d42 (patch)
tree9c689bb6b91ddf22898a800209d603b67dbf2c4f
parentff72e302f8d3628ddfb8c70cba1c6017dfbb1700 (diff)
downloadppe42-binutils-f309035a880c33487eb89d299e839afb213c7d42.tar.gz
ppe42-binutils-f309035a880c33487eb89d299e839afb213c7d42.zip
Read in dynamic symbols if no ordinary ones are available.
-rw-r--r--binutils/ChangeLog5
-rw-r--r--binutils/addr2line.c11
2 files changed, 9 insertions, 7 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog
index 29a8339f97..372893a589 100644
--- a/binutils/ChangeLog
+++ b/binutils/ChangeLog
@@ -1,3 +1,8 @@
+2002-10-07 Gordon Chaffee <chaffee@netvmg.com>
+
+ * addr2line.c (slurp_symtab): Read in dynamic symbols if no
+ ordinary ones are available.
+
2002-09-30 H.J. Lu <hjl@gnu.org>
* readelf.c (get_machine_flags): Handle E_MIPS_MACH_4120,
diff --git a/binutils/addr2line.c b/binutils/addr2line.c
index 174a034890..1d09cd022d 100644
--- a/binutils/addr2line.c
+++ b/binutils/addr2line.c
@@ -96,19 +96,16 @@ static void
slurp_symtab (abfd)
bfd *abfd;
{
- long storage;
long symcount;
+ unsigned int size;
if ((bfd_get_file_flags (abfd) & HAS_SYMS) == 0)
return;
- storage = bfd_get_symtab_upper_bound (abfd);
- if (storage < 0)
- bfd_fatal (bfd_get_filename (abfd));
-
- syms = (asymbol **) xmalloc (storage);
+ symcount = bfd_read_minisymbols (abfd, false, (PTR) &syms, &size);
+ if (symcount == 0)
+ symcount = bfd_read_minisymbols (abfd, true /* dynamic */, (PTR) &syms, &size);
- symcount = bfd_canonicalize_symtab (abfd, syms);
if (symcount < 0)
bfd_fatal (bfd_get_filename (abfd));
}
OpenPOWER on IntegriCloud