From: Fernando Luis Vazquez Cao <fernando_b1@lab.ntt.co.jp>
To: Jan Kara <jack@suse.cz>
Cc: Al Viro <viro@zeniv.linux.org.uk>,
Josef Bacik <jbacik@fusionio.com>,
Eric Sandeen <sandeen@redhat.com>,
Dave Chinner <dchinner@redhat.com>,
Christoph Hellwig <hch@infradead.org>,
linux-fsdevel@vger.kernel.org
Subject: Re: [PATCH 1/9] vfs: add __iterate_supers() and helpers around it
Date: Tue, 25 Sep 2012 19:03:11 +0900 [thread overview]
Message-ID: <5061815F.5070706@lab.ntt.co.jp> (raw)
In-Reply-To: <20120925095248.GE8049@quack.suse.cz>
On 2012/09/25 18:52, Jan Kara wrote:
> On Tue 25-09-12 18:42:16, Fernando Luis Vazquez Cao wrote:
>> On 2012年09月25日 18:11, Jan Kara wrote:
>>> On Fri 14-09-12 15:45:04, Fernando Luis Vázquez Cao wrote:
>>>> iterate_supers() calls a function provided by the caller with the s_umount
>>>> semaphore taken in read mode. However, there may be cases where write mode
>>>> is preferable, so we add __iterate_supers(), which lets one
>>>> specify the mode of the lock, and replace iterate_supers with two helpers
>>>> around __iterate_supers(), iterate_supers_read() and iterate_supers_write().
>>>>
>>>> This will be used to fix the emergency thaw (filesystem unfreeze) code, which
>>>> iterates over the list of superblocks but needs to hold the s_umount semaphore
>>>> in _write_ mode bebore carrying out the actual thaw operation.
>>>>
>>>> This patch introduces no semantic changes since iterate_supers() users become
>>>> iterate_supers_read() which is equivalent.
>>>>
>>>> Cc: Josef Bacik <jbacik@fusionio.com>
>>>> Cc: Eric Sandeen <sandeen@redhat.com>
>>>> Cc: Christoph Hellwig <hch@infradead.org>
>>>> Cc: Jan Kara <jack@suse.cz>
>>>> Cc: Dave Chinner <dchinner@redhat.com>
>>>> Signed-off-by: Fernando Luis Vazquez Cao <fernando@oss.ntt.co.jp>
>>>> ---
>>> ...
>>>> diff -urNp linux-3.6-rc5-orig/fs/super.c linux-3.6-rc5/fs/super.c
>>>> --- linux-3.6-rc5-orig/fs/super.c 2012-09-14 11:53:43.416703312 +0900
>>>> +++ linux-3.6-rc5/fs/super.c 2012-09-14 12:30:52.188833193 +0900
>>>> @@ -537,14 +537,22 @@ void drop_super(struct super_block *sb)
>>>> EXPORT_SYMBOL(drop_super);
>>>> /**
>>>> - * iterate_supers - call function for all active superblocks
>>>> + * __iterate_supers - call function for all active superblocks
>>>> * @f: function to call
>>>> * @arg: argument to pass to it
>>>> + * @wlock: mode of superblock lock (false->read lock, true->write lock)
>>>> *
>>>> * Scans the superblock list and calls given function, passing it
>>>> * locked superblock and given argument.
>>>> + *
>>>> + * When the caller asks for the superblock lock (s_umount semaphore) to be
>>>> + * taken in write mode, the lock is taken but not released because the
>>>> + * function provided by the caller may deactivate the superblock itself.
>>>> + * It is that function's job to unlock the superblock as needed in such a
>>>> + * case.
>>>> */
>>>> -void iterate_supers(void (*f)(struct super_block *, void *), void *arg)
>>>> +static void __iterate_supers(void (*f)(struct super_block *, void *), void *arg,
>>>> + bool wlock)
>>>> {
>>>> struct super_block *sb, *p = NULL;
>>>> @@ -555,10 +563,19 @@ void iterate_supers(void (*f)(struct sup
>>>> sb->s_count++;
>>>> spin_unlock(&sb_lock);
>>>> - down_read(&sb->s_umount);
>>>> + if (wlock)
>>>> + down_write(&sb->s_umount);
>>>> + else
>>>> + down_read(&sb->s_umount);
>>>> +
>>>> if (sb->s_root && (sb->s_flags & MS_BORN))
>>>> f(sb, arg);
>>>> - up_read(&sb->s_umount);
>>>> +
>>>> + /* When the semaphore was taken in write mode the function
>>>> + * provided by the caller takes care of unlocking it as
>>>> + * needed. See explanation above for details. */
>>>> + if (!wlock)
>>>> + up_read(&sb->s_umount);
>>>> spin_lock(&sb_lock);
>>>> if (p)
>>> These locking rules are ugly and counterintuitive. People will easily
>>> get them wrong and create bugs. I'd rather see emergency thaw retake the
>>> s_umount semaphore so that iterate_supers() can drop it...
>> I guess you are referring to treating the write lock differently
>> and not dropping the lock inside __iterate_supers(). The
>> problem is that f() may release the last reference to the
>> superblock which in turn will go away, so letting
>> __iterate_supers() drop the lock is not safe (I added a
>> comment about this issue in the function itself).
> Well, except that iterate_supers() actually takes a passive reference
> (s_count) of the superblock. Thus deactivate_locked_super() will never
> really destroy it. So what I propose should be safe.
Good point. I missed the fact that we are taking a passive
reference there, which should simplifying locking. I will
take that into account for the next revision.
Thanks,
Fernando
--
To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2012-09-25 10:03 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-09-14 6:43 [RFC, PATCH 0/9 v4] fsfreeze: miscellaneous fixes and cleanups Fernando Luis Vázquez Cao
2012-09-14 6:45 ` [PATCH 1/9] vfs: add __iterate_supers() and helpers around it Fernando Luis Vázquez Cao
2012-09-25 9:11 ` Jan Kara
2012-09-25 9:42 ` Fernando Luis Vazquez Cao
2012-09-25 9:52 ` Jan Kara
2012-09-25 10:03 ` Fernando Luis Vazquez Cao [this message]
2012-09-14 6:46 ` [PATCH 2/9] fsfreeze: add unlocked version of thaw_super Fernando Luis Vázquez Cao
2012-09-25 9:13 ` Jan Kara
2012-09-25 9:43 ` Fernando Luis Vazquez Cao
2012-09-14 6:47 ` [PATCH 3/9] fsfreeze: Prevent emergency thaw from looping infinitely Fernando Luis Vázquez Cao
2012-09-14 6:48 ` [PATCH 4/9] fsfreeze: emergency thaw will deadlock on s_umount Fernando Luis Vázquez Cao
2012-09-25 9:24 ` Jan Kara
2012-09-25 10:31 ` Fernando Luis Vazquez Cao
2012-09-14 6:50 ` [PATCH 5/9] xfs: switch to using super methods for fsfreeze Fernando Luis Vázquez Cao
2012-09-14 6:51 ` [PATCH 6/9] fsfreeze: move emergency thaw code to fs/super.c Fernando Luis Vázquez Cao
2012-09-14 6:53 ` [PATCH 7/9] fsfreeze: freeze_super and thaw_bdev don't play well together Fernando Luis Vázquez Cao
2012-09-14 19:20 ` Eric Sandeen
2012-09-15 1:15 ` Eric Sandeen
2012-09-25 9:48 ` Jan Kara
2012-09-25 10:51 ` Fernando Luis Vazquez Cao
2012-09-25 16:39 ` Jan Kara
2012-09-26 8:22 ` Fernando Luis Vazquez Cao
2012-09-26 9:09 ` Jan Kara
2012-10-03 7:58 ` Fernando Luis Vazquez Cao
2012-10-04 8:18 ` Jan Kara
2012-10-05 4:22 ` Fernando Luis Vázquez Cao
2012-10-05 4:30 ` Fernando Luis Vázquez Cao
2012-09-14 6:54 ` [PATCH 8/9] fsfreeze: add vfs ioctl to check freeze state Fernando Luis Vázquez Cao
2012-09-14 6:55 ` [PATCH 9/9] fsfreeze: add block device " Fernando Luis Vázquez Cao
-- strict thread matches above, loose matches on Subject: below --
2012-10-05 5:24 [PATCH 0/9 v5] fsfreeze: miscellaneous fixes and cleanups Fernando Luis Vázquez Cao
2012-10-05 5:31 ` [PATCH 1/9] vfs: add __iterate_supers() and helpers around it Fernando Luis Vázquez Cao
2012-10-08 13:48 ` Jan Kara
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=5061815F.5070706@lab.ntt.co.jp \
--to=fernando_b1@lab.ntt.co.jp \
--cc=dchinner@redhat.com \
--cc=hch@infradead.org \
--cc=jack@suse.cz \
--cc=jbacik@fusionio.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=sandeen@redhat.com \
--cc=viro@zeniv.linux.org.uk \
/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.