|
@@ -2072,11 +2072,23 @@ void pnfs_error_mark_layout_for_return(struct inode *inode,
|
|
}
|
|
}
|
|
EXPORT_SYMBOL_GPL(pnfs_error_mark_layout_for_return);
|
|
EXPORT_SYMBOL_GPL(pnfs_error_mark_layout_for_return);
|
|
|
|
|
|
|
|
+void
|
|
|
|
+pnfs_generic_pg_check_layout(struct nfs_pageio_descriptor *pgio)
|
|
|
|
+{
|
|
|
|
+ if (pgio->pg_lseg == NULL ||
|
|
|
|
+ test_bit(NFS_LSEG_VALID, &pgio->pg_lseg->pls_flags))
|
|
|
|
+ return;
|
|
|
|
+ pnfs_put_lseg(pgio->pg_lseg);
|
|
|
|
+ pgio->pg_lseg = NULL;
|
|
|
|
+}
|
|
|
|
+EXPORT_SYMBOL_GPL(pnfs_generic_pg_check_layout);
|
|
|
|
+
|
|
void
|
|
void
|
|
pnfs_generic_pg_init_read(struct nfs_pageio_descriptor *pgio, struct nfs_page *req)
|
|
pnfs_generic_pg_init_read(struct nfs_pageio_descriptor *pgio, struct nfs_page *req)
|
|
{
|
|
{
|
|
u64 rd_size = req->wb_bytes;
|
|
u64 rd_size = req->wb_bytes;
|
|
|
|
|
|
|
|
+ pnfs_generic_pg_check_layout(pgio);
|
|
if (pgio->pg_lseg == NULL) {
|
|
if (pgio->pg_lseg == NULL) {
|
|
if (pgio->pg_dreq == NULL)
|
|
if (pgio->pg_dreq == NULL)
|
|
rd_size = i_size_read(pgio->pg_inode) - req_offset(req);
|
|
rd_size = i_size_read(pgio->pg_inode) - req_offset(req);
|
|
@@ -2107,6 +2119,7 @@ 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)
|
|
{
|
|
{
|
|
|
|
+ pnfs_generic_pg_check_layout(pgio);
|
|
if (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,
|