Blame SOURCES/elfutils-0.176-gcc-pr88835.patch

c27982
Workaround for https://gcc.gnu.org/bugzilla/show_bug.cgi?id=88835
c27982
c27982
diff --git a/src/readelf.c b/src/readelf.c
c27982
index 33706bd..b55844c 100644
c27982
--- a/src/readelf.c
c27982
+++ b/src/readelf.c
c27982
@@ -10143,7 +10143,7 @@ print_debug_str_section (Dwfl_Module *dwflmod __attribute__ ((unused)),
c27982
       ++digits;
c27982
       tmp >>= 4;
c27982
     }
c27982
-  digits = MAX (4, digits);
c27982
+  digits = MIN (16, MAX (4, digits));
c27982
 
c27982
   printf (gettext ("\nDWARF section [%2zu] '%s' at offset %#" PRIx64 ":\n"
c27982
 		   " %*s  String\n"),
c27982
diff --git a/tests/backtrace.c b/tests/backtrace.c
c27982
index 05e8ef8..d621fbf 100644
c27982
--- a/tests/backtrace.c
c27982
+++ b/tests/backtrace.c
c27982
@@ -185,7 +185,7 @@ frame_callback (Dwfl_Frame *state, void *frame_arg)
c27982
     symname = dwfl_module_addrname (mod, pc_adjusted);
c27982
 
c27982
   printf ("#%2d %#" PRIx64 "%4s\t%s\n", *framenop, (uint64_t) pc,
c27982
-	  ! isactivation ? "- 1" : "", symname);
c27982
+	  ! isactivation ? "- 1" : "", symname ?: "<null>");
c27982
   pid_t tid = dwfl_thread_tid (thread);
c27982
   callback_verify (tid, *framenop, pc, symname, dwfl);
c27982
   (*framenop)++;