NFSD: Batch release pages during splice read
[ Upstream commit 496d83cf0f2fa70cfe256c2499e2d3523d3868f3 ] Large splice reads call put_page() repeatedly. put_page() is relatively expensive to call, so replace it with the new svc_rqst_replace_page() helper to help amortize that cost. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Reviewed-by: NeilBrown <neilb@suse.de> Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
a4f616afb4
commit
86df138e8d
@@ -856,15 +856,10 @@ nfsd_splice_actor(struct pipe_inode_info *pipe, struct pipe_buffer *buf,
|
||||
struct page *page = buf->page;
|
||||
|
||||
if (rqstp->rq_res.page_len == 0) {
|
||||
get_page(page);
|
||||
put_page(*rqstp->rq_next_page);
|
||||
*(rqstp->rq_next_page++) = page;
|
||||
svc_rqst_replace_page(rqstp, page);
|
||||
rqstp->rq_res.page_base = buf->offset;
|
||||
} else if (page != pp[-1]) {
|
||||
get_page(page);
|
||||
if (*rqstp->rq_next_page)
|
||||
put_page(*rqstp->rq_next_page);
|
||||
*(rqstp->rq_next_page++) = page;
|
||||
svc_rqst_replace_page(rqstp, page);
|
||||
}
|
||||
rqstp->rq_res.page_len += sd->len;
|
||||
|
||||
|
Reference in New Issue
Block a user