Re: [PATCH 1/7] nfsd4: implement new 4.1 open reclaim types

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

 



On Wed, Oct 19, 2011 at 07:12:48PM -0700, Benny Halevy wrote:
> From: "J. Bruce Fields" <bfields@xxxxxxxxxx>
> 
> Signed-off-by: Benny Halevy <bhalevy@xxxxxxxxxx>
> ---
>  fs/nfsd/nfs4proc.c   |   15 +++------------
>  fs/nfsd/nfs4state.c  |   10 ++++++++--
>  fs/nfsd/nfs4xdr.c    |   13 +++++++++++++
>  include/linux/nfs4.h |    5 ++++-
>  4 files changed, 28 insertions(+), 15 deletions(-)

Adding Mi Jinlong--is there a chance you might be able to write pynfs
tests for these?  I don't know if clients are using them yet so it would
be nice to know if they work before committing this.

--b.

> 
> diff --git a/fs/nfsd/nfs4proc.c b/fs/nfsd/nfs4proc.c
> index 5b192a2..e3fffab 100644
> --- a/fs/nfsd/nfs4proc.c
> +++ b/fs/nfsd/nfs4proc.c
> @@ -366,12 +366,6 @@ static __be32 nfsd_check_obj_isreg(struct svc_fh *fh)
>  	switch (open->op_claim_type) {
>  		case NFS4_OPEN_CLAIM_DELEGATE_CUR:
>  		case NFS4_OPEN_CLAIM_NULL:
> -			/*
> -			 * (1) set CURRENT_FH to the file being opened,
> -			 * creating it if necessary, (2) set open->op_cinfo,
> -			 * (3) set open->op_truncate if the file is to be
> -			 * truncated after opening, (4) do permission checking.
> -			 */
>  			status = do_open_lookup(rqstp, &cstate->current_fh,
>  						open);
>  			if (status)
> @@ -379,17 +373,14 @@ static __be32 nfsd_check_obj_isreg(struct svc_fh *fh)
>  			break;
>  		case NFS4_OPEN_CLAIM_PREVIOUS:
>  			open->op_openowner->oo_flags |= NFS4_OO_CONFIRMED;
> -			/*
> -			 * The CURRENT_FH is already set to the file being
> -			 * opened.  (1) set open->op_cinfo, (2) set
> -			 * open->op_truncate if the file is to be truncated
> -			 * after opening, (3) do permission checking.
> -			*/
> +		case NFS4_OPEN_CLAIM_FH:
> +		case NFS4_OPEN_CLAIM_DELEG_CUR_FH:
>  			status = do_open_fhandle(rqstp, &cstate->current_fh,
>  						 open);
>  			if (status)
>  				goto out;
>  			break;
> +		case NFS4_OPEN_CLAIM_DELEG_PREV_FH:
>               	case NFS4_OPEN_CLAIM_DELEGATE_PREV:
>  			open->op_openowner->oo_flags |= NFS4_OO_CONFIRMED;
>  			dprintk("NFSD: unsupported OPEN claim type %d\n",
> diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c
> index 62aa91a..7da0748 100644
> --- a/fs/nfsd/nfs4state.c
> +++ b/fs/nfsd/nfs4state.c
> @@ -2562,6 +2562,12 @@ static int share_access_to_flags(u32 share_access)
>  	return delegstateid(ret);
>  }
>  
> +static bool nfsd4_is_deleg_cur(struct nfsd4_open *open)
> +{
> +	return open->op_claim_type == NFS4_OPEN_CLAIM_DELEGATE_CUR ||
> +	       open->op_claim_type == NFS4_OPEN_CLAIM_DELEG_CUR_FH;
> +}
> +
>  static __be32
>  nfs4_check_deleg(struct nfs4_client *cl, struct nfs4_file *fp, struct nfsd4_open *open,
>  		struct nfs4_delegation **dp)
> @@ -2577,7 +2583,7 @@ static int share_access_to_flags(u32 share_access)
>  	if (status)
>  		*dp = NULL;
>  out:
> -	if (open->op_claim_type != NFS4_OPEN_CLAIM_DELEGATE_CUR)
> +	if (!nfsd4_is_deleg_cur(open))
>  		return nfs_ok;
>  	if (status)
>  		return status;
> @@ -2882,7 +2888,7 @@ static int nfs4_set_delegation(struct nfs4_delegation *dp, int flag)
>  			goto out;
>  	} else {
>  		status = nfserr_bad_stateid;
> -		if (open->op_claim_type == NFS4_OPEN_CLAIM_DELEGATE_CUR)
> +		if (nfsd4_is_deleg_cur(open))
>  			goto out;
>  		status = nfserr_jukebox;
>  		fp = alloc_init_file(ino);
> diff --git a/fs/nfsd/nfs4xdr.c b/fs/nfsd/nfs4xdr.c
> index 645a0a9..fdc09a5 100644
> --- a/fs/nfsd/nfs4xdr.c
> +++ b/fs/nfsd/nfs4xdr.c
> @@ -803,6 +803,19 @@ static __be32 nfsd4_decode_opaque(struct nfsd4_compoundargs *argp, struct xdr_ne
>  		if ((status = check_filename(open->op_fname.data, open->op_fname.len, nfserr_inval)))
>  			return status;
>  		break;
> +	case NFS4_OPEN_CLAIM_FH:
> +	case NFS4_OPEN_CLAIM_DELEG_PREV_FH:
> +		if (argp->minorversion < 1)
> +			goto xdr_error;
> +		/* void */
> +		break;
> +	case NFS4_OPEN_CLAIM_DELEG_CUR_FH:
> +		if (argp->minorversion < 1)
> +			goto xdr_error;
> +		status = nfsd4_decode_stateid(argp, &open->op_delegate_stateid);
> +		if (status)
> +			return status;
> +		break;
>  	default:
>  		goto xdr_error;
>  	}
> diff --git a/include/linux/nfs4.h b/include/linux/nfs4.h
> index b875b03..32345c2 100644
> --- a/include/linux/nfs4.h
> +++ b/include/linux/nfs4.h
> @@ -410,7 +410,10 @@ enum open_claim_type4 {
>  	NFS4_OPEN_CLAIM_NULL = 0,
>  	NFS4_OPEN_CLAIM_PREVIOUS = 1,
>  	NFS4_OPEN_CLAIM_DELEGATE_CUR = 2,
> -	NFS4_OPEN_CLAIM_DELEGATE_PREV = 3
> +	NFS4_OPEN_CLAIM_DELEGATE_PREV = 3,
> +	NFS4_OPEN_CLAIM_FH = 4, /* 4.1 */
> +	NFS4_OPEN_CLAIM_DELEG_CUR_FH = 5, /* 4.1 */
> +	NFS4_OPEN_CLAIM_DELEG_PREV_FH = 6, /* 4.1 */
>  };
>  
>  enum opentype4 {
> -- 
> 1.7.6
> 
--
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