All of lore.kernel.org
 help / color / mirror / Atom feed
From: Tom Haynes <thomas.haynes@primarydata.com>
To: Trond Myklebust <trond.myklebust@primarydata.com>
Cc: Linux NFS Mailing list <linux-nfs@vger.kernel.org>
Subject: [PATCH v6 20/53] nfs41: close a small race window when adding new layout to global list
Date: Mon,  2 Feb 2015 14:38:34 -0800	[thread overview]
Message-ID: <1422916747-86649-21-git-send-email-loghyr@primarydata.com> (raw)
In-Reply-To: <1422916747-86649-1-git-send-email-loghyr@primarydata.com>

From: Peng Tao <tao.peng@primarydata.com>

Signed-off-by: Peng Tao <tao.peng@primarydata.com>
Signed-off-by: Tom Haynes <Thomas.Haynes@primarydata.com>
---
 fs/nfs/pnfs.c | 8 +++-----
 1 file changed, 3 insertions(+), 5 deletions(-)

diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c
index 2d25670..fa00b56 100644
--- a/fs/nfs/pnfs.c
+++ b/fs/nfs/pnfs.c
@@ -1288,7 +1288,6 @@ pnfs_update_layout(struct inode *ino,
 	struct nfs_client *clp = server->nfs_client;
 	struct pnfs_layout_hdr *lo;
 	struct pnfs_layout_segment *lseg = NULL;
-	bool first;
 
 	if (!pnfs_enabled_sb(NFS_SERVER(ino)))
 		goto out;
@@ -1321,16 +1320,15 @@ pnfs_update_layout(struct inode *ino,
 	if (pnfs_layoutgets_blocked(lo, 0))
 		goto out_unlock;
 	atomic_inc(&lo->plh_outstanding);
-
-	first = list_empty(&lo->plh_layouts) ? true : false;
 	spin_unlock(&ino->i_lock);
 
-	if (first) {
+	if (list_empty(&lo->plh_layouts)) {
 		/* The lo must be on the clp list if there is any
 		 * chance of a CB_LAYOUTRECALL(FILE) coming in.
 		 */
 		spin_lock(&clp->cl_lock);
-		list_add_tail(&lo->plh_layouts, &server->layouts);
+		if (list_empty(&lo->plh_layouts))
+			list_add_tail(&lo->plh_layouts, &server->layouts);
 		spin_unlock(&clp->cl_lock);
 	}
 
-- 
1.9.3


  parent reply	other threads:[~2015-02-02 22:40 UTC|newest]

Thread overview: 61+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-02-02 22:38 [PATCH v6 00/53] Add Flexfile Layout Module Tom Haynes
2015-02-02 22:38 ` [PATCH v6 01/53] pnfs: Prepare for flexfiles by pulling out common code Tom Haynes
2015-02-02 22:38 ` [PATCH v6 02/53] pnfs: Do not grab the commit_info lock twice when rescheduling writes Tom Haynes
2015-02-02 22:38 ` [PATCH v6 03/53] nfs41: pull data server cache from file layout to generic pnfs Tom Haynes
2015-02-02 22:38 ` [PATCH v6 04/53] nfs41: pull decode_ds_addr " Tom Haynes
2015-02-02 22:38 ` [PATCH v6 05/53] nfs41: pull nfs4_ds_connect " Tom Haynes
2015-02-02 22:38 ` [PATCH v6 06/53] nfs41: allow LD to choose DS connection auth flavor Tom Haynes
2015-02-02 22:38 ` [PATCH v6 07/53] nfs41: move file layout macros to generic pnfs Tom Haynes
2015-02-02 22:38 ` [PATCH v6 08/53] nfsv3: introduce nfs3_set_ds_client Tom Haynes
2015-02-02 22:38 ` [PATCH v6 09/53] nfs41: allow LD to choose DS connection version/minor_version Tom Haynes
2015-02-02 22:38 ` [PATCH v6 10/53] nfs41: create NFSv3 DS connection if specified Tom Haynes
2015-02-03 16:32   ` Anna Schumaker
2015-02-02 22:38 ` [PATCH v6 11/53] pnfs: Add nfs_rpc_ops in calls to nfs_initiate_pgio Tom Haynes
2015-02-02 22:38 ` [PATCH v6 12/53] nfs: allow different protocol in nfs_initiate_commit Tom Haynes
2015-02-02 22:38 ` [PATCH v6 13/53] nfs4: pass slot table to nfs40_setup_sequence Tom Haynes
2015-02-02 22:38 ` [PATCH v6 14/53] nfs4: export nfs4_sequence_done Tom Haynes
2015-02-02 22:38 ` [PATCH v6 15/53] nfs: allow to specify cred in nfs_initiate_pgio Tom Haynes
2015-02-02 22:38 ` [PATCH v6 16/53] NFSv4.1/NFSv3: Add pNFS callbacks for nfs3_(read|write|commit)_done() Tom Haynes
2015-02-02 22:38 ` [PATCH v6 17/53] sunrpc: add rpc_count_iostats_idx Tom Haynes
2015-02-02 22:38 ` [PATCH v6 18/53] nfs: set hostname when creating nfsv3 ds connection Tom Haynes
2015-02-02 22:38 ` [PATCH v6 19/53] nfs/flexclient: export pnfs_layoutcommit_inode Tom Haynes
2015-02-02 22:38 ` Tom Haynes [this message]
2015-02-02 22:38 ` [PATCH v6 21/53] nfs41: serialize first layoutget of a file Tom Haynes
2015-02-02 22:38 ` [PATCH v6 22/53] nfs: save server READ/WRITE/COMMIT status Tom Haynes
2015-02-02 22:38 ` [PATCH v6 23/53] nfs41: pass iomode through layoutreturn args Tom Haynes
2015-02-02 22:38 ` [PATCH v6 24/53] nfs41: make a helper function to send layoutreturn Tom Haynes
2015-02-02 22:38 ` [PATCH v6 25/53] nfs41: add a helper to mark layout for return Tom Haynes
2015-02-02 22:38 ` [PATCH v6 26/53] nfs41: don't use a layout if it is marked for returning Tom Haynes
2015-02-02 22:38 ` [PATCH v6 27/53] nfs41: send layoutreturn in last put_lseg Tom Haynes
2015-02-02 22:38 ` [PATCH v6 28/53] nfs41: clear NFS_LAYOUT_RETURN if layoutreturn is sent or failed to send Tom Haynes
2015-02-02 22:38 ` [PATCH v6 29/53] nfs/filelayout: use pnfs_error_mark_layout_for_return Tom Haynes
2015-02-02 22:38 ` [PATCH v6 30/53] nfs: introduce pg_cleanup op for pgio descriptors Tom Haynes
2015-02-02 22:38 ` [PATCH v6 31/53] pnfs: release lseg in pnfs_generic_pg_cleanup Tom Haynes
2015-02-02 22:38 ` [PATCH v6 32/53] nfs: handle overlapping reqs in lock_and_join Tom Haynes
2015-02-02 22:38 ` [PATCH v6 33/53] nfs: rename pgio header ds_idx to ds_commit_idx Tom Haynes
2015-02-02 22:38 ` [PATCH v6 34/53] pnfs: pass ds_commit_idx through the commit path Tom Haynes
2015-02-02 22:38 ` [PATCH v6 35/53] nfs: add mirroring support to pgio layer Tom Haynes
2015-02-02 22:38 ` [PATCH v6 36/53] nfs: mirroring support for direct io Tom Haynes
2015-02-02 22:38 ` [PATCH v6 37/53] pnfs: fail comparison when bucket verifier not set Tom Haynes
2015-02-02 22:38 ` [PATCH v6 38/53] nfs41: add a debug warning if we destroy an unempty layout Tom Haynes
2015-02-02 22:38 ` [PATCH v6 39/53] nfs: only reset desc->pg_mirror_idx when mirroring is supported Tom Haynes
2015-02-02 22:38 ` [PATCH v6 40/53] nfs: add nfs_pgio_current_mirror helper Tom Haynes
2015-02-02 22:38 ` [PATCH v6 41/53] pnfs: allow LD to ask to resend read through pnfs Tom Haynes
2015-02-02 22:38 ` [PATCH v6 42/53] nfs41: add range to layoutreturn args Tom Haynes
2015-02-02 22:38 ` [PATCH v6 43/53] nfs41: allow async version layoutreturn Tom Haynes
2015-02-02 22:38 ` [PATCH v6 44/53] nfs41: introduce NFS_LAYOUT_RETURN_BEFORE_CLOSE Tom Haynes
2015-02-04 17:18   ` Anna Schumaker
2015-02-04 17:35     ` Tom Haynes
2015-02-02 22:38 ` [PATCH v6 45/53] nfs/flexfiles: send layoutreturn before freeing lseg Tom Haynes
2015-02-02 22:39 ` [PATCH v6 46/53] nfs41: add NFS_LAYOUT_RETRY_LAYOUTGET to layout header flags Tom Haynes
2015-02-02 22:39 ` [PATCH v6 47/53] nfs: add a helper to set NFS_ODIRECT_RESCHED_WRITES to direct writes Tom Haynes
2015-02-02 22:39 ` [PATCH v6 48/53] nfs41: wait for LAYOUTRETURN before retrying LAYOUTGET Tom Haynes
2015-02-02 22:39 ` [PATCH v6 49/53] nfs: count DIO good bytes correctly with mirroring Tom Haynes
2015-02-02 22:39 ` [PATCH v6 50/53] pnfs/flexfiles: Add the FlexFile Layout Driver Tom Haynes
2015-02-02 22:39 ` [PATCH v6 51/53] pnfs: Update documentation on the Layout Drivers Tom Haynes
2015-02-02 22:39 ` [PATCH v6 52/53] nfs41: .init_read and .init_write can be called with valid pg_lseg Tom Haynes
2015-02-02 22:39 ` [PATCH v6 53/53] pnfs: lookup new lseg at lseg boundary Tom Haynes
2015-02-03 14:58 ` [PATCH v6 00/53] Add Flexfile Layout Module Anna Schumaker
2015-02-03 15:10   ` Tom Haynes
     [not found]   ` <99878A33-2C02-4F3B-9BFF-CDE6E480B179@primarydata.com>
2015-02-03 15:11     ` Anna Schumaker
2015-02-03 15:32       ` Trond Myklebust

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=1422916747-86649-21-git-send-email-loghyr@primarydata.com \
    --to=thomas.haynes@primarydata.com \
    --cc=linux-nfs@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.