projects
/
deliverable
/
binutils-gdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
gdb/testsuite/tui: Introduce check_box_contents
[deliverable/binutils-gdb.git]
/
binutils
/
prdbg.c
diff --git
a/binutils/prdbg.c
b/binutils/prdbg.c
index 59313bb82a24ddb670d51d5578af8e45da9393bf..ef6fe61a0ff9562e0603194c11b346088e211bcc 100644
(file)
--- a/
binutils/prdbg.c
+++ b/
binutils/prdbg.c
@@
-1,6
+1,5
@@
/* prdbg.c -- Print out generic debugging information.
/* prdbg.c -- Print out generic debugging information.
- Copyright 1995, 1996, 1999, 2002, 2003, 2004, 2005, 2006, 2007, 2008,
- 2009 Free Software Foundation, Inc.
+ Copyright (C) 1995-2020 Free Software Foundation, Inc.
Written by Ian Lance Taylor <ian@cygnus.com>.
Tags style generation written by Salvador E. Tropea <set@computer.org>.
Written by Ian Lance Taylor <ian@cygnus.com>.
Tags style generation written by Salvador E. Tropea <set@computer.org>.
@@
-287,12
+286,15
@@
static const struct debug_write_fns tg_fns =
pr_end_function, /* Same, does nothing. */
tg_lineno
};
pr_end_function, /* Same, does nothing. */
tg_lineno
};
+
+static int demangle_flags = DMGL_ANSI | DMGL_PARAMS;
\f
/* Print out the generic debugging information recorded in dhandle. */
bfd_boolean
print_debugging_info (FILE *f, void *dhandle, bfd *abfd, asymbol **syms,
\f
/* Print out the generic debugging information recorded in dhandle. */
bfd_boolean
print_debugging_info (FILE *f, void *dhandle, bfd *abfd, asymbol **syms,
- void *demangler, bfd_boolean as_tags)
+ char * (*demangler) (struct bfd *, const char *, int),
+ bfd_boolean as_tags)
{
struct pr_handle info;
{
struct pr_handle info;
@@
-303,7
+305,7
@@
print_debugging_info (FILE *f, void *dhandle, bfd *abfd, asymbol **syms,
info.filename = NULL;
info.abfd = abfd;
info.syms = syms;
info.filename = NULL;
info.abfd = abfd;
info.syms = syms;
- info.demangler =
(char * (*)(struct bfd *, const char *, int))
demangler;
+ info.demangler = demangler;
if (as_tags)
{
if (as_tags)
{
@@
-581,7
+583,7
@@
static bfd_boolean
pr_int_type (void *p, unsigned int size, bfd_boolean unsignedp)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_int_type (void *p, unsigned int size, bfd_boolean unsignedp)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[
1
0];
+ char ab[
4
0];
sprintf (ab, "%sint%d", unsignedp ? "u" : "", size * 8);
return push_type (info, ab);
sprintf (ab, "%sint%d", unsignedp ? "u" : "", size * 8);
return push_type (info, ab);
@@
-593,7
+595,7
@@
static bfd_boolean
pr_float_type (void *p, unsigned int size)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_float_type (void *p, unsigned int size)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[
1
0];
+ char ab[
4
0];
if (size == 4)
return push_type (info, "float");
if (size == 4)
return push_type (info, "float");
@@
-623,7
+625,7
@@
static bfd_boolean
pr_bool_type (void *p, unsigned int size)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_bool_type (void *p, unsigned int size)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[
1
0];
+ char ab[
4
0];
sprintf (ab, "bool%d", size * 8);
sprintf (ab, "bool%d", size * 8);
@@
-672,7
+674,7
@@
pr_enum_type (void *p, const char *tag, const char **names,
if (values[i] != val)
{
if (values[i] != val)
{
- char ab[2
0
];
+ char ab[2
2
];
print_vma (values[i], ab, FALSE, FALSE);
if (! append_type (info, " = ")
print_vma (values[i], ab, FALSE, FALSE);
if (! append_type (info, " = ")
@@
-731,10
+733,16
@@
pr_function_type (void *p, int argcount, bfd_boolean varargs)
for (i = argcount - 1; i >= 0; i--)
{
if (! substitute_type (info, ""))
for (i = argcount - 1; i >= 0; i--)
{
if (! substitute_type (info, ""))
- return FALSE;
+ {
+ free (arg_types);
+ return FALSE;
+ }
arg_types[i] = pop_type (info);
if (arg_types[i] == NULL)
arg_types[i] = pop_type (info);
if (arg_types[i] == NULL)
- return FALSE;
+ {
+ free (arg_types);
+ return FALSE;
+ }
len += strlen (arg_types[i]) + 2;
}
if (varargs)
len += strlen (arg_types[i]) + 2;
}
if (varargs)
@@
-796,7
+804,7
@@
static bfd_boolean
pr_range_type (void *p, bfd_signed_vma lower, bfd_signed_vma upper)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_range_type (void *p, bfd_signed_vma lower, bfd_signed_vma upper)
{
struct pr_handle *info = (struct pr_handle *) p;
- char abl[2
0], abu[20
];
+ char abl[2
2], abu[22
];
assert (info->stack != NULL);
assert (info->stack != NULL);
@@
-821,7
+829,7
@@
pr_array_type (void *p, bfd_signed_vma lower, bfd_signed_vma upper,
{
struct pr_handle *info = (struct pr_handle *) p;
char *range_type;
{
struct pr_handle *info = (struct pr_handle *) p;
char *range_type;
- char abl[2
0], abu[20
], ab[50];
+ char abl[2
2], abu[22
], ab[50];
range_type = pop_type (info);
if (range_type == NULL)
range_type = pop_type (info);
if (range_type == NULL)
@@
-952,10
+960,16
@@
pr_method_type (void *p, bfd_boolean domain, int argcount, bfd_boolean varargs)
for (i = argcount - 1; i >= 0; i--)
{
if (! substitute_type (info, ""))
for (i = argcount - 1; i >= 0; i--)
{
if (! substitute_type (info, ""))
- return FALSE;
+ {
+ free (arg_types);
+ return FALSE;
+ }
arg_types[i] = pop_type (info);
if (arg_types[i] == NULL)
arg_types[i] = pop_type (info);
if (arg_types[i] == NULL)
- return FALSE;
+ {
+ free (arg_types);
+ return FALSE;
+ }
len += strlen (arg_types[i]) + 2;
}
if (varargs)
len += strlen (arg_types[i]) + 2;
}
if (varargs)
@@
-1139,7
+1153,7
@@
pr_struct_field (void *p, const char *name, bfd_vma bitpos, bfd_vma bitsize,
enum debug_visibility visibility)
{
struct pr_handle *info = (struct pr_handle *) p;
enum debug_visibility visibility)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[2
0
];
+ char ab[2
2
];
char *t;
if (! substitute_type (info, name))
char *t;
if (! substitute_type (info, name))
@@
-1323,7
+1337,7
@@
pr_class_baseclass (void *p, bfd_vma bitpos, bfd_boolean is_virtual,
struct pr_handle *info = (struct pr_handle *) p;
char *t;
const char *prefix;
struct pr_handle *info = (struct pr_handle *) p;
char *t;
const char *prefix;
- char ab[2
0
];
+ char ab[2
2
];
char *s, *l, *n;
assert (info->stack != NULL && info->stack->next != NULL);
char *s, *l, *n;
assert (info->stack != NULL && info->stack->next != NULL);
@@
-1483,7
+1497,7
@@
pr_class_method_variant (void *p, const char *physname,
return FALSE;
if (context || voffset != 0)
{
return FALSE;
if (context || voffset != 0)
{
- char ab[2
0
];
+ char ab[2
2
];
if (context)
{
if (context)
{
@@
-1590,7
+1604,7
@@
pr_tag_type (void *p, const char *name, unsigned int id,
{
struct pr_handle *info = (struct pr_handle *) p;
const char *t, *tag;
{
struct pr_handle *info = (struct pr_handle *) p;
const char *t, *tag;
- char idbuf[2
0
];
+ char idbuf[2
2
];
switch (kind)
{
switch (kind)
{
@@
-1686,7
+1700,7
@@
static bfd_boolean
pr_int_constant (void *p, const char *name, bfd_vma val)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_int_constant (void *p, const char *name, bfd_vma val)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[2
0
];
+ char ab[2
2
];
indent (info);
print_vma (val, ab, FALSE, FALSE);
indent (info);
print_vma (val, ab, FALSE, FALSE);
@@
-1713,7
+1727,7
@@
pr_typed_constant (void *p, const char *name, bfd_vma val)
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
- char ab[2
0
];
+ char ab[2
2
];
t = pop_type (info);
if (t == NULL)
t = pop_type (info);
if (t == NULL)
@@
-1736,7
+1750,7
@@
pr_variable (void *p, const char *name, enum debug_var_kind kind,
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
- char ab[2
0
];
+ char ab[2
2
];
if (! substitute_type (info, name))
return FALSE;
if (! substitute_type (info, name))
return FALSE;
@@
-1799,7
+1813,7
@@
pr_function_parameter (void *p, const char *name,
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
- char ab[2
0
];
+ char ab[2
2
];
if (kind == DEBUG_PARM_REFERENCE
|| kind == DEBUG_PARM_REF_REG)
if (kind == DEBUG_PARM_REFERENCE
|| kind == DEBUG_PARM_REF_REG)
@@
-1837,7
+1851,7
@@
static bfd_boolean
pr_start_block (void *p, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_start_block (void *p, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[2
0
];
+ char ab[2
2
];
if (info->parameter > 0)
{
if (info->parameter > 0)
{
@@
-1860,7
+1874,7
@@
static bfd_boolean
pr_lineno (void *p, const char *filename, unsigned long lineno, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_lineno (void *p, const char *filename, unsigned long lineno, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[2
0
];
+ char ab[2
2
];
indent (info);
print_vma (addr, ab, TRUE, TRUE);
indent (info);
print_vma (addr, ab, TRUE, TRUE);
@@
-1875,7
+1889,7
@@
static bfd_boolean
pr_end_block (void *p, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
pr_end_block (void *p, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[2
0
];
+ char ab[2
2
];
info->indent -= 2;
info->indent -= 2;
@@
-1916,14
+1930,14
@@
find_address_in_section (bfd *abfd, asection *section, void *data)
if (found)
return;
if (found)
return;
- if ((bfd_
get_section_flags (abfd,
section) & SEC_ALLOC) == 0)
+ if ((bfd_
section_flags (
section) & SEC_ALLOC) == 0)
return;
return;
- vma = bfd_
get_section_vma (abfd,
section);
+ vma = bfd_
section_vma (
section);
if (pc < vma)
return;
if (pc < vma)
return;
- size = bfd_
get_
section_size (section);
+ size = bfd_section_size (section);
if (pc >= vma + size)
return;
if (pc >= vma + size)
return;
@@
-1947,13
+1961,13
@@
translate_addresses (bfd *abfd, char *addr_hex, FILE *f, asymbol **syms)
/* Start a new compilation unit. */
static bfd_boolean
/* Start a new compilation unit. */
static bfd_boolean
-tg_start_compilation_unit (void * p, const char *f
ile
name ATTRIBUTE_UNUSED)
+tg_start_compilation_unit (void * p, const char *fname ATTRIBUTE_UNUSED)
{
struct pr_handle *info = (struct pr_handle *) p;
free (info->filename);
/* Should it be relative? best way to do it here?. */
{
struct pr_handle *info = (struct pr_handle *) p;
free (info->filename);
/* Should it be relative? best way to do it here?. */
- info->filename = strdup (f
ile
name);
+ info->filename = strdup (fname);
return TRUE;
}
return TRUE;
}
@@
-1961,13
+1975,13
@@
tg_start_compilation_unit (void * p, const char *filename ATTRIBUTE_UNUSED)
/* Start a source file within a compilation unit. */
static bfd_boolean
/* Start a source file within a compilation unit. */
static bfd_boolean
-tg_start_source (void *p, const char *f
ile
name)
+tg_start_source (void *p, const char *fname)
{
struct pr_handle *info = (struct pr_handle *) p;
free (info->filename);
/* Should it be relative? best way to do it here?. */
{
struct pr_handle *info = (struct pr_handle *) p;
free (info->filename);
/* Should it be relative? best way to do it here?. */
- info->filename = strdup (f
ile
name);
+ info->filename = strdup (fname);
return TRUE;
}
return TRUE;
}
@@
-1981,7
+1995,7
@@
tg_enum_type (void *p, const char *tag, const char **names,
struct pr_handle *info = (struct pr_handle *) p;
unsigned int i;
const char *name;
struct pr_handle *info = (struct pr_handle *) p;
unsigned int i;
const char *name;
- char ab[2
0
];
+ char ab[2
2
];
if (! pr_enum_type (p, tag, names, values))
return FALSE;
if (! pr_enum_type (p, tag, names, values))
return FALSE;
@@
-2103,6
+2117,7
@@
tg_start_class_type (void *p, const char *tag, unsigned int id,
struct pr_handle *info = (struct pr_handle *) p;
char *tv = NULL;
const char *name;
struct pr_handle *info = (struct pr_handle *) p;
char *tv = NULL;
const char *name;
+ char idbuf[20];
info->indent += 2;
info->indent += 2;
@@
-2117,8
+2132,6
@@
tg_start_class_type (void *p, const char *tag, unsigned int id,
name = tag;
else
{
name = tag;
else
{
- char idbuf[20];
-
sprintf (idbuf, "%%anon%u", id);
name = idbuf;
}
sprintf (idbuf, "%%anon%u", id);
name = idbuf;
}
@@
-2175,17
+2188,30
@@
tg_class_static_member (void *p, const char *name,
sprintf (full_name, "%s::%s", info->stack->next->type, name);
if (! substitute_type (info, full_name))
sprintf (full_name, "%s::%s", info->stack->next->type, name);
if (! substitute_type (info, full_name))
- return FALSE;
+ {
+ free (full_name);
+ return FALSE;
+ }
if (! prepend_type (info, "static "))
if (! prepend_type (info, "static "))
- return FALSE;
+ {
+ free (full_name);
+ return FALSE;
+ }
t = pop_type (info);
if (t == NULL)
t = pop_type (info);
if (t == NULL)
- return FALSE;
+ {
+ free (full_name);
+ return FALSE;
+ }
if (! tg_fix_visibility (info, visibility))
if (! tg_fix_visibility (info, visibility))
- return FALSE;
+ {
+ free (t);
+ free (full_name);
+ return FALSE;
+ }
fprintf (info->f, "%s\t%s\t0;\"\tkind:x\ttype:%s\tclass:%s\taccess:%s\n",
name, info->filename, t, info->stack->type,
fprintf (info->f, "%s\t%s\t0;\"\tkind:x\ttype:%s\tclass:%s\taccess:%s\n",
name, info->filename, t, info->stack->type,
@@
-2295,12
+2321,18
@@
tg_class_method_variant (void *p, const char *physname ATTRIBUTE_UNUSED,
/* Stick the name of the method into its type. */
if (! substitute_type (info, method_name))
/* Stick the name of the method into its type. */
if (! substitute_type (info, method_name))
- return FALSE;
+ {
+ free (method_name);
+ return FALSE;
+ }
/* Get the type. */
method_type = pop_type (info);
if (method_type == NULL)
/* Get the type. */
method_type = pop_type (info);
if (method_type == NULL)
- return FALSE;
+ {
+ free (method_name);
+ return FALSE;
+ }
/* Pull off the context type if there is one. */
if (! context)
/* Pull off the context type if there is one. */
if (! context)
@@
-2309,12
+2341,21
@@
tg_class_method_variant (void *p, const char *physname ATTRIBUTE_UNUSED,
{
context_type = pop_type (info);
if (context_type == NULL)
{
context_type = pop_type (info);
if (context_type == NULL)
- return FALSE;
+ {
+ free (method_type);
+ free (method_name);
+ return FALSE;
+ }
}
/* Now the top of the stack is the class. */
if (! tg_fix_visibility (info, visibility))
}
/* Now the top of the stack is the class. */
if (! tg_fix_visibility (info, visibility))
- return FALSE;
+ {
+ free (method_type);
+ free (method_name);
+ free (context_type);
+ return FALSE;
+ }
fprintf (info->f, "%s\t%s\t0;\"\tkind:p\ttype:%s\tclass:%s\n",
method_name, info->filename, method_type, info->stack->type);
fprintf (info->f, "%s\t%s\t0;\"\tkind:p\ttype:%s\tclass:%s\n",
method_name, info->filename, method_type, info->stack->type);
@@
-2360,16
+2401,26
@@
tg_class_static_method_variant (void *p,
method_name = strdup (info->stack->next->method);
/* Stick the name of the method into its type. */
if (! substitute_type (info, info->stack->next->method))
method_name = strdup (info->stack->next->method);
/* Stick the name of the method into its type. */
if (! substitute_type (info, info->stack->next->method))
- return FALSE;
+ {
+ free (method_name);
+ return FALSE;
+ }
/* Get the type. */
method_type = pop_type (info);
if (method_type == NULL)
/* Get the type. */
method_type = pop_type (info);
if (method_type == NULL)
- return FALSE;
+ {
+ free (method_name);
+ return FALSE;
+ }
/* Now the top of the stack is the class. */
if (! tg_fix_visibility (info, visibility))
/* Now the top of the stack is the class. */
if (! tg_fix_visibility (info, visibility))
- return FALSE;
+ {
+ free (method_type);
+ free (method_name);
+ return FALSE;
+ }
fprintf (info->f, "%s\t%s\t0;\"\tkind:p\ttype:%s\tclass:%s\taccess:%s\n",
method_name, info->filename, method_type, info->stack->type,
fprintf (info->f, "%s\t%s\t0;\"\tkind:p\ttype:%s\tclass:%s\taccess:%s\n",
method_name, info->filename, method_type, info->stack->type,
@@
-2490,7
+2541,7
@@
static bfd_boolean
tg_int_constant (void *p, const char *name, bfd_vma val)
{
struct pr_handle *info = (struct pr_handle *) p;
tg_int_constant (void *p, const char *name, bfd_vma val)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[2
0
];
+ char ab[2
2
];
indent (info);
print_vma (val, ab, FALSE, FALSE);
indent (info);
print_vma (val, ab, FALSE, FALSE);
@@
-2519,7
+2570,7
@@
tg_typed_constant (void *p, const char *name, bfd_vma val)
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
{
struct pr_handle *info = (struct pr_handle *) p;
char *t;
- char ab[2
0
];
+ char ab[2
2
];
t = pop_type (info);
if (t == NULL)
t = pop_type (info);
if (t == NULL)
@@
-2550,7
+2601,7
@@
tg_variable (void *p, const char *name, enum debug_var_kind kind,
dname = NULL;
if (info->demangler)
dname = NULL;
if (info->demangler)
- dname = info->demangler (info->abfd, name,
DMGL_ANSI | DMGL_PARAMS
);
+ dname = info->demangler (info->abfd, name,
demangle_flags
);
from_class = NULL;
if (dname != NULL)
from_class = NULL;
if (dname != NULL)
@@
-2611,7
+2662,7
@@
tg_start_function (void *p, const char *name, bfd_boolean global)
dname = NULL;
if (info->demangler)
dname = NULL;
if (info->demangler)
- dname = info->demangler (info->abfd, name,
DMGL_ANSI | DMGL_PARAMS
);
+ dname = info->demangler (info->abfd, name,
demangle_flags
);
if (! substitute_type (info, dname ? dname : name))
return FALSE;
if (! substitute_type (info, dname ? dname : name))
return FALSE;
@@
-2697,7
+2748,7
@@
static bfd_boolean
tg_start_block (void *p, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
tg_start_block (void *p, bfd_vma addr)
{
struct pr_handle *info = (struct pr_handle *) p;
- char ab[2
0
], kind, *partof;
+ char ab[2
2
], kind, *partof;
char *t;
bfd_boolean local;
char *t;
bfd_boolean local;
@@
-2744,7
+2795,7
@@
tg_start_block (void *p, bfd_vma addr)
/* Write out line number information. */
static bfd_boolean
/* Write out line number information. */
static bfd_boolean
-tg_lineno (void *p ATTRIBUTE_UNUSED, const char *f
ile
name ATTRIBUTE_UNUSED,
+tg_lineno (void *p ATTRIBUTE_UNUSED, const char *fname ATTRIBUTE_UNUSED,
unsigned long lineno ATTRIBUTE_UNUSED,
bfd_vma addr ATTRIBUTE_UNUSED)
{
unsigned long lineno ATTRIBUTE_UNUSED,
bfd_vma addr ATTRIBUTE_UNUSED)
{
This page took
0.030253 seconds
and
4
git commands to generate.