PR 15068
* utils.c (quit): Call SERIAL_DRAIN_OUTPUT rather than SERIAL_FLUSH_OUTPUT. * serial.h (struct serial_ops): Add drain_output, pointer to function that waits for output to drain. (SERIAL_DRAIN_OUTPUT): Macro to wait for output to drain. * ser-unix.c (hardwire_drain_output): New function and prototype. * ser-unix.c (hardwire_ops): Add entry for drain_output function. * ser-tcp.c (tcp_ops): Ditto. * ser-ocd.c (ocd_ops): Ditto. * ser-mac.c (mac_ops): Ditto. * ser-go32.c (dos_ops): Ditto. * ser-e7kpc.c (e7000pc_ops): Ditto.
This commit is contained in:
parent
d030671bfc
commit
3ffbdf1532
8 changed files with 65 additions and 1 deletions
|
@ -1,3 +1,19 @@
|
||||||
|
Fri Mar 6 13:10:27 1998 Fred Fish <fnf@cygnus.com>
|
||||||
|
|
||||||
|
* utils.c (quit): Call SERIAL_DRAIN_OUTPUT rather than
|
||||||
|
SERIAL_FLUSH_OUTPUT.
|
||||||
|
* serial.h (struct serial_ops): Add drain_output, pointer to
|
||||||
|
function that waits for output to drain.
|
||||||
|
(SERIAL_DRAIN_OUTPUT): Macro to wait for output to drain.
|
||||||
|
* ser-unix.c (hardwire_drain_output): New function and prototype.
|
||||||
|
|
||||||
|
* ser-unix.c (hardwire_ops): Add entry for drain_output function.
|
||||||
|
* ser-tcp.c (tcp_ops): Ditto.
|
||||||
|
* ser-ocd.c (ocd_ops): Ditto.
|
||||||
|
* ser-mac.c (mac_ops): Ditto.
|
||||||
|
* ser-go32.c (dos_ops): Ditto.
|
||||||
|
* ser-e7kpc.c (e7000pc_ops): Ditto.
|
||||||
|
|
||||||
Thu Mar 5 16:07:41 1998 Michael Snyder (msnyder@cleaver.cygnus.com)
|
Thu Mar 5 16:07:41 1998 Michael Snyder (msnyder@cleaver.cygnus.com)
|
||||||
|
|
||||||
* sparcl-tdep.c: fix #endif comments
|
* sparcl-tdep.c: fix #endif comments
|
||||||
|
|
|
@ -453,6 +453,7 @@ static struct serial_ops e7000pc_ops =
|
||||||
e7000pc_print_tty_state,
|
e7000pc_print_tty_state,
|
||||||
e7000pc_noflush_set_tty_state,
|
e7000pc_noflush_set_tty_state,
|
||||||
e7000pc_setbaudrate,
|
e7000pc_setbaudrate,
|
||||||
|
e7000pc_noop, /* wait for output to drain */
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -848,6 +848,7 @@ static struct serial_ops dos_ops =
|
||||||
dos_noflush_set_tty_state,
|
dos_noflush_set_tty_state,
|
||||||
dos_setbaudrate,
|
dos_setbaudrate,
|
||||||
dos_setstopbits,
|
dos_setstopbits,
|
||||||
|
dos_noop, /* wait for output to drain */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -352,6 +352,7 @@ static struct serial_ops mac_ops =
|
||||||
mac_noflush_set_tty_state,
|
mac_noflush_set_tty_state,
|
||||||
mac_set_baud_rate,
|
mac_set_baud_rate,
|
||||||
mac_set_stop_bits,
|
mac_set_stop_bits,
|
||||||
|
mac_noop, /* wait for output to drain */
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -197,6 +197,7 @@ static struct serial_ops ocd_ops =
|
||||||
ocd_print_tty_state,
|
ocd_print_tty_state,
|
||||||
ocd_noflush_set_tty_state,
|
ocd_noflush_set_tty_state,
|
||||||
ocd_setbaudrate,
|
ocd_setbaudrate,
|
||||||
|
ocd_noop, /* wait for output to drain */
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -342,6 +342,7 @@ static struct serial_ops tcp_ops =
|
||||||
tcp_noflush_set_tty_state,
|
tcp_noflush_set_tty_state,
|
||||||
tcp_setbaudrate,
|
tcp_setbaudrate,
|
||||||
tcp_setstopbits,
|
tcp_setstopbits,
|
||||||
|
tcp_return_0, /* wait for output to drain */
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -77,6 +77,7 @@ static int hardwire_set_tty_state PARAMS ((serial_t scb, serial_ttystate state))
|
||||||
static int hardwire_noflush_set_tty_state PARAMS ((serial_t, serial_ttystate,
|
static int hardwire_noflush_set_tty_state PARAMS ((serial_t, serial_ttystate,
|
||||||
serial_ttystate));
|
serial_ttystate));
|
||||||
static void hardwire_print_tty_state PARAMS ((serial_t, serial_ttystate));
|
static void hardwire_print_tty_state PARAMS ((serial_t, serial_ttystate));
|
||||||
|
static int hardwire_drain_output PARAMS ((serial_t));
|
||||||
static int hardwire_flush_output PARAMS ((serial_t));
|
static int hardwire_flush_output PARAMS ((serial_t));
|
||||||
static int hardwire_flush_input PARAMS ((serial_t));
|
static int hardwire_flush_input PARAMS ((serial_t));
|
||||||
static int hardwire_send_break PARAMS ((serial_t));
|
static int hardwire_send_break PARAMS ((serial_t));
|
||||||
|
@ -275,6 +276,38 @@ hardwire_print_tty_state (scb, ttystate)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Wait for the output to drain away, as opposed to flushing (discarding) it */
|
||||||
|
|
||||||
|
static int
|
||||||
|
hardwire_drain_output (scb)
|
||||||
|
serial_t scb;
|
||||||
|
{
|
||||||
|
#ifdef HAVE_TERMIOS
|
||||||
|
return tcdrain (scb->fd);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_TERMIO
|
||||||
|
return ioctl (scb->fd, TCSBRK, 1);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SGTTY
|
||||||
|
/* Get the current state and then restore it using TIOCSETP,
|
||||||
|
which should cause the output to drain and pending input
|
||||||
|
to be discarded. */
|
||||||
|
{
|
||||||
|
struct hardwire_ttystate state;
|
||||||
|
if (get_tty_state (scb, &state))
|
||||||
|
{
|
||||||
|
return (-1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return (ioctl (scb->fd, TIOCSETP, &state.sgttyb));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
hardwire_flush_output (scb)
|
hardwire_flush_output (scb)
|
||||||
serial_t scb;
|
serial_t scb;
|
||||||
|
@ -727,6 +760,7 @@ static struct serial_ops hardwire_ops =
|
||||||
hardwire_noflush_set_tty_state,
|
hardwire_noflush_set_tty_state,
|
||||||
hardwire_setbaudrate,
|
hardwire_setbaudrate,
|
||||||
hardwire_setstopbits,
|
hardwire_setstopbits,
|
||||||
|
hardwire_drain_output, /* wait for output to drain */
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
11
gdb/serial.h
11
gdb/serial.h
|
@ -50,7 +50,9 @@ struct serial_ops {
|
||||||
void (*close) PARAMS ((serial_t));
|
void (*close) PARAMS ((serial_t));
|
||||||
int (*readchar) PARAMS ((serial_t, int timeout));
|
int (*readchar) PARAMS ((serial_t, int timeout));
|
||||||
int (*write) PARAMS ((serial_t, const char *str, int len));
|
int (*write) PARAMS ((serial_t, const char *str, int len));
|
||||||
|
/* Discard pending output */
|
||||||
int (*flush_output) PARAMS ((serial_t));
|
int (*flush_output) PARAMS ((serial_t));
|
||||||
|
/* Discard pending input */
|
||||||
int (*flush_input) PARAMS ((serial_t));
|
int (*flush_input) PARAMS ((serial_t));
|
||||||
int (*send_break) PARAMS ((serial_t));
|
int (*send_break) PARAMS ((serial_t));
|
||||||
void (*go_raw) PARAMS ((serial_t));
|
void (*go_raw) PARAMS ((serial_t));
|
||||||
|
@ -61,6 +63,8 @@ struct serial_ops {
|
||||||
PARAMS ((serial_t, serial_ttystate, serial_ttystate));
|
PARAMS ((serial_t, serial_ttystate, serial_ttystate));
|
||||||
int (*setbaudrate) PARAMS ((serial_t, int rate));
|
int (*setbaudrate) PARAMS ((serial_t, int rate));
|
||||||
int (*setstopbits) PARAMS ((serial_t, int num));
|
int (*setstopbits) PARAMS ((serial_t, int num));
|
||||||
|
/* Wait for output to drain */
|
||||||
|
int (*drain_output) PARAMS ((serial_t));
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Add a new serial interface to the interface list */
|
/* Add a new serial interface to the interface list */
|
||||||
|
@ -83,7 +87,12 @@ serial_t serial_fdopen PARAMS ((const int fd));
|
||||||
|
|
||||||
#define SERIAL_FDOPEN(FD) serial_fdopen(FD)
|
#define SERIAL_FDOPEN(FD) serial_fdopen(FD)
|
||||||
|
|
||||||
/* Flush pending output. Might also flush input (if this system can't flush
|
/* Allow pending output to drain. */
|
||||||
|
|
||||||
|
#define SERIAL_DRAIN_OUTPUT(SERIAL_T) \
|
||||||
|
((SERIAL_T)->ops->drain_output((SERIAL_T)))
|
||||||
|
|
||||||
|
/* Flush (discard) pending output. Might also flush input (if this system can't flush
|
||||||
only output). */
|
only output). */
|
||||||
|
|
||||||
#define SERIAL_FLUSH_OUTPUT(SERIAL_T) \
|
#define SERIAL_FLUSH_OUTPUT(SERIAL_T) \
|
||||||
|
|
Loading…
Add table
Reference in a new issue