On 8/27/2021 9:17 AM, Jie Wang wrote:
> The driver may change offloads info into dev->data->dev_conf
> in dev_configure which may cause port->dev_conf and port->rx_conf
> contain outdated values.
> 
> This patch updates the offloads info if it changes to fix this issue.
> 
> Fixes: ce8d561418d4 ("app/testpmd: add port configuration settings")
> 
> Signed-off-by: Jie Wang <jie1x.w...@intel.com>
> ---
>  app/test-pmd/testpmd.c | 34 ++++++++++++++++++++++++++++++++++
>  app/test-pmd/testpmd.h |  2 ++
>  app/test-pmd/util.c    | 15 +++++++++++++++
>  3 files changed, 51 insertions(+)
> 
> diff --git a/app/test-pmd/testpmd.c b/app/test-pmd/testpmd.c
> index 6cbe9ba3c8..bd67291160 100644
> --- a/app/test-pmd/testpmd.c
> +++ b/app/test-pmd/testpmd.c
> @@ -2461,6 +2461,9 @@ start_port(portid_t pid)
>               }
>  
>               if (port->need_reconfig > 0) {
> +                     struct rte_eth_conf dev_conf_info;
> +                     int k;
> +
>                       port->need_reconfig = 0;
>  
>                       if (flow_isolate_all) {
> @@ -2498,6 +2501,37 @@ start_port(portid_t pid)
>                               port->need_reconfig = 1;
>                               return -1;
>                       }
> +                     /* get rte_eth_conf info */
> +                     if (0 !=
> +                             eth_dev_conf_info_get_print_err(pi,
> +                                                     &dev_conf_info)) {
> +                             fprintf(stderr,
> +                                     "port %d can not get device 
> configuration info\n",
> +                                     pi);
> +                             return -1;
> +                     }
> +                     /* Apply Rx offloads configuration */
> +                     if (dev_conf_info.rxmode.offloads !=
> +                             port->dev_conf.rxmode.offloads) {
> +                             port->dev_conf.rxmode.offloads =
> +                                     dev_conf_info.rxmode.offloads;
> +                             for (k = 0;
> +                                  k < port->dev_info.max_rx_queues;
> +                                  k++)
> +                                     port->rx_conf[k].offloads =
> +                                             dev_conf_info.rxmode.offloads;
> +                     }
> +                     /* Apply Tx offloads configuration */
> +                     if (dev_conf_info.txmode.offloads !=
> +                             port->dev_conf.txmode.offloads) {
> +                             port->dev_conf.txmode.offloads =
> +                                     dev_conf_info.txmode.offloads;
> +                             for (k = 0;
> +                                  k < port->dev_info.max_tx_queues;
> +                                  k++)
> +                                     port->tx_conf[k].offloads =
> +                                             dev_conf_info.txmode.offloads;
> +                     }
>               }

Above implementation gets the configuration from device and applies it to the
testpmd configuration.

Instead, what about a long level target to get rid of testpmd specific copy of
the configuration and rely and the config provided by devices. @Xiaoyun, what do
you think, does this make sense?

So instead of above code, update where RSS hash offload information printed to
use device retrieved config instead of testpmd config, will it work?

Reply via email to