]> www.infradead.org Git - users/willy/pagecache.git/commit
net: dsa: b53: fix jumbo frame mtu check
authorJonas Gorski <jonas.gorski@gmail.com>
Fri, 4 Oct 2024 08:47:17 +0000 (10:47 +0200)
committerPaolo Abeni <pabeni@redhat.com>
Tue, 8 Oct 2024 08:42:27 +0000 (10:42 +0200)
commit42fb3acf6826c6764ba79feb6e15229b43fd2f9f
tree57092f85d6522f4355a9ec4dede45be87d857dd4
parent60ed96bd1e69764f6b4bdf28ce9399d6a79f497b
net: dsa: b53: fix jumbo frame mtu check

JMS_MIN_SIZE is the full ethernet frame length, while mtu is just the
data payload size. Comparing these two meant that mtus between 1500 and
1518 did not trigger enabling jumbo frames.

So instead compare the set mtu ETH_DATA_LEN, which is equal to
JMS_MIN_SIZE - ETH_HLEN - ETH_FCS_LEN;

Also do a check that the requested mtu is actually greater than the
minimum length, else we do not need to enable jumbo frames.

In practice this only introduced a very small range of mtus that did not
work properly. Newer chips allow 2000 byte large frames by default, and
older chips allow 1536 bytes long, which is equivalent to an mtu of
1514. So effectivly only mtus of 1515~1517 were broken.

Fixes: 6ae5834b983a ("net: dsa: b53: add MTU configuration support")
Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com>
Reviewed-by: Florian Fainelli <florian.fainelli@broadcom.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
drivers/net/dsa/b53/b53_common.c