On Mon 24-04-23 11:38:44, Baokun Li wrote: > Now it never fails when inserting a delay extent, so the return value in > ext4_es_insert_delayed_block is no longer necessary, let it return void. > > Signed-off-by: Baokun Li <libaokun1@xxxxxxxxxx> Nice. Feel free to add: Reviewed-by: Jan Kara <jack@xxxxxxx> Honza > --- > fs/ext4/extents_status.c | 10 ++++------ > fs/ext4/extents_status.h | 4 ++-- > fs/ext4/inode.c | 10 ++-------- > 3 files changed, 8 insertions(+), 16 deletions(-) > > diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c > index 2a394c40f4b7..b12c5cfdf601 100644 > --- a/fs/ext4/extents_status.c > +++ b/fs/ext4/extents_status.c > @@ -2020,11 +2020,9 @@ bool ext4_is_pending(struct inode *inode, ext4_lblk_t lblk) > * @lblk - logical block to be added > * @allocated - indicates whether a physical cluster has been allocated for > * the logical cluster that contains the block > - * > - * Returns 0 on success, negative error code on failure. > */ > -int ext4_es_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk, > - bool allocated) > +void ext4_es_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk, > + bool allocated) > { > struct extent_status newes; > int err1 = 0; > @@ -2033,7 +2031,7 @@ int ext4_es_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk, > struct extent_status *es2 = NULL; > > if (EXT4_SB(inode->i_sb)->s_mount_state & EXT4_FC_REPLAY) > - return 0; > + return; > > es_debug("add [%u/1) delayed to extent status tree of inode %lu\n", > lblk, inode->i_ino); > @@ -2075,7 +2073,7 @@ int ext4_es_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk, > > ext4_es_print_tree(inode); > ext4_print_pending_tree(inode); > - return 0; > + return; > } > > /* > diff --git a/fs/ext4/extents_status.h b/fs/ext4/extents_status.h > index 526a68890aa6..c22edb931f1b 100644 > --- a/fs/ext4/extents_status.h > +++ b/fs/ext4/extents_status.h > @@ -249,8 +249,8 @@ extern void ext4_exit_pending(void); > extern void ext4_init_pending_tree(struct ext4_pending_tree *tree); > extern void ext4_remove_pending(struct inode *inode, ext4_lblk_t lblk); > extern bool ext4_is_pending(struct inode *inode, ext4_lblk_t lblk); > -extern int ext4_es_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk, > - bool allocated); > +extern void ext4_es_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk, > + bool allocated); > extern unsigned int ext4_es_delayed_clu(struct inode *inode, ext4_lblk_t lblk, > ext4_lblk_t len); > extern void ext4_clear_inode_es(struct inode *inode); > diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c > index a0bfe77d5537..4221b2dafeb5 100644 > --- a/fs/ext4/inode.c > +++ b/fs/ext4/inode.c > @@ -1641,9 +1641,8 @@ static void ext4_print_free_blocks(struct inode *inode) > static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk) > { > struct ext4_sb_info *sbi = EXT4_SB(inode->i_sb); > - int ret; > + int ret = 0; > bool allocated = false; > - bool reserved = false; > > /* > * If the cluster containing lblk is shared with a delayed, > @@ -1660,7 +1659,6 @@ static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk) > ret = ext4_da_reserve_space(inode); > if (ret != 0) /* ENOSPC */ > goto errout; > - reserved = true; > } else { /* bigalloc */ > if (!ext4_es_scan_clu(inode, &ext4_es_is_delonly, lblk)) { > if (!ext4_es_scan_clu(inode, > @@ -1673,7 +1671,6 @@ static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk) > ret = ext4_da_reserve_space(inode); > if (ret != 0) /* ENOSPC */ > goto errout; > - reserved = true; > } else { > allocated = true; > } > @@ -1683,10 +1680,7 @@ static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk) > } > } > > - ret = ext4_es_insert_delayed_block(inode, lblk, allocated); > - if (ret && reserved) > - ext4_da_release_space(inode, 1); > - > + ext4_es_insert_delayed_block(inode, lblk, allocated); > errout: > return ret; > } > -- > 2.31.1 > -- Jan Kara <jack@xxxxxxxx> SUSE Labs, CR