aboutsummaryrefslogtreecommitdiff
path: root/gdbserver/gdbreplay.cc
diff options
context:
space:
mode:
authorTom Tromey <tromey@adacore.com>2021-02-12 07:33:48 -0700
committerTom Tromey <tromey@adacore.com>2021-02-12 12:45:51 -0700
commit77fba254d9e0372c1f87d163214bff6c8e0e982e (patch)
tree0bee94ed7aeb692458753ac0830955e764bf75a3 /gdbserver/gdbreplay.cc
parent089436f78743628b22e87c2f8d32bd5f9d818f5a (diff)
downloadbinutils-77fba254d9e0372c1f87d163214bff6c8e0e982e.zip
binutils-77fba254d9e0372c1f87d163214bff6c8e0e982e.tar.gz
binutils-77fba254d9e0372c1f87d163214bff6c8e0e982e.tar.bz2
Add stdio support to gdbreplay
I've been using gdbreplay to help debug an intermittent failure, and I wanted it to be a little simpler to use. This patch adds support for "-" as the "address" argument. With this patch you can do: (gdb) target remote | gdbreplay logfile - ... and not have to start gdbreplay in a separate shell. 2021-02-12 Tom Tromey <tromey@adacore.com> * gdbreplay.cc (remote_desc): Remove. (remote_desc_in, remote_desc_out): New globals. (remote_close): Update. (remote_open): Handle "-". (remote_open): Update. (logchar): Log to stderr. (expect, play): Update.
Diffstat (limited to 'gdbserver/gdbreplay.cc')
-rw-r--r--gdbserver/gdbreplay.cc56
1 files changed, 35 insertions, 21 deletions
diff --git a/gdbserver/gdbreplay.cc b/gdbserver/gdbreplay.cc
index 1a53b98..864a31e 100644
--- a/gdbserver/gdbreplay.cc
+++ b/gdbserver/gdbreplay.cc
@@ -66,7 +66,8 @@ typedef int socklen_t;
/* Sort of a hack... */
#define EOL (EOF - 1)
-static int remote_desc;
+static int remote_desc_in;
+static int remote_desc_out;
#ifdef __MINGW32CE__
@@ -141,9 +142,12 @@ static void
remote_close (void)
{
#ifdef USE_WIN32API
- closesocket (remote_desc);
+ gdb_assert (remote_desc_in == remote_desc_out);
+ closesocket (remote_desc_in);
#else
- close (remote_desc);
+ close (remote_desc_in);
+ if (remote_desc_in != remote_desc_out)
+ close (remote_desc_out);
#endif
}
@@ -153,6 +157,15 @@ remote_close (void)
static void
remote_open (const char *name)
{
+#ifndef USE_WIN32API
+ if (strcmp (name, "-") == 0)
+ {
+ remote_desc_in = 0;
+ remote_desc_out = 1;
+ return;
+ }
+#endif
+
const char *last_colon = strrchr (name, ':');
if (last_colon == NULL)
@@ -241,7 +254,7 @@ remote_open (const char *name)
perror_with_name ("Can't bind address");
if (p->ai_socktype == SOCK_DGRAM)
- remote_desc = tmp_desc;
+ remote_desc_in = tmp_desc;
else
{
struct sockaddr_storage sockaddr;
@@ -251,10 +264,10 @@ remote_open (const char *name)
if (listen (tmp_desc, 1) != 0)
perror_with_name ("Can't listen on socket");
- remote_desc = accept (tmp_desc, (struct sockaddr *) &sockaddr,
- &sockaddrsize);
+ remote_desc_in = accept (tmp_desc, (struct sockaddr *) &sockaddr,
+ &sockaddrsize);
- if (remote_desc == -1)
+ if (remote_desc_in == -1)
perror_with_name ("Accept failed");
/* Enable TCP keep alive process. */
@@ -265,7 +278,7 @@ remote_open (const char *name)
/* Tell TCP not to delay small packets. This greatly speeds up
interactive response. */
tmp = 1;
- setsockopt (remote_desc, IPPROTO_TCP, TCP_NODELAY,
+ setsockopt (remote_desc_in, IPPROTO_TCP, TCP_NODELAY,
(char *) &tmp, sizeof (tmp));
if (getnameinfo ((struct sockaddr *) &sockaddr, sockaddrsize,
@@ -290,8 +303,9 @@ remote_open (const char *name)
}
#if defined(F_SETFL) && defined (FASYNC)
- fcntl (remote_desc, F_SETFL, FASYNC);
+ fcntl (remote_desc_in, F_SETFL, FASYNC);
#endif
+ remote_desc_out = remote_desc_in;
fprintf (stderr, "Replay logfile using %s\n", name);
fflush (stderr);
@@ -306,8 +320,8 @@ logchar (FILE *fp)
ch = fgetc (fp);
if (ch != '\r')
{
- fputc (ch, stdout);
- fflush (stdout);
+ fputc (ch, stderr);
+ fflush (stderr);
}
switch (ch)
{
@@ -321,16 +335,16 @@ logchar (FILE *fp)
ungetc (ch, fp);
ch = '\r';
}
- fputc (ch == EOL ? '\n' : '\r', stdout);
- fflush (stdout);
+ fputc (ch == EOL ? '\n' : '\r', stderr);
+ fflush (stderr);
break;
case '\n':
ch = EOL;
break;
case '\\':
ch = fgetc (fp);
- fputc (ch, stdout);
- fflush (stdout);
+ fputc (ch, stderr);
+ fflush (stderr);
switch (ch)
{
case '\\':
@@ -355,12 +369,12 @@ logchar (FILE *fp)
break;
case 'x':
ch2 = fgetc (fp);
- fputc (ch2, stdout);
- fflush (stdout);
+ fputc (ch2, stderr);
+ fflush (stderr);
ch = fromhex (ch2) << 4;
ch2 = fgetc (fp);
- fputc (ch2, stdout);
- fflush (stdout);
+ fputc (ch2, stderr);
+ fflush (stderr);
ch |= fromhex (ch2);
break;
default:
@@ -403,7 +417,7 @@ expect (FILE *fp)
fromlog = logchar (fp);
if (fromlog == EOL)
break;
- fromgdb = gdbchar (remote_desc);
+ fromgdb = gdbchar (remote_desc_in);
if (fromgdb < 0)
remote_error ("Error during read from gdb");
}
@@ -433,7 +447,7 @@ play (FILE *fp)
while ((fromlog = logchar (fp)) != EOL)
{
ch = fromlog;
- if (write (remote_desc, &ch, 1) != 1)
+ if (write (remote_desc_out, &ch, 1) != 1)
remote_error ("Error during write to gdb");
}
}