From: riteshh <riteshh@linux.ibm.com>
To: Qu Wenruo <quwenruo.btrfs@gmx.com>
Cc: Qu Wenruo <wqu@suse.com>, Ritesh Harjani <ritesh.list@gmail.com>,
Neal Gompa <ngompa13@gmail.com>,
Btrfs BTRFS <linux-btrfs@vger.kernel.org>
Subject: Re: [PATCH v3 00/13] btrfs: support read-write for subpage metadata
Date: Wed, 21 Apr 2021 12:33:31 +0530 [thread overview]
Message-ID: <20210421070331.r4enns6ticwpan35@riteshh-domain> (raw)
In-Reply-To: <344f81af-f36d-1484-3a0c-894d111d0605@gmx.com>
On 21/04/19 09:24PM, Qu Wenruo wrote:
> [...]
> > >
> > > diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c
> > > index 45ec3f5ef839..49f78d643392 100644
> > > --- a/fs/btrfs/file.c
> > > +++ b/fs/btrfs/file.c
> > > @@ -1341,7 +1341,17 @@ static int prepare_uptodate_page(struct inode
> > > *inode,
> > > unlock_page(page);
> > > return -EIO;
> > > }
> > > - if (page->mapping != inode->i_mapping) {
> > > +
> > > + /*
> > > + * Since btrfs_readpage() will get the page unlocked, we
> > > have
> > > + * a window where fadvice() can try to release the page.
> > > + * Here we check both inode mapping and PagePrivate() to
> > > + * make sure the page is not released.
> > > + *
> > > + * The priavte flag check is essential for subpage as we
> > > need
> > > + * to store extra bitmap using page->private.
> > > + */
> > > + if (page->mapping != inode->i_mapping ||
> > > PagePrivate(page)) {
> > ^ Obviously it should be !PagePrivate(page).
>
> Hi Ritesh,
>
> Mind to have another try on generic/095?
>
> This time the branch is updated with the following commit at top:
>
> commit d700b16dced6f2e2b47e1ca5588a92216ce84dfb (HEAD -> subpage,
> github/subpage)
> Author: Qu Wenruo <wqu@suse.com>
> Date: Mon Apr 19 13:41:31 2021 +0800
>
> btrfs: fix a crash caused by race between prepare_pages() and
> btrfs_releasepage()
>
> The fix uses the PagePrivate() check to avoid the problem, and passes
> several generic/auto loops without any sign of crash.
>
> But considering I always have difficult in reproducing the bug with previous
> improper fix, your verification would be very helpful.
>
Hi Qu,
Thanks for the patch. I did try above patch but even with this I could still
reproduce the issue.
1. I think the original problem could be due to below logs.
[ 79.079641] run fstests generic/095 at 2021-04-21 06:46:23
<...>
[ 83.634710] Page cache invalidation failure on direct I/O. Possible data corruption due to collision with buffered I/O!
Meaning, there might be a race here between DIO and buffered IO.
So from DIO path we call invalidate_inode_pages2_range(). Somehow this maybe
causing call of btrfs_releasepage().
Now from code, invalidate_inode_pages2_range() can be called from both
__iomap_dio_rw() and from iomap_dio_complete(). So it is not clear as to from
where this might be triggering this bug.
I will try and debug more. But I thought I will update you with above findings.
-ritesh
next prev parent reply other threads:[~2021-04-21 7:04 UTC|newest]
Thread overview: 62+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-03-25 7:14 [PATCH v3 00/13] btrfs: support read-write for subpage metadata Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 01/13] btrfs: add sysfs interface for supported sectorsize Qu Wenruo
2021-03-25 14:41 ` Anand Jain
2021-03-29 18:20 ` David Sterba
2021-04-01 22:32 ` Anand Jain
2021-04-01 17:56 ` David Sterba
2021-03-25 7:14 ` [PATCH v3 02/13] btrfs: use min() to replace open-code in btrfs_invalidatepage() Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 03/13] btrfs: remove unnecessary variable shadowing " Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 04/13] btrfs: refactor how we iterate ordered extent " Qu Wenruo
2021-04-02 1:15 ` Anand Jain
2021-04-02 3:33 ` Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 05/13] btrfs: introduce helpers for subpage dirty status Qu Wenruo
2021-04-01 18:11 ` David Sterba
2021-03-25 7:14 ` [PATCH v3 06/13] btrfs: introduce helpers for subpage writeback status Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 07/13] btrfs: allow btree_set_page_dirty() to do more sanity check on subpage metadata Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 08/13] btrfs: support subpage metadata csum calculation at write time Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 09/13] btrfs: make alloc_extent_buffer() check subpage dirty bitmap Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 10/13] btrfs: make the page uptodate assert to be subpage compatible Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 11/13] btrfs: make set/clear_extent_buffer_dirty() " Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 12/13] btrfs: make set_btree_ioerr() accept extent buffer and " Qu Wenruo
2021-03-25 7:14 ` [PATCH v3 13/13] btrfs: add subpage overview comments Qu Wenruo
2021-03-25 12:20 ` [PATCH v3 00/13] btrfs: support read-write for subpage metadata Neal Gompa
2021-03-25 13:16 ` Qu Wenruo
2021-03-28 20:02 ` Ritesh Harjani
2021-03-29 2:01 ` Qu Wenruo
2021-04-02 1:39 ` Anand Jain
2021-04-02 3:26 ` Qu Wenruo
2021-04-02 8:33 ` Ritesh Harjani
2021-04-02 8:36 ` Qu Wenruo
2021-04-02 8:46 ` Ritesh Harjani
2021-04-02 8:52 ` Qu Wenruo
2021-04-12 11:33 ` Qu Wenruo
2021-04-15 3:44 ` riteshh
2021-04-15 14:52 ` riteshh
2021-04-15 23:19 ` Qu Wenruo
2021-04-15 23:34 ` Qu Wenruo
2021-04-16 1:34 ` Qu Wenruo
2021-04-16 5:50 ` riteshh
2021-04-16 6:14 ` Qu Wenruo
2021-04-16 16:52 ` riteshh
2021-04-19 5:59 ` riteshh
2021-04-19 6:16 ` Qu Wenruo
2021-04-19 7:04 ` riteshh
2021-04-19 7:19 ` Qu Wenruo
2021-04-19 13:24 ` Qu Wenruo
2021-04-21 7:03 ` riteshh [this message]
2021-04-21 7:15 ` Qu Wenruo
2021-04-21 7:30 ` riteshh
2021-04-21 8:26 ` Qu Wenruo
2021-04-21 11:13 ` riteshh
2021-04-21 11:42 ` Qu Wenruo
2021-04-21 12:15 ` riteshh
2021-03-29 18:53 ` David Sterba
2021-04-01 5:36 ` Qu Wenruo
2021-04-01 17:55 ` David Sterba
2021-04-02 1:27 ` Anand Jain
2021-04-03 11:08 ` David Sterba
2021-04-05 6:14 ` Qu Wenruo
2021-04-06 2:31 ` Anand Jain
2021-04-06 19:20 ` David Sterba
2021-04-06 23:59 ` Qu Wenruo
2021-04-06 19:13 ` David Sterba
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=20210421070331.r4enns6ticwpan35@riteshh-domain \
--to=riteshh@linux.ibm.com \
--cc=linux-btrfs@vger.kernel.org \
--cc=ngompa13@gmail.com \
--cc=quwenruo.btrfs@gmx.com \
--cc=ritesh.list@gmail.com \
--cc=wqu@suse.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).