diff options
author | NeilBrown <neilb@suse.de> | 2009-02-06 18:02:46 +1100 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2009-02-12 09:31:01 -0800 |
commit | d7a95c07acbca8128e8a3a776bc1ab43ad744f9f (patch) | |
tree | 581ea5d1b8e385647e9cbc0c0c225cb9301bce82 /include | |
parent | 106d6a4bdb51dc18233e43a4baee041167db3973 (diff) |
md: Ensure an md array never has too many devices.
commit de01dfadf25bf83cfe3d85c163005c4320532658 upstream.
Each different metadata format supported by md supports a
different maximum number of devices.
We really should be enforcing this maximum in the kernel, but
we aren't quite doing that properly.
We currently only enforce it at the 'hot_add' point, which is an
older interface which is not used by current userspace.
We need to also enforce it at 'add_new_disk' time for active arrays
and at 'do_md_run' time when starting a new array.
So move the test from 'hot_add' into 'bind_rdev_to_array' which is
called from both 'hot_add' and 'add_new_disk, and add a new
test in 'analyse_sbs' which is called from 'do_md_run'.
This bug (or missing feature) has been around "forever" and so
the patch is suitable for any -stable that is currently maintained.
Signed-off-by: NeilBrown <neilb@suse.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'include')
0 files changed, 0 insertions, 0 deletions