Commit 32ab3d1b authored by Johannes Thumshirn's avatar Johannes Thumshirn Committed by David Sterba

btrfs: remove pointless indentation in btrfs_read_sys_array()

Instead of checking if we've read a BTRFS_CHUNK_ITEM_KEY from disk and
then process it we could just bail out early if the read disk key wasn't
a BTRFS_CHUNK_ITEM_KEY.

This removes a level of indentation and makes the code nicer to read.
Reviewed-by: default avatarNikolay Borisov <nborisov@suse.com>
Signed-off-by: default avatarJohannes Thumshirn <jthumshirn@suse.de>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 5ae21692
...@@ -6806,48 +6806,49 @@ int btrfs_read_sys_array(struct btrfs_fs_info *fs_info) ...@@ -6806,48 +6806,49 @@ int btrfs_read_sys_array(struct btrfs_fs_info *fs_info)
sb_array_offset += len; sb_array_offset += len;
cur_offset += len; cur_offset += len;
if (key.type == BTRFS_CHUNK_ITEM_KEY) { if (key.type != BTRFS_CHUNK_ITEM_KEY) {
chunk = (struct btrfs_chunk *)sb_array_offset; btrfs_err(fs_info,
/* "unexpected item type %u in sys_array at offset %u",
* At least one btrfs_chunk with one stripe must be (u32)key.type, cur_offset);
* present, exact stripe count check comes afterwards ret = -EIO;
*/ break;
len = btrfs_chunk_item_size(1); }
if (cur_offset + len > array_size)
goto out_short_read;
num_stripes = btrfs_chunk_num_stripes(sb, chunk);
if (!num_stripes) {
btrfs_err(fs_info,
"invalid number of stripes %u in sys_array at offset %u",
num_stripes, cur_offset);
ret = -EIO;
break;
}
type = btrfs_chunk_type(sb, chunk); chunk = (struct btrfs_chunk *)sb_array_offset;
if ((type & BTRFS_BLOCK_GROUP_SYSTEM) == 0) { /*
btrfs_err(fs_info, * At least one btrfs_chunk with one stripe must be present,
"invalid chunk type %llu in sys_array at offset %u", * exact stripe count check comes afterwards
type, cur_offset); */
ret = -EIO; len = btrfs_chunk_item_size(1);
break; if (cur_offset + len > array_size)
} goto out_short_read;
len = btrfs_chunk_item_size(num_stripes); num_stripes = btrfs_chunk_num_stripes(sb, chunk);
if (cur_offset + len > array_size) if (!num_stripes) {
goto out_short_read; btrfs_err(fs_info,
"invalid number of stripes %u in sys_array at offset %u",
num_stripes, cur_offset);
ret = -EIO;
break;
}
ret = read_one_chunk(&key, sb, chunk); type = btrfs_chunk_type(sb, chunk);
if (ret) if ((type & BTRFS_BLOCK_GROUP_SYSTEM) == 0) {
break;
} else {
btrfs_err(fs_info, btrfs_err(fs_info,
"unexpected item type %u in sys_array at offset %u", "invalid chunk type %llu in sys_array at offset %u",
(u32)key.type, cur_offset); type, cur_offset);
ret = -EIO; ret = -EIO;
break; break;
} }
len = btrfs_chunk_item_size(num_stripes);
if (cur_offset + len > array_size)
goto out_short_read;
ret = read_one_chunk(&key, sb, chunk);
if (ret)
break;
array_ptr += len; array_ptr += len;
sb_array_offset += len; sb_array_offset += len;
cur_offset += len; cur_offset += len;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment