diff options
author | Jussi Kivilinna <jussi.kivilinna@mbnet.fi> | 2010-06-07 00:56:27 -0700 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-06-07 00:56:27 -0700 |
commit | 9227a46bfbac0516fb7428715a095e1bc59b872a (patch) | |
tree | 2306b6f10f51a14b815af079b35bcc5eadd003fb | |
parent | 024a07bacf8287a6ddfa83e9d5b951c5e8b4070e (diff) | |
download | kernel_samsung_aries-9227a46bfbac0516fb7428715a095e1bc59b872a.zip kernel_samsung_aries-9227a46bfbac0516fb7428715a095e1bc59b872a.tar.gz kernel_samsung_aries-9227a46bfbac0516fb7428715a095e1bc59b872a.tar.bz2 |
asix: check packet size against mtu+ETH_HLEN instead of ETH_FRAME_LEN
Driver checks received packet is too large in asix_rx_fixup() and fails if it is. Problem is
that MTU might be set larger than 1500 and asix fails to work correctly with VLAN tagged
packets. The check should be 'dev->net->mtu + ETH_HLEN' instead.
Tested with AX88772.
Signed-off-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/usb/asix.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/usb/asix.c b/drivers/net/usb/asix.c index 1f802e9..9516f38 100644 --- a/drivers/net/usb/asix.c +++ b/drivers/net/usb/asix.c @@ -344,7 +344,7 @@ static int asix_rx_fixup(struct usbnet *dev, struct sk_buff *skb) return 2; } - if (size > ETH_FRAME_LEN) { + if (size > dev->net->mtu + ETH_HLEN) { netdev_err(dev->net, "asix_rx_fixup() Bad RX Length %d\n", size); return 0; |