aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/inode.c
diff options
context:
space:
mode:
authorKent Overstreet <kmo@daterainc.com>2013-11-07 15:20:26 -0500
committerKent Overstreet <kmo@daterainc.com>2013-11-24 01:33:46 -0500
commit2c30c71bd653afcbed7f6754e8fe3d16e0e708a1 (patch)
treea6b1147e4302b7216600c397cb47ca7f7f375a43 /fs/btrfs/inode.c
parent33879d4512c021ae65be9706608dacb36b4687b1 (diff)
block: Convert various code to bio_for_each_segment()
With immutable biovecs we don't want code accessing bi_io_vec directly - the uses this patch changes weren't incorrect since they all own the bio, but it makes the code harder to audit for no good reason - also, this will help with multipage bvecs later. Signed-off-by: Kent Overstreet <kmo@daterainc.com> Cc: Jens Axboe <axboe@kernel.dk> Cc: Alexander Viro <viro@zeniv.linux.org.uk> Cc: Chris Mason <chris.mason@fusionio.com> Cc: Jaegeuk Kim <jaegeuk.kim@samsung.com> Cc: Joern Engel <joern@logfs.org> Cc: Prasad Joshi <prasadjoshi.linux@gmail.com> Cc: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/btrfs/inode.c')
-rw-r--r--fs/btrfs/inode.c15
1 files changed, 6 insertions, 9 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index f1a77449d032..d6630dc130ba 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -6779,17 +6779,16 @@ unlock_err:
6779static void btrfs_endio_direct_read(struct bio *bio, int err) 6779static void btrfs_endio_direct_read(struct bio *bio, int err)
6780{ 6780{
6781 struct btrfs_dio_private *dip = bio->bi_private; 6781 struct btrfs_dio_private *dip = bio->bi_private;
6782 struct bio_vec *bvec_end = bio->bi_io_vec + bio->bi_vcnt - 1; 6782 struct bio_vec *bvec;
6783 struct bio_vec *bvec = bio->bi_io_vec;
6784 struct inode *inode = dip->inode; 6783 struct inode *inode = dip->inode;
6785 struct btrfs_root *root = BTRFS_I(inode)->root; 6784 struct btrfs_root *root = BTRFS_I(inode)->root;
6786 struct bio *dio_bio; 6785 struct bio *dio_bio;
6787 u32 *csums = (u32 *)dip->csum; 6786 u32 *csums = (u32 *)dip->csum;
6788 int index = 0;
6789 u64 start; 6787 u64 start;
6788 int i;
6790 6789
6791 start = dip->logical_offset; 6790 start = dip->logical_offset;
6792 do { 6791 bio_for_each_segment_all(bvec, bio, i) {
6793 if (!(BTRFS_I(inode)->flags & BTRFS_INODE_NODATASUM)) { 6792 if (!(BTRFS_I(inode)->flags & BTRFS_INODE_NODATASUM)) {
6794 struct page *page = bvec->bv_page; 6793 struct page *page = bvec->bv_page;
6795 char *kaddr; 6794 char *kaddr;
@@ -6805,18 +6804,16 @@ static void btrfs_endio_direct_read(struct bio *bio, int err)
6805 local_irq_restore(flags); 6804 local_irq_restore(flags);
6806 6805
6807 flush_dcache_page(bvec->bv_page); 6806 flush_dcache_page(bvec->bv_page);
6808 if (csum != csums[index]) { 6807 if (csum != csums[i]) {
6809 btrfs_err(root->fs_info, "csum failed ino %llu off %llu csum %u expected csum %u", 6808 btrfs_err(root->fs_info, "csum failed ino %llu off %llu csum %u expected csum %u",
6810 btrfs_ino(inode), start, csum, 6809 btrfs_ino(inode), start, csum,
6811 csums[index]); 6810 csums[i]);
6812 err = -EIO; 6811 err = -EIO;
6813 } 6812 }
6814 } 6813 }
6815 6814
6816 start += bvec->bv_len; 6815 start += bvec->bv_len;
6817 bvec++; 6816 }
6818 index++;
6819 } while (bvec <= bvec_end);
6820 6817
6821 unlock_extent(&BTRFS_I(inode)->io_tree, dip->logical_offset, 6818 unlock_extent(&BTRFS_I(inode)->io_tree, dip->logical_offset,
6822 dip->logical_offset + dip->bytes - 1); 6819 dip->logical_offset + dip->bytes - 1);