Commit 586a0787 authored by Chuck Lever's avatar Chuck Lever Committed by Anna Schumaker

xprtrdma: Clean up rpcrdma_prepare_readch()

Since commit 9ed5af26 ("SUNRPC: Clean up the handling of page
padding in rpc_prepare_reply_pages()") [Dec 2020] the NFS client
passes payload data to the transport with the padding in xdr->pages
instead of in the send buffer's tail kvec. There's no need for the
extra logic to advance the base of the tail kvec because the upper
layer no longer places XDR padding there.
Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
Signed-off-by: default avatarAnna Schumaker <Anna.Schumaker@Netapp.com>
parent c30f259a
...@@ -628,9 +628,8 @@ static bool rpcrdma_prepare_pagelist(struct rpcrdma_req *req, ...@@ -628,9 +628,8 @@ static bool rpcrdma_prepare_pagelist(struct rpcrdma_req *req,
return false; return false;
} }
/* The tail iovec may include an XDR pad for the page list, /* The tail iovec might not reside in the same page as the
* as well as additional content, and may not reside in the * head iovec.
* same page as the head iovec.
*/ */
static bool rpcrdma_prepare_tail_iov(struct rpcrdma_req *req, static bool rpcrdma_prepare_tail_iov(struct rpcrdma_req *req,
struct xdr_buf *xdr, struct xdr_buf *xdr,
...@@ -748,27 +747,19 @@ static bool rpcrdma_prepare_readch(struct rpcrdma_xprt *r_xprt, ...@@ -748,27 +747,19 @@ static bool rpcrdma_prepare_readch(struct rpcrdma_xprt *r_xprt,
struct rpcrdma_req *req, struct rpcrdma_req *req,
struct xdr_buf *xdr) struct xdr_buf *xdr)
{ {
struct kvec *tail = &xdr->tail[0];
if (!rpcrdma_prepare_head_iov(r_xprt, req, xdr->head[0].iov_len)) if (!rpcrdma_prepare_head_iov(r_xprt, req, xdr->head[0].iov_len))
return false; return false;
/* If there is a Read chunk, the page list is being handled /* If there is a Read chunk, the page list is handled
* via explicit RDMA, and thus is skipped here. * via explicit RDMA, and thus is skipped here.
*/ */
/* Do not include the tail if it is only an XDR pad */ if (tail->iov_len) {
if (xdr->tail[0].iov_len > 3) { if (!rpcrdma_prepare_tail_iov(req, xdr,
unsigned int page_base, len; offset_in_page(tail->iov_base),
tail->iov_len))
/* If the content in the page list is an odd length,
* xdr_write_pages() adds a pad at the beginning of
* the tail iovec. Force the tail's non-pad content to
* land at the next XDR position in the Send message.
*/
page_base = offset_in_page(xdr->tail[0].iov_base);
len = xdr->tail[0].iov_len;
page_base += len & 3;
len -= len & 3;
if (!rpcrdma_prepare_tail_iov(req, xdr, page_base, len))
return false; return false;
kref_get(&req->rl_kref); kref_get(&req->rl_kref);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment