aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gdb/ChangeLog8
-rw-r--r--gdb/remote-hms.c47
-rw-r--r--gdb/ser-go32.c1
3 files changed, 45 insertions, 11 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index 37c0cb5..26c1df9 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,11 @@
+Wed Jun 29 13:11:45 1994 Steve Chamberlain (sac@cirdan.cygnus.com)
+
+ * remote-e7000.c (e7000_open): Don't try a tcp open if we're
+ using go32.
+ * remote-hms.c (flush): New function.
+ (expect): Get edge case right.
+ (hms_read_inferior_memory): Be more tolerant of line noise.
+
Tue Jun 28 14:17:03 1994 Jim Kingdon (kingdon@lioth.cygnus.com)
* configure.in: Use i386m3.mh and i386m3.mt as names of host and
diff --git a/gdb/remote-hms.c b/gdb/remote-hms.c
index 840bf38..38e85f2 100644
--- a/gdb/remote-hms.c
+++ b/gdb/remote-hms.c
@@ -238,10 +238,15 @@ static const char *dev_name;
hms_open knows that we don't have a file open when the program
starts. */
-int is_open = 0;
+static int before = 0xdead;
+static int is_open = 0;
+static int after = 0xdead;
int
check_open ()
{
+if (before != 0xdead
+ || after != 0xdead)
+ printf("OUTCH! \n");
if (!is_open)
{
error ("remote device not open");
@@ -276,6 +281,16 @@ readchar ()
return buf & 0x7f;
}
+static void flush()
+{
+ while (1)
+ {
+ int b = SERIAL_READCHAR (desc, 0);
+ if (b == SERIAL_TIMEOUT)
+ return;
+ }
+}
+
static int
readchar_nofail ()
{
@@ -298,11 +313,12 @@ expect (string)
char *string;
{
char *p = string;
-
+ char c;
immediate_quit = 1;
while (1)
{
- if (readchar () == *p)
+ c = readchar();
+ if (c == *p)
{
p++;
if (*p == '\0')
@@ -311,8 +327,12 @@ expect (string)
return;
}
}
- else
- p = string;
+ else
+ {
+ p = string;
+ if (c == *p)
+ p++;
+ }
}
}
@@ -612,7 +632,7 @@ hms_open (name, from_tty)
printf_filtered ("Connected to remote board running HMS monitor.\n");
add_commands ();
- hms_drain ();
+/* hms_drain ();*/
}
/* Close out all files and local state before this target loses control. */
@@ -1319,6 +1339,8 @@ hms_read_inferior_memory (memaddr, myaddr, len)
abort ();
sprintf (buffer, "m %4x %4x", start & 0xffff, end & 0xffff);
+
+ flush();
hms_write_cr (buffer);
/* drop the echo and newline*/
for (i = 0; i < 13; i++)
@@ -1338,8 +1360,15 @@ hms_read_inferior_memory (memaddr, myaddr, len)
buffer[0] = readchar ();
if (buffer[0] == 'M')
break;
- for (i = 1; i < 66; i++)
+
+ for (i = 1; i < 60; i++) {
buffer[i] = readchar ();
+ }
+ /* sometimes we loose characters in the ascii representation of the
+ data. I don't know where. So just scan for the end of line */
+ i = readchar();
+ while (i != '\n' && i != '\r')
+ i = readchar();
/* Now parse the line */
@@ -1350,7 +1379,6 @@ hms_read_inferior_memory (memaddr, myaddr, len)
byte[p] = gethex (2, buffer + idx, &ok);
byte[p + 1] = gethex (2, buffer + idx + 2, &ok);
idx += 5;
-
}
for (p = 0; p < 16; p++)
@@ -1545,7 +1573,6 @@ static void
hms_drain (args, fromtty)
char *args;
int fromtty;
-
{
int c;
while (1)
@@ -1566,7 +1593,7 @@ static void
add_commands ()
{
- add_com ("hmsdrain", class_obscure, hms_drain,
+ add_com ("hms_drain", class_obscure, hms_drain,
"Drain pending hms text buffers.");
}
diff --git a/gdb/ser-go32.c b/gdb/ser-go32.c
index 72dc997..eced332 100644
--- a/gdb/ser-go32.c
+++ b/gdb/ser-go32.c
@@ -316,7 +316,6 @@ go32_readchar (scb, timeout)
{
char buf;
-
/* Shortcut for polling */
if (timeout == 0)
{