Commit 89aa9e26 authored by Rafi Wiener's avatar Rafi Wiener Committed by Greg Kroah-Hartman

RDMA/mlx5: Clear old rate limit when closing QP

[ Upstream commit c8973df2 ]

Before QP is closed it changes to ERROR state, when this happens
the QP was left with old rate limit that was already removed from
the table.

Fixes: 7d29f349 ("IB/mlx5: Properly adjust rate limit on QP state transitions")
Signed-off-by: default avatarRafi Wiener <rafiw@mellanox.com>
Signed-off-by: default avatarOleg Kuporosov <olegk@mellanox.com>
Signed-off-by: default avatarLeon Romanovsky <leonro@mellanox.com>
Link: https://lore.kernel.org/r/20191002120243.16971-1-leon@kernel.orgSigned-off-by: default avatarDoug Ledford <dledford@redhat.com>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
parent d6706b2e
...@@ -2828,10 +2828,12 @@ static int modify_raw_packet_qp_sq(struct mlx5_core_dev *dev, ...@@ -2828,10 +2828,12 @@ static int modify_raw_packet_qp_sq(struct mlx5_core_dev *dev,
} }
/* Only remove the old rate after new rate was set */ /* Only remove the old rate after new rate was set */
if ((old_rl.rate && if ((old_rl.rate && !mlx5_rl_are_equal(&old_rl, &new_rl)) ||
!mlx5_rl_are_equal(&old_rl, &new_rl)) || (new_state != MLX5_SQC_STATE_RDY)) {
(new_state != MLX5_SQC_STATE_RDY))
mlx5_rl_remove_rate(dev, &old_rl); mlx5_rl_remove_rate(dev, &old_rl);
if (new_state != MLX5_SQC_STATE_RDY)
memset(&new_rl, 0, sizeof(new_rl));
}
ibqp->rl = new_rl; ibqp->rl = new_rl;
sq->state = new_state; sq->state = new_state;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment