diff options
Diffstat (limited to 'fs/nfs')
| -rw-r--r-- | fs/nfs/direct.c | 13 | ||||
| -rw-r--r-- | fs/nfs/file.c | 1 | ||||
| -rw-r--r-- | fs/nfs/flexfilelayout/flexfilelayout.c | 11 | ||||
| -rw-r--r-- | fs/nfs/nfs4namespace.c | 1 | 
4 files changed, 18 insertions, 8 deletions
| diff --git a/fs/nfs/direct.c b/fs/nfs/direct.c index 1b79dd5cf661..3d113cf8908a 100644 --- a/fs/nfs/direct.c +++ b/fs/nfs/direct.c @@ -267,8 +267,6 @@ static void nfs_direct_complete(struct nfs_direct_req *dreq)  {  	struct inode *inode = dreq->inode; -	inode_dio_end(inode); -  	if (dreq->iocb) {  		long res = (long) dreq->error;  		if (dreq->count != 0) { @@ -280,7 +278,10 @@ static void nfs_direct_complete(struct nfs_direct_req *dreq)  	complete(&dreq->completion); +	igrab(inode);  	nfs_direct_req_release(dreq); +	inode_dio_end(inode); +	iput(inode);  }  static void nfs_direct_read_completion(struct nfs_pgio_header *hdr) @@ -410,8 +411,10 @@ static ssize_t nfs_direct_read_schedule_iovec(struct nfs_direct_req *dreq,  	 * generic layer handle the completion.  	 */  	if (requested_bytes == 0) { -		inode_dio_end(inode); +		igrab(inode);  		nfs_direct_req_release(dreq); +		inode_dio_end(inode); +		iput(inode);  		return result < 0 ? result : -EIO;  	} @@ -864,8 +867,10 @@ static ssize_t nfs_direct_write_schedule_iovec(struct nfs_direct_req *dreq,  	 * generic layer handle the completion.  	 */  	if (requested_bytes == 0) { -		inode_dio_end(inode); +		igrab(inode);  		nfs_direct_req_release(dreq); +		inode_dio_end(inode); +		iput(inode);  		return result < 0 ? result : -EIO;  	} diff --git a/fs/nfs/file.c b/fs/nfs/file.c index f96367a2463e..ccd6c1637b27 100644 --- a/fs/nfs/file.c +++ b/fs/nfs/file.c @@ -83,6 +83,7 @@ nfs_file_release(struct inode *inode, struct file *filp)  	dprintk("NFS: release(%pD2)\n", filp);  	nfs_inc_stats(inode, NFSIOS_VFSRELEASE); +	inode_dio_wait(inode);  	nfs_file_clear_open_context(filp);  	return 0;  } diff --git a/fs/nfs/flexfilelayout/flexfilelayout.c b/fs/nfs/flexfilelayout/flexfilelayout.c index 7d399f72ebbb..de03e440b7ee 100644 --- a/fs/nfs/flexfilelayout/flexfilelayout.c +++ b/fs/nfs/flexfilelayout/flexfilelayout.c @@ -907,9 +907,8 @@ retry:  		goto out_mds;  	/* Use a direct mapping of ds_idx to pgio mirror_idx */ -	if (WARN_ON_ONCE(pgio->pg_mirror_count != -	    FF_LAYOUT_MIRROR_COUNT(pgio->pg_lseg))) -		goto out_mds; +	if (pgio->pg_mirror_count != FF_LAYOUT_MIRROR_COUNT(pgio->pg_lseg)) +		goto out_eagain;  	for (i = 0; i < pgio->pg_mirror_count; i++) {  		mirror = FF_LAYOUT_COMP(pgio->pg_lseg, i); @@ -931,7 +930,10 @@ retry:  			(NFS_MOUNT_SOFT|NFS_MOUNT_SOFTERR))  		pgio->pg_maxretrans = io_maxretrans;  	return; - +out_eagain: +	pnfs_generic_pg_cleanup(pgio); +	pgio->pg_error = -EAGAIN; +	return;  out_mds:  	trace_pnfs_mds_fallback_pg_init_write(pgio->pg_inode,  			0, NFS4_MAX_UINT64, IOMODE_RW, @@ -941,6 +943,7 @@ out_mds:  	pgio->pg_lseg = NULL;  	pgio->pg_maxretrans = 0;  	nfs_pageio_reset_write_mds(pgio); +	pgio->pg_error = -EAGAIN;  }  static unsigned int diff --git a/fs/nfs/nfs4namespace.c b/fs/nfs/nfs4namespace.c index a3ab6e219061..873342308dc0 100644 --- a/fs/nfs/nfs4namespace.c +++ b/fs/nfs/nfs4namespace.c @@ -308,6 +308,7 @@ static int try_location(struct fs_context *fc,  	if (IS_ERR(export_path))  		return PTR_ERR(export_path); +	kfree(ctx->nfs_server.export_path);  	ctx->nfs_server.export_path = export_path;  	source = kmalloc(len + 1 + ctx->nfs_server.export_path_len + 1, | 
