On 4/26/2022 2:38 AM, lihuisong (C) wrote:

在 2022/4/26 0:25, Singh, Aman Deep 写道:

On 4/6/2022 2:15 PM, Min Hu (Connor) wrote:
From: Huisong Li <lihuis...@huawei.com>

The macro RTE_ETHER_MIN_LEN isn't the minimum value of MTU. But testpmd
used it when execute 'port config mtu 0 xx' cmd. This patch fix it.

Fixes: 1bb4a528c41f ("ethdev: fix max Rx packet length")
Cc: sta...@dpdk.org

Signed-off-by: Huisong Li <lihuis...@huawei.com>
Signed-off-by: Min Hu (Connor) <humi...@huawei.com>

<...>

@@ -1263,6 +1314,10 @@ port_mtu_set(portid_t port_id, uint16_t mtu)
      if (port_id_is_invalid(port_id, ENABLED_WARN))
          return;
  +    diag = eth_dev_validate_mtu(port_id, mtu);
+    if (diag != 0)
+        return;
+
      if (port->need_reconfig == 0) {
          diag = rte_eth_dev_set_mtu(port_id, mtu);
          if (diag != 0) {
I just wanted to know if these added functions eth_dev_validate_mtu() &  eth_dev_get_overhead_len() are copy of ethdev library API's in file "rte_ethdev.c", which get called by rte_eth_dev_set_mtu.
Is our intent, is to call these twice ?
If port->need_reconfig is 1, rte_eth_dev_set_mtu doesn't be called, and
MTU value is saved to port->dev_conf.rxmode.mtu. This dev_conf.rxmode.mtu
will be set to driver in dev_configure(). This check is performed to
prevent dev_configure() failure. That's what I think.
.

Testpmd stores the MTU value and process it during start_port(), which may postpone any possible error in rte_eth_dev_configure(), so I think
it is OK to duplicate the check in app level.

Acked-by: Ferruh Yigit <ferruh.yi...@xilinx.com>

Reply via email to