From: Jakub Radtke Date: Fri, 15 Jan 2021 05:47:01 +0000 (-0500) Subject: Grow: Block reshape when external metadata and write-intent bitmap X-Git-Tag: mdadm-4.2-rc1~7 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=bdbe7f8199361a170d16f6d114fa61cd7e72599f;p=thirdparty%2Fmdadm.git Grow: Block reshape when external metadata and write-intent bitmap Current kernel sysfs interface for the bitmap is limited. It allows the applying of the bitmap on non-active volumes only. The reshape operation for a volume with a bitmap should be blocked. Signed-off-by: Jakub Radtke Signed-off-by: Jes Sorensen --- diff --git a/Grow.c b/Grow.c index cec83886..11209299 100644 --- a/Grow.c +++ b/Grow.c @@ -1850,15 +1850,14 @@ int Grow_reshape(char *devname, int fd, pr_err("Cannot increase raid-disks on this array beyond %d\n", st->max_devs); return 1; } - if (s->level == 0 && - (array.state & (1<level == 0 && (array.state & (1 << MD_SB_BITMAP_PRESENT)) && + !(array.state & (1 << MD_SB_CLUSTERED)) && !st->ss->external) { + array.state &= ~(1 << MD_SB_BITMAP_PRESENT); + if (md_set_array_info(fd, &array) != 0) { + pr_err("failed to remove internal bitmap.\n"); + return 1; + } + } /* in the external case we need to check that the requested reshape is * supported, and perform an initial check that the container holds the @@ -1922,6 +1921,13 @@ int Grow_reshape(char *devname, int fd, free(subarray); return 1; } + if (content->consistency_policy == + CONSISTENCY_POLICY_BITMAP) { + pr_err("Operation not supported when write-intent bitmap is enabled\n"); + sysfs_free(cc); + free(subarray); + return 1; + } } sysfs_free(cc); }