|
@@ -6346,7 +6346,6 @@ 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 = lrp->args.layout;
|
|
|
|
|
|
dprintk("--> %s\n", __func__);
|
|
|
|
|
@@ -6358,19 +6357,20 @@ static void nfs4_layoutreturn_done(struct rpc_task *task, void *calldata)
|
|
|
rpc_restart_call_prepare(task);
|
|
|
return;
|
|
|
}
|
|
|
- spin_lock(&lo->plh_inode->i_lock);
|
|
|
- if (task->tk_status == 0 && lrp->res.lrs_present)
|
|
|
- pnfs_set_layout_stateid(lo, &lrp->res.stateid, true);
|
|
|
- lo->plh_block_lgets--;
|
|
|
- spin_unlock(&lo->plh_inode->i_lock);
|
|
|
dprintk("<-- %s\n", __func__);
|
|
|
}
|
|
|
|
|
|
static void nfs4_layoutreturn_release(void *calldata)
|
|
|
{
|
|
|
struct nfs4_layoutreturn *lrp = calldata;
|
|
|
+ struct pnfs_layout_hdr *lo = lrp->args.layout;
|
|
|
|
|
|
dprintk("--> %s\n", __func__);
|
|
|
+ spin_lock(&lo->plh_inode->i_lock);
|
|
|
+ if (lrp->res.lrs_present)
|
|
|
+ pnfs_set_layout_stateid(lo, &lrp->res.stateid, true);
|
|
|
+ lo->plh_block_lgets--;
|
|
|
+ spin_unlock(&lo->plh_inode->i_lock);
|
|
|
pnfs_put_layout_hdr(lrp->args.layout);
|
|
|
kfree(calldata);
|
|
|
dprintk("<-- %s\n", __func__);
|