linux-raid.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [md PATCH 3/5] md: Use added disks for external metadata case in start_reshape()
@ 2010-06-09 14:21 Kwolek, Adam
  2010-06-16  4:58 ` Neil Brown
  0 siblings, 1 reply; 3+ messages in thread
From: Kwolek, Adam @ 2010-06-09 14:21 UTC (permalink / raw)
  To: Neil Brown; +Cc: linux-raid@vger.kernel.org, Williams, Dan J, Ciechanowski, Ed

(md: Online Capacity Expansion for IMSM)
Disks added by mdadm for external metadata are not taken for configuration check before reshape.
This causes configuration check fail.

For reshape, we should check if added disks to volume by mdadm, will satisfy degradation condition after operation (comparing difference of target disk number and available disks number to mddev->max_degraded field).
---

 drivers/md/raid5.c |   11 ++++++++++-
 1 files changed, 10 insertions(+), 1 deletions(-)

diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c index 546e23e..dc25a32 100644
--- a/drivers/md/raid5.c
+++ b/drivers/md/raid5.c
@@ -5411,6 +5411,7 @@ static int raid5_start_reshape(mddev_t *mddev)
 	int spares = 0;
 	int added_devices = 0;
 	unsigned long flags;
+	int disk_count = 0;
 
 	if (test_bit(MD_RECOVERY_RUNNING, &mddev->recovery))
 		return -EBUSY;
@@ -5422,12 +5423,20 @@ static int raid5_start_reshape(mddev_t *mddev)
 		if (rdev->raid_disk < 0 &&
 		    !test_bit(Faulty, &rdev->flags))
 			spares++;
+		else
+			/* check reshape condition/spares are added already
+			 */
+			disk_count++;
 
 	if (spares - mddev->degraded < mddev->delta_disks - conf->max_degraded)
 		/* Not enough devices even to make a degraded array
 		 * of that size
+		 * but check first if this is not reshape case
+		 * if not reshape on degraded array /takeover/ than exit
 		 */
-		return -EINVAL;
+		if ((conf->raid_disks + mddev->delta_disks)
+		    > (disk_count + conf->max_degraded))
+			return -EINVAL;
 
 	/* Refuse to reduce size of the array.  Any reductions in
 	 * array size must be through explicit setting of array_size


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2010-06-18  8:35 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-06-09 14:21 [md PATCH 3/5] md: Use added disks for external metadata case in start_reshape() Kwolek, Adam
2010-06-16  4:58 ` Neil Brown
2010-06-18  8:35   ` Kwolek, Adam

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).