gfs2: Add gfs2_aspace_writepages()
authorMatthew Wilcox (Oracle) <willy@infradead.org>
Fri, 19 Jul 2024 17:51:01 +0000 (18:51 +0100)
committerAndreas Gruenbacher <agruenba@redhat.com>
Mon, 2 Sep 2024 12:46:21 +0000 (14:46 +0200)
This saves one indirect function call per folio and gets us closer to
removing aops->writepage.

Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
fs/gfs2/meta_io.c

index 2b26e8d529aa1e9bd36f8dfbacbd686c0489ce2f..cfb204c9396c91a5158b853a5b0a148eb9c95de9 100644 (file)
@@ -30,9 +30,9 @@
 #include "util.h"
 #include "trace_gfs2.h"
 
-static int gfs2_aspace_writepage(struct page *page, struct writeback_control *wbc)
+static void gfs2_aspace_write_folio(struct folio *folio,
+               struct writeback_control *wbc)
 {
-       struct folio *folio = page_folio(page);
        struct buffer_head *bh, *head;
        int nr_underway = 0;
        blk_opf_t write_flags = REQ_META | REQ_PRIO | wbc_to_write_flags(wbc);
@@ -66,8 +66,8 @@ static int gfs2_aspace_writepage(struct page *page, struct writeback_control *wb
        } while ((bh = bh->b_this_page) != head);
 
        /*
-        * The page and its buffers are protected by PageWriteback(), so we can
-        * drop the bh refcounts early.
+        * The folio and its buffers are protected from truncation by
+        * the writeback flag, so we can drop the bh refcounts early.
         */
        BUG_ON(folio_test_writeback(folio));
        folio_start_writeback(folio);
@@ -84,14 +84,31 @@ static int gfs2_aspace_writepage(struct page *page, struct writeback_control *wb
 
        if (nr_underway == 0)
                folio_end_writeback(folio);
+}
+
+static int gfs2_aspace_writepage(struct page *page, struct writeback_control *wbc)
+{
+       gfs2_aspace_write_folio(page_folio(page), wbc);
 
        return 0;
 }
 
+static int gfs2_aspace_writepages(struct address_space *mapping,
+               struct writeback_control *wbc)
+{
+       struct folio *folio = NULL;
+       int error;
+
+       while ((folio = writeback_iter(mapping, wbc, folio, &error)))
+               gfs2_aspace_write_folio(folio, wbc);
+
+       return error;
+}
+
 const struct address_space_operations gfs2_meta_aops = {
        .dirty_folio    = block_dirty_folio,
        .invalidate_folio = block_invalidate_folio,
-       .writepage = gfs2_aspace_writepage,
+       .writepages = gfs2_aspace_writepages,
        .release_folio = gfs2_release_folio,
 };
 
@@ -99,6 +116,7 @@ const struct address_space_operations gfs2_rgrp_aops = {
        .dirty_folio    = block_dirty_folio,
        .invalidate_folio = block_invalidate_folio,
        .writepage = gfs2_aspace_writepage,
+       .writepages = gfs2_aspace_writepages,
        .release_folio = gfs2_release_folio,
 };