RDMA/rtrs: Move sq_wr_avail to rtrs_con
authorJack Wang <jinpu.wang@ionos.com>
Mon, 12 Jul 2021 06:07:50 +0000 (08:07 +0200)
committerJason Gunthorpe <jgg@nvidia.com>
Thu, 15 Jul 2021 17:24:14 +0000 (14:24 -0300)
In order to account HB for sq_wr_avail properly, move sq_wr_avail from
rtrs_srv_con to rtrs_con.

Although rtrs-clt do not care sq_wr_avail, but still init it to
max_send_wr.

Fixes: b38041d50add ("RDMA/rtrs: Do not signal for heatbeat")
Link: https://lore.kernel.org/r/20210712060750.16494-7-jinpu.wang@ionos.com
Signed-off-by: Jack Wang <jinpu.wang@ionos.com>
Reviewed-by: Aleksei Marov <aleksei.marov@ionos.com>
Reviewed-by: Gioh Kim <gi-oh.kim@ionos.com>
Reviewed-by: Md Haris Iqbal <haris.iqbal@ionos.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
drivers/infiniband/ulp/rtrs/rtrs-clt.c
drivers/infiniband/ulp/rtrs/rtrs-pri.h
drivers/infiniband/ulp/rtrs/rtrs-srv.c
drivers/infiniband/ulp/rtrs/rtrs-srv.h
drivers/infiniband/ulp/rtrs/rtrs.c

index f023676e05e4d7e576632661ababb652866e61f7..ece3205531b8ebecacd6a3488436be2afc71cdbe 100644 (file)
@@ -1680,6 +1680,7 @@ static int create_con_cq_qp(struct rtrs_clt_con *con)
                              sess->queue_depth * 3 + 1);
                max_send_sge = 2;
        }
+       atomic_set(&con->c.sq_wr_avail, max_send_wr);
        cq_num = max_send_wr + max_recv_wr;
        /* alloc iu to recv new rkey reply when server reports flags set */
        if (sess->flags & RTRS_MSG_NEW_RKEY_F || con->c.cid == 0) {
index 76581ebaed1d3e20599f8a2bdc302e06fc2e56e6..d12ddfa5074792125141228502ddef7c0430a16c 100644 (file)
@@ -97,6 +97,7 @@ struct rtrs_con {
        unsigned int            cid;
        int                     nr_cqe;
        atomic_t                wr_cnt;
+       atomic_t                sq_wr_avail;
 };
 
 struct rtrs_sess {
index 44ed15f388968113e3e59553f0b76a8fdd48acca..cd9a4ccf4c28961b3164c965253f0c6721e5875a 100644 (file)
@@ -507,11 +507,11 @@ bool rtrs_srv_resp_rdma(struct rtrs_srv_op *id, int status)
                ib_update_fast_reg_key(mr->mr, ib_inc_rkey(mr->mr->rkey));
        }
        if (unlikely(atomic_sub_return(1,
-                                      &con->sq_wr_avail) < 0)) {
+                                      &con->c.sq_wr_avail) < 0)) {
                rtrs_err(s, "IB send queue full: sess=%s cid=%d\n",
                         kobject_name(&sess->kobj),
                         con->c.cid);
-               atomic_add(1, &con->sq_wr_avail);
+               atomic_add(1, &con->c.sq_wr_avail);
                spin_lock(&con->rsp_wr_wait_lock);
                list_add_tail(&id->wait_list, &con->rsp_wr_wait_list);
                spin_unlock(&con->rsp_wr_wait_lock);
@@ -1268,7 +1268,7 @@ static void rtrs_srv_rdma_done(struct ib_cq *cq, struct ib_wc *wc)
                 * post_send() RDMA write completions of IO reqs (read/write)
                 * and hb.
                 */
-               atomic_add(s->signal_interval, &con->sq_wr_avail);
+               atomic_add(s->signal_interval, &con->c.sq_wr_avail);
 
                if (unlikely(!list_empty_careful(&con->rsp_wr_wait_list)))
                        rtrs_rdma_process_wr_wait_list(con);
@@ -1680,7 +1680,7 @@ static int create_con(struct rtrs_srv_sess *sess,
                 */
        }
        cq_num = max_send_wr + max_recv_wr;
-       atomic_set(&con->sq_wr_avail, max_send_wr);
+       atomic_set(&con->c.sq_wr_avail, max_send_wr);
        cq_vector = rtrs_srv_get_next_cq_vector(sess);
 
        /* TODO: SOFTIRQ can be faster, but be careful with softirq context */
index 6785c3b6363e6afeff8d05d662e4029b267bed3b..e81774f5acd33662e05ef6118df3446a0dc378a6 100644 (file)
@@ -42,7 +42,6 @@ struct rtrs_srv_stats {
 
 struct rtrs_srv_con {
        struct rtrs_con         c;
-       atomic_t                sq_wr_avail;
        struct list_head        rsp_wr_wait_list;
        spinlock_t              rsp_wr_wait_lock;
 };
index b56dc5b82db08d2746e8c3c5fb21ac66ee183924..ca542e477d3848353f8c4b94e2170878ff9745c3 100644 (file)
@@ -191,6 +191,7 @@ static int rtrs_post_rdma_write_imm_empty(struct rtrs_con *con,
        struct rtrs_sess *sess = con->sess;
        enum ib_send_flags sflags;
 
+       atomic_dec_if_positive(&con->sq_wr_avail);
        sflags = (atomic_inc_return(&con->wr_cnt) % sess->signal_interval) ?
                0 : IB_SEND_SIGNALED;