gdb: fix possible nullptr dereference in a remote_debug_printf call
authorAndrew Burgess <aburgess@redhat.com>
Tue, 18 Jul 2023 12:52:20 +0000 (13:52 +0100)
committerAndrew Burgess <aburgess@redhat.com>
Thu, 3 Aug 2023 08:54:27 +0000 (09:54 +0100)
While working on another patch I triggered a segfault from within the
function remote_target::discard_pending_stop_replies.  Turns out this
was caused by a cut&paste error introduced in this commit:

  commit df5ad102009c41ab4dfadbb8cfb8c8b2a02a4f78
  Date:   Wed Dec 1 09:40:03 2021 -0500

      gdb, gdbserver: detach fork child when detaching from fork parent

This commit adds a remote_debug_printf call that was copied from
earlier in the function, however, the new call wasn't updated to use
the appropriate local variable.  The local variable that it is using
might be nullptr, in which case we trigger undefined behaviour, and
could crash, which is what I was seeing.

Fixed by updating to use the correct local variable.

gdb/remote.c

index 7e3d6adfe4f1d19f647ad971cbb8190dcc2e1952..ff3d7e5cd327f217c8edab3bdb4ae731691e133d 100644 (file)
@@ -7564,8 +7564,8 @@ remote_target::discard_pending_stop_replies (struct inferior *inf)
   for (auto it = iter; it != rs->stop_reply_queue.end (); ++it)
     remote_debug_printf
       ("discarding queued stop reply: ptid: %s, ws: %s\n",
-       reply->ptid.to_string().c_str(),
-       reply->ws.to_string ().c_str ());
+       (*it)->ptid.to_string().c_str(),
+       (*it)->ws.to_string ().c_str ());
   rs->stop_reply_queue.erase (iter, rs->stop_reply_queue.end ());
 }