RDMA/rxe: Compute the maximum sges and inline size based on the WQE size
authorRao Shoaib <rao.shoaib@oracle.com>
Tue, 14 Jan 2020 00:41:20 +0000 (16:41 -0800)
committerJason Gunthorpe <jgg@mellanox.com>
Wed, 15 Jan 2020 20:36:41 +0000 (16:36 -0400)
The SGE buffer size and max_inline data should be derived from the size of
the WQE. Each value individually sets the WQE size, so compute the actual
sizes based on the actual WQE size and configure the QP with the maximums.

Also fix the missing return of the actual maximum capability to the caller.

Link: https://lore.kernel.org/r/1578962480-17814-3-git-send-email-rao.shoaib@oracle.com
Signed-off-by: Rao Shoaib <rao.shoaib@oracle.com>
Reviewed-by: Jason Gunthorpe <jgg@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/sw/rxe/rxe_qp.c

index e2c6d1cedf416b6c5cda7136bfcf500fd12badfa..ec21f616ac98d1c31ab5273bb18a8957b3b1c8f8 100644 (file)
@@ -237,19 +237,17 @@ static int rxe_qp_init_req(struct rxe_dev *rxe, struct rxe_qp *qp,
         */
        qp->src_port = RXE_ROCE_V2_SPORT +
                (hash_32_generic(qp_num(qp), 14) & 0x3fff);
-
        qp->sq.max_wr           = init->cap.max_send_wr;
-       qp->sq.max_sge          = init->cap.max_send_sge;
-       qp->sq.max_inline       = init->cap.max_inline_data;
 
-       wqe_size = max_t(int, sizeof(struct rxe_send_wqe) +
-                        qp->sq.max_sge * sizeof(struct ib_sge),
-                        sizeof(struct rxe_send_wqe) +
-                        qp->sq.max_inline);
+       /* These caps are limited by rxe_qp_chk_cap() done by the caller */
+       wqe_size = max_t(int, init->cap.max_send_sge * sizeof(struct ib_sge),
+                        init->cap.max_inline_data);
+       qp->sq.max_sge = init->cap.max_send_sge =
+               wqe_size / sizeof(struct ib_sge);
+       qp->sq.max_inline = init->cap.max_inline_data = wqe_size;
+       wqe_size += sizeof(struct rxe_send_wqe);
 
-       qp->sq.queue = rxe_queue_init(rxe,
-                                     &qp->sq.max_wr,
-                                     wqe_size);
+       qp->sq.queue = rxe_queue_init(rxe, &qp->sq.max_wr, wqe_size);
        if (!qp->sq.queue)
                return -ENOMEM;