aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2011-02-06 23:38:38 +0000
committerAlan Modra <amodra@gmail.com>2011-02-06 23:38:38 +0000
commit02f2d833d849131cc63318139ea78ccb6bbaa9f2 (patch)
treeab17ee7c7c41dd0e2dadc2ed55f008a01e9af26b
parentcac9794631d045afd7125b304140a86dee99524f (diff)
downloadgdb-02f2d833d849131cc63318139ea78ccb6bbaa9f2.zip
gdb-02f2d833d849131cc63318139ea78ccb6bbaa9f2.tar.gz
gdb-02f2d833d849131cc63318139ea78ccb6bbaa9f2.tar.bz2
PR gprof/12468
* corefile.c (core_create_function_syms): Set is_func for targets that have no BSF_FUNCTION syms.
-rw-r--r--gprof/ChangeLog6
-rw-r--r--gprof/corefile.c19
2 files changed, 23 insertions, 2 deletions
diff --git a/gprof/ChangeLog b/gprof/ChangeLog
index 73427a6..fbf8b90 100644
--- a/gprof/ChangeLog
+++ b/gprof/ChangeLog
@@ -1,3 +1,9 @@
+2011-02-07 Alan Modra <amodra@gmail.com>
+
+ PR gprof/12468
+ * corefile.c (core_create_function_syms): Set is_func for targets
+ that have no BSF_FUNCTION syms.
+
2011-01-10 Nick Clifton <nickc@redhat.com>
* po/da.po: Updated Danish translation.
diff --git a/gprof/corefile.c b/gprof/corefile.c
index 6b10d17..fd4644b 100644
--- a/gprof/corefile.c
+++ b/gprof/corefile.c
@@ -1,7 +1,7 @@
/* corefile.c
Copyright 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008, 2009,
- 2010 Free Software Foundation, Inc.
+ 2010, 2011 Free Software Foundation, Inc.
This file is part of GNU Binutils.
@@ -573,6 +573,20 @@ core_create_function_syms (void)
int cxxclass;
long i;
struct function_map * found;
+ int core_has_func_syms = 0;
+
+ switch (core_bfd->xvec->flavour)
+ {
+ default:
+ break;
+ case bfd_target_coff_flavour:
+ case bfd_target_ecoff_flavour:
+ case bfd_target_xcoff_flavour:
+ case bfd_target_elf_flavour:
+ case bfd_target_nlm_flavour:
+ case bfd_target_som_flavour:
+ core_has_func_syms = 1;
+ }
/* Pass 1 - determine upper bound on number of function names. */
symtab.len = 0;
@@ -678,7 +692,8 @@ core_create_function_syms (void)
}
}
- symtab.limit->is_func = (core_syms[i]->flags & BSF_FUNCTION) != 0;
+ symtab.limit->is_func = (!core_has_func_syms
+ || (core_syms[i]->flags & BSF_FUNCTION) != 0);
symtab.limit->is_bb_head = TRUE;
if (cxxclass == 't')