Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/sandpoint At least KuroBox Classic and HG seem to h...



details:   https://anonhg.NetBSD.org/src/rev/b9ae5da0dcd9
branches:  trunk
changeset: 1019918:b9ae5da0dcd9
user:      rin <rin%NetBSD.org@localhost>
date:      Thu Mar 25 05:35:50 2021 +0000

description:
At least KuroBox Classic and HG seem to have buggy UART, for which
ETXRDY interrupts are sometimes (once per a few hours?) lost; TX stalls
until next RX arrives.

Since interrupt-based I/O works just fine for other devices, I believe
this problem is due to UART and not to PIC or its driver.

In order to work around this bug, enable COM_HW_BROKEN_ETXRDY bit, as
well as carry out polling once per 10 sec or 1k tics (arbitrary, but
1 min seems too long).

XXX
Apply this for other MPC824x-based boards?

diffstat:

 sys/arch/sandpoint/conf/KUROBOX         |   5 +++--
 sys/arch/sandpoint/sandpoint/com_eumb.c |  17 +++++++++++++++--
 2 files changed, 18 insertions(+), 4 deletions(-)

diffs (57 lines):

diff -r c00223c0b155 -r b9ae5da0dcd9 sys/arch/sandpoint/conf/KUROBOX
--- a/sys/arch/sandpoint/conf/KUROBOX   Thu Mar 25 05:34:49 2021 +0000
+++ b/sys/arch/sandpoint/conf/KUROBOX   Thu Mar 25 05:35:50 2021 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: KUROBOX,v 1.8 2020/01/03 03:44:42 thorpej Exp $
+#      $NetBSD: KUROBOX,v 1.9 2021/03/25 05:35:50 rin Exp $
 #
 # KuroBox/LinkStation support
 #
@@ -7,7 +7,8 @@
 
 no com0
 no satmgr0
-com0   at eumb? unit 1                 # console at 0x4600
+com0   at eumb? unit 1 flags 0x1       # console at 0x4600
+                                       # XXX flags 0x1 to work around H/W bug
 #com1  at eumb? unit 0
 satmgr0 at eumb? unit 0                        # satmgr at 0x4500
 
diff -r c00223c0b155 -r b9ae5da0dcd9 sys/arch/sandpoint/sandpoint/com_eumb.c
--- a/sys/arch/sandpoint/sandpoint/com_eumb.c   Thu Mar 25 05:34:49 2021 +0000
+++ b/sys/arch/sandpoint/sandpoint/com_eumb.c   Thu Mar 25 05:35:50 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: com_eumb.c,v 1.11 2021/03/17 14:50:11 rin Exp $ */
+/* $NetBSD: com_eumb.c,v 1.12 2021/03/25 05:35:50 rin Exp $ */
 
 /*-
  * Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: com_eumb.c,v 1.11 2021/03/17 14:50:11 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: com_eumb.c,v 1.12 2021/03/25 05:35:50 rin Exp $");
 
 #include <sys/param.h>
 #include <sys/device.h>
@@ -99,6 +99,19 @@
        sc->sc_frequency = 4 * ticks_per_sec;
        epicirq = (eaa->eumb_unit == 1) ? 25 : 24;
 
+       /*
+        * XXX
+        * At least KuroBox Classic and HG seem to have a hardware bug, by
+        * which ETXRDY interrupt is sometimes, say, once per few hours,
+        * lost; output stalls until next input arrives. In order to work
+        * around this problem, push TX queue manually by low-rate.
+        */
+#define        COM_EUMB_FLAG_BROKEN_ETXRDY     __BIT(0)
+       if (device_cfdata(self)->cf_flags & COM_EUMB_FLAG_BROKEN_ETXRDY) {
+               SET(sc->sc_hwflags, COM_HW_BROKEN_ETXRDY);
+               sc->sc_poll_ticks = 10 * hz;    /* once per 10 sec */
+       }
+
        com_attach_subr(sc);
 
        intr_establish_xname(epicirq + I8259_ICU, IST_LEVEL, IPL_SERIAL,



Home | Main Index | Thread Index | Old Index