|
@@ -193,7 +193,7 @@ static int try_to_extend_transaction(handle_t *handle, struct inode *inode)
|
|
|
* so before we call here everything must be consistently dirtied against
|
|
|
* this transaction.
|
|
|
*/
|
|
|
- int ext4_truncate_restart_trans(handle_t *handle, struct inode *inode,
|
|
|
+int ext4_truncate_restart_trans(handle_t *handle, struct inode *inode,
|
|
|
int nblocks)
|
|
|
{
|
|
|
int ret;
|
|
@@ -209,6 +209,7 @@ static int try_to_extend_transaction(handle_t *handle, struct inode *inode)
|
|
|
up_write(&EXT4_I(inode)->i_data_sem);
|
|
|
ret = ext4_journal_restart(handle, blocks_for_truncate(inode));
|
|
|
down_write(&EXT4_I(inode)->i_data_sem);
|
|
|
+ ext4_discard_preallocations(inode);
|
|
|
|
|
|
return ret;
|
|
|
}
|