From d5cbaa15541c43d4df31e60fb61e7bc9a8b766fa Mon Sep 17 00:00:00 2001 From: Jim Wilson Date: Tue, 20 Sep 2005 18:13:32 +0000 Subject: Add mangled names to addr2line -i output. * dwarf2.c (find_abstract_instance_name): Don't early exit when name set. For DW_AT_name case, only set name if not already set. Handle DW_AT_MIPS_linkage_name. --- bfd/dwarf2.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'bfd/dwarf2.c') diff --git a/bfd/dwarf2.c b/bfd/dwarf2.c index 0a0fc12..ca792f4 100644 --- a/bfd/dwarf2.c +++ b/bfd/dwarf2.c @@ -1568,17 +1568,22 @@ find_abstract_instance_name (struct comp_unit *unit, bfd_uint64_t die_ref) } else { - for (i = 0; i < abbrev->num_attrs && !name; ++i) + for (i = 0; i < abbrev->num_attrs; ++i) { info_ptr = read_attribute (&attr, &abbrev->attrs[i], unit, info_ptr); switch (attr.name) { case DW_AT_name: - name = attr.u.str; + /* Prefer DW_AT_MIPS_linkage_name over DW_AT_name. */ + if (name == NULL) + name = attr.u.str; break; case DW_AT_specification: name = find_abstract_instance_name (unit, attr.u.val); break; + case DW_AT_MIPS_linkage_name: + name = attr.u.str; + break; default: break; } -- cgit v1.1