From: Yishai Hadas <yish...@mellanox.com>

Add support to set a destination that is a flow table, this can come
from the DEVX destination.

Signed-off-by: Yishai Hadas <yish...@mellanox.com>
Signed-off-by: Leon Romanovsky <leo...@mellanox.com>
---
 drivers/infiniband/hw/mlx5/main.c | 13 ++++++++-----
 1 file changed, 8 insertions(+), 5 deletions(-)

diff --git a/drivers/infiniband/hw/mlx5/main.c 
b/drivers/infiniband/hw/mlx5/main.c
index 614d0f69886e..68c574d8a0ee 100644
--- a/drivers/infiniband/hw/mlx5/main.c
+++ b/drivers/infiniband/hw/mlx5/main.c
@@ -3792,9 +3792,6 @@ mlx5_ib_raw_fs_rule_add(struct mlx5_ib_dev *dev,
        if (fs_matcher->priority > MLX5_IB_FLOW_LAST_PRIO)
                return ERR_PTR(-ENOMEM);
 
-       if (dest_type != MLX5_FLOW_DESTINATION_TYPE_TIR)
-               return ERR_PTR(-ENOTSUPP);
-
        dst = kzalloc(sizeof(*dst), GFP_KERNEL);
        if (!dst)
                return ERR_PTR(-ENOMEM);
@@ -3808,8 +3805,14 @@ mlx5_ib_raw_fs_rule_add(struct mlx5_ib_dev *dev,
                goto unlock;
        }
 
-       dst->type = dest_type;
-       dst->tir_num = dest_id;
+       if (dest_type == MLX5_FLOW_DESTINATION_TYPE_TIR) {
+               dst->type = dest_type;
+               dst->tir_num = dest_id;
+       } else {
+               dst->type = MLX5_FLOW_DESTINATION_TYPE_FLOW_TABLE_NUM;
+               dst->ft_num = dest_id;
+       }
+
        handler = _create_raw_flow_rule(dev, ft_prio, dst, fs_matcher, cmd_in,
                                        inlen);
 
-- 
2.14.4

Reply via email to