patch-2.2.14 linux/drivers/isdn/hisax/hscx_irq.c
Next file: linux/drivers/isdn/hisax/ipac.h
Previous file: linux/drivers/isdn/hisax/hscx.h
Back to the patch index
Back to the overall index
- Lines: 68
- Date:
Tue Jan 4 10:12:16 2000
- Orig file:
v2.2.13/linux/drivers/isdn/hisax/hscx_irq.c
- Orig date:
Tue Jan 4 11:10:34 2000
diff -u --recursive --new-file v2.2.13/linux/drivers/isdn/hisax/hscx_irq.c linux/drivers/isdn/hisax/hscx_irq.c
@@ -1,4 +1,4 @@
-/* $Id: hscx_irq.c,v 1.12 1999/07/01 08:11:42 keil Exp $
+/* $Id: hscx_irq.c,v 1.13 1999/10/14 20:25:28 keil Exp $
* hscx_irq.c low level b-channel stuff for Siemens HSCX
*
@@ -7,6 +7,9 @@
* This is an include file for fast inline IRQ stuff
*
* $Log: hscx_irq.c,v $
+ * Revision 1.13 1999/10/14 20:25:28 keil
+ * add a statistic for error monitoring
+ *
* Revision 1.12 1999/07/01 08:11:42 keil
* Common HiSax version for 2.0, 2.1, 2.2 and 2.3 kernel
*
@@ -181,16 +184,28 @@
if (val & 0x80) { /* RME */
r = READHSCX(cs, hscx, HSCX_RSTA);
if ((r & 0xf0) != 0xa0) {
- if (!(r & 0x80))
+ if (!(r & 0x80)) {
if (cs->debug & L1_DEB_WARN)
debugl1(cs, "HSCX invalid frame");
- if ((r & 0x40) && bcs->mode)
+#ifdef ERROR_STATISTIC
+ bcs->err_inv++;
+#endif
+ }
+ if ((r & 0x40) && bcs->mode) {
if (cs->debug & L1_DEB_WARN)
debugl1(cs, "HSCX RDO mode=%d",
bcs->mode);
- if (!(r & 0x20))
+#ifdef ERROR_STATISTIC
+ bcs->err_rdo++;
+#endif
+ }
+ if (!(r & 0x20)) {
if (cs->debug & L1_DEB_WARN)
debugl1(cs, "HSCX CRC error");
+#ifdef ERROR_STATISTIC
+ bcs->err_crc++;
+#endif
+ }
WriteHSCXCMDR(cs, hscx, 0x80);
} else {
count = READHSCX(cs, hscx, HSCX_RBCL) & (
@@ -265,6 +280,9 @@
if (bcs->mode == 1)
hscx_fill_fifo(bcs);
else {
+#ifdef ERROR_STATISTIC
+ bcs->err_tx++;
+#endif
/* Here we lost an TX interrupt, so
* restart transmitting the whole frame.
*/
@@ -295,6 +313,9 @@
/* Here we lost an TX interrupt, so
* restart transmitting the whole frame.
*/
+#ifdef ERROR_STATISTIC
+ bcs->err_tx++;
+#endif
if (bcs->tx_skb) {
skb_push(bcs->tx_skb, bcs->hw.hscx.count);
bcs->tx_cnt += bcs->hw.hscx.count;
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)