public inbox for gdb-prs@sourceware.org
help / color / mirror / Atom feed
* [Bug remote/28360] New: segfault in bfd_get_elf_phdr_upper_bound
@ 2021-09-21 11:18 vries at gcc dot gnu.org
  2021-09-21 11:31 ` [Bug remote/28360] " vries at gcc dot gnu.org
  2021-09-21 12:34 ` vries at gcc dot gnu.org
  0 siblings, 2 replies; 3+ messages in thread
From: vries at gcc dot gnu.org @ 2021-09-21 11:18 UTC (permalink / raw)
  To: gdb-prs

https://sourceware.org/bugzilla/show_bug.cgi?id=28360

            Bug ID: 28360
           Summary: segfault in bfd_get_elf_phdr_upper_bound
           Product: gdb
           Version: HEAD
            Status: NEW
          Severity: normal
          Priority: P2
         Component: remote
          Assignee: unassigned at sourceware dot org
          Reporter: vries at gcc dot gnu.org
  Target Milestone: ---

While investigating PR28355, I decided to emulate the gdbserver internal error
by doing:
...
diff --git a/gdbserver/regcache.cc b/gdbserver/regcache.cc
index 312f14ee9dd..de664cfc987 100644
--- a/gdbserver/regcache.cc
+++ b/gdbserver/regcache.cc
@@ -252,7 +252,7 @@ find_regno (const struct target_desc *tdesc, const char
*name)
   for (int i = 0; i < tdesc->reg_defs.size (); ++i)
     {
       if (strcmp (name, find_register_by_number (tdesc, i).name) == 0)
-       return i;
+       {}
     }
   internal_error (__FILE__, __LINE__, "Unknown register %s requested",
                  name);
...
and ran gdb.server/*.exp.

Annoyingly, a few times we report "ERROR: GDB process no longer exists" while
in fact GDB is alive, and it's just the gdbserver that crashed.

This is due to running gdb_test_multiple with the gdb_spawn_id set to the
spawn_id of the gdbserver, which looks wrong.

Anyway, there is an actual gdb crash in test-case
gdb.server/server-exec-info.exp:
...
(gdb) builtin_spawn
/home/vries/gdb_versions/devel/build/gdb/testsuite/../../gdb/../gdbserver/gdbserver
--once localhost:2403
/home/vries/gdb_versions/devel/build/gdb/testsuite/outputs/gdb.server/server-exec-info/server-exec-info^M
Process
/home/vries/gdb_versions/devel/build/gdb/testsuite/outputs/gdb.server/server-exec-info/server-exec-info
created; pid = 2570^M
Listening on port 2403^M
target remote localhost:2403^M
Remote debugging using localhost:2403^M
Remote connection closed^M
(gdb) set sysroot remote:^M
warning: "remote:" is deprecated, use "target:" instead.^M
warning: sysroot set to "target:".^M
^M
^M
Fatal signal: Segmentation fault^M
...

In more detail:
...
Thread 1 "gdb" received signal SIGSEGV, Segmentation fault.
0x0000000000e89dcc in bfd_get_elf_phdr_upper_bound (abfd=0x0)
    at /home/vries/gdb_versions/devel/src/bfd/elf.c:12299
12299     if (abfd->xvec->flavour != bfd_target_elf_flavour)
...

backtrace:
...
(gdb) bt
#0  0x0000000000e89dcc in bfd_get_elf_phdr_upper_bound (abfd=0x0)
    at /home/vries/gdb_versions/devel/src/bfd/elf.c:12299
#1  0x000000000084c371 in linux_vsyscall_range_raw (gdbarch=0x358a400,
range=0x2b32000)
    at /home/vries/gdb_versions/devel/src/gdb/linux-tdep.c:2335
#2  0x000000000084c70d in linux_vsyscall_range (gdbarch=0x358a400,
range=0x7fffffffd070)
    at /home/vries/gdb_versions/devel/src/gdb/linux-tdep.c:2412
#3  0x0000000000768c0e in gdbarch_vsyscall_range (gdbarch=0x358a400,
range=0x7fffffffd070)
    at /home/vries/gdb_versions/devel/src/gdb/gdbarch.c:5233
#4  0x0000000000abf5f0 in svr4_current_sos ()
    at /home/vries/gdb_versions/devel/src/gdb/solib-svr4.c:1373
#5  0x0000000000ac7e35 in update_solib_list (from_tty=0)
    at /home/vries/gdb_versions/devel/src/gdb/solib.c:722
#6  0x0000000000ac8419 in solib_add (pattern=0x0, from_tty=0, readsyms=1)
    at /home/vries/gdb_versions/devel/src/gdb/solib.c:959
#7  0x0000000000ac96ed in reload_shared_libraries (ignored=0x0, from_tty=0,
e=0x2acdd20)
    at /home/vries/gdb_versions/devel/src/gdb/solib.c:1377
#8  0x0000000000ac981d in gdb_sysroot_changed (ignored=0x0, from_tty=0,
e=0x2acdd20)
    at /home/vries/gdb_versions/devel/src/gdb/solib.c:1416
#9  0x00000000005cf349 in do_set_command (arg=0x7fffffffe131 "remote:",
from_tty=0, 
    c=0x2acdd20) at
/home/vries/gdb_versions/devel/src/gdb/cli/cli-setshow.c:521
#10 0x0000000000b77f04 in execute_command (p=0x7fffffffe131 "remote:",
from_tty=0)
    at /home/vries/gdb_versions/devel/src/gdb/top.c:666
#11 0x000000000087c5da in catch_command_errors (
    command=0xb779cd <execute_command(char const*, int)>, 
    arg=0x7fffffffe125 "set sysroot remote:", from_tty=0, do_bp_actions=true)
    at /home/vries/gdb_versions/devel/src/gdb/main.c:523
#12 0x000000000087c7b2 in execute_cmdargs (cmdarg_vec=0x7fffffffd760,
file_type=CMDARG_FILE, 
    cmd_type=CMDARG_COMMAND, ret=0x7fffffffd73c)
    at /home/vries/gdb_versions/devel/src/gdb/main.c:618
#13 0x000000000087db9d in captured_main_1 (context=0x7fffffffd9a0)
    at /home/vries/gdb_versions/devel/src/gdb/main.c:1322
#14 0x000000000087ddce in captured_main (data=0x7fffffffd9a0)
    at /home/vries/gdb_versions/devel/src/gdb/main.c:1343
#15 0x000000000087de39 in gdb_main (args=0x7fffffffd9a0)
    at /home/vries/gdb_versions/devel/src/gdb/main.c:1368
#16 0x0000000000417c6e in main (argc=15, argv=0x7fffffffdaa8)
    at /home/vries/gdb_versions/devel/src/gdb/gdb.c:32
...

-- 
You are receiving this mail because:
You are on the CC list for the bug.

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [Bug remote/28360] segfault in bfd_get_elf_phdr_upper_bound
  2021-09-21 11:18 [Bug remote/28360] New: segfault in bfd_get_elf_phdr_upper_bound vries at gcc dot gnu.org
@ 2021-09-21 11:31 ` vries at gcc dot gnu.org
  2021-09-21 12:34 ` vries at gcc dot gnu.org
  1 sibling, 0 replies; 3+ messages in thread
From: vries at gcc dot gnu.org @ 2021-09-21 11:31 UTC (permalink / raw)
  To: gdb-prs

https://sourceware.org/bugzilla/show_bug.cgi?id=28360

--- Comment #1 from Tom de Vries <vries at gcc dot gnu.org> ---
With this:
...
diff --git a/gdb/linux-tdep.c b/gdb/linux-tdep.c
index ae2f7c14f6d..d7eaa75a34a 100644
--- a/gdb/linux-tdep.c
+++ b/gdb/linux-tdep.c
@@ -2327,7 +2327,7 @@ linux_vsyscall_range_raw (struct gdbarch *gdbarch, struct
mem_ra
nge *range)
   /* It doesn't make sense to access the host's /proc when debugging a
      core file.  Instead, look for the PT_LOAD segment that matches
      the vDSO.  */
