aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/extent-tree.c
diff options
context:
space:
mode:
authorJosef Bacik <jbacik@fusionio.com>2012-08-27 17:48:15 -0400
committerChris Mason <chris.mason@fusionio.com>2012-10-01 15:19:04 -0400
commitca7e70f59078046db28501519308c2061b0e7a6f (patch)
tree9685496d94625bc732e029f2a21f049506bf8618 /fs/btrfs/extent-tree.c
parent06d3d22b456c2f87aeb1eb4517eeabb47e21fcc9 (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.c2
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);