btrfs: raid56: handle endio in scrub_rbio
authorChristoph Hellwig <hch@lst.de>
Wed, 11 Jan 2023 06:23:34 +0000 (07:23 +0100)
committerDavid Sterba <dsterba@suse.com>
Wed, 15 Feb 2023 18:38:55 +0000 (19:38 +0100)
The only caller of scrub_rbio calls rbio_orig_end_io right after it,
move it into scrub_rbio to match the other work item helpers.

Reviewed-by: Qu Wenruo <wqu@suse.com>
Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/raid56.c

index d06bdc20551d07b43151ad3eaee503a23e99f7d8..642828c1b299cb11ff94f585626a0dbf6394d734 100644 (file)
@@ -2701,7 +2701,7 @@ static int scrub_assemble_read_bios(struct btrfs_raid_bio *rbio)
        return 0;
 }
 
-static int scrub_rbio(struct btrfs_raid_bio *rbio)
+static void scrub_rbio(struct btrfs_raid_bio *rbio)
 {
        bool need_check = false;
        int sector_nr;
@@ -2709,18 +2709,18 @@ static int scrub_rbio(struct btrfs_raid_bio *rbio)
 
        ret = alloc_rbio_essential_pages(rbio);
        if (ret)
-               return ret;
+               goto out;
 
        bitmap_clear(rbio->error_bitmap, 0, rbio->nr_sectors);
 
        ret = scrub_assemble_read_bios(rbio);
        if (ret < 0)
-               return ret;
+               goto out;
 
        /* We may have some failures, recover the failed sectors first. */
        ret = recover_scrub_rbio(rbio);
        if (ret < 0)
-               return ret;
+               goto out;
 
        /*
         * We have every sector properly prepared. Can finish the scrub
@@ -2737,17 +2737,13 @@ static int scrub_rbio(struct btrfs_raid_bio *rbio)
                        break;
                }
        }
-       return ret;
+out:
+       rbio_orig_end_io(rbio, errno_to_blk_status(ret));
 }
 
 static void scrub_rbio_work_locked(struct work_struct *work)
 {
-       struct btrfs_raid_bio *rbio;
-       int ret;
-
-       rbio = container_of(work, struct btrfs_raid_bio, work);
-       ret = scrub_rbio(rbio);
-       rbio_orig_end_io(rbio, errno_to_blk_status(ret));
+       scrub_rbio(container_of(work, struct btrfs_raid_bio, work));
 }
 
 void raid56_parity_submit_scrub_rbio(struct btrfs_raid_bio *rbio)