]> git.ipfire.org Git - thirdparty/mdadm.git/commitdiff
Assemble.c Don't ignore faulty disk when array is auto assembled.
authorMariusz Tkaczyk <mariusz.tkaczyk@intel.com>
Thu, 7 Jun 2018 12:47:47 +0000 (14:47 +0200)
committerJes Sorensen <jsorensen@fb.com>
Fri, 8 Jun 2018 16:47:14 +0000 (12:47 -0400)
Since commit 20dc76d15b40 ("imsm: Set disk slot number") mdadm
sets slot number for each disk in imsm array. Now auto-assemble determines
devices using slot number and ignores devices on the same slot that have
older generation number.
It causes infinit loop if failed device is still visible in system
(it has metadata, but it is not merged with exisiting array).

To avoid it, out-of-sync device should be added to the best[]. Later
mdadm adds it as spare to the container.

Imsm doesn't support disk replacement feature, so it can use rooms for
replacements.

Signed-off-by: Mariusz Tkaczyk <mariusz.tkaczyk@intel.com>
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
Assemble.c

index e83d550b2c7bd80c6f4b9726e17ba16307c7882a..32e6f6ffd1c82c36f05d1148be0902203ac4d0e7 100644 (file)
@@ -779,6 +779,8 @@ static int load_devices(struct devs *devices, char *devmap,
                        if (best[i] == -1 || (devices[best[i]].i.events
                                              < devices[devcnt].i.events))
                                best[i] = devcnt;
+                       else if (st->ss == &super_imsm)
+                               best[i+1] = devcnt;
                }
                devcnt++;
        }