diff options
author | Alexandre Oliva <oliva@lsd.ic.unicamp.br> | 2011-11-30 19:43:00 +0100 |
---|---|---|
committer | Chris Mason <chris.mason@oracle.com> | 2011-11-30 19:43:00 +0100 |
commit | be064d113906f04ea13088a8260e1e68ae0a4050 (patch) | |
tree | 0adeb137e165fbcc5c9ed66d00189ef3194781f4 /fs/btrfs | |
parent | Btrfs: skip block groups without enough space for a cluster (diff) | |
download | linux-be064d113906f04ea13088a8260e1e68ae0a4050.tar.xz linux-be064d113906f04ea13088a8260e1e68ae0a4050.zip |
Btrfs: skip allocation attempt from empty cluster
If we don't have a cluster, don't bother trying to allocate from it,
jumping right away to the attempt to allocate a new cluster.
Signed-off-by: Alexandre Oliva <oliva@lsd.ic.unicamp.br>
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs')
-rw-r--r-- | fs/btrfs/extent-tree.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 71c8e7049d0c..813c6bb96c9a 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c @@ -5299,9 +5299,9 @@ alloc: * people trying to start a new cluster */ spin_lock(&last_ptr->refill_lock); - if (last_ptr->block_group && - (last_ptr->block_group->ro || - !block_group_bits(last_ptr->block_group, data))) + if (!last_ptr->block_group || + last_ptr->block_group->ro || + !block_group_bits(last_ptr->block_group, data)) goto refill_cluster; offset = btrfs_alloc_from_cluster(block_group, last_ptr, |