Skip to content

Commit ac01f26

Browse files
lorddoskiaskdave
authored andcommitted
btrfs: handle failure of add_pending_csums
add_pending_csums was added as part of the new data=ordered implementation in e6dcd2d ("Btrfs: New data=ordered implementation"). Even back then it called the btrfs_csum_file_blocks which can fail but it never bothered handling the failure. In ENOMEM situation this could lead to the filesystem failing to write the checksums for a particular extent and not detect this. On read this could lead to the filesystem erroring out due to crc mismatch. Fix it by propagating failure from add_pending_csums and handling them. Signed-off-by: Nikolay Borisov <nborisov@suse.com> Reviewed-by: Josef Bacik <jbacik@fb.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
1 parent a8fd1f7 commit ac01f26

File tree

1 file changed

+9
-2
lines changed

1 file changed

+9
-2
lines changed

fs/btrfs/inode.c

Lines changed: 9 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2042,12 +2042,15 @@ static noinline int add_pending_csums(struct btrfs_trans_handle *trans,
20422042
struct inode *inode, struct list_head *list)
20432043
{
20442044
struct btrfs_ordered_sum *sum;
2045+
int ret;
20452046

20462047
list_for_each_entry(sum, list, list) {
20472048
trans->adding_csums = true;
2048-
btrfs_csum_file_blocks(trans,
2049+
ret = btrfs_csum_file_blocks(trans,
20492050
BTRFS_I(inode)->root->fs_info->csum_root, sum);
20502051
trans->adding_csums = false;
2052+
if (ret)
2053+
return ret;
20512054
}
20522055
return 0;
20532056
}
@@ -3061,7 +3064,11 @@ static int btrfs_finish_ordered_io(struct btrfs_ordered_extent *ordered_extent)
30613064
goto out;
30623065
}
30633066

3064-
add_pending_csums(trans, inode, &ordered_extent->list);
3067+
ret = add_pending_csums(trans, inode, &ordered_extent->list);
3068+
if (ret) {
3069+
btrfs_abort_transaction(trans, ret);
3070+
goto out;
3071+
}
30653072

30663073
btrfs_ordered_update_i_size(inode, 0, ordered_extent);
30673074
ret = btrfs_update_inode_fallback(trans, root, inode);

0 commit comments

Comments
 (0)