Commit bafd7e9d authored by Pankaj Raghav's avatar Pankaj Raghav Committed by Andrew Morton

filemap: call filemap_get_folios_tag() from filemap_get_folios()

filemap_get_folios() is filemap_get_folios_tag() with XA_PRESENT as the
tag that is being matched.  Return filemap_get_folios_tag() with
XA_PRESENT as the tag instead of duplicating the code in
filemap_get_folios().

No functional changes.

Link: https://lkml.kernel.org/r/20231006110120.136809-1-kernel@pankajraghav.comSigned-off-by: default avatarPankaj Raghav <p.raghav@samsung.com>
Reviewed-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 0dfca313
...@@ -2120,48 +2120,13 @@ unsigned find_lock_entries(struct address_space *mapping, pgoff_t *start, ...@@ -2120,48 +2120,13 @@ unsigned find_lock_entries(struct address_space *mapping, pgoff_t *start,
* index @start and up to index @end (inclusive). The folios are returned * index @start and up to index @end (inclusive). The folios are returned
* in @fbatch with an elevated reference count. * in @fbatch with an elevated reference count.
* *
* The first folio may start before @start; if it does, it will contain
* @start. The final folio may extend beyond @end; if it does, it will
* contain @end. The folios have ascending indices. There may be gaps
* between the folios if there are indices which have no folio in the
* page cache. If folios are added to or removed from the page cache
* while this is running, they may or may not be found by this call.
*
* Return: The number of folios which were found. * Return: The number of folios which were found.
* We also update @start to index the next folio for the traversal. * We also update @start to index the next folio for the traversal.
*/ */
unsigned filemap_get_folios(struct address_space *mapping, pgoff_t *start, unsigned filemap_get_folios(struct address_space *mapping, pgoff_t *start,
pgoff_t end, struct folio_batch *fbatch) pgoff_t end, struct folio_batch *fbatch)
{ {
XA_STATE(xas, &mapping->i_pages, *start); return filemap_get_folios_tag(mapping, start, end, XA_PRESENT, fbatch);
struct folio *folio;
rcu_read_lock();
while ((folio = find_get_entry(&xas, end, XA_PRESENT)) != NULL) {
/* Skip over shadow, swap and DAX entries */
if (xa_is_value(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
* 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 broken 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); EXPORT_SYMBOL(filemap_get_folios);
...@@ -2240,7 +2205,13 @@ EXPORT_SYMBOL(filemap_get_folios_contig); ...@@ -2240,7 +2205,13 @@ EXPORT_SYMBOL(filemap_get_folios_contig);
* @tag: The tag index * @tag: The tag index
* @fbatch: The batch to fill * @fbatch: The batch to fill
* *
* Same as filemap_get_folios(), but only returning folios tagged with @tag. * The first folio may start before @start; if it does, it will contain
* @start. The final folio may extend beyond @end; if it does, it will
* contain @end. The folios have ascending indices. There may be gaps
* between the folios if there are indices which have no folio in the
* page cache. If folios are added to or removed from the page cache
* while this is running, they may or may not be found by this call.
* Only returns folios that are tagged with @tag.
* *
* Return: The number of folios found. * Return: The number of folios found.
* Also update @start to index the next folio for traversal. * Also update @start to index the next folio for traversal.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment