summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2004-04-29 16:20:03 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2004-04-29 16:20:03 +0000
commitdaafc0966315ee045f1fde655d8dc8015a79c651 (patch)
treed3af99bdbc013848270e82d1cf054ad3f7592244
parentc082379018832e72c95068e938deaf79530a9458 (diff)
Bugfix sync with mvme68k:
- wait until all RX processing is over to invoke ddb upon break - turn off the most annoying log() messages unless option DEBUG
-rw-r--r--sys/arch/mvme88k/dev/cl.c33
1 files changed, 21 insertions, 12 deletions
diff --git a/sys/arch/mvme88k/dev/cl.c b/sys/arch/mvme88k/dev/cl.c
index 889d6c77053..4044f457283 100644
--- a/sys/arch/mvme88k/dev/cl.c
+++ b/sys/arch/mvme88k/dev/cl.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cl.c,v 1.44 2004/04/24 19:51:47 miod Exp $ */
+/* $OpenBSD: cl.c,v 1.45 2004/04/29 16:20:02 miod Exp $ */
/*
* Copyright (c) 1995 Dale Rahn. All rights reserved.
@@ -1316,21 +1316,27 @@ cl_mintr(arg)
log(LOG_WARNING, "cl_mintr: channel %x timer 2 unexpected\n",channel);
}
if (misr & 0x20) {
+#ifdef DEBUG
log(LOG_WARNING, "cl_mintr: channel %x cts %x\n",channel,
((msvr & 0x20) != 0x0)
);
+#endif
}
if (misr & 0x40) {
struct tty *tp = sc->sc_cl[channel].tty;
+#ifdef DEBUG
log(LOG_WARNING, "cl_mintr: channel %x cd %x\n",channel,
((msvr & 0x40) != 0x0)
);
+#endif
ttymodem(tp, ((msvr & 0x40) != 0x0) );
}
if (misr & 0x80) {
+#ifdef DEBUG
log(LOG_WARNING, "cl_mintr: channel %x dsr %x\n",channel,
((msvr & 0x80) != 0x0)
);
+#endif
}
bus_space_write_1(iot, ioh, CL_MEOIR, 0);
return 1;
@@ -1481,6 +1487,9 @@ cl_rxintr(arg)
int i;
u_int8_t reoir;
u_char buffer[CL_FIFO_MAX +1];
+#ifdef DDB
+ int wantddb = 0;
+#endif
iot = sc->sc_iot;
ioh = sc->sc_ioh;
@@ -1494,31 +1503,30 @@ cl_rxintr(arg)
sc->sc_rxintrcnt.ev_count++;
channel = rir & 0x3;
cmr = bus_space_read_1(iot, ioh, CL_CMR);
- reoir = 0x08;
sc->sc_cl[channel].rxcnt ++;
risrl = bus_space_read_1(iot, ioh, CL_RISRL);
if (risrl & 0x80) {
/* timeout, no characters */
- reoir = 0x08;
} else
- /* We don't need no sinkin special characters */
+ /* We don't need no stinkin special characters */
if (risrl & 0x08) {
cl_overflow(sc, channel, (long *)&sc->sc_fotime, "fifo");
- reoir = 0x08;
} else
if (risrl & 0x04) {
cl_parity(sc, channel);
- reoir = 0x08;
} else
if (risrl & 0x02) {
cl_frame(sc, channel);
- reoir = 0x08;
} else
if (risrl & 0x01) {
+#ifdef DDB
+ if (sc->sc_cl[channel].cl_consio)
+ wantddb = db_console;
+#endif
cl_break(sc, channel);
- reoir = 0x08;
}
+ reoir = 0x08;
switch (cmr & CL_RXMASK) {
case CL_RXDMAINT:
@@ -1622,6 +1630,10 @@ cl_rxintr(arg)
/* we probably will go to hell quickly now */
bus_space_write_1(iot, ioh, CL_REOIR, 0x08);
}
+#ifdef DDB
+ if (wantddb != 0)
+ Debugger();
+#endif
return 1;
}
@@ -1659,10 +1671,7 @@ cl_break(sc, channel)
struct clsoftc *sc;
int channel;
{
-#ifdef DDB
- if (sc->sc_cl[channel].cl_consio && db_console != 0)
- Debugger();
-#else
+#ifdef DEBUG
log(LOG_WARNING, "%s[%d]: break detected\n", sc->sc_dev.dv_xname,
channel);
#endif