diff options
Diffstat (limited to 'gdb/remote-bug.c')
-rw-r--r-- | gdb/remote-bug.c | 223 |
1 files changed, 134 insertions, 89 deletions
diff --git a/gdb/remote-bug.c b/gdb/remote-bug.c index d332771..8e4db09 100644 --- a/gdb/remote-bug.c +++ b/gdb/remote-bug.c @@ -68,7 +68,7 @@ static int bug_write_inferior_memory (); /* To be silent, or to loudly echo all input and output to and from the target. */ -static int quiet = 1; +static int bug88k_snoop = 0; /* This is the serial descriptor to our target. */ @@ -326,7 +326,7 @@ readchar () if (buf == SERIAL_TIMEOUT) error ("Timeout reading from remote system."); - if (!quiet) + if (bug88k_snoop) printf ("%c", buf); return buf & 0x7f; @@ -340,7 +340,7 @@ readchar_nofail () buf = SERIAL_READCHAR (desc, timeout); if (buf == SERIAL_TIMEOUT) buf = 0; - if (!quiet) + if (bug88k_snoop) if (buf) printf ("%c", buf); else @@ -358,7 +358,7 @@ pollchar() buf = SERIAL_READCHAR (desc, 0); if (buf == SERIAL_TIMEOUT) buf = 0; - if (!quiet) + if (bug88k_snoop) if (buf) printf ("%c", buf); else @@ -688,84 +688,107 @@ bug_resume (pid, step, sig) return; } +/* Given a null terminated list of strings LIST, read the input until we find one of + them. Return the index of the string found or -1 on error. '?' means match + any single character. Note that with the algorithm we use, the initial + character of the string cannot recur in the string, or we will not find some + cases of the string in the input. If PASSTHROUGH is non-zero, then + pass non-matching data on. */ + static int -double_scan (a, b) - char *a, *b; +multi_scan (list, passthrough) + char *list[]; + int passthrough; { - /* Strings to look for. '?' means match any single character. - Note that with the algorithm we use, the initial character - of the string cannot recur in the string, or we will not - find some cases of the string in the input. */ + char *swallowed = NULL; /* holding area */ + char *swallowed_p = swallowed; /* Current position in swallowed. */ + int ch; + int ch_handled; + int i; + int string_count; + int max_length; + char **plist; - char *pa = a; - char *pb = b; + /* Look through the strings. Count them. Find the largest one so we can + allocate a holding area. */ - /* Large enough for either sizeof (bpt) or sizeof (exitmsg) chars. */ - char swallowed[50]; + for (max_length = string_count = i = 0; + list[i] != NULL; + ++i, ++string_count) + { + int length = strlen(list[i]); - /* Current position in swallowed. */ - char *swallowed_p = swallowed; + if (length > max_length) + max_length = length; + } - int ch = readchar(); - int ch_handled; - int swallowed_cr = 0; + /* if we have no strings, then something is wrong. */ + if (string_count == 0) + return(-1); - for (;;) + /* otherwise, we will need a holding area big enough to hold almost two + copies of our largest string. */ + swallowed_p = swallowed = alloca(max_length << 1); + + /* and a list of pointers to current scan points. */ + plist = alloca(string_count * sizeof(*plist)); + + /* and initialize */ + for (i = 0; i < string_count; ++i) + plist[i] = list[i]; + + for (ch = readchar(); /* loop forever */ ; ch = readchar()) { QUIT; /* Let user quit and leave process running */ ch_handled = 0; - if (ch == *pa) - { - pa++; - if (*pa == '\0') - break; - ch_handled = 1; - - *swallowed_p++ = ch; - } - else - pa = a; - if (ch == *pb || *pb == '?') + for (i = 0; i < string_count; ++i) { - pb++; - if (*pb == '\0') - break; + if (ch == *plist[i] || *plist[i] == '?') + { + ++plist[i]; + if (*plist[i] == '\0') + return(i); + + if (!ch_handled) + *swallowed_p++ = ch; - if (!ch_handled) - *swallowed_p++ = ch; - ch_handled = 1; + ch_handled = 1; + } + else + plist[i] = list[i]; } - else - pb = b; if (!ch_handled) { char *p; /* Print out any characters which have been swallowed. */ - for (p = swallowed; p < swallowed_p; ++p) - putc (*p, stdout); - swallowed_p = swallowed; - - if ((ch != '\r' && ch != '\n') || swallowed_cr > 10) + if (passthrough) { + for (p = swallowed; p < swallowed_p; ++p) + putc (*p, stdout); + putc (ch, stdout); - swallowed_cr = 10; } - swallowed_cr++; + swallowed_p = swallowed; } - - ch = readchar (); } - return(*pa == '\0'); + return(-1); } /* Wait until the remote machine stops, then return, storing status in STATUS just as `wait' would. */ +static char *wait_strings[] = { + "At Breakpoint", + "Exception: Data Access Fault (Local Bus Timeout)", + "\r8???-Bug>", + NULL, +}; + int bug_wait (status) WAITTYPE *status; @@ -775,32 +798,53 @@ bug_wait (status) WSETEXIT ((*status), 0); - if (need_artificial_trap != 0) + /* read off leftovers from resume so that the rest can be passed + back out as stdout. */ + if (need_artificial_trap == 0) { - WSETSTOP ((*status), SIGTRAP); - need_artificial_trap--; - /* user output from the target can be discarded here. (?) */ - expect_prompt(); - return 0; + expect("Effective address: "); + (void) get_hex_word(); + expect ("\r\n"); } - /* read off leftovers from resume */ - expect("Effective address: "); - (void) get_hex_word(); - expect ("\r\n"); - timeout = -1; /* Don't time out -- user program is running. */ immediate_quit = 1; /* Helps ability to QUIT */ - if (double_scan("At Breakpoint", "8???-Bug>")) + switch (multi_scan(wait_strings, need_artificial_trap == 0)) { - /* breakpoint case */ + case 0: /* breakpoint case */ WSETSTOP ((*status), SIGTRAP); - expect_prompt (); - } - else /* exit case */ - WSETEXIT ((*status), 0); + /* user output from the target can be discarded here. (?) */ + expect_prompt(); + break; + + case 1: /* bus error */ + WSETSTOP ((*status), SIGBUS); + /* user output from the target can be discarded here. (?) */ + expect_prompt(); + break; + + case 2: /* normal case */ + if (need_artificial_trap != 0) + { + /* stepping */ + WSETSTOP ((*status), SIGTRAP); + need_artificial_trap--; + break; + } + else + { + /* exit case */ + WSETEXIT ((*status), 0); + break; + } + case -1: /* trouble */ + default: + fprintf_filtered (stderr, + "Trouble reading target during wait\n"); + break; + } timeout = old_timeout; immediate_quit = old_immediate_quit; @@ -844,7 +888,7 @@ bug_write (a, l) SERIAL_WRITE (desc, a, l); - if (!quiet) + if (bug88k_snoop) for (i = 0; i < l; i++) { printf ("%c", a[i]); @@ -862,6 +906,7 @@ bug_write_cr (s) return; } +#if 0 /* not currently used */ /* Read from remote while the input matches STRING. Return zero on success, -1 on failure. */ @@ -884,6 +929,7 @@ bug_scan (s) return(0); } +#endif /* never */ static int bug_srec_write_cr (s) @@ -894,7 +940,7 @@ bug_srec_write_cr (s) if (srec_echo_pace) for (p = s; *p; ++p) { - if (!quiet) + if (bug88k_snoop) printf ("%c", *p); do @@ -1119,6 +1165,12 @@ start_load() data records each containing srec_bytes, and an S7 termination record. */ +static char *srecord_strings[] = { + "S-RECORD", + "8???-Bug>", + NULL, +}; + static int bug_write_inferior_memory (memaddr, myaddr, len) CORE_ADDR memaddr; @@ -1142,7 +1194,7 @@ bug_write_inferior_memory (memaddr, myaddr, len) if (retries > 0) { - if (!quiet) + if (bug88k_snoop) printf("\n<retrying...>\n"); /* This expect_prompt call is extremely important. Without @@ -1203,7 +1255,7 @@ bug_write_inferior_memory (memaddr, myaddr, len) if (srec_sleep != 0) sleep(srec_sleep); - /* This pollchar is probably redundant to the double_scan + /* This pollchar is probably redundant to the multi_scan below. Trouble is, we can't be sure when or where an error message will appear. Apparently, when running at full speed from a typical sun4, error messages tend to @@ -1211,7 +1263,7 @@ bug_write_inferior_memory (memaddr, myaddr, len) if ((x = pollchar()) != 0) { - if (!quiet) + if (bug88k_snoop) printf("\n<retrying...>\n"); ++retries; @@ -1233,7 +1285,7 @@ bug_write_inferior_memory (memaddr, myaddr, len) /* Having finished the load, we need to figure out whether we had any errors. */ - } while (double_scan("S-RECORD", "8???-Bug>"));; + } while (multi_scan(srecord_strings, 0) == 0);; return(0); } @@ -1452,20 +1504,6 @@ bug_com (args, fromtty) } static void -bug_quiet (args, fromtty) - char *args; - int fromtty; -{ - quiet = !quiet; - if (quiet) - printf_filtered ("Snoop disabled\n"); - else - printf_filtered ("Snoop enabled\n"); - - return; -} - -static void bug_device (args, fromtty) char *args; int fromtty; @@ -1537,8 +1575,6 @@ _initialize_remote_bug () add_com ("bug <command>", class_obscure, bug_com, "Send a command to the BUG monitor."); - add_com ("snoop", class_obscure, bug_quiet, - "Show what commands are going to the monitor"); add_com ("device", class_obscure, bug_device, "Set the terminal line for BUG communications"); @@ -1604,5 +1640,14 @@ much slower, but generally more reliable.", &setlist), &showlist); + add_show_from_set + (add_set_cmd ("bug88k-snoop", class_support, var_boolean, + (char *) &bug88k_snoop, + "\ +Set echoing of what's going to and from the monitor.\n\ +When on, echo data going out on and coming back from the serial line.", + &setlist), + &showlist); + dev_name = NULL; } |