udf: Move incrementing of goal block directly into inode_getblk()
inode_getblk() sets goal block for the next allocation to the currently allocated block. This is obviously one less than what the goal block should be which we fixup in udf_get_block(). Just set the right goal block directly in inode_getblk(). Signed-off-by: Jan Kara <jack@suse.cz>
This commit is contained in:
parent
101ee137d3
commit
de80dae03c
|
@ -339,11 +339,6 @@ static int udf_get_block(struct inode *inode, sector_t block,
|
|||
iinfo = UDF_I(inode);
|
||||
|
||||
down_write(&iinfo->i_data_sem);
|
||||
if (block == iinfo->i_next_alloc_block + 1) {
|
||||
iinfo->i_next_alloc_block++;
|
||||
iinfo->i_next_alloc_goal++;
|
||||
}
|
||||
|
||||
/*
|
||||
* Block beyond EOF and prealloc extents? Just discard preallocation
|
||||
* as it is not useful and complicates things.
|
||||
|
@ -810,8 +805,8 @@ static sector_t inode_getblk(struct inode *inode, sector_t block,
|
|||
goto out_free;
|
||||
}
|
||||
*new = 1;
|
||||
iinfo->i_next_alloc_block = block;
|
||||
iinfo->i_next_alloc_goal = newblocknum;
|
||||
iinfo->i_next_alloc_block = block + 1;
|
||||
iinfo->i_next_alloc_goal = newblocknum + 1;
|
||||
inode->i_ctime = current_time(inode);
|
||||
|
||||
if (IS_SYNC(inode))
|
||||
|
|
Loading…
Reference in New Issue