diff options
author | Josef Bacik <jbacik@fusionio.com> | 2012-08-27 17:48:15 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@fusionio.com> | 2012-10-01 15:19:04 -0400 |
commit | ca7e70f59078046db28501519308c2061b0e7a6f (patch) | |
tree | 9685496d94625bc732e029f2a21f049506bf8618 /fs/btrfs/extent-tree.c | |
parent | 06d3d22b456c2f87aeb1eb4517eeabb47e21fcc9 (diff) |
Btrfs: do not needlessly restart the transaction for enospc
We will stop and restart a transaction every time we move to a different leaf
when truncating a file. This is for enospc reasons, but really we could
probably get away with doing this a little better by actually working until we
hit an ENOSPC. So add a ->failfast flag to the block_rsv and set it when we do
truncates which will fail as soon as the block rsv runs out of space, and then
at that point we can stop and restart the transaction and refill the block rsv
and carry on. This will make rm'ing of a file with lots of extents a bit
faster. Thanks,
Signed-off-by: Josef Bacik <jbacik@fusionio.com>
Diffstat (limited to 'fs/btrfs/extent-tree.c')
-rw-r--r-- | fs/btrfs/extent-tree.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 62fc92f2b9d7..df2f17b0ac5d 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
@@ -6308,7 +6308,7 @@ use_block_rsv(struct btrfs_trans_handle *trans, | |||
6308 | ret = block_rsv_use_bytes(block_rsv, blocksize); | 6308 | ret = block_rsv_use_bytes(block_rsv, blocksize); |
6309 | if (!ret) | 6309 | if (!ret) |
6310 | return block_rsv; | 6310 | return block_rsv; |
6311 | if (ret) { | 6311 | if (ret && !block_rsv->failfast) { |
6312 | static DEFINE_RATELIMIT_STATE(_rs, | 6312 | static DEFINE_RATELIMIT_STATE(_rs, |
6313 | DEFAULT_RATELIMIT_INTERVAL, | 6313 | DEFAULT_RATELIMIT_INTERVAL, |
6314 | /*DEFAULT_RATELIMIT_BURST*/ 2); | 6314 | /*DEFAULT_RATELIMIT_BURST*/ 2); |