Commit ed429d6b authored by Trond Myklebust's avatar Trond Myklebust

NFSv4.1/pNFS: Don't pass stateids by value to pnfs_send_layoutreturn()

A stateid is a structure, pass it as a pointer.
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@primarydata.com>
parent 138a2935
...@@ -53,7 +53,7 @@ static DEFINE_SPINLOCK(pnfs_spinlock); ...@@ -53,7 +53,7 @@ static DEFINE_SPINLOCK(pnfs_spinlock);
static LIST_HEAD(pnfs_modules_tbl); static LIST_HEAD(pnfs_modules_tbl);
static int static int
pnfs_send_layoutreturn(struct pnfs_layout_hdr *lo, nfs4_stateid stateid, pnfs_send_layoutreturn(struct pnfs_layout_hdr *lo, const nfs4_stateid *stateid,
enum pnfs_iomode iomode, bool sync); enum pnfs_iomode iomode, bool sync);
/* Return the registered pnfs layout driver module matching given id */ /* Return the registered pnfs layout driver module matching given id */
...@@ -391,7 +391,7 @@ static void pnfs_layoutreturn_before_put_lseg(struct pnfs_layout_segment *lseg, ...@@ -391,7 +391,7 @@ static void pnfs_layoutreturn_before_put_lseg(struct pnfs_layout_segment *lseg,
spin_unlock(&inode->i_lock); spin_unlock(&inode->i_lock);
if (send) { if (send) {
/* Send an async layoutreturn so we dont deadlock */ /* Send an async layoutreturn so we dont deadlock */
pnfs_send_layoutreturn(lo, stateid, iomode, false); pnfs_send_layoutreturn(lo, &stateid, iomode, false);
} }
} else } else
spin_unlock(&inode->i_lock); spin_unlock(&inode->i_lock);
...@@ -947,7 +947,7 @@ void pnfs_clear_layoutreturn_waitbit(struct pnfs_layout_hdr *lo) ...@@ -947,7 +947,7 @@ void pnfs_clear_layoutreturn_waitbit(struct pnfs_layout_hdr *lo)
} }
static int static int
pnfs_send_layoutreturn(struct pnfs_layout_hdr *lo, nfs4_stateid stateid, pnfs_send_layoutreturn(struct pnfs_layout_hdr *lo, const nfs4_stateid *stateid,
enum pnfs_iomode iomode, bool sync) enum pnfs_iomode iomode, bool sync)
{ {
struct inode *ino = lo->plh_inode; struct inode *ino = lo->plh_inode;
...@@ -964,7 +964,7 @@ pnfs_send_layoutreturn(struct pnfs_layout_hdr *lo, nfs4_stateid stateid, ...@@ -964,7 +964,7 @@ pnfs_send_layoutreturn(struct pnfs_layout_hdr *lo, nfs4_stateid stateid,
goto out; goto out;
} }
lrp->args.stateid = stateid; nfs4_stateid_copy(&lrp->args.stateid, stateid);
lrp->args.layout_type = NFS_SERVER(ino)->pnfs_curr_ld->id; lrp->args.layout_type = NFS_SERVER(ino)->pnfs_curr_ld->id;
lrp->args.inode = ino; lrp->args.inode = ino;
lrp->args.range.iomode = iomode; lrp->args.range.iomode = iomode;
...@@ -1035,7 +1035,7 @@ _pnfs_return_layout(struct inode *ino) ...@@ -1035,7 +1035,7 @@ _pnfs_return_layout(struct inode *ino)
spin_unlock(&ino->i_lock); spin_unlock(&ino->i_lock);
pnfs_free_lseg_list(&tmp_list); pnfs_free_lseg_list(&tmp_list);
if (send) if (send)
status = pnfs_send_layoutreturn(lo, stateid, IOMODE_ANY, true); status = pnfs_send_layoutreturn(lo, &stateid, IOMODE_ANY, true);
out_put_layout_hdr: out_put_layout_hdr:
pnfs_put_layout_hdr(lo); pnfs_put_layout_hdr(lo);
out: out:
...@@ -1126,7 +1126,7 @@ bool pnfs_roc(struct inode *ino) ...@@ -1126,7 +1126,7 @@ bool pnfs_roc(struct inode *ino)
pnfs_free_lseg_list(&tmp_list); pnfs_free_lseg_list(&tmp_list);
pnfs_layoutcommit_inode(ino, true); pnfs_layoutcommit_inode(ino, true);
if (layoutreturn) if (layoutreturn)
pnfs_send_layoutreturn(lo, stateid, IOMODE_ANY, true); pnfs_send_layoutreturn(lo, &stateid, IOMODE_ANY, true);
return roc; return roc;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment