There does not exist an API for driver to get/set the hash key length from/to the firmware.
--- #define NFP_NET_CFG_RSS_KEY_SZ 0x28 #define NFP_NET_CFG_MACADDR 0x0024 --- The original logic try to use the 'NFP_NET_CFG_RSS_KEY_SZ' as the inexistent API, read from this address will get wrong hash key length and write to this address will overwrite the MAC address unexpected, which will cause very strange problem. Fixes: 934e4c60fbff ("nfp: add RSS") Cc: sta...@dpdk.org Signed-off-by: Chaoyong He <chaoyong...@corigine.com> Reviewed-by: Peng Zhang <peng.zh...@corigine.com> --- drivers/net/nfp/nfp_net_common.c | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/drivers/net/nfp/nfp_net_common.c b/drivers/net/nfp/nfp_net_common.c index aaa515bac2..62550e4cad 100644 --- a/drivers/net/nfp/nfp_net_common.c +++ b/drivers/net/nfp/nfp_net_common.c @@ -1966,9 +1966,6 @@ nfp_net_rss_hash_write(struct rte_eth_dev *dev, /* Configuring where to apply the RSS hash */ nn_cfg_writel(hw, NFP_NET_CFG_RSS_CTRL, cfg_rss_ctrl); - /* Writing the key size */ - nn_cfg_writeb(hw, NFP_NET_CFG_RSS_KEY_SZ, rss_conf->rss_key_len); - return 0; } @@ -2059,7 +2056,7 @@ nfp_net_rss_hash_conf_get(struct rte_eth_dev *dev, rss_conf->rss_hf = rss_hf; /* Reading the key size */ - rss_conf->rss_key_len = nn_cfg_readl(hw, NFP_NET_CFG_RSS_KEY_SZ); + rss_conf->rss_key_len = NFP_NET_CFG_RSS_KEY_SZ; /* Reading the key byte a byte */ for (i = 0; i < rss_conf->rss_key_len; i++) { -- 2.43.5