From: Chuck Lever Date: Fri, 20 Oct 2017 14:47:39 +0000 (-0400) Subject: xprtrdma: Clean up SGE accounting in rpcrdma_prepare_msg_sges() X-Git-Tag: v4.15-rc1~60^2~49 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=ad99f0530710af72b5bbecda9e770c736e92b328;p=users%2Fdwmw2%2Flinux.git xprtrdma: Clean up SGE accounting in rpcrdma_prepare_msg_sges() Clean up. rpcrdma_prepare_hdr_sge() sets num_sge to one, then rpcrdma_prepare_msg_sges() sets num_sge again to the count of SGEs it added, plus one for the header SGE just mapped in rpcrdma_prepare_hdr_sge(). This is confusing, and nails in an assumption about when these functions are called. Instead, maintain a running count that both functions can update with just the number of SGEs they have added to the SGE array. Signed-off-by: Chuck Lever Signed-off-by: Anna Schumaker --- diff --git a/net/sunrpc/xprtrdma/rpc_rdma.c b/net/sunrpc/xprtrdma/rpc_rdma.c index b8818c09a621f..3c9255824d94f 100644 --- a/net/sunrpc/xprtrdma/rpc_rdma.c +++ b/net/sunrpc/xprtrdma/rpc_rdma.c @@ -637,7 +637,7 @@ map_tail: } out: - req->rl_send_wr.num_sge = sge_no + 1; + req->rl_send_wr.num_sge += sge_no; return true; out_mapping_overflow: