nfs41: .init_read and .init_write can be called with valid pg_lseg

With pgio refactoring in v3.15, .init_read and .init_write can be
called with valid pgio->pg_lseg. file layout was fixed at that time
by commit c6194271f (pnfs: filelayout: support non page aligned
layouts). But the generic helper still needs to be fixed.

Cc: stable@vger.kernel.org # 3.15+
Signed-off-by: Peng Tao <tao.peng@primarydata.com>
This commit is contained in:
Peng Tao 2015-01-24 22:14:52 +08:00 committed by Tom Haynes
parent 8f9cdcb26b
commit cb5d04bc39

View File

@ -1711,19 +1711,19 @@ pnfs_generic_pg_init_read(struct nfs_pageio_descriptor *pgio, struct nfs_page *r
{ {
u64 rd_size = req->wb_bytes; u64 rd_size = req->wb_bytes;
WARN_ON_ONCE(pgio->pg_lseg != NULL); if (pgio->pg_lseg == NULL) {
if (pgio->pg_dreq == NULL)
rd_size = i_size_read(pgio->pg_inode) - req_offset(req);
else
rd_size = nfs_dreq_bytes_left(pgio->pg_dreq);
if (pgio->pg_dreq == NULL) pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode,
rd_size = i_size_read(pgio->pg_inode) - req_offset(req); req->wb_context,
else req_offset(req),
rd_size = nfs_dreq_bytes_left(pgio->pg_dreq); rd_size,
IOMODE_READ,
pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, GFP_KERNEL);
req->wb_context, }
req_offset(req),
rd_size,
IOMODE_READ,
GFP_KERNEL);
/* If no lseg, fall back to read through mds */ /* If no lseg, fall back to read through mds */
if (pgio->pg_lseg == NULL) if (pgio->pg_lseg == NULL)
nfs_pageio_reset_read_mds(pgio); nfs_pageio_reset_read_mds(pgio);
@ -1735,14 +1735,13 @@ void
pnfs_generic_pg_init_write(struct nfs_pageio_descriptor *pgio, pnfs_generic_pg_init_write(struct nfs_pageio_descriptor *pgio,
struct nfs_page *req, u64 wb_size) struct nfs_page *req, u64 wb_size)
{ {
WARN_ON_ONCE(pgio->pg_lseg != NULL); if (pgio->pg_lseg == NULL)
pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode,
pgio->pg_lseg = pnfs_update_layout(pgio->pg_inode, req->wb_context,
req->wb_context, req_offset(req),
req_offset(req), wb_size,
wb_size, IOMODE_RW,
IOMODE_RW, GFP_NOFS);
GFP_NOFS);
/* If no lseg, fall back to write through mds */ /* If no lseg, fall back to write through mds */
if (pgio->pg_lseg == NULL) if (pgio->pg_lseg == NULL)
nfs_pageio_reset_write_mds(pgio); nfs_pageio_reset_write_mds(pgio);