aboutsummaryrefslogtreecommitdiff
path: root/binutils
diff options
context:
space:
mode:
authorBhuvanendra Kumar N <Bhuvanendra.KumarN@amd.com>2022-06-27 13:07:55 +0530
committerAlok Kumar Sharma <AlokKumar.Sharma@amd.com>2022-06-27 13:34:09 +0530
commit2d1388e73c700f689b23d53b504e0991fe196596 (patch)
treebc3d421f06657165aee3c19fcc62b71eadd19870 /binutils
parent0d8fb090a7d51c79095983e22b097ba1e6eeb17b (diff)
downloadgdb-2d1388e73c700f689b23d53b504e0991fe196596.zip
gdb-2d1388e73c700f689b23d53b504e0991fe196596.tar.gz
gdb-2d1388e73c700f689b23d53b504e0991fe196596.tar.bz2
Fix location list offset address dump under DW_AT_location (dwarf-5)
For clang compiled objects with dwarf-5, location list offset address dump under DW_AT_location is corrected, where DW_FORM_loclistx is used. While dumping the location list offset, the address dumped is wrong where it was refering to .debug_addr instead of .debug_loclists * dwarf.c (fetch_indexed_value): Add base_address as parameter and use it to access the section offset. (read_and_display_attr_value): Handle DW_FORM_loclistx form separately. Pass loclists_base to fetch_indexed_value().
Diffstat (limited to 'binutils')
-rw-r--r--binutils/dwarf.c38
1 files changed, 26 insertions, 12 deletions
diff --git a/binutils/dwarf.c b/binutils/dwarf.c
index d9a3144..d9a1ee5 100644
--- a/binutils/dwarf.c
+++ b/binutils/dwarf.c
@@ -838,7 +838,8 @@ fetch_indexed_addr (dwarf_vma offset, uint32_t num_bytes)
static dwarf_vma
fetch_indexed_value (dwarf_vma idx,
- enum dwarf_section_display_enum sec_enum)
+ enum dwarf_section_display_enum sec_enum,
+ dwarf_vma base_address)
{
struct dwarf_section *section = &debug_displays [sec_enum].section;
@@ -863,8 +864,12 @@ fetch_indexed_value (dwarf_vma idx,
dwarf_vma offset = idx * pointer_size;
- /* Offsets are biased by the size of the section header. */
- offset += bias;
+ /* Offsets are biased by the size of the section header
+ or base address. */
+ if (sec_enum == loclists)
+ offset += base_address;
+ else
+ offset += bias;
if (offset + pointer_size > section->size)
{
@@ -2808,13 +2813,23 @@ read_and_display_attr_value (unsigned long attribute,
if (do_wide)
/* We have already displayed the form name. */
- printf (_("%c(index: 0x%s): %s"), delimiter,
- dwarf_vmatoa ("x", uvalue),
- dwarf_vmatoa ("x", fetch_indexed_addr (offset, pointer_size)));
+ if (form == DW_FORM_loclistx)
+ printf (_("%c(index: 0x%s): %s"), delimiter,
+ dwarf_vmatoa ("x", uvalue),
+ dwarf_vmatoa ("x", debug_info_p->loc_offsets [uvalue]));
+ else
+ printf (_("%c(index: 0x%s): %s"), delimiter,
+ dwarf_vmatoa ("x", uvalue),
+ dwarf_vmatoa ("x", fetch_indexed_addr (offset, pointer_size)));
else
- printf (_("%c(addr_index: 0x%s): %s"), delimiter,
- dwarf_vmatoa ("x", uvalue),
- dwarf_vmatoa ("x", fetch_indexed_addr (offset, pointer_size)));
+ if (form == DW_FORM_loclistx)
+ printf (_("%c(addr_index: 0x%s): %s"), delimiter,
+ dwarf_vmatoa ("x", uvalue),
+ dwarf_vmatoa ("x", debug_info_p->loc_offsets [uvalue]));
+ else
+ printf (_("%c(addr_index: 0x%s): %s"), delimiter,
+ dwarf_vmatoa ("x", uvalue),
+ dwarf_vmatoa ("x", fetch_indexed_addr (offset, pointer_size)));
}
break;
@@ -2898,9 +2913,8 @@ read_and_display_attr_value (unsigned long attribute,
lmax, sizeof (*debug_info_p->have_frame_base));
debug_info_p->max_loc_offsets = lmax;
}
-
if (form == DW_FORM_loclistx)
- uvalue = fetch_indexed_value (uvalue, loclists);
+ uvalue = fetch_indexed_value (num, loclists, debug_info_p->loclists_base);
else if (this_set != NULL)
uvalue += this_set->section_offsets [DW_SECT_LOC];
@@ -2969,7 +2983,7 @@ read_and_display_attr_value (unsigned long attribute,
}
if (form == DW_FORM_rnglistx)
- uvalue = fetch_indexed_value (uvalue, rnglists);
+ uvalue = fetch_indexed_value (uvalue, rnglists, 0);
debug_info_p->range_lists [num] = uvalue;
debug_info_p->num_range_lists++;