From: Mike Frysinger <vapier@gentoo.org>
To: gdb-patches@sourceware.org
Subject: [patch] early abort if child spawning failed
Date: Sat, 22 Sep 2007 02:31:00 -0000 [thread overview]
Message-ID: <200709212231.11507.vapier@gentoo.org> (raw)
[-- Attachment #1.1: Type: text/plain, Size: 596 bytes --]
if you use gdbserver to listen on a port and the specified program fails to
launch properly, the server process will continue on to the accept() call and
sit there forever ... you cant control+c the process as the signals are taken
over which means you have to connect with gdb to force the server to re-check
itself and then abort ... all in all, a pita for a simple typo.
the attached patch checks the status field immediately after launch rather
than falling down into the main loop and waiting for the remote debugger to
connect for the status to get properly checked.
-mike
[-- Attachment #1.2: This is a digitally signed message part. --]
[-- Type: application/pgp-signature, Size: 827 bytes --]
[-- Attachment #2: gdbserver-check-initial-startup.patch --]
[-- Type: text/x-diff, Size: 997 bytes --]
2007-09-21 Mike Frysinger <vapier@gentoo.org>
* server.c (main): Check status after start_inferior.
Index: server.c
===================================================================
RCS file: /cvs/src/src/gdb/gdbserver/server.c,v
retrieving revision 1.56
diff -u -p -r1.56 server.c
--- server.c 23 Aug 2007 18:08:48 -0000 1.56
+++ server.c 22 Sep 2007 02:30:10 -0000
@@ -900,9 +900,14 @@ main (int argc, char *argv[])
/* Wait till we are at first instruction in program. */
signal = start_inferior (&argv[2], &status);
+ if (status == 'W' || status == 'X')
+ {
+ fprintf (stderr, "Aborting server; child exited with %i\n", signal);
+ exit (signal);
+ }
+
/* We are now (hopefully) stopped at the first instruction of
- the target process. This assumes that the target process was
- successfully created. */
+ the target process. */
/* Don't report shared library events on the initial connection,
even if some libraries are preloaded. */
next reply other threads:[~2007-09-22 2:31 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-09-22 2:31 Mike Frysinger [this message]
2007-09-22 3:58 ` Daniel Jacobowitz
2007-09-22 4:18 ` Mike Frysinger
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=200709212231.11507.vapier@gentoo.org \
--to=vapier@gentoo.org \
--cc=gdb-patches@sourceware.org \
--cc=vapier@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox