diff options
author | Alan Modra <amodra@gmail.com> | 2009-02-12 12:47:39 +0000 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2009-02-12 12:47:39 +0000 |
commit | d401d98a57f2e2d30befd5dbe479aaa2d5e83deb (patch) | |
tree | 87209154fa19df0abee30996e3768cfa4907dde9 /gprof/alpha.c | |
parent | 5d7cb8dff5604ea7f2a1cc598a95b2067c16dde6 (diff) | |
download | binutils-gdb-d401d98a57f2e2d30befd5dbe479aaa2d5e83deb.tar.gz |
* corefile.c (core_create_function_syms): Remove "<locore>" and
"<hicore>" sentinels.
* gprof.c: Likewise.
* cg_print.c (cg_print_function_ordering): Likewise.
* alpha.c (alpha_find_call): Add check for return value of sym_lookup.
* mips.c (mips_find_call): Likewise.
* sparc.c (sparc_find_call): Likewise.
* tahoe.c (tahoe_find_call): Likewise.
* vax.c (vax_find_call): Likewise.
Diffstat (limited to 'gprof/alpha.c')
-rw-r--r-- | gprof/alpha.c | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/gprof/alpha.c b/gprof/alpha.c index b14e842c5eb..1a3ebf9704b 100644 --- a/gprof/alpha.c +++ b/gprof/alpha.c @@ -148,17 +148,20 @@ alpha_find_call (Sym *parent, bfd_vma p_lowpc, bfd_vma p_highpc) if (hist_check_address (dest_pc)) { child = sym_lookup (&symtab, dest_pc); - DBG (CALLDEBUG, - printf (" 0x%lx\t; name=%s, addr=0x%lx", - (unsigned long) dest_pc, child->name, - (unsigned long) child->addr)); - if (child->addr == dest_pc || child->addr == dest_pc - 8) - { - DBG (CALLDEBUG, printf ("\n")); - /* a hit: */ - arc_add (parent, child, (unsigned long) 0); - continue; - } + if (child) + { + DBG (CALLDEBUG, + printf (" 0x%lx\t; name=%s, addr=0x%lx", + (unsigned long) dest_pc, child->name, + (unsigned long) child->addr)); + if (child->addr == dest_pc || child->addr == dest_pc - 8) + { + DBG (CALLDEBUG, printf ("\n")); + /* a hit: */ + arc_add (parent, child, (unsigned long) 0); + continue; + } + } } /* * Something funny going on. |