Rdma-core exposes E-Switch Manager vport metadata
for matching in flow rules.
Use that metadata when available.

Signed-off-by: Rongwei Liu <rongw...@nvidia.com>
Acked-by: Dariusz Sosnowski <dsosnow...@nvidia.com>
---
 drivers/net/mlx5/mlx5_flow_dv.c | 18 +++++++++++++++---
 1 file changed, 15 insertions(+), 3 deletions(-)

diff --git a/drivers/net/mlx5/mlx5_flow_dv.c b/drivers/net/mlx5/mlx5_flow_dv.c
index c217634d9b..d555a9cdcb 100644
--- a/drivers/net/mlx5/mlx5_flow_dv.c
+++ b/drivers/net/mlx5/mlx5_flow_dv.c
@@ -10885,9 +10885,21 @@ flow_dv_translate_item_port_id(struct rte_eth_dev 
*dev, void *key,
 
        MLX5_ASSERT(wks);
        if (pid_v && pid_v->id == MLX5_PORT_ESW_MGR) {
-               flow_dv_translate_item_source_vport(key,
-                               key_type & MLX5_SET_MATCHER_V ?
-                               mlx5_flow_get_esw_manager_vport_id(dev) : 
0xffff);
+               priv = dev->data->dev_private;
+               if (priv->sh->dev_cap.esw_info.regc_mask) {
+                       if (key_type & MLX5_SET_MATCHER_M) {
+                               vport_meta = 
priv->sh->dev_cap.esw_info.regc_mask;
+                       } else {
+                               vport_meta = 
priv->sh->dev_cap.esw_info.regc_value;
+                               wks->vport_meta_tag = vport_meta;
+                       }
+                       flow_dv_translate_item_meta_vport(key, vport_meta,
+                                                         
priv->sh->dev_cap.esw_info.regc_mask);
+               } else {
+                       flow_dv_translate_item_source_vport(key,
+                                       key_type & MLX5_SET_MATCHER_V ?
+                                       mlx5_flow_get_esw_manager_vport_id(dev) 
: 0xffff);
+               }
                return 0;
        }
        mask = pid_m ? pid_m->id : 0xffff;
-- 
2.27.0

Reply via email to