diff options
author | Chris Mason <chris.mason@oracle.com> | 2009-11-11 10:16:57 -0500 |
---|---|---|
committer | Chris Mason <chris.mason@oracle.com> | 2009-11-11 14:20:20 -0500 |
commit | 33b258086441dd07e00133c79fcd8cbc6a76d737 (patch) | |
tree | beab74a12b7650576dbe2f97301f0905699d4292 | |
parent | f5a84ee3cdd88d96b7bcede10af58598ad8d52a7 (diff) |
Btrfs: allow more metadata chunk preallocation
On an FS where all of the space has not been allocated into chunks yet,
the enospc can return enospc just because the existing metadata chunks
are full.
We get around this by allowing more metadata chunks to be allocated up
to a certain limit, and finding the right limit is a little fuzzy. The
problem is the reservations for delalloc would preallocate way too much
of the FS as metadata. We need to start saying no and just force some
IO to happen.
But we also need to let a reasonable amount of the FS become metadata.
This bumps the hard limit up, later releases will have a better system.
Signed-off-by: Chris Mason <chris.mason@oracle.com>
-rw-r--r-- | fs/btrfs/extent-tree.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 2a4cdceeb575..8d1fd6dc22ac 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
@@ -2976,10 +2976,10 @@ static int maybe_allocate_chunk(struct btrfs_root *root, | |||
2976 | 2976 | ||
2977 | free_space = btrfs_super_total_bytes(disk_super); | 2977 | free_space = btrfs_super_total_bytes(disk_super); |
2978 | /* | 2978 | /* |
2979 | * we allow the metadata to grow to a max of either 5gb or 5% of the | 2979 | * we allow the metadata to grow to a max of either 10gb or 5% of the |
2980 | * space in the volume. | 2980 | * space in the volume. |
2981 | */ | 2981 | */ |
2982 | min_metadata = min((u64)5 * 1024 * 1024 * 1024, | 2982 | min_metadata = min((u64)10 * 1024 * 1024 * 1024, |
2983 | div64_u64(free_space * 5, 100)); | 2983 | div64_u64(free_space * 5, 100)); |
2984 | if (info->total_bytes >= min_metadata) { | 2984 | if (info->total_bytes >= min_metadata) { |
2985 | spin_unlock(&info->lock); | 2985 | spin_unlock(&info->lock); |