diff options
author | Josef Bacik <jbacik@fusionio.com> | 2013-08-14 14:02:47 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@fusionio.com> | 2013-09-01 08:05:05 -0400 |
commit | 00361589d2eebd90fca022148c763e40d3e90871 (patch) | |
tree | 161dfa7f29d5aa907de0fee6bdc487f9a2bcb342 /fs/btrfs/free-space-cache.c | |
parent | 9ffba8cda917c0158857426f0e74b64d0206aaa9 (diff) |
Btrfs: avoid starting a transaction in the write path
I noticed while looking at a deadlock that we are always starting a transaction
in cow_file_range(). This isn't really needed since we only need a transaction
if we are doing an inline extent, or if the allocator needs to allocate a chunk.
So push down all the transaction start stuff to be closer to where we actually
need a transaction in all of these cases. This will hopefully reduce our write
latency when we are committing often. Thanks,
Signed-off-by: Josef Bacik <jbacik@fusionio.com>
Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs/btrfs/free-space-cache.c')
-rw-r--r-- | fs/btrfs/free-space-cache.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/fs/btrfs/free-space-cache.c b/fs/btrfs/free-space-cache.c index b21a3cd667d8..25f906fd0221 100644 --- a/fs/btrfs/free-space-cache.c +++ b/fs/btrfs/free-space-cache.c | |||
@@ -2525,8 +2525,7 @@ setup_cluster_bitmap(struct btrfs_block_group_cache *block_group, | |||
2525 | * returns zero and sets up cluster if things worked out, otherwise | 2525 | * returns zero and sets up cluster if things worked out, otherwise |
2526 | * it returns -enospc | 2526 | * it returns -enospc |
2527 | */ | 2527 | */ |
2528 | int btrfs_find_space_cluster(struct btrfs_trans_handle *trans, | 2528 | int btrfs_find_space_cluster(struct btrfs_root *root, |
2529 | struct btrfs_root *root, | ||
2530 | struct btrfs_block_group_cache *block_group, | 2529 | struct btrfs_block_group_cache *block_group, |
2531 | struct btrfs_free_cluster *cluster, | 2530 | struct btrfs_free_cluster *cluster, |
2532 | u64 offset, u64 bytes, u64 empty_size) | 2531 | u64 offset, u64 bytes, u64 empty_size) |