diff options
author | Qu Wenruo <wqu@suse.com> | 2019-12-17 11:58:20 +0100 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2020-01-20 16:40:56 +0100 |
commit | f6d2a5c263afca84646cf3300dc13061bedbd99e (patch) | |
tree | 8a90ee52722dc29dedfd8a1263ce51764183d804 /fs/anon_inodes.c | |
parent | btrfs: Remove unneeded semicolon (diff) | |
download | linux-f6d2a5c263afca84646cf3300dc13061bedbd99e.tar.xz linux-f6d2a5c263afca84646cf3300dc13061bedbd99e.zip |
btrfs: tree-checker: Check leaf chunk item size
Inspired by btrfs-progs github issue #208, where chunk item in chunk
tree has invalid num_stripes (0).
Although that can already be caught by current btrfs_check_chunk_valid(),
that function doesn't really check item size as it needs to handle chunk
item in super block sys_chunk_array().
This patch will add two extra checks for chunk items in chunk tree:
- Basic chunk item size
If the item is smaller than btrfs_chunk (which already contains one
stripe), exit right now as reading num_stripes may even go beyond
eb boundary.
- Item size check against num_stripes
If item size doesn't match with calculated chunk size, then either the
item size or the num_stripes is corrupted. Error out anyway.
Reviewed-by: Josef Bacik <josef@toxicpanda.com>
Signed-off-by: Qu Wenruo <wqu@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'fs/anon_inodes.c')
0 files changed, 0 insertions, 0 deletions