Commit 048883e0 authored by Peng Tao's avatar Peng Tao Committed by Trond Myklebust

nfs: fix pg_test page count calculation

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>
parent a41cbe86
...@@ -508,7 +508,7 @@ size_t nfs_generic_pg_test(struct nfs_pageio_descriptor *desc, ...@@ -508,7 +508,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 (((mirror->pg_count + req->wb_bytes) >> PAGE_SHIFT) * if (((mirror->pg_count + req->wb_bytes) >> PAGE_SHIFT) *
sizeof(struct page) > PAGE_SIZE) sizeof(struct page *) > PAGE_SIZE)
return 0; return 0;
return min(mirror->pg_bsize - mirror->pg_count, (size_t)req->wb_bytes); return min(mirror->pg_bsize - mirror->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