[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4A86BAF3.5060609@gmail.com>
Date: Sat, 15 Aug 2009 15:41:07 +0200
From: Roel Kluin <roel.kluin@...il.com>
To: Andrew Morton <akpm@...ux-foundation.org>
CC: David Miller <davem@...emloft.net>, romieu@...zoreil.com,
netdev@...r.kernel.org
Subject: Re: [PATCH] WAN: bit and/or confusion
Fix the tests that check whether Frame* bits are not set
Signed-off-by: Roel Kluin <roel.kluin@...il.com>
---
> we need
>
> else if (!(skb->data[pkt_len] & FrameCrc))
> vfr is "valid frame". 0 is invalid.
>
> rab is "receive message aborted". The data sheet doesn't actually say
> if the bit is active-high or active-low (grr).
Maybe someone could test this?
diff --git a/drivers/net/wan/dscc4.c b/drivers/net/wan/dscc4.c
index 8face5d..b686050 100644
--- a/drivers/net/wan/dscc4.c
+++ b/drivers/net/wan/dscc4.c
@@ -663,9 +663,9 @@ static inline void dscc4_rx_skb(struct dscc4_dev_priv *dpriv,
} else {
if (skb->data[pkt_len] & FrameRdo)
dev->stats.rx_fifo_errors++;
- else if (!(skb->data[pkt_len] | ~FrameCrc))
+ else if (!(skb->data[pkt_len] & FrameCrc))
dev->stats.rx_crc_errors++;
- else if (!(skb->data[pkt_len] | ~(FrameVfr | FrameRab)))
+ else if (!(skb->data[pkt_len] & (FrameVfr | FrameRab)))
dev->stats.rx_length_errors++;
else
dev->stats.rx_errors++;
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists