From: Brian Foster <bfoster@redhat.com>
To: "Darrick J. Wong" <djwong@kernel.org>
Cc: linux-fsdevel@vger.kernel.org, linux-xfs@vger.kernel.org,
linux-mm@kvack.org
Subject: Re: [PATCH 2/7] filemap: add helper to look up dirty folios in a range
Date: Tue, 10 Jun 2025 08:17:45 -0400 [thread overview]
Message-ID: <aEgiaXohtmidV3T9@bfoster> (raw)
In-Reply-To: <20250609154802.GB6156@frogsfrogsfrogs>
On Mon, Jun 09, 2025 at 08:48:02AM -0700, Darrick J. Wong wrote:
> On Thu, Jun 05, 2025 at 01:33:52PM -0400, Brian Foster wrote:
> > Add a new filemap_get_folios_dirty() helper to look up existing dirty
> > folios in a range and add them to a folio_batch. This is to support
> > optimization of certain iomap operations that only care about dirty
> > folios in a target range. For example, zero range only zeroes the subset
> > of dirty pages over unwritten mappings, seek hole/data may use similar
> > logic in the future, etc.
> >
> > Note that the helper is intended for use under internal fs locks.
> > Therefore it trylocks folios in order to filter out clean folios.
> > This loosely follows the logic from filemap_range_has_writeback().
> >
> > Signed-off-by: Brian Foster <bfoster@redhat.com>
>
> You might want to cc willy directly on this one...
Er yeah, I'll do that for v2.
> > ---
> > include/linux/pagemap.h | 2 ++
> > mm/filemap.c | 42 +++++++++++++++++++++++++++++++++++++++++
> > 2 files changed, 44 insertions(+)
> >
...
> > diff --git a/mm/filemap.c b/mm/filemap.c
> > index bada249b9fb7..d28e984cdfd4 100644
> > --- a/mm/filemap.c
> > +++ b/mm/filemap.c
> > @@ -2334,6 +2334,48 @@ unsigned filemap_get_folios_tag(struct address_space *mapping, pgoff_t *start,
> > }
> > EXPORT_SYMBOL(filemap_get_folios_tag);
> >
> > +unsigned filemap_get_folios_dirty(struct address_space *mapping, pgoff_t *start,
> > + pgoff_t end, struct folio_batch *fbatch)
>
> This ought to have a comment explaining what the function does.
> It identifies every folio starting at @*start and ending before @end
> that is dirty and tries to assign them to @fbatch, right?
>
Yep, or at least every folio that starts before end. I'll add a comment
and incorporate all the followup feedback. Thanks.
Brian
> The code looks reasonable to me; hopefully there aren't some subtleties
> that I'm missing here :P
>
> > +{
> > + XA_STATE(xas, &mapping->i_pages, *start);
> > + struct folio *folio;
> > +
> > + rcu_read_lock();
> > + while ((folio = find_get_entry(&xas, end, XA_PRESENT)) != NULL) {
> > + if (xa_is_value(folio))
> > + continue;
> > + if (folio_trylock(folio)) {
> > + bool clean = !folio_test_dirty(folio) &&
> > + !folio_test_writeback(folio);
> > + folio_unlock(folio);
> > + if (clean) {
> > + folio_put(folio);
> > + continue;
> > + }
> > + }
> > + if (!folio_batch_add(fbatch, folio)) {
> > + unsigned long nr = folio_nr_pages(folio);
> > + *start = folio->index + nr;
> > + goto out;
> > + }
> > + }
> > + /*
> > + * We come here when there is no page beyond @end. We take care to not
>
> ...no folio beyond @end?
>
> --D
>
> > + * overflow the index @start as it confuses some of the callers. This
> > + * breaks the iteration when there is a page at index -1 but that is
> > + * already broke anyway.
> > + */
> > + if (end == (pgoff_t)-1)
> > + *start = (pgoff_t)-1;
> > + else
> > + *start = end + 1;
> > +out:
> > + rcu_read_unlock();
> > +
> > + return folio_batch_count(fbatch);
> > +}
> > +EXPORT_SYMBOL(filemap_get_folios_dirty);
> > +
> > /*
> > * CD/DVDs are error prone. When a medium error occurs, the driver may fail
> > * a _large_ part of the i/o request. Imagine the worst scenario:
> > --
> > 2.49.0
> >
> >
>
next prev parent reply other threads:[~2025-06-10 12:14 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-06-05 17:33 [PATCH 0/7] iomap: zero range folio batch support Brian Foster
2025-06-05 17:33 ` [PATCH 1/7] iomap: move pos+len BUG_ON() to after folio lookup Brian Foster
2025-06-09 16:16 ` Darrick J. Wong
2025-06-10 4:20 ` Christoph Hellwig
2025-06-10 12:16 ` Brian Foster
2025-06-05 17:33 ` [PATCH 2/7] filemap: add helper to look up dirty folios in a range Brian Foster
2025-06-09 15:48 ` Darrick J. Wong
2025-06-10 4:21 ` Christoph Hellwig
2025-06-10 12:17 ` Brian Foster [this message]
2025-06-10 4:22 ` Christoph Hellwig
2025-06-05 17:33 ` [PATCH 3/7] iomap: optional zero range dirty folio processing Brian Foster
2025-06-09 16:04 ` Darrick J. Wong
2025-06-10 4:27 ` Christoph Hellwig
2025-06-10 12:21 ` Brian Foster
2025-06-10 12:21 ` Brian Foster
2025-06-10 13:29 ` Christoph Hellwig
2025-06-10 14:19 ` Brian Foster
2025-06-11 3:54 ` Christoph Hellwig
2025-06-10 14:55 ` Darrick J. Wong
2025-06-11 3:55 ` Christoph Hellwig
2025-06-12 4:06 ` Darrick J. Wong
2025-06-10 4:27 ` Christoph Hellwig
2025-06-05 17:33 ` [PATCH 4/7] xfs: always trim mapping to requested range for zero range Brian Foster
2025-06-09 16:07 ` Darrick J. Wong
2025-06-05 17:33 ` [PATCH 5/7] xfs: fill dirty folios on zero range of unwritten mappings Brian Foster
2025-06-06 2:02 ` kernel test robot
2025-06-06 15:20 ` Brian Foster
2025-06-09 16:12 ` Darrick J. Wong
2025-06-10 4:31 ` Christoph Hellwig
2025-06-10 12:24 ` Brian Foster
2025-07-02 18:50 ` Darrick J. Wong
2025-06-05 17:33 ` [PATCH 6/7] iomap: remove old partial eof zeroing optimization Brian Foster
2025-06-10 4:32 ` Christoph Hellwig
2025-06-05 17:33 ` [PATCH RFC 7/7] xfs: error tag to force zeroing on debug kernels Brian Foster
2025-06-10 4:33 ` Christoph Hellwig
2025-06-10 12:26 ` Brian Foster
2025-06-10 13:30 ` Christoph Hellwig
2025-06-10 14:20 ` Brian Foster
2025-06-10 19:12 ` Brian Foster
2025-06-11 3:56 ` Christoph Hellwig
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=aEgiaXohtmidV3T9@bfoster \
--to=bfoster@redhat.com \
--cc=djwong@kernel.org \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=linux-xfs@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 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.