]> git.ipfire.org Git - thirdparty/mdadm.git/blobdiff - Monitor.c
sysfs/sysfs_read: Count working_disks
[thirdparty/mdadm.git] / Monitor.c
index b94fd7c5be5bb0ed7d24186bc9763fc0b01777c6..22045280790c41643fcbb2ca224856ff6deee8d6 100644 (file)
--- a/Monitor.c
+++ b/Monitor.c
@@ -481,7 +481,8 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
        if (st->devnm[0] == 0)
                strcpy(st->devnm, fd2devnm(fd));
 
-       sra = sysfs_read(-1, st->devnm, GET_LEVEL | GET_MISMATCH);
+       sra = sysfs_read(-1, st->devnm, GET_LEVEL | GET_DISKS | GET_DEGRADED |
+                        GET_MISMATCH | GET_DEVS | GET_STATE);
        if (!sra)
                goto disappeared;
 
@@ -522,9 +523,9 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
                alert("NewArray", st->devname, NULL, ainfo);
        }
 
-       if (st->utime == array.utime && st->failed == array.failed_disks &&
+       if (st->utime == array.utime && st->failed == sra->array.failed_disks &&
            st->working == array.working_disks &&
-           st->spare == array.spare_disks &&
+           st->spare == sra->array.spare_disks &&
            (mse == NULL  || (mse->percent == st->percent))) {
                if ((st->active < st->raid) && st->spare == 0)
                        retval = 1;
@@ -534,8 +535,8 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
            mse->pattern && strchr(mse->pattern, '_') /* degraded */)
                alert("DegradedArray", dev, NULL, ainfo);
 
-       if (st->utime == 0 && /* new array */
-           st->expected_spares > 0 && array.spare_disks < st->expected_spares)
+       if (st->utime == 0 && /* new array */ st->expected_spares > 0 &&
+           sra->array.spare_disks < st->expected_spares)
                alert("SparesMissing", dev, NULL, ainfo);
        if (st->percent < 0 && st->percent != RESYNC_UNKNOWN &&
            mse->percent >= 0)
@@ -573,7 +574,7 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
        }
        st->percent = mse->percent;
 
-       remaining_disks = array.nr_disks;
+       remaining_disks = sra->array.nr_disks;
        for (i = 0; i < MAX_DISKS && remaining_disks > 0; i++) {
                mdu_disk_info_t disc;
                disc.number = i;
@@ -635,12 +636,12 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
                st->devstate[i] = newstate;
                st->devid[i] = makedev(disc.major, disc.minor);
        }
-       st->active = array.active_disks;
+       st->active = sra->array.active_disks;
        st->working = array.working_disks;
-       st->spare = array.spare_disks;
-       st->failed = array.failed_disks;
+       st->spare = sra->array.spare_disks;
+       st->failed = sra->array.failed_disks;
        st->utime = array.utime;
-       st->raid = array.raid_disks;
+       st->raid = sra->array.raid_disks;
        st->err = 0;
        if ((st->active < st->raid) && st->spare == 0)
                retval = 1;