Btrfs: use larger system chunks
authorChris Mason <chris.mason@oracle.com>
Mon, 16 Jan 2012 13:13:11 +0000 (08:13 -0500)
committerChris Mason <chris.mason@oracle.com>
Mon, 16 Jan 2012 20:38:24 +0000 (15:38 -0500)
system chunks by default are very small.  This makes them slightly
larger and also fixes the conditional checks to make sure we don't
allocate a billion of them at once.

Signed-off-by: Chris Mason <chris.mason@oracle.com>
fs/btrfs/extent-tree.c
fs/btrfs/volumes.c

index e0ad5f0f895ea789ef8a7fe2b58f3ce3c523cabd..700879ed64cfcc73f43f6e03819e579578db1e57 100644 (file)
@@ -3384,6 +3384,9 @@ static int should_alloc_chunk(struct btrfs_root *root,
 
        /* 256MB or 2% of the FS */
        thresh = max_t(u64, 256 * 1024 * 1024, div_factor_fine(thresh, 2));
+       /* system chunks need a much small threshold */
+       if (sinfo->flags & BTRFS_BLOCK_GROUP_SYSTEM)
+               thresh = 32 * 1024 * 1024;
 
        if (num_bytes > thresh && sinfo->bytes_used < div_factor(num_bytes, 8))
                return 0;
index 59e878f9fdcc6e6bf0ef0e325f3a2fce94011baa..7ffdb154daec5620745ca0ba4f961f243e5a5f57 100644 (file)
@@ -3166,7 +3166,7 @@ static int __btrfs_alloc_chunk(struct btrfs_trans_handle *trans,
                        max_stripe_size = 256 * 1024 * 1024;
                max_chunk_size = max_stripe_size;
        } else if (type & BTRFS_BLOCK_GROUP_SYSTEM) {
-               max_stripe_size = 8 * 1024 * 1024;
+               max_stripe_size = 32 * 1024 * 1024;
                max_chunk_size = 2 * max_stripe_size;
        } else {
                printk(KERN_ERR "btrfs: invalid chunk type 0x%llx requested\n",