-  if (!target_has_execution ())
+  if (!target_has_execution () && core_bfd != nullptr)
     {
       long phdrs_size;
       int num_phdrs, i;
...
we have instead:
...
(gdb) set sysroot remote:^M
warning: "remote:" is deprecated, use "target:" instead.^M
warning: sysroot set to "target:".^M
warning: unable to open /proc file '/proc/0/task/0/maps'^M
(gdb) PASS: gdb.server/server-exec-info.exp: set sysroot remote:
info files^M
(gdb) FAIL: gdb.server/server-exec-info.exp: info files
...

-- 
You are receiving this mail because:
You are on the CC list for the bug.

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [Bug remote/28360] segfault in bfd_get_elf_phdr_upper_bound
  2021-09-21 11:18 [Bug remote/28360] New: segfault in bfd_get_elf_phdr_upper_bound vries at gcc dot gnu.org
  2021-09-21 11:31 ` [Bug remote/28360] " vries at gcc dot gnu.org
@ 2021-09-21 12:34 ` vries at gcc dot gnu.org
  1 sibling, 0 replies; 3+ messages in thread
From: vries at gcc dot gnu.org @ 2021-09-21 12:34 UTC (permalink / raw)
  To: gdb-prs

https://sourceware.org/bugzilla/show_bug.cgi?id=28360

Tom de Vries <vries at gcc dot gnu.org> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |palves at sourceware dot org

--- Comment #2 from Tom de Vries <vries at gcc dot gnu.org> ---
(In reply to Tom de Vries from comment #1)
> With this:
> ...
> diff --git a/gdb/linux-tdep.c b/gdb/linux-tdep.c
> index ae2f7c14f6d..d7eaa75a34a 100644
> --- a/gdb/linux-tdep.c
> +++ b/gdb/linux-tdep.c
> @@ -2327,7 +2327,7 @@ linux_vsyscall_range_raw (struct gdbarch *gdbarch,
> struct mem_ra
> nge *range)
>    /* It doesn't make sense to access the host's /proc when debugging a
>       core file.  Instead, look for the PT_LOAD segment that matches
>       the vDSO.  */
> -  if (!target_has_execution ())
> +  if (!target_has_execution () && core_bfd != nullptr)
>      {
>        long phdrs_size;
>        int num_phdrs, i;
> ...
> we have instead:
> ...
> (gdb) set sysroot remote:^M
> warning: "remote:" is deprecated, use "target:" instead.^M
> warning: sysroot set to "target:".^M
> warning: unable to open /proc file '/proc/0/task/0/maps'^M
> (gdb) PASS: gdb.server/server-exec-info.exp: set sysroot remote:
> info files^M
> (gdb) FAIL: gdb.server/server-exec-info.exp: info files
> ...

Not sure if this is correct, and if this is a fix or a workaround.

-- 
You are receiving this mail because:
You are on the CC list for the bug.

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2021-09-21 12:34 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-09-21 11:18 [Bug remote/28360] New: segfault in bfd_get_elf_phdr_upper_bound vries at gcc dot gnu.org
2021-09-21 11:31 ` [Bug remote/28360] " vries at gcc dot gnu.org
2021-09-21 12:34 ` vries at gcc dot gnu.org

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).