From: Vamsi Attunuru <vattun...@marvell.com>

VF index needs to be checked against maxvf count
before incrementing it for preparing pf_func.

Fixes: 520270d518 ("net/octeontx2: support PF and VF action")

Signed-off-by: Vamsi Attunuru <vattun...@marvell.com>
---
 drivers/net/octeontx2/otx2_flow_parse.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/net/octeontx2/otx2_flow_parse.c 
b/drivers/net/octeontx2/otx2_flow_parse.c
index 2cba0a4..6b2617b 100644
--- a/drivers/net/octeontx2/otx2_flow_parse.c
+++ b/drivers/net/octeontx2/otx2_flow_parse.c
@@ -833,14 +833,14 @@ otx2_flow_parse_actions(struct rte_eth_dev *dev,
                                actions->conf;
                        req_act |= OTX2_FLOW_ACT_VF;
                        if (vf_act->original == 0) {
-                               vf_id = (vf_act->id & RVU_PFVF_FUNC_MASK) + 1;
+                               vf_id = vf_act->id & RVU_PFVF_FUNC_MASK;
                                if (vf_id  >= hw->maxvf) {
                                        errmsg = "invalid vf specified";
                                        errcode = EINVAL;
                                        goto err_exit;
                                }
                                pf_func &= (0xfc00);
-                               pf_func = (pf_func | vf_id);
+                               pf_func = (pf_func | (vf_id + 1));
                        }
                        break;
 
-- 
2.8.4

Reply via email to