projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
breakpoints/19546: Fix crash after updating breakpoints
[deliverable/binutils-gdb.git]
/
gprof
/
corefile.c
diff --git
a/gprof/corefile.c
b/gprof/corefile.c
index 9f93ceeab3d67097ba4d6898f25db339d36edb1f..37942b564addb3bf91829ff81e83a851a9f9992c 100644
(file)
--- a/
gprof/corefile.c
+++ b/
gprof/corefile.c
@@
-1,7
+1,6
@@
/* corefile.c
/* corefile.c
- Copyright 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008, 2009,
- 2010, 2011 Free Software Foundation, Inc.
+ Copyright (C) 1999-2016 Free Software Foundation, Inc.
This file is part of GNU Binutils.
This file is part of GNU Binutils.
@@
-54,6
+53,7
@@
extern void vax_find_call (Sym *, bfd_vma, bfd_vma);
extern void tahoe_find_call (Sym *, bfd_vma, bfd_vma);
extern void sparc_find_call (Sym *, bfd_vma, bfd_vma);
extern void mips_find_call (Sym *, bfd_vma, bfd_vma);
extern void tahoe_find_call (Sym *, bfd_vma, bfd_vma);
extern void sparc_find_call (Sym *, bfd_vma, bfd_vma);
extern void mips_find_call (Sym *, bfd_vma, bfd_vma);
+extern void aarch64_find_call (Sym *, bfd_vma, bfd_vma);
static void
parse_error (const char *filename)
static void
parse_error (const char *filename)
@@
-68,7
+68,7
@@
parse_error (const char *filename)
static int
cmp_symbol_map (const void * l, const void * r)
{
static int
cmp_symbol_map (const void * l, const void * r)
{
- return strcmp (((struct function_map *) l)->function_name,
+ return strcmp (((struct function_map *) l)->function_name,
((struct function_map *) r)->function_name);
}
((struct function_map *) r)->function_name);
}
@@
-163,6
+163,8
@@
read_function_mappings (const char *filename)
symbol_map[i].is_first = 1;
qsort (symbol_map, symbol_map_count, sizeof (struct function_map), cmp_symbol_map);
symbol_map[i].is_first = 1;
qsort (symbol_map, symbol_map_count, sizeof (struct function_map), cmp_symbol_map);
+
+ fclose (file);
}
void
}
void
@@
-320,6
+322,10
@@
find_call (Sym *parent, bfd_vma p_lowpc, bfd_vma p_highpc)
mips_find_call (parent, p_lowpc, p_highpc);
break;
mips_find_call (parent, p_lowpc, p_highpc);
break;
+ case bfd_arch_aarch64:
+ aarch64_find_call (parent, p_lowpc, p_highpc);
+ break;
+
default:
fprintf (stderr, _("%s: -c not supported on architecture %s\n"),
whoami, bfd_printable_name(core_bfd));
default:
fprintf (stderr, _("%s: -c not supported on architecture %s\n"),
whoami, bfd_printable_name(core_bfd));
@@
-394,13
+400,19
@@
core_sym_class (asymbol *sym)
Allow for multiple iterations of both - apparently GCC can clone
clones and subprograms. */
int digit_seen = 0;
Allow for multiple iterations of both - apparently GCC can clone
clones and subprograms. */
int digit_seen = 0;
-#define CLONE_NAME ".clone."
-#define CLONE_NAME_LEN strlen (CLONE_NAME)
-
+#define CLONE_NAME ".clone."
+#define CLONE_NAME_LEN strlen (CLONE_NAME)
+#define CONSTPROP_NAME ".constprop."
+#define CONSTPROP_NAME_LEN strlen (CONSTPROP_NAME)
+
if (strlen (name) > CLONE_NAME_LEN
&& strncmp (name, CLONE_NAME, CLONE_NAME_LEN) == 0)
name += CLONE_NAME_LEN - 1;
if (strlen (name) > CLONE_NAME_LEN
&& strncmp (name, CLONE_NAME, CLONE_NAME_LEN) == 0)
name += CLONE_NAME_LEN - 1;
+ else if (strlen (name) > CONSTPROP_NAME_LEN
+ && strncmp (name, CONSTPROP_NAME, CONSTPROP_NAME_LEN) == 0)
+ name += CONSTPROP_NAME_LEN - 1;
+
for (name++; *name; name++)
if (digit_seen && *name == '.')
break;
for (name++; *name; name++)
if (digit_seen && *name == '.')
break;
@@
-470,7
+482,7
@@
get_src_info (bfd_vma addr, const char **filename, const char **name, int *line_
/* Return number of symbols in a symbol-table file. */
/* Return number of symbols in a symbol-table file. */
-static int
+static int
num_of_syms_in (FILE * f)
{
const int BUFSIZE = 1024;
num_of_syms_in (FILE * f)
{
const int BUFSIZE = 1024;
@@
-479,7
+491,7
@@
num_of_syms_in (FILE * f)
char type;
char * name = (char *) xmalloc (BUFSIZE);
int num = 0;
char type;
char * name = (char *) xmalloc (BUFSIZE);
int num = 0;
-
+
while (!feof (f) && fgets (buf, BUFSIZE - 1, f))
{
if (sscanf (buf, "%s %c %s", address, &type, name) == 3)
while (!feof (f) && fgets (buf, BUFSIZE - 1, f))
{
if (sscanf (buf, "%s %c %s", address, &type, name) == 3)
This page took
0.024605 seconds
and
4
git commands to generate.