From: Cleber Rosa <crosa@redhat.com>
To: gdb-patches@sourceware.org
Cc: crosa@redhat.com, areis@redhat.com
Subject: [PATCH 3/4] GDBServer: introduce --server-stderr command line option
Date: Sat, 21 Mar 2015 02:35:00 -0000 [thread overview]
Message-ID: <1426905265-8495-4-git-send-email-crosa@redhat.com> (raw)
In-Reply-To: <1426905265-8495-1-git-send-email-crosa@redhat.com>
This command line option will redirect all of the gdbserver's own
output (always sent to stderr) to a separate file. This feature
makes it possible to distinguish between the inferior process stderr
and gdbserver's own stderr.
gdb/doc/ChangeLog:
2015-03-20 Cleber Rosa <crosa@redhat.com>
* gdb.texinfo (info): Added section on command line and monitor
commands.
(gdbserver man): Added section on new command line option.
gdb/gdbserver/ChangeLog:
2015-03-20 Cleber Rosa <crosa@redhat.com>
* server.c (set_server_stderr): New utility function.
(gdbserver_usage): Add help on '--server-stderr' option.
(captured_main): Add command line option parsing for
'--server-stderr'. Replace stderr with gdbserver's own
stderr.
---
gdb/doc/gdb.texinfo | 10 ++++++++++
gdb/gdbserver/server.c | 28 +++++++++++++++++++++++++++-
2 files changed, 37 insertions(+), 1 deletion(-)
diff --git a/gdb/doc/gdb.texinfo b/gdb/doc/gdb.texinfo
index 552da31..2834794 100644
--- a/gdb/doc/gdb.texinfo
+++ b/gdb/doc/gdb.texinfo
@@ -19205,6 +19205,12 @@ The @option{--remote-debug} option tells @code{gdbserver} to display
remote protocol debug output. These options are intended for
@code{gdbserver} development and for bug reports to the developers.
+@cindex @option{--server-stderr}, @code{gdbserver} option
+The @option{--server-stderr} option tells @code{gdbserver} that any content
+that it would normally generate itself to its own @code{stderr} should be
+redirected to another file. This is useful if you want to keep the
+inferior @code{stderr} separate from the one generated by @code{gdbserver}.
+
@cindex @option{--debug-format}, @code{gdbserver} option
The @option{--debug-format=option1[,option2,...]} option tells
@code{gdbserver} to include additional information in each output.
@@ -40886,6 +40892,10 @@ Instruct @code{gdbserver} to include extra information in each line
of debugging output.
@xref{Other Command-Line Arguments for gdbserver}.
+@item --server-stderr
+Instruct @code{gdbserver} to redirect its own @code{stderr} to another
+file.
+
@item --wrapper
Specify a wrapper to launch programs
for debugging. The option should be followed by the name of the
diff --git a/gdb/gdbserver/server.c b/gdb/gdbserver/server.c
index 9dec972..db26f24 100644
--- a/gdb/gdbserver/server.c
+++ b/gdb/gdbserver/server.c
@@ -723,6 +723,25 @@ get_features_xml (const char *annex)
return NULL;
}
+/* Opens a file and redirects the server own stderr to it */
+
+static int
+set_server_stderr (char *path)
+{
+ FILE *tmp;
+
+ tmp = fopen (path, "w");
+ if (tmp == NULL)
+ {
+ fprintf (stderr,
+ "Could not open server stderr file '%s': %s\n",
+ path, strerror(errno));
+ return -1;
+ }
+ server_stderr = tmp;
+ return 0;
+}
+
void
monitor_show_help (void)
{
@@ -3017,6 +3036,7 @@ gdbserver_usage (FILE *stream)
" none\n"
" timestamp\n"
" --remote-debug Enable remote protocol debugging output.\n"
+ " --server-stderr=PATH Redirect server's STDERR to file at PATH.\n"
" --version Display version information and exit.\n"
" --wrapper WRAPPER -- Run WRAPPER to start new programs.\n"
" --once Exit after the first connection has "
@@ -3186,7 +3206,13 @@ captured_main (int argc, char *argv[])
while (*next_arg != NULL && **next_arg == '-')
{
- if (strcmp (*next_arg, "--version") == 0)
+ if (strncmp (*next_arg, "--server-stderr=",
+ sizeof ("--server-stderr=") - 1) == 0)
+ {
+ char *path = *next_arg + (sizeof ("--server-stderr=") - 1);
+ set_server_stderr (path);
+ }
+ else if (strcmp (*next_arg, "--version") == 0)
{
gdbserver_version ();
exit (0);
--
1.9.3
next prev parent reply other threads:[~2015-03-21 2:35 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-03-21 2:35 [PATCH 0/4] GDBServer: introduce a dedicated stderr stream Cleber Rosa
2015-03-21 2:35 ` [PATCH 4/4] GDBServer: add 'monitor set server-stderr' command Cleber Rosa
2015-03-21 8:29 ` Eli Zaretskii
2015-03-23 20:09 ` Cleber Rosa
2015-03-21 2:35 ` [PATCH 1/4] GDBServer: introduce a stderr stream dedicated to the server Cleber Rosa
2015-03-21 2:35 ` Cleber Rosa [this message]
2015-03-21 8:26 ` [PATCH 3/4] GDBServer: introduce --server-stderr command line option Eli Zaretskii
2015-03-23 18:51 ` Cleber Rosa
2015-03-23 19:12 ` Eli Zaretskii
2015-03-23 20:35 ` Cleber Rosa
2015-03-23 20:43 ` Eli Zaretskii
2015-03-21 2:35 ` [PATCH 2/4] GDBServer: give more complete usage information Cleber Rosa
2015-03-21 17:05 ` Pedro Alves
2015-03-24 14:15 ` Cleber Rosa
2015-03-31 14:44 ` Cleber Rosa
2015-04-01 10:10 ` Pedro Alves
2015-03-21 15:05 ` [PATCH 0/4] GDBServer: introduce a dedicated stderr stream Pedro Alves
2015-03-24 17:07 ` Cleber Rosa
2015-04-01 11:17 ` Pedro Alves
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=1426905265-8495-4-git-send-email-crosa@redhat.com \
--to=crosa@redhat.com \
--cc=areis@redhat.com \
--cc=gdb-patches@sourceware.org \
/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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).