Commit 49bf6ab4 authored by Zhang Yi's avatar Zhang Yi Committed by Theodore Ts'o

ext4: factor out a helper to check the cluster allocation state

Factor out a common helper ext4_clu_alloc_state(), check whether the
cluster containing a delalloc block to be added has been allocated or
has delalloc reservation, no logic changes.
Signed-off-by: default avatarZhang Yi <yi.zhang@huawei.com>
Reviewed-by: default avatarJan Kara <jack@suse.cz>
Link: https://patch.msgid.link/20240517124005.347221-9-yi.zhang@huaweicloud.comSigned-off-by: default avatarTheodore Ts'o <tytso@mit.edu>
parent 0d66b23d
...@@ -1649,6 +1649,35 @@ static void ext4_print_free_blocks(struct inode *inode) ...@@ -1649,6 +1649,35 @@ static void ext4_print_free_blocks(struct inode *inode)
return; return;
} }
/*
* Check whether the cluster containing lblk has been allocated or has
* delalloc reservation.
*
* Returns 0 if the cluster doesn't have either, 1 if it has delalloc
* reservation, 2 if it's already been allocated, negative error code on
* failure.
*/
static int ext4_clu_alloc_state(struct inode *inode, ext4_lblk_t lblk)
{
struct ext4_sb_info *sbi = EXT4_SB(inode->i_sb);
int ret;
/* Has delalloc reservation? */
if (ext4_es_scan_clu(inode, &ext4_es_is_delonly, lblk))
return 1;
/* Already been allocated? */
if (ext4_es_scan_clu(inode, &ext4_es_is_mapped, lblk))
return 2;
ret = ext4_clu_mapped(inode, EXT4_B2C(sbi, lblk));
if (ret < 0)
return ret;
if (ret > 0)
return 2;
return 0;
}
/* /*
* ext4_insert_delayed_block - adds a delayed block to the extents status * ext4_insert_delayed_block - adds a delayed block to the extents status
* tree, incrementing the reserved cluster/block * tree, incrementing the reserved cluster/block
...@@ -1682,23 +1711,15 @@ static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk) ...@@ -1682,23 +1711,15 @@ static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk)
if (ret != 0) /* ENOSPC */ if (ret != 0) /* ENOSPC */
return ret; return ret;
} else { /* bigalloc */ } else { /* bigalloc */
if (!ext4_es_scan_clu(inode, &ext4_es_is_delonly, lblk)) { ret = ext4_clu_alloc_state(inode, lblk);
if (!ext4_es_scan_clu(inode, if (ret < 0)
&ext4_es_is_mapped, lblk)) { return ret;
ret = ext4_clu_mapped(inode, if (ret == 2)
EXT4_B2C(sbi, lblk)); allocated = true;
if (ret < 0) if (ret == 0) {
return ret; ret = ext4_da_reserve_space(inode, 1);
if (ret == 0) { if (ret != 0) /* ENOSPC */
ret = ext4_da_reserve_space(inode, 1); return ret;
if (ret != 0) /* ENOSPC */
return ret;
} else {
allocated = true;
}
} else {
allocated = true;
}
} }
} }
......
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