summaryrefslogtreecommitdiffstats
path: root/Monitor.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2012-06-04 04:31:40 +0200
committerNeilBrown <neilb@suse.de>2012-06-04 04:31:40 +0200
commit9dad51d41853a1bf791dfe418b67fefac21c4670 (patch)
tree02418b4e58745742430fa3f0c2fec9ce2e712a61 /Monitor.c
parentMonitor: Allow correct monitoring of more member devices. (diff)
downloadmdadm-9dad51d41853a1bf791dfe418b67fefac21c4670.tar.xz
mdadm-9dad51d41853a1bf791dfe418b67fefac21c4670.zip
Monitor: fix inconsistencies in values for ->percent
->percent sometimes stores negative values recording states like 'pending' or 'delayed'. The value '-2' means both 'delayed' and in Monitor, 'unknown'. Also, '-1' has a meaning but not #define. So change the #defines to be prefixed with "RESYNC_", instead of "PROCESS_", add new "_NONE" and "_UNKNOWN", and use correct value in each location. Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'Monitor.c')
-rw-r--r--Monitor.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/Monitor.c b/Monitor.c
index 12b85f33..d9295b52 100644
--- a/Monitor.c
+++ b/Monitor.c
@@ -178,7 +178,7 @@ int Monitor(struct mddev_dev *devlist,
}
st->next = statelist;
st->devnum = INT_MAX;
- st->percent = -2;
+ st->percent = RESYNC_UNKNOWN;
st->expected_spares = mdlist->spare_disks;
if (mdlist->spare_group)
st->spare_group = strdup(mdlist->spare_group);
@@ -194,7 +194,7 @@ int Monitor(struct mddev_dev *devlist,
st->devname = strdup(dv->devname);
st->next = statelist;
st->devnum = INT_MAX;
- st->percent = -2;
+ st->percent = RESYNC_UNKNOWN;
st->expected_spares = -1;
if (mdlist) {
st->expected_spares = mdlist->spare_disks;
@@ -536,7 +536,7 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
st->expected_spares > 0 &&
array.spare_disks < st->expected_spares)
alert("SparesMissing", dev, NULL, ainfo);
- if (st->percent == -1 &&
+ if (st->percent < 0 && st->percent != RESYNC_UNKNOWN &&
mse->percent >= 0)
alert("RebuildStarted", dev, NULL, ainfo);
if (st->percent >= 0 &&
@@ -552,7 +552,7 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
alert(percentalert, dev, NULL, ainfo);
}
- if (mse->percent == -1 &&
+ if (mse->percent == RESYNC_NONE &&
st->percent >= 0) {
/* Rebuild/sync/whatever just finished.
* If there is a number in /mismatch_cnt,
@@ -702,7 +702,7 @@ static int add_new_arrays(struct mdstat_ent *mdstat, struct state **statelist,
st->next = *statelist;
st->err = 1;
st->devnum = mse->devnum;
- st->percent = -2;
+ st->percent = RESYNC_UNKNOWN;
st->expected_spares = -1;
if (mse->metadata_version &&
strncmp(mse->metadata_version, "external:", 9) == 0 &&