aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/super.c
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2007-04-10 13:51:41 -0400
committerDavid Woodhouse <dwmw2@hera.kernel.org>2007-04-10 13:51:41 -0400
commit79b2cb1fa6430501907cb1384abbddf074833e45 (patch)
tree495f4481f83b97a9b25eb16cdbeb0f699f424fee /fs/btrfs/super.c
parent48ddc6f44b5a167c00573b6012727d674e9c667a (diff)
Btrfs: only cow in get_block when create==1
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/super.c')
-rw-r--r--fs/btrfs/super.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c
index 91aa1b4c50af..a3183972f310 100644
--- a/fs/btrfs/super.c
+++ b/fs/btrfs/super.c
@@ -1020,7 +1020,7 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
1020 1020
1021 ret = btrfs_lookup_file_extent(trans, root, path, 1021 ret = btrfs_lookup_file_extent(trans, root, path,
1022 inode->i_ino, 1022 inode->i_ino,
1023 iblock << inode->i_blkbits, 1); 1023 iblock << inode->i_blkbits, create);
1024 if (ret < 0) { 1024 if (ret < 0) {
1025 err = ret; 1025 err = ret;
1026 goto out; 1026 goto out;
@@ -1046,7 +1046,8 @@ static int btrfs_get_block_lock(struct inode *inode, sector_t iblock,
1046 if (ret == 0) { 1046 if (ret == 0) {
1047 err = 0; 1047 err = 0;
1048 BUG_ON(btrfs_file_extent_disk_num_blocks(item) != 1); 1048 BUG_ON(btrfs_file_extent_disk_num_blocks(item) != 1);
1049 if (btrfs_file_extent_generation(item) != trans->transid) { 1049 if (create &&
1050 btrfs_file_extent_generation(item) != trans->transid) {
1050 struct btrfs_key ins; 1051 struct btrfs_key ins;
1051 ret = btrfs_alloc_extent(trans, root, 1, 1052 ret = btrfs_alloc_extent(trans, root, 1,
1052 blocknr, (u64)-1, &ins); 1053 blocknr, (u64)-1, &ins);