aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorstephen hemminger <shemminger@vyatta.com>2012-06-06 06:01:30 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2012-07-16 11:47:37 -0400
commit527a2a53232256fbaab9e72637839381eb6f42b1 (patch)
treefc1ce68faa414b1c0bdf7a0e40084ffdc89a0e71
parent5eceb057268c275e8193a03ed159bf540038feac (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.c10
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)