aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2010-04-06 09:37:47 -0400
committerChris Mason <chris.mason@oracle.com>2010-04-06 09:37:47 -0400
commit9f680ce04ea19dabbbafe01b57b61930a9b70741 (patch)
tree30447eb92851fe8542469a69cfd126bec30f9dd2
parentab6e24103cbd215e922938a4f58c75194761a60e (diff)
Btrfs: make sure the chunk allocator doesn't create zero length chunks
A recent commit allowed for smaller chunks to be created, but didn't make sure they were always bigger than a stripe. After some divides, this led to zero length stripes. Signed-off-by: Chris Mason <chris.mason@oracle.com>
-rw-r--r--fs/btrfs/volumes.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c
index 9bf1f581b872..b584e9a2add2 100644
--- a/fs/btrfs/volumes.c
+++ b/fs/btrfs/volumes.c
@@ -2249,6 +2249,12 @@ again:
2249 if (!looped) 2249 if (!looped)
2250 calc_size = max_t(u64, min_stripe_size, calc_size); 2250 calc_size = max_t(u64, min_stripe_size, calc_size);
2251 2251
2252 /*
2253 * we're about to do_div by the stripe_len so lets make sure
2254 * we end up with something bigger than a stripe
2255 */
2256 calc_size = max_t(u64, calc_size, stripe_len * 4);
2257
2252 do_div(calc_size, stripe_len); 2258 do_div(calc_size, stripe_len);
2253 calc_size *= stripe_len; 2259 calc_size *= stripe_len;
2254 2260