diff options
author | Nisar Sayed <Nisar.Sayed@microchip.com> | 2017-08-01 12:24:33 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2017-08-02 19:39:58 +0200 |
commit | 0573f94b1abfb42952275ca67f665dbd720b00d7 (patch) | |
tree | ad136e947271f6a632d941fe4f5c806dcfc85d4b | |
parent | lan78xx: USB fast connect/disconnect crash fix (diff) | |
download | linux-0573f94b1abfb42952275ca67f665dbd720b00d7.tar.xz linux-0573f94b1abfb42952275ca67f665dbd720b00d7.zip |
lan78xx: Fix to handle hard_header_len update
Fix to handle hard_header_len update
When ifconfig up/down sequence is initiated hard_header_len
get updated incrementally for each ifconfig up /down sequence,
this leads invalid hard_header_len, moving to lan78xx_bind
to have one time update of hard_header_len addresses the issue.
Signed-off-by: Nisar Sayed <Nisar.Sayed@microchip.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/usb/lan78xx.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/net/usb/lan78xx.c b/drivers/net/usb/lan78xx.c index 8ef3639649a0..b99a7fb09f8e 100644 --- a/drivers/net/usb/lan78xx.c +++ b/drivers/net/usb/lan78xx.c @@ -2367,9 +2367,6 @@ static int lan78xx_reset(struct lan78xx_net *dev) /* Init LTM */ lan78xx_init_ltm(dev); - dev->net->hard_header_len += TX_OVERHEAD; - dev->hard_mtu = dev->net->mtu + dev->net->hard_header_len; - if (dev->udev->speed == USB_SPEED_SUPER) { buf = DEFAULT_BURST_CAP_SIZE / SS_USB_PKT_SIZE; dev->rx_urb_size = DEFAULT_BURST_CAP_SIZE; @@ -2855,6 +2852,9 @@ static int lan78xx_bind(struct lan78xx_net *dev, struct usb_interface *intf) return ret; } + dev->net->hard_header_len += TX_OVERHEAD; + dev->hard_mtu = dev->net->mtu + dev->net->hard_header_len; + /* Init all registers */ ret = lan78xx_reset(dev); |