Skip to content

Commit

Permalink
page cache: Convert filemap_range_has_page to XArray
Browse files Browse the repository at this point in the history
Instead of calling find_get_pages_range() and putting any reference,
use xas_find() to iterate over any entries in the range, skipping the
shadow/swap entries.

Signed-off-by: Matthew Wilcox <[email protected]>
  • Loading branch information
Matthew Wilcox committed Oct 21, 2018
1 parent 22ecdb4 commit 8fa8e53
Showing 1 changed file with 19 additions and 8 deletions.
27 changes: 19 additions & 8 deletions mm/filemap.c
Original file line number Diff line number Diff line change
Expand Up @@ -455,20 +455,31 @@ EXPORT_SYMBOL(filemap_flush);
bool filemap_range_has_page(struct address_space *mapping,
loff_t start_byte, loff_t end_byte)
{
pgoff_t index = start_byte >> PAGE_SHIFT;
pgoff_t end = end_byte >> PAGE_SHIFT;
struct page *page;
XA_STATE(xas, &mapping->i_pages, start_byte >> PAGE_SHIFT);
pgoff_t max = end_byte >> PAGE_SHIFT;

if (end_byte < start_byte)
return false;

if (mapping->nrpages == 0)
return false;
rcu_read_lock();
for (;;) {
page = xas_find(&xas, max);
if (xas_retry(&xas, page))
continue;
/* Shadow entries don't count */
if (xa_is_value(page))
continue;
/*
* We don't need to try to pin this page; we're about to
* release the RCU lock anyway. It is enough to know that
* there was a page here recently.
*/
break;
}
rcu_read_unlock();

if (!find_get_pages_range(mapping, &index, end, 1, &page))
return false;
put_page(page);
return true;
return page != NULL;
}
EXPORT_SYMBOL(filemap_range_has_page);

Expand Down

0 comments on commit 8fa8e53

Please sign in to comment.