[dpdk-dev] [PATCH v2 01/22] ethdev: fix MTU size exceeds max rx packet length

Ferruh Yigit ferruh.yigit at intel.com
Wed Jan 13 12:04:20 CET 2021


On 1/6/2021 3:36 AM, Yang, SteveX wrote:

<...>

>>> If max rx packet length is smaller then MTU + Ether overhead, that
>>> will drop all MTU size packets.
>>>
>>> Update the MTU size according to the max rx packet and Ether overhead.
>>>

Can you please elaborate the explanation a little more, it is hard to understand 
the problem with above description.

Problem is:
"
Ethdev is using default Ethernet overhead to decide if provided 'max_rx_pkt_len' 
value is bigger than max (non jumbo) MTU value, and limits it to MAX if it is.

Since the application/driver used Ethernet overhead is different than the ethdev 
one, check result is wrong.

If the driver is using Ethernet overhead bigger than the default one, the 
provided 'max_rx_pkt_len' is trimmed down, and in the driver when correct 
Ethernet overhead is used to convert back, the resulting MTU is less than the 
intended one, causing some packets to be dropped.

Like,
app     -> max_rx_pkt_len = 1500/*mtu*/ + 22/*overhead*/ = 1522
ethdev  -> 1522 > 1518/*MAX*/; max_rx_pkt_len = 1518
driver  -> MTU = 1518 - 22 = 1496
Packets with size 1497-1500 are dropped although intention is to be able to 
send/receive them.

The fix is to make ethdev use the correct Ethernet overhead for port, instead of 
default one.
"

Addition to above, the code reviews suggest slight difference, like dropping the 
ethdev check completely for non-jumbo packets, please reflect them to the commit 
log if changes are implemented.

>>> Fixes: 59d0ecdbf0e1 ("ethdev: MTU accessors")
>>>
>>> Signed-off-by: Steve Yang <stevex.yang at intel.com>
>>> ---


More information about the dev mailing list