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@xxxxxxxxx> --- Grow.c | 12 ++++++++++++ 1 files changed, 12 insertions(+), 0 deletions(-) diff --git a/Grow.c b/Grow.c index 184a973..1828f83 100644 --- 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,17 @@ int reshape_container(char *container, char *devname, if (!adev) adev = content->text_version; + if (last_devnum == mdstat->devnum) { + /* do not allow for reentry reshape_array() + * for the same device. It can happen when resahpe_array + */ + 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, -- To unsubscribe from this list: send the line "unsubscribe linux-raid" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html