net/mlx5: fix Tx recovery
authorRaja Zidane <rzidane@nvidia.com>
Wed, 18 May 2022 09:42:32 +0000 (12:42 +0300)
committerRaslan Darawsheh <rasland@nvidia.com>
Wed, 1 Jun 2022 07:49:42 +0000 (09:49 +0200)
When an error occurs in Tx, and it is moved to ERROR state, it
is not recoverable, during recovery it's state cannot be modified
to INIT. to modify state from RESET to INIT, the port must be
passed in modify attributes, and in case of ERROR to READY
modification path, it was not provided.

Provide port number when changing state from RESET to INIT.

Fixes: 3a87b964edd3 ("net/mlx5: create Tx queues with DevX")
Cc: stable@dpdk.org
Signed-off-by: Raja Zidane <rzidane@nvidia.com>
Acked-by: Matan Azrad <matan@nvidia.com>
Acked-by: Dmitry Kozlyuk <dkozlyuk@nvidia.com>
drivers/net/mlx5/linux/mlx5_verbs.c

index b6ba21c..67a7bec 100644 (file)
@@ -94,7 +94,6 @@ mlx5_ibv_modify_qp(struct mlx5_txq_obj *obj, enum mlx5_txq_modify_type type,
                .qp_state = IBV_QPS_RESET,
                .port_num = dev_port,
        };
-       int attr_mask = (IBV_QP_STATE | IBV_QP_PORT);
        int ret;
 
        if (type != MLX5_TXQ_MOD_RST2RDY) {
@@ -108,10 +107,8 @@ mlx5_ibv_modify_qp(struct mlx5_txq_obj *obj, enum mlx5_txq_modify_type type,
                if (type == MLX5_TXQ_MOD_RDY2RST)
                        return 0;
        }
-       if (type == MLX5_TXQ_MOD_ERR2RDY)
-               attr_mask = IBV_QP_STATE;
        mod.qp_state = IBV_QPS_INIT;
-       ret = mlx5_glue->modify_qp(obj->qp, &mod, attr_mask);
+       ret = mlx5_glue->modify_qp(obj->qp, &mod, IBV_QP_STATE | IBV_QP_PORT);
        if (ret) {
                DRV_LOG(ERR, "Cannot change Tx QP state to INIT %s",
                        strerror(errno));