Commit b1443e2f authored by David S. Miller's avatar David S. Miller

cassini: Only use chip checksum for ipv4 packets.

According to David Monro, at least with Natsemi Saturn chips the
cassini driver has some trouble with ipv6 checksums.

Until we have more information about what's going on here, only
use the chip checksums for ipv4.

This workaround was suggested and tested by David.

Update version and release date.
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 7d227cd2
...@@ -142,8 +142,8 @@ ...@@ -142,8 +142,8 @@
#define DRV_MODULE_NAME "cassini" #define DRV_MODULE_NAME "cassini"
#define PFX DRV_MODULE_NAME ": " #define PFX DRV_MODULE_NAME ": "
#define DRV_MODULE_VERSION "1.5" #define DRV_MODULE_VERSION "1.6"
#define DRV_MODULE_RELDATE "4 Jan 2008" #define DRV_MODULE_RELDATE "21 May 2008"
#define CAS_DEF_MSG_ENABLE \ #define CAS_DEF_MSG_ENABLE \
(NETIF_MSG_DRV | \ (NETIF_MSG_DRV | \
...@@ -2136,9 +2136,12 @@ static int cas_rx_process_pkt(struct cas *cp, struct cas_rx_comp *rxc, ...@@ -2136,9 +2136,12 @@ static int cas_rx_process_pkt(struct cas *cp, struct cas_rx_comp *rxc,
if (addr) if (addr)
cas_page_unmap(addr); cas_page_unmap(addr);
} }
skb->csum = csum_unfold(~csum);
skb->ip_summed = CHECKSUM_COMPLETE;
skb->protocol = eth_type_trans(skb, cp->dev); skb->protocol = eth_type_trans(skb, cp->dev);
if (skb->protocol == htons(ETH_P_IP)) {
skb->csum = csum_unfold(~csum);
skb->ip_summed = CHECKSUM_COMPLETE;
} else
skb->ip_summed = CHECKSUM_NONE;
return len; return len;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment