Current code just generated 40 bytes standard rss
hash key of ice driver. The extended 12 bytes
were filled by hardware and were invalid for users.
This patch generate 52 bytes rss hash key for ice
driver just as other drivers.

Fixes: 50370662b727 ("net/ice: support device and queue ops")
Fixes: 20d6a017e148 ("net/ice: fix build with GCC 12")

Signed-off-by: Yuying Zhang <yuying.zh...@intel.com>
---
 drivers/net/ice/ice_ethdev.c | 8 ++++++--
 1 file changed, 6 insertions(+), 2 deletions(-)

diff --git a/drivers/net/ice/ice_ethdev.c b/drivers/net/ice/ice_ethdev.c
index 949b13324f..4bad39c2c1 100644
--- a/drivers/net/ice/ice_ethdev.c
+++ b/drivers/net/ice/ice_ethdev.c
@@ -3350,7 +3350,8 @@ static int ice_init_rss(struct ice_pf *pf)
 
        rss_conf = &dev_data->dev_conf.rx_adv_conf.rss_conf;
        nb_q = dev_data->nb_rx_queues;
-       vsi->rss_key_size = ICE_AQC_GET_SET_RSS_KEY_DATA_RSS_KEY_SIZE;
+       vsi->rss_key_size = ICE_AQC_GET_SET_RSS_KEY_DATA_RSS_KEY_SIZE +
+                           ICE_AQC_GET_SET_RSS_KEY_DATA_HASH_KEY_SIZE;
        vsi->rss_lut_size = pf->hash_lut_size;
 
        if (nb_q == 0) {
@@ -3391,7 +3392,10 @@ static int ice_init_rss(struct ice_pf *pf)
                                   vsi->rss_key_size));
 
        rte_memcpy(key.standard_rss_key, vsi->rss_key,
-               RTE_MIN(sizeof(key.standard_rss_key), vsi->rss_key_size));
+               ICE_AQC_GET_SET_RSS_KEY_DATA_RSS_KEY_SIZE);
+       rte_memcpy(key.extended_hash_key,
+               &vsi->rss_key[ICE_AQC_GET_SET_RSS_KEY_DATA_RSS_KEY_SIZE],
+               ICE_AQC_GET_SET_RSS_KEY_DATA_HASH_KEY_SIZE);
        ret = ice_aq_set_rss_key(hw, vsi->idx, &key);
        if (ret)
                goto out;
-- 
2.25.1

Reply via email to