diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2004-08-19 17:10:16 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2004-08-19 17:10:16 +0000 |
commit | a17ac5bd7c4d299e4593d8a5bd123903ca912cb9 (patch) | |
tree | c531d5eb99cb2b21f8518c42435d173a0785db98 /sys/arch | |
parent | e7c4bc59699e63dc4fa29f04f86230fa604f2471 (diff) |
Fix (well, rewrite) the start() logic - not only would it eat characters,
but it could cause the output to stop completely.
While there, fix cnputc() prototype and clean up cngetc().
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/mvme88k/dev/dart.c | 84 |
1 files changed, 34 insertions, 50 deletions
diff --git a/sys/arch/mvme88k/dev/dart.c b/sys/arch/mvme88k/dev/dart.c index 48f611842bf..a61a0229c03 100644 --- a/sys/arch/mvme88k/dev/dart.c +++ b/sys/arch/mvme88k/dev/dart.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dart.c,v 1.39 2004/08/02 08:35:00 miod Exp $ */ +/* $OpenBSD: dart.c,v 1.40 2004/08/19 17:10:15 miod Exp $ */ /* * Mach Operating System @@ -319,7 +319,7 @@ dartstart(tp) { dev_t dev; struct dartsoftc *sc; - int s, cc; + int s; union dart_pt_io *ptaddr; union dartreg *addr; int port; @@ -339,7 +339,7 @@ dartstart(tp) s = spltty(); - if (tp->t_state & (TS_TIMEOUT |TS_BUSY | TS_TTSTOP)) + if (tp->t_state & (TS_TIMEOUT | TS_BUSY | TS_TTSTOP)) goto bail; if (tp->t_outq.c_cc <= tp->t_lowat) { @@ -352,9 +352,6 @@ dartstart(tp) selwakeup(&tp->t_wsel); } - if (tp->t_state & (TS_TIMEOUT | TS_BUSY | TS_TTSTOP)) - goto bail; - dprintf(("dartstart: dev(%d, %d)\n", major(dev), minor(dev))); if (port != CONS_PORT) @@ -363,35 +360,33 @@ dartstart(tp) if (tp->t_outq.c_cc != 0) { tp->t_state |= TS_BUSY; - cc = tp->t_outq.c_cc; + /* load transmitter until it is full */ while (ptaddr->read.rd_sr & TXRDY) { - if(cc == 0) - break; c = getc(&tp->t_outq); - cc--; - if (tp->t_flags & CS8 || c <= 0177) { - if (port != CONS_PORT) - dprintf(("dartstart: writing char \"%c\" (0x%02x) to port %d\n", - c & 0xff, c & 0xff, port)); - ptaddr->write.wr_tb = c & 0xff; - - if (port != CONS_PORT) - dprintf(("dartstart: enabling Tx int\n")); - if (port == A_PORT) - dart_sv_reg.sv_imr = dart_sv_reg.sv_imr | ITXRDYA; - else - dart_sv_reg.sv_imr = dart_sv_reg.sv_imr | ITXRDYB; - addr->write.wr_imr = dart_sv_reg.sv_imr; - } else { - tp->t_state &= ~TS_BUSY; - if (port != CONS_PORT) - dprintf(("dartxint: timing out char \"%c\" (0x%02x)\n", - c & 0xff, c % 0xff)); - timeout_add(&tp->t_rstrt_to, 1); - tp->t_state |= TS_TIMEOUT; - } + if (port != CONS_PORT) + dprintf(("dartstart: writing char \"%c\" (0x%02x) to port %d\n", + c & 0xff, c & 0xff, port)); + ptaddr->write.wr_tb = c & 0xff; + + if (port != CONS_PORT) + dprintf(("dartstart: enabling Tx int\n")); + if (port == A_PORT) + dart_sv_reg.sv_imr = dart_sv_reg.sv_imr | ITXRDYA; + else + dart_sv_reg.sv_imr = dart_sv_reg.sv_imr | ITXRDYB; + addr->write.wr_imr = dart_sv_reg.sv_imr; + + if (tp->t_outq.c_cc == 0) + break; + } + + tp->t_state &= ~TS_BUSY; + + if (tp->t_outq.c_cc != 0) { + timeout_add(&tp->t_rstrt_to, 1); + tp->t_state |= TS_TIMEOUT; } } bail: @@ -1185,7 +1180,7 @@ dartcninit(cp) void dartcnputc(dev, c) dev_t dev; - char c; + int c; { union dartreg *addr; union dart_pt_io *ptaddr; @@ -1254,7 +1249,6 @@ dartcngetc(dev) #else m88k_psr_type psr; #endif - char buf[] = "char x"; port = DART_PORT(dev); #if 1 @@ -1271,7 +1265,7 @@ dartcngetc(dev) /* enable receiver */ ptaddr->write.wr_cr = RXEN; - do { + for (;;) { /* read status reg */ sr = ptaddr->read.rd_sr; @@ -1286,34 +1280,24 @@ dartcngetc(dev) ptaddr->write.wr_cr = BRKINTRESET; DELAY_CR; ptaddr->write.wr_cr = ERRRESET; -#if 1 - splx(s); -#else - set_psr(psr); -#endif - return c; + break; } - if (sr & (FRERR|PERR|ROVRN)) { + if (sr & (FRERR | PERR | ROVRN)) { /* clear error state */ ptaddr->write.wr_cr = ERRRESET; DELAY_CR; ptaddr->write.wr_cr = BRKINTRESET; } else { - buf[5] = (char) c; -#if 1 - splx(s); -#else - set_psr(psr); -#endif - return (c & 0x7f); + /* c &= 0x7f; */ + break; } } - } while (-1); + } #if 1 splx(s); #else set_psr(psr); #endif - return -1; + return c; } |