|
@@ -2429,7 +2429,7 @@ static int modify_raw_packet_qp_rq(struct mlx5_ib_dev *dev,
|
|
|
if (raw_qp_param->set_mask & MLX5_RAW_QP_MOD_SET_RQ_Q_CTR_ID) {
|
|
|
if (MLX5_CAP_GEN(dev->mdev, modify_rq_counter_set_id)) {
|
|
|
MLX5_SET64(modify_rq_in, in, modify_bitmask,
|
|
|
- MLX5_MODIFY_RQ_IN_MODIFY_BITMASK_MODIFY_RQ_COUNTER_SET_ID);
|
|
|
+ MLX5_MODIFY_RQ_IN_MODIFY_BITMASK_RQ_COUNTER_SET_ID);
|
|
|
MLX5_SET(rqc, rqc, counter_set_id, raw_qp_param->rq_q_ctr_id);
|
|
|
} else
|
|
|
pr_info_once("%s: RAW PACKET QP counters are not supported on current FW\n",
|
|
@@ -4910,6 +4910,16 @@ int mlx5_ib_modify_wq(struct ib_wq *wq, struct ib_wq_attr *wq_attr,
|
|
|
MLX5_SET(modify_rq_in, in, rq_state, curr_wq_state);
|
|
|
MLX5_SET(rqc, rqc, state, wq_state);
|
|
|
|
|
|
+ if (curr_wq_state == IB_WQS_RESET && wq_state == IB_WQS_RDY) {
|
|
|
+ if (MLX5_CAP_GEN(dev->mdev, modify_rq_counter_set_id)) {
|
|
|
+ MLX5_SET64(modify_rq_in, in, modify_bitmask,
|
|
|
+ MLX5_MODIFY_RQ_IN_MODIFY_BITMASK_RQ_COUNTER_SET_ID);
|
|
|
+ MLX5_SET(rqc, rqc, counter_set_id, dev->port->q_cnts.set_id);
|
|
|
+ } else
|
|
|
+ pr_info_once("%s: Receive WQ counters are not supported on current FW\n",
|
|
|
+ dev->ib_dev.name);
|
|
|
+ }
|
|
|
+
|
|
|
err = mlx5_core_modify_rq(dev->mdev, rwq->core_qp.qpn, in, inlen);
|
|
|
kvfree(in);
|
|
|
if (!err)
|