[gdb] Fix segfault in solib_contains_address_p
authorTom de Vries <tdevries@suse.de>
Wed, 14 Oct 2020 10:24:42 +0000 (12:24 +0200)
committerTom de Vries <tdevries@suse.de>
Wed, 14 Oct 2020 10:24:42 +0000 (12:24 +0200)
Starting commit bb2a67773c "Use a std::vector in target_section_table" we run
into:
...
ERROR: GDB process no longer exists
GDB process exited with wait status 22239 exp12 0 0 CHILDKILLED SIGABRT
UNRESOLVED: gdb.base/exec-invalid-sysroot.exp: continue to exec catchpoint
...
which reproduces as:
...
Thread 1 "gdb" received signal SIGSEGV, Segmentation fault.
solib_contains_address_p (address=4196111, solib=0x1dd9970)
    at /home/vries/gdb_versions/devel/src/gdb/solib.c:1120
1120      for (target_section &p : solib->sections->sections)
(gdb) p solib->sections->sections
Cannot access memory at address 0x0
...

Fix this by handling solib->sections == nullptr in solib_contains_address_p.

Build and reg-tested on x86_64-linux.

gdb/ChangeLog:

2020-10-14  Tom de Vries  <tdevries@suse.de>

PR gdb/26733
* solib.c (solib_contains_address_p): Handle
'solib->sections == nullptr'.

gdb/ChangeLog
gdb/solib.c

index 954eaa35d4df44c501c569e03e62d4c3fb96a48a..70e1e81a167fd342ca2fd5cc939e2f67b0948d3b 100644 (file)
@@ -1,3 +1,9 @@
+2020-10-14  Tom de Vries  <tdevries@suse.de>
+
+       PR gdb/26733
+       * solib.c (solib_contains_address_p): Handle
+       'solib->sections == nullptr'.
+
 2020-10-13  Simon Marchi  <simon.marchi@polymtl.ca>
 
        PR gdb/26642
index b4864429e9aa22f604de75530a575334aaa9017c..28f6a4ecbfbcf545e95f1ea3c82a4d681a7fe3a7 100644 (file)
@@ -1113,6 +1113,9 @@ bool
 solib_contains_address_p (const struct so_list *const solib,
                          CORE_ADDR address)
 {
+  if (solib->sections == nullptr)
+    return false;
+
   for (target_section &p : *solib->sections)
     if (p.addr <= address && address < p.endaddr)
       return true;