提交 f7b68046 编写于 作者: J Jan Kara 提交者: Linus Torvalds

mm: use find_get_pages_range() in filemap_range_has_page()

We want only pages from given range in filemap_range_has_page(),
furthermore we want at most a single page.

So use find_get_pages_range() instead of pagevec_lookup() and remove
unnecessary code.

Link: http://lkml.kernel.org/r/20170726114704.7626-10-jack@suse.czSigned-off-by: NJan Kara <jack@suse.cz>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 8338141f
...@@ -393,8 +393,7 @@ bool filemap_range_has_page(struct address_space *mapping, ...@@ -393,8 +393,7 @@ bool filemap_range_has_page(struct address_space *mapping,
{ {
pgoff_t index = start_byte >> PAGE_SHIFT; pgoff_t index = start_byte >> PAGE_SHIFT;
pgoff_t end = end_byte >> PAGE_SHIFT; pgoff_t end = end_byte >> PAGE_SHIFT;
struct pagevec pvec; struct page *page;
bool ret;
if (end_byte < start_byte) if (end_byte < start_byte)
return false; return false;
...@@ -402,12 +401,10 @@ bool filemap_range_has_page(struct address_space *mapping, ...@@ -402,12 +401,10 @@ bool filemap_range_has_page(struct address_space *mapping,
if (mapping->nrpages == 0) if (mapping->nrpages == 0)
return false; return false;
pagevec_init(&pvec, 0); if (!find_get_pages_range(mapping, &index, end, 1, &page))
if (!pagevec_lookup(&pvec, mapping, &index, 1))
return false; return false;
ret = (pvec.pages[0]->index <= end); put_page(page);
pagevec_release(&pvec); return true;
return ret;
} }
EXPORT_SYMBOL(filemap_range_has_page); EXPORT_SYMBOL(filemap_range_has_page);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册