]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
gfs2: use bdev_rw_virt in gfs2_read_super
authorChristoph Hellwig <hch@lst.de>
Wed, 7 May 2025 12:04:34 +0000 (14:04 +0200)
committerJens Axboe <axboe@kernel.dk>
Wed, 7 May 2025 13:31:07 +0000 (07:31 -0600)
Switch gfs2_read_super to allocate the superblock buffer using kmalloc
which falls back to the page allocator for PAGE_SIZE allocation but
gives us a kernel virtual address and then use bdev_rw_virt to perform
the synchronous read into it.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Andreas Gruenbacher <agruenba@redhat.com>
Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
Link: https://lore.kernel.org/r/20250507120451.4000627-11-hch@lst.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
fs/gfs2/ops_fstype.c

index e83d293c361423493ca94059ad64e089859746af..7c1014ba7ac79f1a231d38dc3cf2a3806ad23d98 100644 (file)
@@ -226,28 +226,22 @@ static void gfs2_sb_in(struct gfs2_sbd *sdp, const struct gfs2_sb *str)
 
 static int gfs2_read_super(struct gfs2_sbd *sdp, sector_t sector, int silent)
 {
-       struct super_block *sb = sdp->sd_vfs;
-       struct page *page;
-       struct bio_vec bvec;
-       struct bio bio;
+       struct gfs2_sb *sb;
        int err;
 
-       page = alloc_page(GFP_KERNEL);
-       if (unlikely(!page))
+       sb = kmalloc(PAGE_SIZE, GFP_KERNEL);
+       if (unlikely(!sb))
                return -ENOMEM;
-
-       bio_init(&bio, sb->s_bdev, &bvec, 1, REQ_OP_READ | REQ_META);
-       bio.bi_iter.bi_sector = sector * (sb->s_blocksize >> 9);
-       __bio_add_page(&bio, page, PAGE_SIZE, 0);
-
-       err = submit_bio_wait(&bio);
+       err = bdev_rw_virt(sdp->sd_vfs->s_bdev,
+                       sector * (sdp->sd_vfs->s_blocksize >> 9), sb, PAGE_SIZE,
+                       REQ_OP_READ | REQ_META);
        if (err) {
                pr_warn("error %d reading superblock\n", err);
-               __free_page(page);
+               kfree(sb);
                return err;
        }
-       gfs2_sb_in(sdp, page_address(page));
-       __free_page(page);
+       gfs2_sb_in(sdp, sb);
+       kfree(sb);
        return gfs2_check_sb(sdp, silent);
 }