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