Commit 5c4b93f4 authored by Naohiro Aota's avatar Naohiro Aota Committed by David Sterba
Browse files

btrfs: zoned: fix write time activation failure for metadata block group



Since commit 13bb483d ("btrfs: zoned: activate metadata block group on
write time"), we activate a metadata block group at the write time. If the
zone capacity is small enough, we can allocate the entire region before the
first write. Then, we hit the btrfs_zoned_bg_is_full() in
btrfs_zone_activate() and the activation fails.

For a data block group, we activate it at the allocation time and we should
check the fullness condition in the caller side. Add, a WARN to check the
fullness condition.

For a metadata block group, we don't need the fullness check because we
activate it at the write time. Instead, activating it once it is written
should be invalid. Catch that with a WARN too.

Fixes: 13bb483d ("btrfs: zoned: activate metadata block group on write time")
CC: stable@vger.kernel.org # 6.6+
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: default avatarNaohiro Aota <naohiro.aota@wdc.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent daa0fde3
Loading
Loading
Loading
Loading
+9 −4
Original line number Diff line number Diff line
@@ -2169,11 +2169,16 @@ bool btrfs_zone_activate(struct btrfs_block_group *block_group)
		goto out_unlock;
	}

	/* No space left */
	if (btrfs_zoned_bg_is_full(block_group)) {
	if (block_group->flags & BTRFS_BLOCK_GROUP_DATA) {
		/* The caller should check if the block group is full. */
		if (WARN_ON_ONCE(btrfs_zoned_bg_is_full(block_group))) {
			ret = false;
			goto out_unlock;
		}
	} else {
		/* Since it is already written, it should have been active. */
		WARN_ON_ONCE(block_group->meta_write_pointer != block_group->start);
	}

	for (i = 0; i < map->num_stripes; i++) {
		struct btrfs_zoned_device_info *zinfo;