]> git.ipfire.org Git - thirdparty/mdadm.git/commitdiff
FIX: Container can be left frozen
authorAdam Kwolek <adam.kwolek@intel.com>
Wed, 9 Feb 2011 03:07:26 +0000 (14:07 +1100)
committerNeilBrown <neilb@suse.de>
Wed, 9 Feb 2011 03:07:26 +0000 (14:07 +1100)
When container operation fails before child process starts,
array can be left frozen because container_reshape() doesn't make
unfreeze() operation in all error cases, as it is responsible for.

add unfreeze() operation for error case scenarios in reshape_container()

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 8229b4d4e5bc0a6cdc00d4a7c707107c4cbeaf5b..f245e03aedac4f2c4d7742ffd80bf26910a9b127 100644 (file)
--- a/Grow.c
+++ b/Grow.c
@@ -2122,8 +2122,10 @@ int reshape_container(char *container, int cfd, char *devname,
        if (reshape_super(st, -1, info->new_level,
                          info->new_layout, info->new_chunk,
                          info->array.raid_disks + info->delta_disks,
-                         backup_file, devname, quiet))
+                         backup_file, devname, quiet)) {
+               unfreeze(st);
                return 1;
+       }
 
        sync_metadata(st);
 
@@ -2134,6 +2136,7 @@ int reshape_container(char *container, int cfd, char *devname,
        switch (fork()) {
        case -1: /* error */
                perror("Cannot fork to complete reshape\n");
+               unfreeze(st);
                return 1;
        default: /* parent */
                printf(Name ": multi-array reshape continues in background\n");