The memory size of bandwidth config parameters is not set correctly in
memory copy process, which leads to the wrong values. This patch fixed
the size to the correct value.

Fixes: 3a6bfc37eaf4 ("net/ice: support QoS config VF bandwidth in DCF")

Signed-off-by: Ting Xu <ting...@intel.com>
---
 drivers/net/ice/ice_dcf_sched.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/net/ice/ice_dcf_sched.c b/drivers/net/ice/ice_dcf_sched.c
index 090988c6e1..dcf2723494 100644
--- a/drivers/net/ice/ice_dcf_sched.c
+++ b/drivers/net/ice/ice_dcf_sched.c
@@ -833,7 +833,7 @@ static int ice_dcf_hierarchy_commit(struct rte_eth_dev *dev,
                        goto fail_clear;
                }
                /* store the bandwidth information for replay */
-               ice_memcpy(hw->qos_bw_cfg[vf_id], vf_bw, sizeof(*vf_bw),
+               ice_memcpy(hw->qos_bw_cfg[vf_id], vf_bw, size,
                           ICE_NONDMA_TO_NONDMA);
                ice_memset(vf_bw, 0, size, ICE_NONDMA_MEM);
        }
@@ -859,7 +859,7 @@ static int ice_dcf_hierarchy_commit(struct rte_eth_dev *dev,
                ret_val = ICE_ERR_NO_MEMORY;
                goto fail_clear;
        }
-       ice_memcpy(hw->qos_bw_cfg[ICE_DCF_VFID], tc_bw, sizeof(*tc_bw),
+       ice_memcpy(hw->qos_bw_cfg[ICE_DCF_VFID], tc_bw, size,
                   ICE_NONDMA_TO_NONDMA);
 
        hw->tm_conf.committed = true;
-- 
2.17.1

Reply via email to