Commit 6dd379c7 authored by Brian Foster's avatar Brian Foster Committed by Darrick J. Wong

xfs: drop extra transaction roll from inode extent truncate

The inode extent truncate path unmaps extents from the inode block
mapping, finishes deferred ops to free the associated extents and
then explicitly rolls the transaction before processing the next
extent. The latter extent roll is spurious as xfs_defer_finish()
always returns a clean transaction and automatically relogs inodes
attached to the transaction (with lock_flags == 0). This can
unnecessarily increase the number of log ticket regrants that occur
during a long running truncate operation. Remove the explicit
transaction roll.
Signed-off-by: default avatarBrian Foster <bfoster@redhat.com>
Reviewed-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
parent b96cb835
...@@ -1534,17 +1534,10 @@ xfs_itruncate_extents_flags( ...@@ -1534,17 +1534,10 @@ xfs_itruncate_extents_flags(
if (error) if (error)
goto out; goto out;
/* /* free the just unmapped extents */
* Duplicate the transaction that has the permanent
* reservation and commit the old transaction.
*/
error = xfs_defer_finish(&tp); error = xfs_defer_finish(&tp);
if (error) if (error)
goto out; goto out;
error = xfs_trans_roll_inode(&tp, ip);
if (error)
goto out;
} }
if (whichfork == XFS_DATA_FORK) { if (whichfork == XFS_DATA_FORK) {
......
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