From: NeilBrown Date: Thu, 28 May 2015 06:43:15 +0000 (+1000) Subject: Grow: fix problem with --grow --continue X-Git-Tag: mdadm-3.3.3~40 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8e7ddc5f50af00e569ef115e25c635e2d74e90f0;p=thirdparty%2Fmdadm.git Grow: fix problem with --grow --continue If an array is being reshaped using backup space on a 'spare' device, then mdadm --grow --continue won't find it as by the time it runs, nothing looks like a spare are more. The spare has been added to the array, but has no data yet. So allow reshape_prepare_fdlist to find a newly-incorporated spare and report this so it can be used. Reported-by: Xiao Ni Signed-off-by: NeilBrown --- diff --git a/Grow.c b/Grow.c index a20ff3e7..85de1d27 100644 --- a/Grow.c +++ b/Grow.c @@ -850,7 +850,8 @@ int reshape_prepare_fdlist(char *devname, for (sd = sra->devs; sd; sd = sd->next) { if (sd->disk.state & (1<disk.state & (1<disk.state & (1<disk.raid_disk < raid_disks) { char *dn = map_dev(sd->disk.major, sd->disk.minor, 1); fdlist[sd->disk.raid_disk] @@ -3184,7 +3185,7 @@ started: d = reshape_prepare_fdlist(devname, sra, odisks, nrdisks, blocks, backup_file, fdlist, offsets); - if (d < 0) { + if (d < odisks) { goto release; } if ((st->ss->manage_reshape == NULL) || @@ -3196,7 +3197,7 @@ started: devname); pr_err(" Please provide one with \"--backup=...\"\n"); goto release; - } else if (sra->array.spare_disks == 0) { + } else if (d == odisks) { pr_err("%s: Cannot grow - need a spare or backup-file to backup critical section\n", devname); goto release; }