diff options
author | bde <bde@FreeBSD.org> | 1996-11-30 15:29:31 +0000 |
---|---|---|
committer | bde <bde@FreeBSD.org> | 1996-11-30 15:29:31 +0000 |
commit | 87d2c32cebe5c2ed26d29f4d8c4e7972205b0ee5 (patch) | |
tree | 18a3f0dbdaa0a91740c929d5e2d6eb4ffa5b7da5 | |
parent | e7c48f38709dc93cc82ecf0c18723dff1081d3a2 (diff) | |
download | FreeBSD-src-87d2c32cebe5c2ed26d29f4d8c4e7972205b0ee5.zip FreeBSD-src-87d2c32cebe5c2ed26d29f4d8c4e7972205b0ee5.tar.gz |
Reset h/w fifos (if any) in siostop(). Now ttyflush() works fairly well
with sio devices (not perfectly, since there is no way to flush the tx
holding register on 8250-16450's. I'm not sure if resetting the fifos
flushes the tx shift register).
Reminded by: NIST-PCTS
-rw-r--r-- | sys/dev/sio/sio.c | 12 | ||||
-rw-r--r-- | sys/i386/isa/sio.c | 12 | ||||
-rw-r--r-- | sys/isa/sio.c | 12 |
3 files changed, 27 insertions, 9 deletions
diff --git a/sys/dev/sio/sio.c b/sys/dev/sio/sio.c index d4125c3..0b70455 100644 --- a/sys/dev/sio/sio.c +++ b/sys/dev/sio/sio.c @@ -31,7 +31,7 @@ * SUCH DAMAGE. * * from: @(#)com.c 7.5 (Berkeley) 5/16/91 - * $Id: sio.c,v 1.151 1996/11/30 15:03:05 bde Exp $ + * $Id: sio.c,v 1.152 1996/11/30 15:19:19 bde Exp $ */ #include "opt_comconsole.h" @@ -2123,6 +2123,10 @@ siostop(tp, rw) return; disable_intr(); if (rw & FWRITE) { + if (com->hasfifo) + /* XXX does this flush everything? */ + outb(com->iobase + com_fifo, + FIFO_XMT_RST | com->fifo_image); com->obufs[0].l_queued = FALSE; com->obufs[1].l_queued = FALSE; if (com->state & CS_ODONE) @@ -2131,13 +2135,15 @@ siostop(tp, rw) com->tp->t_state &= ~TS_BUSY; } if (rw & FREAD) { + if (com->hasfifo) + /* XXX does this flush everything? */ + outb(com->iobase + com_fifo, + FIFO_RCV_RST | com->fifo_image); com_events -= (com->iptr - com->ibuf); com->iptr = com->ibuf; } enable_intr(); comstart(tp); - - /* XXX should clear h/w fifos too. */ } static struct tty * diff --git a/sys/i386/isa/sio.c b/sys/i386/isa/sio.c index d4125c3..0b70455 100644 --- a/sys/i386/isa/sio.c +++ b/sys/i386/isa/sio.c @@ -31,7 +31,7 @@ * SUCH DAMAGE. * * from: @(#)com.c 7.5 (Berkeley) 5/16/91 - * $Id: sio.c,v 1.151 1996/11/30 15:03:05 bde Exp $ + * $Id: sio.c,v 1.152 1996/11/30 15:19:19 bde Exp $ */ #include "opt_comconsole.h" @@ -2123,6 +2123,10 @@ siostop(tp, rw) return; disable_intr(); if (rw & FWRITE) { + if (com->hasfifo) + /* XXX does this flush everything? */ + outb(com->iobase + com_fifo, + FIFO_XMT_RST | com->fifo_image); com->obufs[0].l_queued = FALSE; com->obufs[1].l_queued = FALSE; if (com->state & CS_ODONE) @@ -2131,13 +2135,15 @@ siostop(tp, rw) com->tp->t_state &= ~TS_BUSY; } if (rw & FREAD) { + if (com->hasfifo) + /* XXX does this flush everything? */ + outb(com->iobase + com_fifo, + FIFO_RCV_RST | com->fifo_image); com_events -= (com->iptr - com->ibuf); com->iptr = com->ibuf; } enable_intr(); comstart(tp); - - /* XXX should clear h/w fifos too. */ } static struct tty * diff --git a/sys/isa/sio.c b/sys/isa/sio.c index d4125c3..0b70455 100644 --- a/sys/isa/sio.c +++ b/sys/isa/sio.c @@ -31,7 +31,7 @@ * SUCH DAMAGE. * * from: @(#)com.c 7.5 (Berkeley) 5/16/91 - * $Id: sio.c,v 1.151 1996/11/30 15:03:05 bde Exp $ + * $Id: sio.c,v 1.152 1996/11/30 15:19:19 bde Exp $ */ #include "opt_comconsole.h" @@ -2123,6 +2123,10 @@ siostop(tp, rw) return; disable_intr(); if (rw & FWRITE) { + if (com->hasfifo) + /* XXX does this flush everything? */ + outb(com->iobase + com_fifo, + FIFO_XMT_RST | com->fifo_image); com->obufs[0].l_queued = FALSE; com->obufs[1].l_queued = FALSE; if (com->state & CS_ODONE) @@ -2131,13 +2135,15 @@ siostop(tp, rw) com->tp->t_state &= ~TS_BUSY; } if (rw & FREAD) { + if (com->hasfifo) + /* XXX does this flush everything? */ + outb(com->iobase + com_fifo, + FIFO_RCV_RST | com->fifo_image); com_events -= (com->iptr - com->ibuf); com->iptr = com->ibuf; } enable_intr(); comstart(tp); - - /* XXX should clear h/w fifos too. */ } static struct tty * |