bool do_balance, enum iostat_type io_type)
 {
        pgoff_t index;
-       struct pagevec pvec;
+       struct folio_batch fbatch;
        int step = 0;
        int nwritten = 0;
        int ret = 0;
-       int nr_pages, done = 0;
+       int nr_folios, done = 0;
 
-       pagevec_init(&pvec);
+       folio_batch_init(&fbatch);
 
 next_step:
        index = 0;
 
-       while (!done && (nr_pages = pagevec_lookup_tag(&pvec,
-                       NODE_MAPPING(sbi), &index, PAGECACHE_TAG_DIRTY))) {
+       while (!done && (nr_folios = filemap_get_folios_tag(NODE_MAPPING(sbi),
+                               &index, (pgoff_t)-1, PAGECACHE_TAG_DIRTY,
+                               &fbatch))) {
                int i;
 
-               for (i = 0; i < nr_pages; i++) {
-                       struct page *page = pvec.pages[i];
+               for (i = 0; i < nr_folios; i++) {
+                       struct page *page = &fbatch.folios[i]->page;
                        bool submitted = false;
 
                        /* give a priority to WB_SYNC threads */
                        if (--wbc->nr_to_write == 0)
                                break;
                }
-               pagevec_release(&pvec);
+               folio_batch_release(&fbatch);
                cond_resched();
 
                if (wbc->nr_to_write == 0) {