summaryrefslogtreecommitdiffstats
path: root/sys/dev/sk
diff options
context:
space:
mode:
authoryongari <yongari@FreeBSD.org>2010-07-09 21:21:08 +0000
committeryongari <yongari@FreeBSD.org>2010-07-09 21:21:08 +0000
commit798f7ab69e46d82d0672529ff51f8b141d37c764 (patch)
tree6e3e6db1292f1016b4e06df1a8341a093191d18d /sys/dev/sk
parent5e9badadafc232a66f795183716dc2ec221a1038 (diff)
downloadFreeBSD-src-798f7ab69e46d82d0672529ff51f8b141d37c764.zip
FreeBSD-src-798f7ab69e46d82d0672529ff51f8b141d37c764.tar.gz
Some revision of Yukon controller generates corrupted frame when TX
checksum offloading is enabled. The frame has a valid checksum value so payload might be modified during TX checksum calculation. Disable TX checksum offloading but give users chance to enable it when they know their controller works without problems with TX checksum offloading. Reported by: Andrzej Tobola <ato <> iem dot pw dot edu dot pl>
Diffstat (limited to 'sys/dev/sk')
-rw-r--r--sys/dev/sk/if_sk.c29
1 files changed, 21 insertions, 8 deletions
diff --git a/sys/dev/sk/if_sk.c b/sys/dev/sk/if_sk.c
index 0f5d2b1..c8cd956 100644
--- a/sys/dev/sk/if_sk.c
+++ b/sys/dev/sk/if_sk.c
@@ -1169,14 +1169,17 @@ sk_ioctl(ifp, command, data)
break;
}
mask = ifr->ifr_reqcap ^ ifp->if_capenable;
- if (mask & IFCAP_HWCSUM) {
- ifp->if_capenable ^= IFCAP_HWCSUM;
- if (IFCAP_HWCSUM & ifp->if_capenable &&
- IFCAP_HWCSUM & ifp->if_capabilities)
- ifp->if_hwassist = SK_CSUM_FEATURES;
+ if ((mask & IFCAP_TXCSUM) != 0 &&
+ (IFCAP_TXCSUM & ifp->if_capabilities) != 0) {
+ ifp->if_capenable ^= IFCAP_TXCSUM;
+ if ((ifp->if_capenable & IFCAP_TXCSUM) != 0)
+ ifp->if_hwassist |= SK_CSUM_FEATURES;
else
- ifp->if_hwassist = 0;
+ ifp->if_hwassist &= ~SK_CSUM_FEATURES;
}
+ if ((mask & IFCAP_RXCSUM) != 0 &&
+ (IFCAP_RXCSUM & ifp->if_capabilities) != 0)
+ ifp->if_capenable ^= IFCAP_RXCSUM;
SK_IF_UNLOCK(sc_if);
break;
default:
@@ -1363,13 +1366,23 @@ sk_attach(dev)
* SK_GENESIS has a bug in checksum offload - From linux.
*/
if (sc_if->sk_softc->sk_type != SK_GENESIS) {
- ifp->if_capabilities = IFCAP_HWCSUM;
- ifp->if_hwassist = SK_CSUM_FEATURES;
+ ifp->if_capabilities = IFCAP_TXCSUM | IFCAP_RXCSUM;
+ ifp->if_hwassist = 0;
} else {
ifp->if_capabilities = 0;
ifp->if_hwassist = 0;
}
ifp->if_capenable = ifp->if_capabilities;
+ /*
+ * Some revision of Yukon controller generates corrupted
+ * frame when TX checksum offloading is enabled. The
+ * frame has a valid checksum value so payload might be
+ * modified during TX checksum calculation. Disable TX
+ * checksum offloading but give users chance to enable it
+ * when they know their controller works without problems
+ * with TX checksum offloading.
+ */
+ ifp->if_capenable &= ~IFCAP_TXCSUM;
ifp->if_ioctl = sk_ioctl;
ifp->if_start = sk_start;
ifp->if_init = sk_init;
OpenPOWER on IntegriCloud