|
@@ -5706,6 +5706,7 @@ static void nfs4_layoutreturn_done(struct rpc_task *task, void *calldata)
|
|
|
{
|
|
|
struct nfs4_layoutreturn *lrp = calldata;
|
|
|
struct nfs_server *server;
|
|
|
+ struct pnfs_layout_hdr *lo = NFS_I(lrp->args.inode)->layout;
|
|
|
|
|
|
dprintk("--> %s\n", __func__);
|
|
|
|
|
@@ -5717,16 +5718,15 @@ static void nfs4_layoutreturn_done(struct rpc_task *task, void *calldata)
|
|
|
nfs_restart_rpc(task, lrp->clp);
|
|
|
return;
|
|
|
}
|
|
|
+ spin_lock(&lo->plh_inode->i_lock);
|
|
|
if (task->tk_status == 0) {
|
|
|
- struct pnfs_layout_hdr *lo = NFS_I(lrp->args.inode)->layout;
|
|
|
-
|
|
|
if (lrp->res.lrs_present) {
|
|
|
- spin_lock(&lo->plh_inode->i_lock);
|
|
|
pnfs_set_layout_stateid(lo, &lrp->res.stateid, true);
|
|
|
- spin_unlock(&lo->plh_inode->i_lock);
|
|
|
} else
|
|
|
BUG_ON(!list_empty(&lo->plh_segs));
|
|
|
}
|
|
|
+ lo->plh_block_lgets--;
|
|
|
+ spin_unlock(&lo->plh_inode->i_lock);
|
|
|
dprintk("<-- %s\n", __func__);
|
|
|
}
|
|
|
|