From f309035a880c33487eb89d299e839afb213c7d42 Mon Sep 17 00:00:00 2001 From: Nick Clifton Date: Mon, 7 Oct 2002 17:25:08 +0000 Subject: Read in dynamic symbols if no ordinary ones are available. --- binutils/ChangeLog | 5 +++++ binutils/addr2line.c | 11 ++++------- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 29a8339..372893a 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,8 @@ +2002-10-07 Gordon Chaffee + + * addr2line.c (slurp_symtab): Read in dynamic symbols if no + ordinary ones are available. + 2002-09-30 H.J. Lu * readelf.c (get_machine_flags): Handle E_MIPS_MACH_4120, diff --git a/binutils/addr2line.c b/binutils/addr2line.c index 174a034..1d09cd0 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)); } -- cgit v1.1