ext4: clean up ext4_ext_insert_extent() call in ext4_ext_map_blocks()
Now that the eofblocks code has been removed, we don't need to assign 0 to err before calling ext4_ext_insert_extent() since it will assign a return value to ret anyway. The variable free_on_err can be eliminated and replaced by a reference to allocated_clusters which clearly conveys the idea that newly allocated blocks should be freed when recovering from an extent insertion failure. The error handling code itself should be restructured so that it errors out immediately on an insertion failure in the case where no new blocks have been allocated (bigalloc) rather than proceeding further into the mapping code. The initializer for fb_flags can also be rearranged for improved readability. Finally, insert a missing space in nearby code. No known bugs are addressed by this patch - it's simply a cleanup. Reviewed-by: Ritesh Harjani <riteshh@linux.ibm.com> Signed-off-by: Eric Whitney <enwlinux@gmail.com> Link: https://lore.kernel.org/r/20200311205033.25013-1-enwlinux@gmail.com Signed-off-by: Theodore Ts'o <tytso@mit.edu>
This commit is contained in:
parent
eb5760863f
commit
3499046134
@ -4028,7 +4028,7 @@ int ext4_ext_map_blocks(handle_t *handle, struct inode *inode,
|
|||||||
struct ext4_extent newex, *ex, *ex2;
|
struct ext4_extent newex, *ex, *ex2;
|
||||||
struct ext4_sb_info *sbi = EXT4_SB(inode->i_sb);
|
struct ext4_sb_info *sbi = EXT4_SB(inode->i_sb);
|
||||||
ext4_fsblk_t newblock = 0;
|
ext4_fsblk_t newblock = 0;
|
||||||
int free_on_err = 0, err = 0, depth, ret;
|
int err = 0, depth, ret;
|
||||||
unsigned int allocated = 0, offset = 0;
|
unsigned int allocated = 0, offset = 0;
|
||||||
unsigned int allocated_clusters = 0;
|
unsigned int allocated_clusters = 0;
|
||||||
struct ext4_allocation_request ar;
|
struct ext4_allocation_request ar;
|
||||||
@ -4226,7 +4226,6 @@ int ext4_ext_map_blocks(handle_t *handle, struct inode *inode,
|
|||||||
goto out2;
|
goto out2;
|
||||||
ext_debug("allocate new block: goal %llu, found %llu/%u\n",
|
ext_debug("allocate new block: goal %llu, found %llu/%u\n",
|
||||||
ar.goal, newblock, allocated);
|
ar.goal, newblock, allocated);
|
||||||
free_on_err = 1;
|
|
||||||
allocated_clusters = ar.len;
|
allocated_clusters = ar.len;
|
||||||
ar.len = EXT4_C2B(sbi, ar.len) - offset;
|
ar.len = EXT4_C2B(sbi, ar.len) - offset;
|
||||||
if (ar.len > allocated)
|
if (ar.len > allocated)
|
||||||
@ -4237,23 +4236,28 @@ got_allocated_blocks:
|
|||||||
ext4_ext_store_pblock(&newex, newblock + offset);
|
ext4_ext_store_pblock(&newex, newblock + offset);
|
||||||
newex.ee_len = cpu_to_le16(ar.len);
|
newex.ee_len = cpu_to_le16(ar.len);
|
||||||
/* Mark unwritten */
|
/* Mark unwritten */
|
||||||
if (flags & EXT4_GET_BLOCKS_UNWRIT_EXT){
|
if (flags & EXT4_GET_BLOCKS_UNWRIT_EXT) {
|
||||||
ext4_ext_mark_unwritten(&newex);
|
ext4_ext_mark_unwritten(&newex);
|
||||||
map->m_flags |= EXT4_MAP_UNWRITTEN;
|
map->m_flags |= EXT4_MAP_UNWRITTEN;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = 0;
|
|
||||||
err = ext4_ext_insert_extent(handle, inode, &path, &newex, flags);
|
err = ext4_ext_insert_extent(handle, inode, &path, &newex, flags);
|
||||||
|
if (err) {
|
||||||
|
if (allocated_clusters) {
|
||||||
|
int fb_flags = 0;
|
||||||
|
|
||||||
if (err && free_on_err) {
|
/*
|
||||||
int fb_flags = flags & EXT4_GET_BLOCKS_DELALLOC_RESERVE ?
|
* free data blocks we just allocated.
|
||||||
EXT4_FREE_BLOCKS_NO_QUOT_UPDATE : 0;
|
* not a good idea to call discard here directly,
|
||||||
/* free data blocks we just allocated */
|
* but otherwise we'd need to call it every free().
|
||||||
/* not a good idea to call discard here directly,
|
*/
|
||||||
* but otherwise we'd need to call it every free() */
|
ext4_discard_preallocations(inode);
|
||||||
ext4_discard_preallocations(inode);
|
if (flags & EXT4_GET_BLOCKS_DELALLOC_RESERVE)
|
||||||
ext4_free_blocks(handle, inode, NULL, newblock,
|
fb_flags = EXT4_FREE_BLOCKS_NO_QUOT_UPDATE;
|
||||||
EXT4_C2B(sbi, allocated_clusters), fb_flags);
|
ext4_free_blocks(handle, inode, NULL, newblock,
|
||||||
|
EXT4_C2B(sbi, allocated_clusters),
|
||||||
|
fb_flags);
|
||||||
|
}
|
||||||
goto out2;
|
goto out2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user