diff options
author | Eric Sandeen <sandeen@redhat.com> | 2013-01-30 19:55:01 -0500 |
---|---|---|
committer | Josef Bacik <jbacik@fusionio.com> | 2013-02-20 12:59:26 -0500 |
commit | 063d006fa06fbf73fab370921120380333a33e85 (patch) | |
tree | 5a6650052c7409fc8895762fcc7ef8015e5088b8 /fs/btrfs/volumes.c | |
parent | 1971e917c8c99ff190264305803fbafcbbac1422 (diff) |
btrfs: ensure we don't overrun devices_info[] in __btrfs_alloc_chunk
WARN_ON isn't enough, we need to stop the loop if for any reason
we would overrun the devices_info array.
I tried to track down the connection between the length of
the alloc_devices list and the rw_devices counter but
it wasn't immediately obvious, so be defensive about it.
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: Josef Bacik <jbacik@fusionio.com>
Diffstat (limited to 'fs/btrfs/volumes.c')
-rw-r--r-- | fs/btrfs/volumes.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c index c7843349c795..305b6a63ab1f 100644 --- a/fs/btrfs/volumes.c +++ b/fs/btrfs/volumes.c | |||
@@ -3734,12 +3734,16 @@ static int __btrfs_alloc_chunk(struct btrfs_trans_handle *trans, | |||
3734 | if (max_avail < BTRFS_STRIPE_LEN * dev_stripes) | 3734 | if (max_avail < BTRFS_STRIPE_LEN * dev_stripes) |
3735 | continue; | 3735 | continue; |
3736 | 3736 | ||
3737 | if (ndevs == fs_devices->rw_devices) { | ||
3738 | WARN(1, "%s: found more than %llu devices\n", | ||
3739 | __func__, fs_devices->rw_devices); | ||
3740 | break; | ||
3741 | } | ||
3737 | devices_info[ndevs].dev_offset = dev_offset; | 3742 | devices_info[ndevs].dev_offset = dev_offset; |
3738 | devices_info[ndevs].max_avail = max_avail; | 3743 | devices_info[ndevs].max_avail = max_avail; |
3739 | devices_info[ndevs].total_avail = total_avail; | 3744 | devices_info[ndevs].total_avail = total_avail; |
3740 | devices_info[ndevs].dev = device; | 3745 | devices_info[ndevs].dev = device; |
3741 | ++ndevs; | 3746 | ++ndevs; |
3742 | WARN_ON(ndevs > fs_devices->rw_devices); | ||
3743 | } | 3747 | } |
3744 | 3748 | ||
3745 | /* | 3749 | /* |