static blk_status_t btrfs_bio_csum(struct btrfs_bio *bbio)
 {
        if (bbio->bio.bi_opf & REQ_META)
-               return btree_csum_one_bio(&bbio->bio);
+               return btree_csum_one_bio(bbio);
        return btrfs_csum_one_bio(bbio);
 }
 
 
        return csum_one_extent_buffer(eb);
 }
 
-blk_status_t btree_csum_one_bio(struct bio *bio)
+blk_status_t btree_csum_one_bio(struct btrfs_bio *bbio)
 {
-       struct bio_vec *bvec;
-       struct btrfs_root *root;
-       struct bvec_iter_all iter_all;
+       struct btrfs_fs_info *fs_info = bbio->inode->root->fs_info;
+       struct bvec_iter iter;
+       struct bio_vec bv;
        int ret = 0;
 
-       ASSERT(!bio_flagged(bio, BIO_CLONED));
-       bio_for_each_segment_all(bvec, bio, iter_all) {
-               root = BTRFS_I(bvec->bv_page->mapping->host)->root;
-               ret = csum_dirty_buffer(root->fs_info, bvec);
+       bio_for_each_segment(bv, &bbio->bio, iter) {
+               ret = csum_dirty_buffer(fs_info, &bv);
                if (ret)
                        break;
        }
 
 int btrfs_read_extent_buffer(struct extent_buffer *buf,
                             struct btrfs_tree_parent_check *check);
 
-blk_status_t btree_csum_one_bio(struct bio *bio);
+blk_status_t btree_csum_one_bio(struct btrfs_bio *bbio);
 int btrfs_alloc_log_tree_node(struct btrfs_trans_handle *trans,
                              struct btrfs_root *root);
 int btrfs_init_log_root_tree(struct btrfs_trans_handle *trans,