From: Benny Halevy <bhalevy@panasas.com>
To: "J. Bruce Fields" <bfields@fieldses.org>
Cc: linux-nfs@vger.kernel.org, Alexandros Batsakis <batsakis@netapp.com>
Subject: Re: [PATCH 12/14] nfsd4: remove use of mutex for file_hashtable
Date: Wed, 18 Mar 2009 23:07:51 +0200 [thread overview]
Message-ID: <49C162A7.3040505@panasas.com> (raw)
In-Reply-To: <20090318210329.GC18894@fieldses.org>
On Mar. 18, 2009, 23:03 +0200, "J. Bruce Fields" <bfields@fieldses.org> wrote:
> On Wed, Mar 18, 2009 at 10:40:41PM +0200, Benny Halevy wrote:
>> On Mar. 18, 2009, 22:28 +0200, "J. Bruce Fields" <bfields@fieldses.org> wrote:
>>> static inline void
>>> put_nfs4_file(struct nfs4_file *fi)
>>> {
>>> - kref_put(&fi->fi_ref, free_nfs4_file);
>> missing spin_lock(&recall_lock);?
>>
>>
>>> + if (atomic_dec_and_lock(&fi->fi_ref, &recall_lock)) {
>>> + list_del(&fi->fi_hash);
>>> + spin_unlock(&recall_lock);
>>> + iput(fi->fi_inode);
>>> + kmem_cache_free(file_slab, fi);
>>> + }
>> } else {
>> spin_unlock(&recall_lock);
>> }
>>
>> or am I missing something?
>
> From include/linux/spinlock.h:
>
> /**
> * atomic_dec_and_lock - lock on reaching reference count zero
> * @atomic: the atomic counter
> * @lock: the spinlock in question
> *
> * Decrements @atomic by 1. If the result is 0, returns true and locks
> * @lock. Returns false for all other cases.
> */
>
> So it's useful for cases such as this, when a reference-counted object
> is reachable from some data structure visible to others, and you want to
> remove it from that structure on dropping the last reference (as opposed
> to keeping one reference for the structure itself, and requiring the
> object to be explicitly removed).
>
> (Unless I'm missing something else.)
My bad. I did miss that.
Patch looks good to me now.
Benny
>
> --b.
next prev parent reply other threads:[~2009-03-18 21:07 UTC|newest]
Thread overview: 38+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-03-11 0:26 miscellaneous nfsd4 state changes J. Bruce Fields
2009-03-11 0:26 ` [PATCH 01/14] nfsd4: trivial preprocess_stateid_op cleanup J. Bruce Fields
2009-03-11 0:26 ` [PATCH 02/14] nfsd4: move check_stateid_generation check J. Bruce Fields
2009-03-11 0:26 ` [PATCH 03/14] nfsd4: remove redundant "if" in nfs4_preprocess_stateid_op J. Bruce Fields
2009-03-11 0:26 ` [PATCH 04/14] nfsd4: remove unneeded local variable J. Bruce Fields
2009-03-11 0:26 ` [PATCH 05/14] nfsd4: remove some dprintk's J. Bruce Fields
2009-03-11 0:26 ` [PATCH 06/14] nfsd4: add a helper function to decide if stateid is delegation J. Bruce Fields
2009-03-11 0:26 ` [PATCH 07/14] nfsd4: separate delegreturn case from preprocess_stateid_op J. Bruce Fields
2009-03-11 0:26 ` [PATCH 08/14] nfsd4: fail when delegreturn gets a non-delegation stateid J. Bruce Fields
2009-03-11 0:26 ` [PATCH 09/14] nfsd4: remove unused CHECK_FH flag J. Bruce Fields
2009-03-11 0:26 ` [PATCH 10/14] nfsd4: rename io_during_grace_disallowed J. Bruce Fields
2009-03-11 0:26 ` [PATCH 11/14] nfsd4: put_nfs4_client does not require state lock J. Bruce Fields
2009-03-11 0:27 ` [PATCH 12/14] nfsd4: remove use of mutex for file_hashtable J. Bruce Fields
2009-03-11 0:27 ` [PATCH 13/14] nfsd4: fix do_probe_callback errors J. Bruce Fields
2009-03-11 0:27 ` [PATCH 14/14] nfsd4: move rpc_client setup to a separate function J. Bruce Fields
2009-03-12 10:59 ` Benny Halevy
2009-03-12 10:55 ` [PATCH 13/14] nfsd4: fix do_probe_callback errors Benny Halevy
2009-03-12 21:41 ` J. Bruce Fields
2009-03-11 18:52 ` [PATCH 12/14] nfsd4: remove use of mutex for file_hashtable Benny Halevy
2009-03-12 0:05 ` J. Bruce Fields
2009-03-12 10:49 ` Benny Halevy
2009-03-13 17:18 ` J. Bruce Fields
2009-03-18 20:28 ` J. Bruce Fields
2009-03-18 20:40 ` Benny Halevy
2009-03-18 21:03 ` J. Bruce Fields
2009-03-18 21:07 ` Benny Halevy [this message]
2009-03-11 1:52 ` [PATCH 08/14] nfsd4: fail when delegreturn gets a non-delegation stateid Yang Hongyang
2009-03-11 20:07 ` J. Bruce Fields
2009-03-11 18:29 ` Benny Halevy
2009-03-12 0:03 ` J. Bruce Fields
2009-03-11 1:47 ` [PATCH 07/14] nfsd4: separate delegreturn case from preprocess_stateid_op Yang Hongyang
2009-03-11 19:51 ` J. Bruce Fields
2009-03-11 1:12 ` [PATCH 03/14] nfsd4: remove redundant "if" in nfs4_preprocess_stateid_op Yang Hongyang
2009-03-11 1:23 ` J. Bruce Fields
2009-03-11 1:26 ` Yang Hongyang
2009-03-11 18:05 ` Benny Halevy
2009-03-11 19:49 ` J. Bruce Fields
2009-03-11 2:09 ` [PATCH 01/14] nfsd4: trivial preprocess_stateid_op cleanup Yang Hongyang
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=49C162A7.3040505@panasas.com \
--to=bhalevy@panasas.com \
--cc=batsakis@netapp.com \
--cc=bfields@fieldses.org \
--cc=linux-nfs@vger.kernel.org \
/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