diff options
author | stephen hemminger <shemminger@vyatta.com> | 2012-06-06 06:01:30 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2012-07-16 11:47:37 -0400 |
commit | 527a2a53232256fbaab9e72637839381eb6f42b1 (patch) | |
tree | fc1ce68faa414b1c0bdf7a0e40084ffdc89a0e71 | |
parent | 5eceb057268c275e8193a03ed159bf540038feac (diff) |
sky2: fix checksum bit management on some chips
[ Upstream commit 5ff0feac88ced864f44adb145142269196fa79d9 ]
The newer flavors of Yukon II use a different method for receive
checksum offload. This is indicated in the driver by the SKY2_HW_NEW_LE
flag. On these newer chips, the BMU_ENA_RX_CHKSUM should not be set.
The driver would get incorrectly toggle the bit, enabling the old
checksum logic on these chips and cause a BUG_ON() assertion. If
receive checksum was toggled via ethtool.
Reported-by: Kirill Smelkov <kirr@mns.spb.ru>
Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r-- | drivers/net/sky2.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index f2e31c87d9f..9d4a2a38545 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c | |||
@@ -4206,10 +4206,12 @@ static int sky2_set_features(struct net_device *dev, u32 features) | |||
4206 | struct sky2_port *sky2 = netdev_priv(dev); | 4206 | struct sky2_port *sky2 = netdev_priv(dev); |
4207 | u32 changed = dev->features ^ features; | 4207 | u32 changed = dev->features ^ features; |
4208 | 4208 | ||
4209 | if (changed & NETIF_F_RXCSUM) { | 4209 | if ((changed & NETIF_F_RXCSUM) && |
4210 | u32 on = features & NETIF_F_RXCSUM; | 4210 | !(sky2->hw->flags & SKY2_HW_NEW_LE)) { |
4211 | sky2_write32(sky2->hw, Q_ADDR(rxqaddr[sky2->port], Q_CSR), | 4211 | sky2_write32(sky2->hw, |
4212 | on ? BMU_ENA_RX_CHKSUM : BMU_DIS_RX_CHKSUM); | 4212 | Q_ADDR(rxqaddr[sky2->port], Q_CSR), |
4213 | (features & NETIF_F_RXCSUM) | ||
4214 | ? BMU_ENA_RX_CHKSUM : BMU_DIS_RX_CHKSUM); | ||
4213 | } | 4215 | } |
4214 | 4216 | ||
4215 | if (changed & NETIF_F_RXHASH) | 4217 | if (changed & NETIF_F_RXHASH) |