summaryrefslogtreecommitdiff
path: root/binutils/addr2line.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@bigpond.net.au>2009-10-01 06:33:15 +0000
committerAlan Modra <amodra@bigpond.net.au>2009-10-01 06:33:15 +0000
commit5eda3bd30f1ba4961dab5a051b0effbbd774667a (patch)
tree9157fdfaad21ca975bf219e89a89362f637eccc6 /binutils/addr2line.c
parentae797c4010f1f086db943a8a59327c5edbf6e157 (diff)
downloadbinutils-redhat-5eda3bd30f1ba4961dab5a051b0effbbd774667a.tar.gz
* addr2line.c (slurp_symtab): Don't use bfd_read_minisymbols.
Diffstat (limited to 'binutils/addr2line.c')
-rw-r--r--binutils/addr2line.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/binutils/addr2line.c b/binutils/addr2line.c
index 5425664554..187252151f 100644
--- a/binutils/addr2line.c
+++ b/binutils/addr2line.c
@@ -100,17 +100,27 @@ usage (FILE *stream, int status)
static void
slurp_symtab (bfd *abfd)
{
+ long storage;
long symcount;
- unsigned int size;
- void *minisyms = &syms;
+ bfd_boolean dynamic = FALSE;
if ((bfd_get_file_flags (abfd) & HAS_SYMS) == 0)
return;
- symcount = bfd_read_minisymbols (abfd, FALSE, &minisyms, &size);
- if (symcount == 0)
- symcount = bfd_read_minisymbols (abfd, TRUE /* dynamic */, &minisyms, &size);
+ storage = bfd_get_symtab_upper_bound (abfd);
+ if (storage == 0)
+ {
+ storage = bfd_get_dynamic_symtab_upper_bound (abfd);
+ dynamic = TRUE;
+ }
+ if (storage < 0)
+ bfd_fatal (bfd_get_filename (abfd));
+ syms = (asymbol **) xmalloc (storage);
+ if (dynamic)
+ symcount = bfd_canonicalize_dynamic_symtab (abfd, syms);
+ else
+ symcount = bfd_canonicalize_symtab (abfd, syms);
if (symcount < 0)
bfd_fatal (bfd_get_filename (abfd));
}