]> git.ipfire.org Git - thirdparty/mdadm.git/commitdiff
Add updating component_size to manager thread of mdmon
authorPawel Baldysiak <pawel.baldysiak@intel.com>
Wed, 3 Apr 2013 01:43:42 +0000 (12:43 +1100)
committerNeilBrown <neilb@suse.de>
Mon, 8 Apr 2013 01:32:53 +0000 (11:32 +1000)
Mdmon does not update component_size now. It is wrong because in case
of size's expansion component_size is changed by mdadm but mdmon does not
reread its new value and uses a wrong, old one. As a result the metadata
is incorrect during size's expansion. It contains no information that
resync is in progress (there is no checkpoint too). The metadata is
as if resync has already been finished but it has not.

Component_size will be set to match information in sysfs. This value
will be updated by manager thread in manage_member() function.
Now mdmon uses the correct, current value of component_size and the
correct metadata (containing information about resync and checkpoint)
is written.

Signed-off-by: Pawel Baldysiak <pawel.baldysiak@intel.com>
Signed-off-by: NeilBrown <neilb@suse.de>
managemon.c

index d155b042c1414071dd880eb4dad7ec7249d8493c..2c55b3c778a15bc56b86e4acd1a97a358eaf00c6 100644 (file)
@@ -444,6 +444,7 @@ static void manage_member(struct mdstat_ent *mdstat,
        char buf[64];
        int frozen;
        struct supertype *container = a->container;
+       unsigned long long int component_size = 0;
 
        if (container == NULL)
                /* Raced with something */
@@ -453,6 +454,9 @@ static void manage_member(struct mdstat_ent *mdstat,
        a->info.array.raid_disks = mdstat->raid_disks;
        // MORE
 
+       if (sysfs_get_ll(&a->info, NULL, "component_size", &component_size) >= 0)
+               a->info.component_size = component_size << 1;
+
        /* honor 'frozen' */
        if (sysfs_get_str(&a->info, NULL, "metadata_version", buf, sizeof(buf)) > 0)
                frozen = buf[9] == '-';