btrfs: save the bio iter for checksum validation in common code
authorChristoph Hellwig <hch@lst.de>
Sat, 21 Jan 2023 06:50:04 +0000 (07:50 +0100)
committerDavid Sterba <dsterba@suse.com>
Wed, 15 Feb 2023 18:38:51 +0000 (19:38 +0100)
All callers of btrfs_submit_bio that want to validate checksums
currently have to store a copy of the iter in the btrfs_bio.  Move
the assignment into common code.

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/bio.c
fs/btrfs/compression.c
fs/btrfs/extent_io.c
fs/btrfs/inode.c

index 088817618f57457ce59f7f233af8c027ef6d3c62..8285aa49586a1ace1dbdc863907e2baeb014669f 100644 (file)
@@ -63,7 +63,6 @@ struct bio *btrfs_bio_clone_partial(struct bio *orig, u64 offset, u64 size,
        btrfs_bio_init(bbio, inode, end_io, private);
 
        bio_trim(bio, offset >> 9, size >> 9);
-       bbio->iter = bio->bi_iter;
        return bio;
 }
 
@@ -254,6 +253,10 @@ void btrfs_submit_bio(struct btrfs_fs_info *fs_info, struct bio *bio, int mirror
                BUG();
        }
 
+       /* Save the iter for the end_io handler for data reads. */
+       if (bio_op(bio) == REQ_OP_READ && !(bio->bi_opf & REQ_META))
+               bbio->iter = bio->bi_iter;
+
        if (!bioc) {
                /* Single mirror read/write fast path */
                bbio->mirror_num = mirror_num;
index 069b7d28ca03b3e8ffab11383f332a7f6d9f9a1a..3e504a21e75692bc145f94b99e7691e36402f5ca 100644 (file)
@@ -789,10 +789,6 @@ void btrfs_submit_compressed_read(struct inode *inode, struct bio *bio,
                        submit = true;
 
                if (submit) {
-                       /* Save the original iter for read repair */
-                       if (bio_op(comp_bio) == REQ_OP_READ)
-                               btrfs_bio(comp_bio)->iter = comp_bio->bi_iter;
-
                        /*
                         * Save the initial offset of this chunk, as there
                         * is no direct correlation between compressed pages and
index a8e8567aa4280f34c84fd8be275354b64894e984..1e28ae62d0cee1994f1f571e8c90c6c69c71b657 100644 (file)
@@ -756,7 +756,6 @@ int btrfs_repair_one_sector(struct btrfs_inode *inode, struct btrfs_bio *failed_
        }
 
        bio_add_page(repair_bio, page, failrec->len, pgoff);
-       repair_bbio->iter = repair_bio->bi_iter;
 
        btrfs_debug(fs_info,
                    "repair read error: submitting new read to mirror %d",
index 7c8f5349ed7a4cc635dffe6b3e68f94652551bf3..c368a45bc079d6f13934cea865e96a8e0c9399ed 100644 (file)
@@ -2773,9 +2773,6 @@ void btrfs_submit_data_read_bio(struct btrfs_inode *inode, struct bio *bio,
                return;
        }
 
-       /* Save the original iter for read repair */
-       btrfs_bio(bio)->iter = bio->bi_iter;
-
        /*
         * Lookup bio sums does extra checks around whether we need to csum or
         * not, which is why we ignore skip_sum here.
@@ -7988,10 +7985,6 @@ static void btrfs_submit_dio_bio(struct bio *bio, struct btrfs_inode *inode,
        struct btrfs_fs_info *fs_info = inode->root->fs_info;
        blk_status_t ret;
 
-       /* Save the original iter for read repair */
-       if (btrfs_op(bio) == BTRFS_MAP_READ)
-               btrfs_bio(bio)->iter = bio->bi_iter;
-
        if (inode->flags & BTRFS_INODE_NODATASUM)
                goto map;