From: Al Viro <viro@ZenIV.linux.org.uk>
To: Peter Zijlstra <peterz@infradead.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>,
Chris Mason <clm@fb.com>,
linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org,
David Howells <dhowells@redhat.com>,
elena.reshetova@intel.com, ishkamiel@gmail.com,
dwindsor@gmail.com, gregkh@linuxfoundation.org
Subject: Re: [RFC][PATCH 00/10] On inode::i_count and the usage vs reference count issue
Date: Fri, 24 Feb 2017 20:42:27 +0000 [thread overview]
Message-ID: <20170224204227.GN29622@ZenIV.linux.org.uk> (raw)
In-Reply-To: <20170224154329.478276481@infradead.org>
On Fri, Feb 24, 2017 at 04:43:29PM +0100, Peter Zijlstra wrote:
> There's a number of options here:
>
> - I'm not completely insane, and these patches can be made to work.
>
> - We decide usage-counts are useful and try and support them in refcount_t;
> this has the down-side that people can more easily write bad code (by doing
> from 0 increments that should not have happened).
>
> - We decide usage-counts need their own type (urgh, more...).
>
> - None of the above, we keep i_count as is and let people hunt and convert
> actual refcounts.
The last one; if some object has non-trivial lifetime rules, don't try to
shoehorn it into refcount_t. VFS-side the same goes for
struct dentry (non-trivial lifetime and locking rules)
struct mount (per-CPU fun, barriers, etc.)
struct super_block (non-trivial lifecycle and lifetime rules)
I'm not sure if struct file is a good match, BTW - net/unix/garbage.c would
be one place in need of a careful looking into if we went for it.
prev parent reply other threads:[~2017-02-24 20:42 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-02-24 15:43 [RFC][PATCH 00/10] On inode::i_count and the usage vs reference count issue Peter Zijlstra
2017-02-24 15:43 ` [RFC][PATCH 01/10] fs: Use lockdep_assert_held() instead of comments Peter Zijlstra
2017-02-24 15:43 ` [RFC][PATCH 02/10] fs: Avoid looking at i_count without i_lock held Peter Zijlstra
[not found] ` <CA+55aFxLw8FXf61rsGYDjA1tS=joDeaF7OSgaepLWwcz4zt=dg@mail.gmail.com>
2017-02-24 17:06 ` Peter Zijlstra
2017-02-24 15:43 ` [RFC][PATCH 03/10] fs: Introduce i_count() Peter Zijlstra
2017-02-24 15:43 ` [RFC][PATCH 04/10] fs: Restructure iput() Peter Zijlstra
2017-02-24 15:43 ` [RFC][PATCH 05/10] fs: Remove iput_final() Peter Zijlstra
2017-02-24 15:43 ` [RFC][PATCH 06/10] fs: Rework i_count Peter Zijlstra
2017-02-24 20:49 ` Al Viro
2017-02-24 15:43 ` [RFC][PATCH 07/10] orangefs: Use RCU for destroy_inode Peter Zijlstra
2017-02-24 20:52 ` Al Viro
2017-02-24 23:00 ` Mike Marshall
2017-02-25 20:31 ` Mike Marshall
2017-02-27 0:34 ` Mike Marshall
2017-02-27 1:20 ` Linus Torvalds
2017-02-27 8:44 ` David Howells
2017-02-27 14:44 ` Mike Marshall
2017-02-24 15:43 ` [RFC][PATCH 08/10] fs: Do RCU versions for find_inode() Peter Zijlstra
2017-02-24 15:43 ` [RFC][PATCH 09/10] locking/refcount: Provide refcount_dec_unless() Peter Zijlstra
2017-02-27 9:28 ` Reshetova, Elena
2017-02-24 15:43 ` [RFC][PATCH 10/10] fs: Convert i_count over to refcount_t Peter Zijlstra
2017-02-24 16:43 ` [RFC][PATCH 00/10] On inode::i_count and the usage vs reference count issue Christoph Hellwig
2017-02-24 17:07 ` Peter Zijlstra
2017-02-24 20:59 ` David Windsor
[not found] ` <CA+55aFy1bNbsX_3T-s_EUwTP-r_SmJJMvB3=-2nffehFVP=EdQ@mail.gmail.com>
[not found] ` <CA+55aFz0DbAGZ8gc+s35nm1N5frXjK_NOh7QzuSfZeJbjsT6Sg@mail.gmail.com>
[not found] ` <CA+55aFyR8wkHps5_AqUqzx8MDMNxRZZ7+MYH9g=ZCUi=4Oey8w@mail.gmail.com>
2017-02-24 19:24 ` Fwd: " Linus Torvalds
2017-02-24 20:42 ` Al Viro [this message]
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=20170224204227.GN29622@ZenIV.linux.org.uk \
--to=viro@zeniv.linux.org.uk \
--cc=clm@fb.com \
--cc=dhowells@redhat.com \
--cc=dwindsor@gmail.com \
--cc=elena.reshetova@intel.com \
--cc=gregkh@linuxfoundation.org \
--cc=ishkamiel@gmail.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=peterz@infradead.org \
--cc=torvalds@linux-foundation.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 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.