Commit d788a349 authored by Josef Bacik's avatar Josef Bacik Committed by Chris Mason

Btrfs: don't abort transaction in run_delalloc_nocow

This is just the write path, the only reason we start a transaction is so we can
check cross references, we don't make any actual changes, so there is no reason
to abort the transaction if we fail.  Thanks,
Signed-off-by: default avatarJosef Bacik <jbacik@fusionio.com>
Signed-off-by: default avatarChris Mason <chris.mason@fusionio.com>
parent 02ecd2c2
...@@ -1180,10 +1180,8 @@ static noinline int run_delalloc_nocow(struct inode *inode, ...@@ -1180,10 +1180,8 @@ static noinline int run_delalloc_nocow(struct inode *inode,
while (1) { while (1) {
ret = btrfs_lookup_file_extent(trans, root, path, ino, ret = btrfs_lookup_file_extent(trans, root, path, ino,
cur_offset, 0); cur_offset, 0);
if (ret < 0) { if (ret < 0)
btrfs_abort_transaction(trans, root, ret);
goto error; goto error;
}
if (ret > 0 && path->slots[0] > 0 && check_prev) { if (ret > 0 && path->slots[0] > 0 && check_prev) {
leaf = path->nodes[0]; leaf = path->nodes[0];
btrfs_item_key_to_cpu(leaf, &found_key, btrfs_item_key_to_cpu(leaf, &found_key,
...@@ -1197,10 +1195,8 @@ static noinline int run_delalloc_nocow(struct inode *inode, ...@@ -1197,10 +1195,8 @@ static noinline int run_delalloc_nocow(struct inode *inode,
leaf = path->nodes[0]; leaf = path->nodes[0];
if (path->slots[0] >= btrfs_header_nritems(leaf)) { if (path->slots[0] >= btrfs_header_nritems(leaf)) {
ret = btrfs_next_leaf(root, path); ret = btrfs_next_leaf(root, path);
if (ret < 0) { if (ret < 0)
btrfs_abort_transaction(trans, root, ret);
goto error; goto error;
}
if (ret > 0) if (ret > 0)
break; break;
leaf = path->nodes[0]; leaf = path->nodes[0];
...@@ -1291,10 +1287,8 @@ static noinline int run_delalloc_nocow(struct inode *inode, ...@@ -1291,10 +1287,8 @@ static noinline int run_delalloc_nocow(struct inode *inode,
ret = cow_file_range(inode, locked_page, ret = cow_file_range(inode, locked_page,
cow_start, found_key.offset - 1, cow_start, found_key.offset - 1,
page_started, nr_written, 1); page_started, nr_written, 1);
if (ret) { if (ret)
btrfs_abort_transaction(trans, root, ret);
goto error; goto error;
}
cow_start = (u64)-1; cow_start = (u64)-1;
} }
...@@ -1341,10 +1335,8 @@ static noinline int run_delalloc_nocow(struct inode *inode, ...@@ -1341,10 +1335,8 @@ static noinline int run_delalloc_nocow(struct inode *inode,
BTRFS_DATA_RELOC_TREE_OBJECTID) { BTRFS_DATA_RELOC_TREE_OBJECTID) {
ret = btrfs_reloc_clone_csums(inode, cur_offset, ret = btrfs_reloc_clone_csums(inode, cur_offset,
num_bytes); num_bytes);
if (ret) { if (ret)
btrfs_abort_transaction(trans, root, ret);
goto error; goto error;
}
} }
extent_clear_unlock_delalloc(inode, cur_offset, extent_clear_unlock_delalloc(inode, cur_offset,
...@@ -1366,10 +1358,8 @@ static noinline int run_delalloc_nocow(struct inode *inode, ...@@ -1366,10 +1358,8 @@ static noinline int run_delalloc_nocow(struct inode *inode,
if (cow_start != (u64)-1) { if (cow_start != (u64)-1) {
ret = cow_file_range(inode, locked_page, cow_start, end, ret = cow_file_range(inode, locked_page, cow_start, end,
page_started, nr_written, 1); page_started, nr_written, 1);
if (ret) { if (ret)
btrfs_abort_transaction(trans, root, ret);
goto error; goto error;
}
} }
error: error:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment