Btrfs: Hold csum mutex while reading in sums during readpages
authorChris Mason <chris.mason@oracle.com>
Mon, 4 Aug 2008 12:35:53 +0000 (08:35 -0400)
committerChris Mason <chris.mason@oracle.com>
Thu, 25 Sep 2008 15:04:06 +0000 (11:04 -0400)
Signed-off-by: Chris Mason <chris.mason@oracle.com>
fs/btrfs/file-item.c
fs/btrfs/inode.c

index a5ff19b34b219fc3a00c37e336849433693df34c..70af24aa582bf155a46781a1fc2e1b2801d0097f 100644 (file)
@@ -150,7 +150,6 @@ int btrfs_lookup_bio_sums(struct btrfs_root *root, struct inode *inode,
        struct extent_io_tree *io_tree = &BTRFS_I(inode)->io_tree;
 
        path = btrfs_alloc_path();
-       path->reada = 2;
 
        WARN_ON(bio->bi_vcnt <= 0);
 
@@ -177,6 +176,7 @@ int btrfs_lookup_bio_sums(struct btrfs_root *root, struct inode *inode,
                                printk("no csum found for inode %lu start "
                                       "%llu\n", inode->i_ino,
                                       (unsigned long long)offset);
+                               item = NULL;
                                goto found;
                        }
                        btrfs_item_key_to_cpu(path->nodes[0], &found_key,
index 76365ad9bfbfe7eeaa4f63b17267e086d3010634..640648c66b22da9699fe63a42af37763b91ddab9 100644 (file)
@@ -376,7 +376,9 @@ int btrfs_submit_bio_hook(struct inode *inode, int rw, struct bio *bio,
        if (!(rw & (1 << BIO_RW))) {
                if (!btrfs_test_opt(root, NODATASUM) &&
                    !btrfs_test_flag(inode, NODATASUM)) {
+                       mutex_lock(&BTRFS_I(inode)->csum_mutex);
                        btrfs_lookup_bio_sums(root, inode, bio);
+                       mutex_unlock(&BTRFS_I(inode)->csum_mutex);
                }
                goto mapit;
        }