mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 06:44:00 -04:00
btrfs: check for NULL root after calls to btrfs_csum_root()
btrfs_csum_root() can return a NULL pointer in case the root we are looking for is not in the rb tree that tracks roots. So add checks to every caller that is missing such check to log a message and return an error. Reported-by: Chris Mason <clm@meta.com> Link: https://lore.kernel.org/linux-btrfs/20260208161657.3972997-1-clm@meta.com/ Reviewed-by: Boris Burkov <boris@bur.io> Signed-off-by: Filipe Manana <fdmanana@suse.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
committed by
David Sterba
parent
5024282870
commit
2b4cb4e58f
@@ -2295,8 +2295,7 @@ void raid56_parity_recover(struct bio *bio, struct btrfs_io_context *bioc,
|
||||
static void fill_data_csums(struct btrfs_raid_bio *rbio)
|
||||
{
|
||||
struct btrfs_fs_info *fs_info = rbio->bioc->fs_info;
|
||||
struct btrfs_root *csum_root = btrfs_csum_root(fs_info,
|
||||
rbio->bioc->full_stripe_logical);
|
||||
struct btrfs_root *csum_root;
|
||||
const u64 start = rbio->bioc->full_stripe_logical;
|
||||
const u32 len = (rbio->nr_data * rbio->stripe_nsectors) <<
|
||||
fs_info->sectorsize_bits;
|
||||
@@ -2329,6 +2328,15 @@ static void fill_data_csums(struct btrfs_raid_bio *rbio)
|
||||
goto error;
|
||||
}
|
||||
|
||||
csum_root = btrfs_csum_root(fs_info, rbio->bioc->full_stripe_logical);
|
||||
if (unlikely(!csum_root)) {
|
||||
btrfs_err(fs_info,
|
||||
"missing csum root for extent at bytenr %llu",
|
||||
rbio->bioc->full_stripe_logical);
|
||||
ret = -EUCLEAN;
|
||||
goto error;
|
||||
}
|
||||
|
||||
ret = btrfs_lookup_csums_bitmap(csum_root, NULL, start, start + len - 1,
|
||||
rbio->csum_buf, rbio->csum_bitmap);
|
||||
if (ret < 0)
|
||||
|
||||
Reference in New Issue
Block a user