Re: [PATCH 1/1] NFSD: detect mismatch of file handle and delegation stateid in OPEN op

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

 



On Tue, 2025-06-10 at 09:50 -0400, Chuck Lever wrote:
> On 6/10/25 9:41 AM, Dai Ngo wrote:
> > When the client sends an OPEN with claim type CLAIM_DELEG_CUR_FH or
> > CLAIM_DELEGATION_CUR, the delegation stateid and the file handle
> > must belongs to the same file, otherwise return NFS4ERR_BAD_STATEID.
> > 
> > Signed-off-by: Dai Ngo <dai.ngo@xxxxxxxxxx>
> > ---
> >  fs/nfsd/nfs4state.c | 5 +++++
> >  1 file changed, 5 insertions(+)
> > 
> > diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c
> > index 59a693f22452..be2ee641a22d 100644
> > --- a/fs/nfsd/nfs4state.c
> > +++ b/fs/nfsd/nfs4state.c
> > @@ -6318,6 +6318,11 @@ nfsd4_process_open2(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nf
> >  		status = nfs4_check_deleg(cl, open, &dp);
> >  		if (status)
> >  			goto out;
> > +		if (dp && nfsd4_is_deleg_cur(open) &&
> > +				(dp->dl_stid.sc_file != fp)) {
> > +			status = nfserr_bad_stateid;
> 
> How does the client react to NFS4ERR_BAD_STATEID ? Does it retry the
> same request or does it reflect the failure to the application?
> 

I imagine this triggers the client to go into state recovery, which
won't be terribly helpful. Another reason to consider a different error
code. I suggest:

    15.1.1.4. NFS4ERR_INVAL (Error Code 22)

    The arguments for this operation are not valid for some reason, even though they do match those specified in the XDR definition for the request.

This might bubble up as an application error and get noticed that way.

> 
> > +			goto out;
> > +		}
> >  		stp = nfsd4_find_and_lock_existing_open(fp, open);
> >  	} else {
> >  		open->op_file = NULL;
> 

-- 
Jeff Layton <jlayton@xxxxxxxxxx>





[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