aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/volumes.c
diff options
context:
space:
mode:
authorEric Sandeen <sandeen@redhat.com>2013-01-30 19:55:01 -0500
committerJosef Bacik <jbacik@fusionio.com>2013-02-20 12:59:26 -0500
commit063d006fa06fbf73fab370921120380333a33e85 (patch)
tree5a6650052c7409fc8895762fcc7ef8015e5088b8 /fs/btrfs/volumes.c
parent1971e917c8c99ff190264305803fbafcbbac1422 (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.c6
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 /*