From 582945c2d3bbead4a71de521a392e292a4a84e24 Mon Sep 17 00:00:00 2001 From: Pawel Piatkowski Date: Wed, 20 Dec 2023 10:32:49 +0100 Subject: [PATCH 1/1] manage: adjust checking subarray state in update_subarray Only changing bitmap related consistency_policy requires subarray to be inactive. consistency_policy with PPL or NO_PPL value can be changed on active subarray. It fixes regression introduced in commit db10eab68e652f141169 ("Fix --update-subarray on active volume") Signed-off-by: Pawel Piatkowski Signed-off-by: Mariusz Tkaczyk --- Manage.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Manage.c b/Manage.c index f0d4cb01..91532266 100644 --- a/Manage.c +++ b/Manage.c @@ -1749,6 +1749,7 @@ int Update_subarray(char *dev, char *subarray, enum update_opt update, int fd, rv = 2; struct mdinfo *info = NULL; char *update_verb = map_num(update_options, update); + bool allow_active = update == UOPT_PPL || update == UOPT_NO_PPL; memset(st, 0, sizeof(*st)); @@ -1763,7 +1764,7 @@ int Update_subarray(char *dev, char *subarray, enum update_opt update, goto free_super; } - if (is_subarray_active(subarray, st->devnm)) { + if (!allow_active && is_subarray_active(subarray, st->devnm)) { if (verbose >= 0) pr_err("Subarray %s in %s is active, cannot update %s\n", subarray, dev, update_verb); -- 2.41.0