aboutsummaryrefslogtreecommitdiffstats
path: root/net/sunrpc
diff options
context:
space:
mode:
authorTrond Myklebust <Trond.Myklebust@netapp.com>2012-08-02 13:21:43 -0400
committerTrond Myklebust <Trond.Myklebust@netapp.com>2012-09-28 15:58:42 -0400
commita11a2bf4de5679fa0b63474c7d39bea2dac7d061 (patch)
treed59f027797b629d029596f968ccf65dc7916509f /net/sunrpc
parent13fe4ba1b64c099843c75b4f0633ad30a4526637 (diff)
SUNRPC: Optimise away unnecessary data moves in xdr_align_pages
We only have to call xdr_shrink_pagelen() if the remaining RPC message does not fit in the page buffer length that we supplied to xdr_align_pages(). Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'net/sunrpc')
-rw-r--r--net/sunrpc/xdr.c23
1 files changed, 13 insertions, 10 deletions
diff --git a/net/sunrpc/xdr.c b/net/sunrpc/xdr.c
index fbbd1c475b43..08f50afd5f2a 100644
--- a/net/sunrpc/xdr.c
+++ b/net/sunrpc/xdr.c
@@ -730,21 +730,24 @@ static unsigned int xdr_align_pages(struct xdr_stream *xdr, unsigned int len)
730 730
731 if (xdr->nwords == 0) 731 if (xdr->nwords == 0)
732 return 0; 732 return 0;
733 if (nwords > xdr->nwords) {
734 nwords = xdr->nwords;
735 len = nwords << 2;
736 }
737 /* Realign pages to current pointer position */ 733 /* Realign pages to current pointer position */
738 iov = buf->head; 734 iov = buf->head;
739 if (iov->iov_len > cur) 735 if (iov->iov_len > cur) {
740 xdr_shrink_bufhead(buf, iov->iov_len - cur); 736 xdr_shrink_bufhead(buf, iov->iov_len - cur);
737 xdr->nwords = XDR_QUADLEN(buf->len - cur);
738 }
741 739
742 /* Truncate page data and move it into the tail */ 740 if (nwords > xdr->nwords) {
743 if (buf->page_len > len) 741 nwords = xdr->nwords;
744 xdr_shrink_pagelen(buf, buf->page_len - len); 742 len = nwords << 2;
745 else 743 }
744 if (buf->page_len <= len)
746 len = buf->page_len; 745 len = buf->page_len;
747 xdr->nwords = XDR_QUADLEN(buf->len - cur); 746 else if (nwords < xdr->nwords) {
747 /* Truncate page data and move it into the tail */
748 xdr_shrink_pagelen(buf, buf->page_len - len);
749 xdr->nwords = XDR_QUADLEN(buf->len - cur);
750 }
748 return len; 751 return len;
749} 752}
750 753