950-0265-net-lan78xx-Allow-for-VLAN-headers-in-timeout.patch 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. From 50340b55bb7af7c12259d3bce5da6ba969c58e00 Mon Sep 17 00:00:00 2001
  2. From: Dave Stevenson <[email protected]>
  3. Date: Wed, 4 Apr 2018 16:34:24 +0100
  4. Subject: [PATCH 265/454] net: lan78xx: Allow for VLAN headers in timeout.
  5. The frame abort timeout being set by lan78xx_set_rx_max_frame_length
  6. didn't account for any VLAN headers, resulting in very low
  7. throughput if used with tagged VLANs.
  8. Use VLAN_ETH_HLEN instead of ETH_HLEN to correct for this.
  9. See https://github.com/raspberrypi/linux/issues/2458
  10. Signed-off-by: Dave Stevenson <[email protected]>
  11. ---
  12. drivers/net/usb/lan78xx.c | 5 +++--
  13. 1 file changed, 3 insertions(+), 2 deletions(-)
  14. --- a/drivers/net/usb/lan78xx.c
  15. +++ b/drivers/net/usb/lan78xx.c
  16. @@ -2194,7 +2194,7 @@ static int lan78xx_change_mtu(struct net
  17. if ((ll_mtu % dev->maxpacket) == 0)
  18. return -EDOM;
  19. - ret = lan78xx_set_rx_max_frame_length(dev, new_mtu + ETH_HLEN);
  20. + ret = lan78xx_set_rx_max_frame_length(dev, new_mtu + VLAN_ETH_HLEN);
  21. netdev->mtu = new_mtu;
  22. @@ -2487,7 +2487,8 @@ static int lan78xx_reset(struct lan78xx_
  23. buf |= FCT_TX_CTL_EN_;
  24. ret = lan78xx_write_reg(dev, FCT_TX_CTL, buf);
  25. - ret = lan78xx_set_rx_max_frame_length(dev, dev->net->mtu + ETH_HLEN);
  26. + ret = lan78xx_set_rx_max_frame_length(dev,
  27. + dev->net->mtu + VLAN_ETH_HLEN);
  28. ret = lan78xx_read_reg(dev, MAC_RX, &buf);
  29. buf |= MAC_RX_RXEN_;