aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfs/nfs4filelayout.c
diff options
context:
space:
mode:
authorAndy Adamson <andros@netapp.com>2012-06-20 15:03:31 -0400
committerTrond Myklebust <Trond.Myklebust@netapp.com>2012-07-16 14:36:52 -0400
commit82c7c7a5a9270b13380a588dc57b7541a5e4f541 (patch)
tree20b38256e4ef38d34b2b291d3cdcfa322cfa0218 /fs/nfs/nfs4filelayout.c
parent8626e4a42675ff9903f7d4fbf14d8ebc11b5926c (diff)
NFSv4.1 return the LAYOUT for each file with failed DS connection I/O
First mark the deviceid invalid to prevent any future use. Then fence all files involved in I/O to a DS with a connection error by sending a LAYOUTRETURN. Signed-off-by: Andy Adamson <andros@netapp.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/nfs/nfs4filelayout.c')
-rw-r--r--fs/nfs/nfs4filelayout.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/fs/nfs/nfs4filelayout.c b/fs/nfs/nfs4filelayout.c
index 85b70639921b..26b96de831ea 100644
--- a/fs/nfs/nfs4filelayout.c
+++ b/fs/nfs/nfs4filelayout.c
@@ -205,9 +205,8 @@ static int filelayout_async_handle_error(struct rpc_task *task,
205 case -EPIPE: 205 case -EPIPE:
206 dprintk("%s DS connection error %d\n", __func__, 206 dprintk("%s DS connection error %d\n", __func__,
207 task->tk_status); 207 task->tk_status);
208 if (!filelayout_test_devid_invalid(devid))
209 _pnfs_return_layout(inode);
210 filelayout_mark_devid_invalid(devid); 208 filelayout_mark_devid_invalid(devid);
209 _pnfs_return_layout(inode);
211 rpc_wake_up(&tbl->slot_tbl_waitq); 210 rpc_wake_up(&tbl->slot_tbl_waitq);
212 nfs4_ds_disconnect(clp); 211 nfs4_ds_disconnect(clp);
213 /* fall through */ 212 /* fall through */