md: fix two bugs when attempting to resize RAID0 array.
authorNeilBrown <neilb@suse.de>
Thu, 21 Feb 2013 03:33:17 +0000 (14:33 +1100)
committerBen Hutchings <ben@decadent.org.uk>
Wed, 20 Mar 2013 15:03:18 +0000 (15:03 +0000)
commit84453f1a9d27a3a9be88269cc14ee9099856f268
tree0cd73487f3fd09a4c994bcaf18c20aad22c3abf8
parentb923f0d70914a257e4545ede4155f9889acc653b
md: fix two bugs when attempting to resize RAID0 array.

commit a64685399181780998281fe07309a94b25dd24c3 upstream.

You cannot resize a RAID0 array (in terms of making the devices
bigger), but the code doesn't entirely stop you.
So:

 disable setting of the available size on each device for
 RAID0 and Linear devices.  This must not change as doing so
 can change the effective layout of data.

 Make sure that the size that raid0_size() reports is accurate,
 but rounding devices sizes to chunk sizes.  As the device sizes
 cannot change now, this isn't so important, but it is best to be
 safe.

Without this change:
  mdadm --grow /dev/md0 -z max
  mdadm --grow /dev/md0 -Z max
  then read to the end of the array

can cause a BUG in a RAID0 array.

These bugs have been present ever since it became possible
to resize any device, which is a long time.  So the fix is
suitable for any -stable kerenl.

Signed-off-by: NeilBrown <neilb@suse.de>
[bwh: Backported to 3.2: adjust context]
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
drivers/md/md.c
drivers/md/raid0.c