stable.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Andrew W Elble <aweits@rit.edu>
To: <gregkh@linuxfoundation.org>
Cc: trond.myklebust@primarydata.com, bfields@redhat.com,
	<stable@vger.kernel.org>
Subject: Re: FAILED: patch "[PATCH] nfsd: Fix another OPEN stateid race" failed to apply to 4.4-stable tree
Date: Mon, 04 Dec 2017 08:21:34 -0500	[thread overview]
Message-ID: <m21skaiq75.fsf@discipline.rit.edu> (raw)
In-Reply-To: <15123788152932@kroah.com> (gregkh@linuxfoundation.org's message of "Mon, 04 Dec 2017 10:13:35 +0100")

<gregkh@linuxfoundation.org> writes:

> The patch below does not apply to the 4.4-stable tree.
> If someone wants it applied there, or to any other stable or longterm
> tree, then please email the backport, including the original git commit
> id to <stable@vger.kernel.org>.
>
> thanks,
>
> greg k-h

Greg,

  These backport cleanly if you cherry-pick 8c7245abda first:

commit 8c7245abda877d4689b3371db8ae2a4400d7d9ce
then
commit 15ca08d3299682dc49bad73251677b2c5017ef08
then
commit d8a1a000555ecd1b824ac1ed6df8fe364dfbbbb0

Thanks,

Andy


>
> ------------------ original commit in Linus's tree ------------------
>
>>>From d8a1a000555ecd1b824ac1ed6df8fe364dfbbbb0 Mon Sep 17 00:00:00 2001
> From: Trond Myklebust <trond.myklebust@primarydata.com>
> Date: Fri, 3 Nov 2017 08:00:11 -0400
> Subject: [PATCH] nfsd: Fix another OPEN stateid race
>
> If nfsd4_process_open2() is initialising a new stateid, and yet the
> call to nfs4_get_vfs_file() fails for some reason, then we must
> declare the stateid closed, and unhash it before dropping the mutex.
>
> Right now, we unhash the stateid after dropping the mutex, and without
> changing the stateid type, meaning that another OPEN could theoretically
> look it up and attempt to use it.
>
> Reported-by: Andrew W Elble <aweits@rit.edu>
> Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
> Cc: stable@vger.kernel.org
> Signed-off-by: J. Bruce Fields <bfields@redhat.com>
>
> diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c
> index ee8fde2dfa92..457f0e7ece74 100644
> --- a/fs/nfsd/nfs4state.c
> +++ b/fs/nfsd/nfs4state.c
> @@ -4502,6 +4502,7 @@ nfsd4_process_open2(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nf
>  	struct nfs4_ol_stateid *stp = NULL;
>  	struct nfs4_delegation *dp = NULL;
>  	__be32 status;
> +	bool new_stp = false;
>  
>  	/*
>  	 * Lookup file; if found, lookup stateid and check open request,
> @@ -4521,11 +4522,19 @@ nfsd4_process_open2(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nf
>  			goto out;
>  	}
>  
> +	if (!stp) {
> +		stp = init_open_stateid(fp, open);
> +		if (!open->op_stp)
> +			new_stp = true;
> +	}
> +
>  	/*
>  	 * OPEN the file, or upgrade an existing OPEN.
>  	 * If truncate fails, the OPEN fails.
> +	 *
> +	 * stp is already locked.
>  	 */
> -	if (stp) {
> +	if (!new_stp) {
>  		/* Stateid was found, this is an OPEN upgrade */
>  		status = nfs4_upgrade_open(rqstp, fp, current_fh, stp, open);
>  		if (status) {
> @@ -4533,22 +4542,11 @@ nfsd4_process_open2(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nf
>  			goto out;
>  		}
>  	} else {
> -		/* stp is returned locked. */
> -		stp = init_open_stateid(fp, open);
> -		/* See if we lost the race to some other thread */
> -		if (stp->st_access_bmap != 0) {
> -			status = nfs4_upgrade_open(rqstp, fp, current_fh,
> -						stp, open);
> -			if (status) {
> -				mutex_unlock(&stp->st_mutex);
> -				goto out;
> -			}
> -			goto upgrade_out;
> -		}
>  		status = nfs4_get_vfs_file(rqstp, fp, current_fh, stp, open);
>  		if (status) {
> -			mutex_unlock(&stp->st_mutex);
> +			stp->st_stid.sc_type = NFS4_CLOSED_STID;
>  			release_open_stateid(stp);
> +			mutex_unlock(&stp->st_mutex);
>  			goto out;
>  		}
>  
> @@ -4557,7 +4555,7 @@ nfsd4_process_open2(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nf
>  		if (stp->st_clnt_odstate == open->op_odstate)
>  			open->op_odstate = NULL;
>  	}
> -upgrade_out:
> +
>  	nfs4_inc_and_copy_stateid(&open->op_stateid, &stp->st_stid);
>  	mutex_unlock(&stp->st_mutex);
>  
>

-- 
Andrew W. Elble
aweits@discipline.rit.edu
Infrastructure Engineer, Communications Technical Lead
Rochester Institute of Technology
PGP: BFAD 8461 4CCF DC95 DA2C B0EB 965B 082E 863E C912

  reply	other threads:[~2017-12-04 13:28 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-12-04  9:13 FAILED: patch "[PATCH] nfsd: Fix another OPEN stateid race" failed to apply to 4.4-stable tree gregkh
2017-12-04 13:21 ` Andrew W Elble [this message]
2017-12-04 13:59   ` Greg KH
2017-12-04 18:59   ` J. Bruce Fields

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=m21skaiq75.fsf@discipline.rit.edu \
    --to=aweits@rit.edu \
    --cc=bfields@redhat.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=stable@vger.kernel.org \
    --cc=trond.myklebust@primarydata.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).