diff options
author | Mark Harmstone <mark@harmstone.com> | 2025-09-02 13:34:10 +0300 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2025-09-05 20:52:10 +0300 |
commit | 3d1267475b94b3df7a61e4ea6788c7c5d9e473c4 (patch) | |
tree | 42e2cb5f5791763eb3e916ab0ded19a335be48a7 /drivers/cdx/controller/mcdi_functions.c | |
parent | 5a91f52c8650334aaf8c4c7c90f40c6906994225 (diff) | |
download | linux-3d1267475b94b3df7a61e4ea6788c7c5d9e473c4.tar.xz |
btrfs: don't allow adding block device of less than 1 MB
Commit 15ae0410c37a79 ("btrfs-progs: add error handling for
device_get_partition_size_fd_stat()") in btrfs-progs inadvertently
changed it so that if the BLKGETSIZE64 ioctl on a block device returned
a size of 0, this was no longer seen as an error condition.
Unfortunately this is how disconnected NBD devices behave, meaning that
with btrfs-progs 6.16 it's now possible to add a device you can't
remove:
# btrfs device add /dev/nbd0 /root/temp
# btrfs device remove /dev/nbd0 /root/temp
ERROR: error removing device '/dev/nbd0': Invalid argument
This check should always have been done kernel-side anyway, so add a
check in btrfs_init_new_device() that the new device doesn't have a size
less than BTRFS_DEVICE_RANGE_RESERVED (i.e. 1 MB).
Reviewed-by: Qu Wenruo <wqu@suse.com>
Signed-off-by: Mark Harmstone <mark@harmstone.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'drivers/cdx/controller/mcdi_functions.c')
0 files changed, 0 insertions, 0 deletions