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