f2fs: use find_get_pages_tag() for looking up single page
authorJan Kara <jack@suse.cz>
Thu, 16 Nov 2017 01:34:55 +0000 (17:34 -0800)
committerLinus Torvalds <torvalds@linux-foundation.org>
Thu, 16 Nov 2017 02:21:04 +0000 (18:21 -0800)
__get_first_dirty_index() wants to lookup only the first dirty page
after given index.  There's no point in using pagevec_lookup_tag() for
that.  Just use find_get_pages_tag() directly.

Link: http://lkml.kernel.org/r/20171009151359.31984-8-jack@suse.cz
Signed-off-by: Jan Kara <jack@suse.cz>
Reviewed-by: Chao Yu <yuchao0@huawei.com>
Reviewed-by: Daniel Jordan <daniel.m.jordan@oracle.com>
Cc: Jaegeuk Kim <jaegeuk@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
fs/f2fs/file.c

index 517e112c8a9a943467492435c9f15c1668e079a8..f78b76ec4707032ae3c57337ee4b689bb26613d5 100644 (file)
@@ -313,18 +313,19 @@ int f2fs_sync_file(struct file *file, loff_t start, loff_t end, int datasync)
 static pgoff_t __get_first_dirty_index(struct address_space *mapping,
                                                pgoff_t pgofs, int whence)
 {
-       struct pagevec pvec;
+       struct page *page;
        int nr_pages;
 
        if (whence != SEEK_DATA)
                return 0;
 
        /* find first dirty page index */
-       pagevec_init(&pvec, 0);
-       nr_pages = pagevec_lookup_tag(&pvec, mapping, &pgofs,
-                                       PAGECACHE_TAG_DIRTY, 1);
-       pgofs = nr_pages ? pvec.pages[0]->index : ULONG_MAX;
-       pagevec_release(&pvec);
+       nr_pages = find_get_pages_tag(mapping, &pgofs, PAGECACHE_TAG_DIRTY,
+                                     1, &page);
+       if (!nr_pages)
+               return ULONG_MAX;
+       pgofs = page->index;
+       put_page(page);
        return pgofs;
 }