]> git.ipfire.org Git - thirdparty/mdadm.git/commitdiff
FIX: Do not allow for multiple reshape_array() execution during reshape_container...
authorAdam Kwolek <adam.kwolek@intel.com>
Thu, 15 Dec 2011 03:34:36 +0000 (14:34 +1100)
committerNeilBrown <neilb@suse.de>
Thu, 15 Dec 2011 03:34:36 +0000 (14:34 +1100)
It can happen during reshape restart that reshape_array() can exit without
error (e.g. Grow.c:1915) and reshape is not moved to next array.
reshape_array() is called again for the same device.
Do not allow for such execution and check if last reshaped array is not
the current one.
This patch can be treat not as solution, but it allows for such errors
detection.

Signed-off-by: Adam Kwolek <adam.kwolek@intel.com>
Signed-off-by: NeilBrown <neilb@suse.de>
Grow.c

diff --git a/Grow.c b/Grow.c
index 184a973a8be8e10f5d2790eef2fff6ec6aed9e35..70b273445cc5fad95372508964500782dd689bdc 100644 (file)
--- a/Grow.c
+++ b/Grow.c
@@ -2462,6 +2462,7 @@ int reshape_container(char *container, char *devname,
 {
        struct mdinfo *cc = NULL;
        int rv = restart;
+       int last_devnum = -1;
 
        /* component_size is not meaningful for a container,
         * so pass '-1' meaning 'no change'
@@ -2546,6 +2547,24 @@ int reshape_container(char *container, char *devname,
                if (!adev)
                        adev = content->text_version;
 
+               if (last_devnum == mdstat->devnum) {
+                       /* Do not allow for multiple reshape_array() calls for
+                        * the same array.
+                        * It can happen when reshape_array() returns without
+                        * error, when reshape is not finished (wrong reshape
+                        * starting/continuation conditions).  Mdmon doesn't
+                        * switch to next array in container and reentry
+                        * conditions for the same array occur.
+                        * This is possibly interim until the behaviour of
+                        * reshape_array is resolved().
+                        */
+                       printf(Name ": Multiple reshape execution detected for "
+                              "device  %s.", adev);
+                       close(fd);
+                       break;
+               }
+               last_devnum = mdstat->devnum;
+
                sysfs_init(content, fd, mdstat->devnum);
 
                rv = reshape_array(container, fd, adev, st,