Blame SOURCES/0014-Grow-block-n-on-external-volumes.patch

25786b
From 20e114e334ed6ed3280c37a9a08fb95578393d1a Mon Sep 17 00:00:00 2001
25786b
From: Mateusz Kusiak <mateusz.kusiak@intel.com>
25786b
Date: Thu, 19 May 2022 09:16:08 +0200
91179e
Subject: [PATCH 14/83] Grow: block -n on external volumes.
25786b
25786b
Performing --raid-devices on external metadata volume should be blocked
25786b
as it causes unwanted behaviour.
25786b
25786b
Eg. Performing
25786b
mdadm -G /dev/md/volume -l10 -n4
25786b
on r0_d2 inside 4 disk container, returns
25786b
mdadm: Need 2 spares to avoid degraded array, only have 0.
25786b
25786b
Signed-off-by: Mateusz Kusiak <mateusz.kusiak@intel.com>
25786b
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
25786b
---
25786b
 Grow.c | 8 ++++++++
25786b
 1 file changed, 8 insertions(+)
25786b
25786b
diff --git a/Grow.c b/Grow.c
25786b
index 8a242b0f..f6efbc48 100644
25786b
--- a/Grow.c
25786b
+++ b/Grow.c
25786b
@@ -1892,6 +1892,14 @@ int Grow_reshape(char *devname, int fd,
25786b
 
25786b
 		if (retval) {
25786b
 			pr_err("Cannot read superblock for %s\n", devname);
25786b
+			close(cfd);
25786b
+			free(subarray);
25786b
+			return 1;
25786b
+		}
25786b
+
25786b
+		if (s->raiddisks && subarray) {
25786b
+			pr_err("--raid-devices operation can be performed on a container only\n");
25786b
+			close(cfd);
25786b
 			free(subarray);
25786b
 			return 1;
25786b
 		}
25786b
-- 
91179e
2.38.1
25786b