diff options
author | gdb-2.8 <gdb@fsf.org> | 1988-09-03 08:00:00 +0100 |
---|---|---|
committer | Pedro Alves <palves@redhat.com> | 2012-06-03 15:36:31 +0100 |
commit | 3bf57d210832b28e9361990830eb722a619f031b (patch) | |
tree | ba506d293bde0f6500d0cee3e643ebf8890d9cf7 /gdb/remote.c | |
parent | 7c75bab3d3ef344a6a0b13b9ab59ecd5855aceb5 (diff) | |
download | fsf-binutils-gdb-3bf57d210832b28e9361990830eb722a619f031b.zip fsf-binutils-gdb-3bf57d210832b28e9361990830eb722a619f031b.tar.gz fsf-binutils-gdb-3bf57d210832b28e9361990830eb722a619f031b.tar.bz2 |
gdb-2.8
Diffstat (limited to 'gdb/remote.c')
-rw-r--r-- | gdb/remote.c | 28 |
1 files changed, 22 insertions, 6 deletions
diff --git a/gdb/remote.c b/gdb/remote.c index 23f27df..27a7322 100644 --- a/gdb/remote.c +++ b/gdb/remote.c @@ -71,11 +71,24 @@ anyone else from sharing it farther. Help stamp out software hoarding! #include "frame.h" #include "inferior.h" -#include <sys/wait.h> +#include "wait.h" #include <sys/ioctl.h> #include <a.out.h> #include <sys/file.h> + +#ifdef HAVE_TERMIO +#include <termio.h> +#undef TIOCGETP +#define TIOCGETP TCGETA +#undef TIOCSETN +#define TIOCSETN TCSETA +#undef TIOCSETP +#define TIOCSETP TCSETAF +#define TERMINAL struct termio +#else #include <sgtty.h> +#define TERMINAL struct sgttyb +#endif int kiodebug; @@ -101,7 +114,7 @@ remote_open (name, from_tty) char *name; int from_tty; { - struct sgttyb sg; + TERMINAL sg; remote_debugging = 0; dcache_init (); @@ -111,7 +124,11 @@ remote_open (name, from_tty) perror_with_name (name); ioctl (remote_desc, TIOCGETP, &sg); +#ifdef HAVE_TERMIO + sg.c_lflag &= ~ICANON; +#else sg.sg_flags = RAW; +#endif ioctl (remote_desc, TIOCSETP, &sg); if (from_tty) @@ -165,18 +182,17 @@ remote_resume (step, signal) int remote_wait (status) - union wait *status; + WAITTYPE *status; { char buf[PBUFSIZ]; - status->w_status = 0; + WSETEXIT ((*status), 0); getpkt (buf); if (buf[0] == 'E') error ("Remote failure reply: %s", buf); if (buf[0] != 'S') error ("Invalid remote reply: %s", buf); - status->w_stopval = WSTOPPED; - status->w_stopsig = (fromhex (buf[1]) << 4) + fromhex (buf[2]); + WSETSTOP ((*status), (((fromhex (buf[1])) << 4) + (fromhex (buf[2])))); } /* Read the remote registers into the block REGS. */ |