Commit f67da137 authored by Peng Tao's avatar Peng Tao Committed by Sasha Levin

nfs: fix pg_test page count calculation

[ Upstream commit 048883e0 ]

We really want sizeof(struct page *) instead. Otherwise we limit
maximum IO size to 64 pages rather than 512 pages on a 64bit system.

Fixes 2e11f829(nfs: cap request size to fit a kmalloced page array).

Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: default avatarPeng Tao <tao.peng@primarydata.com>
Fixes: 2e11f829 ("nfs: cap request size to fit a kmalloced page array")
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@primarydata.com>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent 8bf6c729
...@@ -486,7 +486,7 @@ size_t nfs_generic_pg_test(struct nfs_pageio_descriptor *desc, ...@@ -486,7 +486,7 @@ size_t nfs_generic_pg_test(struct nfs_pageio_descriptor *desc,
* for it without upsetting the slab allocator. * for it without upsetting the slab allocator.
*/ */
if (((desc->pg_count + req->wb_bytes) >> PAGE_SHIFT) * if (((desc->pg_count + req->wb_bytes) >> PAGE_SHIFT) *
sizeof(struct page) > PAGE_SIZE) sizeof(struct page *) > PAGE_SIZE)
return 0; return 0;
return min(desc->pg_bsize - desc->pg_count, (size_t)req->wb_bytes); return min(desc->pg_bsize - desc->pg_count, (size_t)req->wb_bytes);
......
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