Commit 5d48f00d authored by Stefan Richter's avatar Stefan Richter Committed by David S. Miller

firewire: net: fix maximum possible MTU

Commit b3e3893e ("net: use core MTU range checking in misc drivers")
mistakenly introduced an upper limit for firewire-net's MTU based on the
local link layer controller's reception capability.  Revert this.  Neither
RFC 2734 nor our implementation impose any particular upper limit.

Actually, to be on the safe side and to make the code explicit, set
ETH_MAX_MTU = 65535 as upper limit now.

(I replaced sizeof(struct rfc2734_header) by the equivalent
RFC2374_FRAG_HDR_SIZE in order to avoid distracting long/int conversions.)

Fixes: b3e3893e('net: use core MTU range checking in misc drivers')
CC: netdev@vger.kernel.org
CC: linux1394-devel@lists.sourceforge.net
CC: Jarod Wilson <jarod@redhat.com>
Signed-off-by: default avatarStefan Richter <stefanr@s5r6.in-berlin.de>
Acked-by: default avatarJarod Wilson <jarod@redhat.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent e2897b82
...@@ -1467,10 +1467,11 @@ static int fwnet_probe(struct fw_unit *unit, ...@@ -1467,10 +1467,11 @@ static int fwnet_probe(struct fw_unit *unit,
* Use the RFC 2734 default 1500 octets or the maximum payload * Use the RFC 2734 default 1500 octets or the maximum payload
* as initial MTU * as initial MTU
*/ */
net->max_mtu = (1 << (card->max_receive + 1)) net->mtu = min(1500U,
- sizeof(struct rfc2734_header) - IEEE1394_GASP_HDR_SIZE; (1U << (card->max_receive + 1))
net->mtu = min(1500U, net->max_mtu); - RFC2374_FRAG_HDR_SIZE - IEEE1394_GASP_HDR_SIZE);
net->min_mtu = ETH_MIN_MTU; net->min_mtu = ETH_MIN_MTU;
net->max_mtu = ETH_MAX_MTU;
/* Set our hardware address while we're at it */ /* Set our hardware address while we're at it */
ha = (union fwnet_hwaddr *)net->dev_addr; ha = (union fwnet_hwaddr *)net->dev_addr;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment