On 10/11/2023 10:27 AM, Jie Hai wrote:
> A new field 'algorithm' has been added to rss_conf, check it
> in case of ignoring unsupported values.
> 
> Signed-off-by: Jie Hai <haij...@huawei.com>
> ---
>  drivers/net/cnxk/cnxk_ethdev.c     | 5 +++++
>  drivers/net/cnxk/cnxk_ethdev_ops.c | 3 +++
>  2 files changed, 8 insertions(+)
> 
> diff --git a/drivers/net/cnxk/cnxk_ethdev.c b/drivers/net/cnxk/cnxk_ethdev.c
> index 01b707b6c4ac..dc150de745df 100644
> --- a/drivers/net/cnxk/cnxk_ethdev.c
> +++ b/drivers/net/cnxk/cnxk_ethdev.c
> @@ -976,6 +976,10 @@ nix_rss_default_setup(struct cnxk_eth_dev *dev)
>       if (rss_hash_level)
>               rss_hash_level -= 1;
>  
> +     if (eth_dev->data->dev_conf.rx_adv_conf.rss_conf.algorithm !=
> +         RTE_ETH_HASH_FUNCTION_DEFAULT)
> +             return -EINVAL;
> +
>       flowkey_cfg = cnxk_rss_ethdev_to_nix(dev, rss_hf, rss_hash_level);
>       return roc_nix_rss_default_setup(&dev->nix, flowkey_cfg);
>  }
> @@ -1373,6 +1377,7 @@ cnxk_nix_configure(struct rte_eth_dev *eth_dev)
>       }
>  
>       /* Configure RSS */
> +
>

Looks like unintended change.

>       rc = nix_rss_default_setup(dev);
>       if (rc) {
>               plt_err("Failed to configure rss rc=%d", rc);
> diff --git a/drivers/net/cnxk/cnxk_ethdev_ops.c 
> b/drivers/net/cnxk/cnxk_ethdev_ops.c
> index 3ade8eed3626..b6cba99cbb7f 100644
> --- a/drivers/net/cnxk/cnxk_ethdev_ops.c
> +++ b/drivers/net/cnxk/cnxk_ethdev_ops.c
> @@ -1054,6 +1054,9 @@ cnxk_nix_rss_hash_update(struct rte_eth_dev *eth_dev,
>       int rc = -EINVAL;
>       uint8_t alg_idx;
>  
> +     if (rss_conf->algorithm != RTE_ETH_HASH_FUNCTION_DEFAULT)
> +             goto fail;
> +
>       if (rss_conf->rss_key && rss_conf->rss_key_len != ROC_NIX_RSS_KEY_LEN) {
>               plt_err("Hash key size mismatch %d vs %d",
>                       rss_conf->rss_key_len, ROC_NIX_RSS_KEY_LEN);

Reply via email to