]> git.proxmox.com Git - mirror_ubuntu-zesty-kernel.git/commitdiff
btrfs: refactor __btrfs_lookup_bio_sums to use bio_for_each_segment_all
authorChristoph Hellwig <hch@lst.de>
Fri, 25 Nov 2016 08:07:52 +0000 (09:07 +0100)
committerDavid Sterba <dsterba@suse.com>
Wed, 30 Nov 2016 12:45:20 +0000 (13:45 +0100)
Rework the loop a little bit to use the generic bio_for_each_segment_all
helper for iterating over the bio.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Omar Sandoval <osandov@fb.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/file-item.c

index fad3804fc3357691fdadd48b1e931f48ae6d314d..5e74178ba9d994c45a8c3efcc0afe9bb4dc42245 100644 (file)
@@ -163,7 +163,7 @@ static int __btrfs_lookup_bio_sums(struct btrfs_root *root,
                                   struct inode *inode, struct bio *bio,
                                   u64 logical_offset, u32 *dst, int dio)
 {
-       struct bio_vec *bvec = bio->bi_io_vec;
+       struct bio_vec *bvec;
        struct btrfs_io_bio *btrfs_bio = btrfs_io_bio(bio);
        struct btrfs_csum_item *item = NULL;
        struct extent_io_tree *io_tree = &BTRFS_I(inode)->io_tree;
@@ -176,8 +176,7 @@ static int __btrfs_lookup_bio_sums(struct btrfs_root *root,
        u64 page_bytes_left;
        u32 diff;
        int nblocks;
-       int bio_index = 0;
-       int count;
+       int count = 0, i;
        u16 csum_size = btrfs_super_csum_size(root->fs_info->super_copy);
 
        path = btrfs_alloc_path();
@@ -223,8 +222,11 @@ static int __btrfs_lookup_bio_sums(struct btrfs_root *root,
        if (dio)
                offset = logical_offset;
 
-       page_bytes_left = bvec->bv_len;
-       while (bio_index < bio->bi_vcnt) {
+       bio_for_each_segment_all(bvec, bio, i) {
+               page_bytes_left = bvec->bv_len;
+               if (count)
+                       goto next;
+
                if (!dio)
                        offset = page_offset(bvec->bv_page) + bvec->bv_offset;
                count = btrfs_find_ordered_sum(inode, offset, disk_bytenr,
@@ -285,29 +287,17 @@ static int __btrfs_lookup_bio_sums(struct btrfs_root *root,
 found:
                csum += count * csum_size;
                nblocks -= count;
-
+next:
                while (count--) {
                        disk_bytenr += root->sectorsize;
                        offset += root->sectorsize;
                        page_bytes_left -= root->sectorsize;
-                       if (!page_bytes_left) {
-                               bio_index++;
-                               /*
-                                * make sure we're still inside the
-                                * bio before we update page_bytes_left
-                                */
-                               if (bio_index >= bio->bi_vcnt) {
-                                       WARN_ON_ONCE(count);
-                                       goto done;
-                               }
-                               bvec++;
-                               page_bytes_left = bvec->bv_len;
-                       }
-
+                       if (!page_bytes_left)
+                               break; /* move to next bio */
                }
        }
 
-done:
+       WARN_ON_ONCE(count);
        btrfs_free_path(path);
        return 0;
 }