From: Chuck Lever Date: Sun, 4 Feb 2024 23:16:50 +0000 (-0500) Subject: svcrdma: Update max_send_sges after QP is created X-Git-Tag: for-linus-6.9~365^2~20 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=4c8c0fa0d32a99c75d732d541c13b3e59555f49f;p=users%2Fdwmw2%2Flinux.git svcrdma: Update max_send_sges after QP is created rdma_create_qp() can modify cap.max_send_sges. Copy the new value to the svcrdma transport so it is bound by the new limit instead of the requested one. Signed-off-by: Chuck Lever --- diff --git a/net/sunrpc/xprtrdma/svc_rdma_transport.c b/net/sunrpc/xprtrdma/svc_rdma_transport.c index 8be0493797cf5..839c0e80e5cd4 100644 --- a/net/sunrpc/xprtrdma/svc_rdma_transport.c +++ b/net/sunrpc/xprtrdma/svc_rdma_transport.c @@ -467,6 +467,7 @@ static struct svc_xprt *svc_rdma_accept(struct svc_xprt *xprt) trace_svcrdma_qp_err(newxprt, ret); goto errout; } + newxprt->sc_max_send_sges = qp_attr.cap.max_send_sge; newxprt->sc_qp = newxprt->sc_cm_id->qp; if (!(dev->attrs.device_cap_flags & IB_DEVICE_MEM_MGT_EXTENSIONS))