aboutsummaryrefslogtreecommitdiff
path: root/binutils/readelf.c
diff options
context:
space:
mode:
authorIndu Bhagat <indu.bhagat@oracle.com>2025-02-04 11:58:11 -0800
committerIndu Bhagat <indu.bhagat@oracle.com>2025-02-06 07:34:09 -0800
commit4e2182df14602eb9c65b1c1fb4685da8dc1ec9e7 (patch)
tree216714125ca619cddc6a1109413e7f7a3f4e2542 /binutils/readelf.c
parent078d38682291b06c44a3e091ad87c302d9385eb4 (diff)
downloadbinutils-users/ibhagat/try-pr32589.zip
binutils-users/ibhagat/try-pr32589.tar.gz
binutils-users/ibhagat/try-pr32589.tar.bz2
objdump, readelf: apply relocations before textual dumpusers/ibhagat/try-pr32589
PR libsframe/32589 - function start address is zero in SFrame section dump Currently, readelf and objdump display SFrame section in object file with function start addresses of each function as 0. This makes it difficult to correlate SFrame stack trace information with the individual functions in the object file. Use the dump_dwarf () interface to dump SFrame section. The current infrastructure (for DWARF debug sections) already supports relocating the section contents before dumping, so lets use that. Even after the section contents are relocated, there is need to fixup the function start address, which is what sframe_fde_tbl_reloc_fixup () is about. As a side effect, objdump now adds two new ways of dumping SFrame sections: - objdump -WS <obj> - objdump --dwarf=sframe We do not publicize these options. The lone advertised user interfacing option (in --help) remains: - objdump --sframe Furthermore, we continue to keep the same error messaging as earlier (by folding the check for section into the new display_sframe_section () function): $ objdump --sframe=sframe bubble_sort.o ... No sframe section present $ objdump --sframe=.sfram bubble_sort.o ... No .sfram section present Note the new API dump_sframe_reloc (). This new API is exposed because objdump / readelf will need it. Since this addition is backwards compatible, update libtool-version with age+1 and revision+1. TBD: - Add tests where the fixup function is exercised. No explicit tests for that yet on x86_64. Although the AArch64 one sort of suffices ? binutils/ * dwarf.c (display_sframe): New definition. (dwarf_select_sections_all): Enable SFrame section too. (struct dwarf_section_display): Add entry for SFrame section. * dwarf.h (enum dwarf_section_display_enum): Add enumerator for SFrame. * objdump.c (dump_section_sframe): Remove. (dump_sframe_section): Add new definition. (dump_bfd): Use dump_sframe_section. * binutils/readelf.c (dump_section_as_sframe): Remove. gas/testsuite/ * gas/cfi-sframe/cfi-sframe-aarch64-pac-ab-key-1.d:
Diffstat (limited to 'binutils/readelf.c')
-rw-r--r--binutils/readelf.c40
1 files changed, 1 insertions, 39 deletions
diff --git a/binutils/readelf.c b/binutils/readelf.c
index 70d0c53..2c2097d 100644
--- a/binutils/readelf.c
+++ b/binutils/readelf.c
@@ -17099,44 +17099,6 @@ dump_section_as_ctf (Elf_Internal_Shdr * section, Filedata * filedata)
#endif
static bool
-dump_section_as_sframe (Elf_Internal_Shdr * section, Filedata * filedata)
-{
- void * data = NULL;
- sframe_decoder_ctx *sfd_ctx = NULL;
- const char *print_name = printable_section_name (filedata, section);
-
- bool ret = true;
- size_t sf_size;
- int err = 0;
-
- if (strcmp (print_name, "") == 0)
- {
- error (_("Section name must be provided \n"));
- ret = false;
- return ret;
- }
-
- data = get_section_contents (section, filedata);
- sf_size = section->sh_size;
- /* Decode the contents of the section. */
- sfd_ctx = sframe_decode ((const char*)data, sf_size, &err);
- if (!sfd_ctx)
- {
- ret = false;
- error (_("SFrame decode failure: %s\n"), sframe_errmsg (err));
- goto fail;
- }
-
- printf (_("Contents of the SFrame section %s:"), print_name);
- /* Dump the contents as text. */
- dump_sframe (sfd_ctx, section->sh_addr);
-
- fail:
- free (data);
- return ret;
-}
-
-static bool
load_specific_debug_section (enum dwarf_section_display_enum debug,
const Elf_Internal_Shdr * sec,
void * data)
@@ -17703,7 +17665,7 @@ process_section_contents (Filedata * filedata)
#endif
if (dump & SFRAME_DUMP)
{
- if (! dump_section_as_sframe (section, filedata))
+ if (! display_debug_section (i, section, filedata))
res = false;
}
}