Re: [PATCH 19/70] NFSd: Allow lockowners to hold several stateids

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 7 May 2014 11:20:06 -0400
Bruce Fields <bfields@xxxxxxxxxxxx> wrote:

> Then did "NFSd: Lock owners are not per open stateid" introduce a
> temporary regression?
> 
> --b.
> 

No, I don't think it does. Even after that patch, you still only have
one lock stateid per lockowner. That patch is just adding some plumbing
that will eventually allow you to break that limitation.

That said, there are some problems with locking during the traversal of
the so_stateids list in this set that I'm looking at today.

> On Fri, Apr 18, 2014 at 02:44:13PM -0400, Trond Myklebust wrote:
> > Signed-off-by: Trond Myklebust <trond.myklebust@xxxxxxxxxxxxxxx>
> > ---
> >  fs/nfsd/nfs4state.c | 46 +++++++++++++++++++++++++++++-----------------
> >  1 file changed, 29 insertions(+), 17 deletions(-)
> > 
> > diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c
> > index 0809e8355577..dad2f7b511b8 100644
> > --- a/fs/nfsd/nfs4state.c
> > +++ b/fs/nfsd/nfs4state.c
> > @@ -4390,6 +4390,19 @@ alloc_init_lock_stateid(struct nfs4_lockowner *lo, struct nfs4_file *fp, struct
> >  	return stp;
> >  }
> >  
> > +static struct nfs4_ol_stateid *
> > +find_lock_stateid(struct nfs4_lockowner *lo, struct inode *inode)
> > +{
> > +	struct nfs4_ol_stateid *lst;
> > +
> > +	list_for_each_entry(lst, &lo->lo_owner.so_stateids, st_perstateowner) {
> > +		if (lst->st_file->fi_inode == inode)
> > +			return lst;
> > +	}
> > +	return NULL;
> > +}
> > +
> > +
> >  static int
> >  check_lock_length(u64 offset, u64 length)
> >  {
> > @@ -4419,25 +4432,24 @@ static __be32 lookup_or_create_lock_state(struct nfsd4_compound_state *cstate, s
> >  
> >  	lo = find_lockowner_str(fi->fi_inode, &cl->cl_clientid,
> >  				&lock->v.new.owner, nn);
> > -	if (lo) {
> > -		if (!cstate->minorversion)
> > -			return nfserr_bad_seqid;
> > -		/* XXX: a lockowner always has exactly one stateid: */
> > -		*lst = list_first_entry(&lo->lo_owner.so_stateids,
> > -				struct nfs4_ol_stateid, st_perstateowner);
> > -		return nfs_ok;
> > +	if (!lo) {
> > +		strhashval = ownerstr_hashval(cl->cl_clientid.cl_id,
> > +				&lock->v.new.owner);
> > +		lo = alloc_init_lock_stateowner(strhashval, cl, ost, lock);
> > +		if (lo == NULL)
> > +			return nfserr_jukebox;
> >  	}
> > -	strhashval = ownerstr_hashval(cl->cl_clientid.cl_id,
> > -			&lock->v.new.owner);
> > -	lo = alloc_init_lock_stateowner(strhashval, cl, ost, lock);
> > -	if (lo == NULL)
> > -		return nfserr_jukebox;
> > -	*lst = alloc_init_lock_stateid(lo, fi, ost);
> > +	if (!cstate->minorversion)
> > +		return nfserr_bad_seqid;
> > +	*lst = find_lock_stateid(lo, fi->fi_inode);
> >  	if (*lst == NULL) {
> > -		release_lockowner(lo);
> > -		return nfserr_jukebox;
> > +		*lst = alloc_init_lock_stateid(lo, fi, ost);
> > +		if (*lst == NULL) {
> > +			release_lockowner_if_empty(lo);
> > +			return nfserr_jukebox;
> > +		}
> > +		*new = true;
> >  	}
> > -	*new = true;
> >  	return nfs_ok;
> >  }
> >  
> > @@ -4596,7 +4608,7 @@ out:
> >  	if (filp)
> >  		fput(filp);
> >  	if (status && new_state)
> > -		release_lockowner(lock_sop);
> > +		release_lockowner_if_empty(lock_sop);
> >  	nfsd4_bump_seqid(cstate, status);
> >  	nfs4_unlock_state();
> >  	if (file_lock)
> > -- 
> > 1.9.0
> > 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html


-- 
Jeff Layton <jlayton@xxxxxxxxxxxxxxx>
--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux