提交 1ef6841b 编写于 作者: A Ayaz Abdulla 提交者: Jeff Garzik

forcedeth: fix rx error policy

This patch enforces a stricter policy on rx errors. The driver needs to
verify whether there are multiple rx errors versus a single error.
Signed-off-by: NAyaz Abdulla <aabdulla@nvidia.com>
Signed-off-by: NJeff Garzik <jgarzik@redhat.com>
上级 8bad4afe
...@@ -402,6 +402,7 @@ union ring_type { ...@@ -402,6 +402,7 @@ union ring_type {
#define NV_RX_FRAMINGERR (1<<29) #define NV_RX_FRAMINGERR (1<<29)
#define NV_RX_ERROR (1<<30) #define NV_RX_ERROR (1<<30)
#define NV_RX_AVAIL (1<<31) #define NV_RX_AVAIL (1<<31)
#define NV_RX_ERROR_MASK (NV_RX_ERROR1|NV_RX_ERROR2|NV_RX_ERROR3|NV_RX_ERROR4|NV_RX_CRCERR|NV_RX_OVERFLOW|NV_RX_FRAMINGERR)
#define NV_RX2_CHECKSUMMASK (0x1C000000) #define NV_RX2_CHECKSUMMASK (0x1C000000)
#define NV_RX2_CHECKSUM_IP (0x10000000) #define NV_RX2_CHECKSUM_IP (0x10000000)
...@@ -419,6 +420,7 @@ union ring_type { ...@@ -419,6 +420,7 @@ union ring_type {
/* error and avail are the same for both */ /* error and avail are the same for both */
#define NV_RX2_ERROR (1<<30) #define NV_RX2_ERROR (1<<30)
#define NV_RX2_AVAIL (1<<31) #define NV_RX2_AVAIL (1<<31)
#define NV_RX2_ERROR_MASK (NV_RX2_ERROR1|NV_RX2_ERROR2|NV_RX2_ERROR3|NV_RX2_ERROR4|NV_RX2_CRCERR|NV_RX2_OVERFLOW|NV_RX2_FRAMINGERR)
#define NV_RX3_VLAN_TAG_PRESENT (1<<16) #define NV_RX3_VLAN_TAG_PRESENT (1<<16)
#define NV_RX3_VLAN_TAG_MASK (0x0000FFFF) #define NV_RX3_VLAN_TAG_MASK (0x0000FFFF)
...@@ -2632,7 +2634,7 @@ static int nv_rx_process(struct net_device *dev, int limit) ...@@ -2632,7 +2634,7 @@ static int nv_rx_process(struct net_device *dev, int limit)
if (likely(flags & NV_RX_DESCRIPTORVALID)) { if (likely(flags & NV_RX_DESCRIPTORVALID)) {
len = flags & LEN_MASK_V1; len = flags & LEN_MASK_V1;
if (unlikely(flags & NV_RX_ERROR)) { if (unlikely(flags & NV_RX_ERROR)) {
if (flags & NV_RX_ERROR4) { if ((flags & NV_RX_ERROR_MASK) == NV_RX_ERROR4) {
len = nv_getlen(dev, skb->data, len); len = nv_getlen(dev, skb->data, len);
if (len < 0) { if (len < 0) {
dev->stats.rx_errors++; dev->stats.rx_errors++;
...@@ -2641,7 +2643,7 @@ static int nv_rx_process(struct net_device *dev, int limit) ...@@ -2641,7 +2643,7 @@ static int nv_rx_process(struct net_device *dev, int limit)
} }
} }
/* framing errors are soft errors */ /* framing errors are soft errors */
else if (flags & NV_RX_FRAMINGERR) { else if ((flags & NV_RX_ERROR_MASK) == NV_RX_FRAMINGERR) {
if (flags & NV_RX_SUBSTRACT1) { if (flags & NV_RX_SUBSTRACT1) {
len--; len--;
} }
...@@ -2667,7 +2669,7 @@ static int nv_rx_process(struct net_device *dev, int limit) ...@@ -2667,7 +2669,7 @@ static int nv_rx_process(struct net_device *dev, int limit)
if (likely(flags & NV_RX2_DESCRIPTORVALID)) { if (likely(flags & NV_RX2_DESCRIPTORVALID)) {
len = flags & LEN_MASK_V2; len = flags & LEN_MASK_V2;
if (unlikely(flags & NV_RX2_ERROR)) { if (unlikely(flags & NV_RX2_ERROR)) {
if (flags & NV_RX2_ERROR4) { if ((flags & NV_RX2_ERROR_MASK) == NV_RX2_ERROR4) {
len = nv_getlen(dev, skb->data, len); len = nv_getlen(dev, skb->data, len);
if (len < 0) { if (len < 0) {
dev->stats.rx_errors++; dev->stats.rx_errors++;
...@@ -2676,7 +2678,7 @@ static int nv_rx_process(struct net_device *dev, int limit) ...@@ -2676,7 +2678,7 @@ static int nv_rx_process(struct net_device *dev, int limit)
} }
} }
/* framing errors are soft errors */ /* framing errors are soft errors */
else if (flags & NV_RX2_FRAMINGERR) { else if ((flags & NV_RX2_ERROR_MASK) == NV_RX2_FRAMINGERR) {
if (flags & NV_RX2_SUBSTRACT1) { if (flags & NV_RX2_SUBSTRACT1) {
len--; len--;
} }
...@@ -2766,7 +2768,7 @@ static int nv_rx_process_optimized(struct net_device *dev, int limit) ...@@ -2766,7 +2768,7 @@ static int nv_rx_process_optimized(struct net_device *dev, int limit)
if (likely(flags & NV_RX2_DESCRIPTORVALID)) { if (likely(flags & NV_RX2_DESCRIPTORVALID)) {
len = flags & LEN_MASK_V2; len = flags & LEN_MASK_V2;
if (unlikely(flags & NV_RX2_ERROR)) { if (unlikely(flags & NV_RX2_ERROR)) {
if (flags & NV_RX2_ERROR4) { if ((flags & NV_RX2_ERROR_MASK) == NV_RX2_ERROR4) {
len = nv_getlen(dev, skb->data, len); len = nv_getlen(dev, skb->data, len);
if (len < 0) { if (len < 0) {
dev_kfree_skb(skb); dev_kfree_skb(skb);
...@@ -2774,7 +2776,7 @@ static int nv_rx_process_optimized(struct net_device *dev, int limit) ...@@ -2774,7 +2776,7 @@ static int nv_rx_process_optimized(struct net_device *dev, int limit)
} }
} }
/* framing errors are soft errors */ /* framing errors are soft errors */
else if (flags & NV_RX2_FRAMINGERR) { else if ((flags & NV_RX2_ERROR_MASK) == NV_RX2_FRAMINGERR) {
if (flags & NV_RX2_SUBSTRACT1) { if (flags & NV_RX2_SUBSTRACT1) {
len--; len--;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册