Blame SOURCES/0074-Change-update-to-enum-in-update_super-and-update_sub.patch

2b63fb
From 03312b5240438ffc3b63114bdc87e911222f01e5 Mon Sep 17 00:00:00 2001
2b63fb
From: Mateusz Kusiak <mateusz.kusiak@intel.com>
2b63fb
Date: Mon, 2 Jan 2023 09:35:22 +0100
2b63fb
Subject: [PATCH 74/83] Change update to enum in update_super and
2b63fb
 update_subarray
2b63fb
2b63fb
Use already existing enum, change update_super and update_subarray
2b63fb
update to enum globally.
2b63fb
Refactor function references also.
2b63fb
Remove code specific options from update_options.
2b63fb
2b63fb
Signed-off-by: Mateusz Kusiak <mateusz.kusiak@intel.com>
2b63fb
Signed-off-by: Jes Sorensen <jes@trained-monkey.org>
2b63fb
---
2b63fb
 Assemble.c    | 14 +++++++++-----
2b63fb
 Examine.c     |  2 +-
2b63fb
 Grow.c        |  9 +++++----
2b63fb
 Manage.c      | 14 ++++++++------
2b63fb
 maps.c        | 21 ---------------------
2b63fb
 mdadm.h       | 12 +++++++++---
2b63fb
 super-intel.c | 16 ++++++++--------
2b63fb
 super0.c      |  9 ++++-----
2b63fb
 super1.c      | 17 ++++++++---------
2b63fb
 9 files changed, 52 insertions(+), 62 deletions(-)
2b63fb
2b63fb
diff --git a/Assemble.c b/Assemble.c
2b63fb
index 8b0af0c9..dba910cd 100644
2b63fb
--- a/Assemble.c
2b63fb
+++ b/Assemble.c
2b63fb
@@ -695,12 +695,16 @@ static int load_devices(struct devs *devices, char *devmap,
2b63fb
 			} else if (strcmp(c->update, "revert-reshape") == 0 &&
2b63fb
 				   c->invalid_backup)
2b63fb
 				err = tst->ss->update_super(tst, content,
2b63fb
-							    "revert-reshape-nobackup",
2b63fb
+							    UOPT_SPEC_REVERT_RESHAPE_NOBACKUP,
2b63fb
 							    devname, c->verbose,
2b63fb
 							    ident->uuid_set,
2b63fb
 							    c->homehost);
2b63fb
 			else
2b63fb
-				err = tst->ss->update_super(tst, content, c->update,
2b63fb
+				/*
2b63fb
+				 * Mapping is temporary, will be removed in this patchset
2b63fb
+				 */
2b63fb
+				err = tst->ss->update_super(tst, content,
2b63fb
+							    map_name(update_options, c->update),
2b63fb
 							    devname, c->verbose,
2b63fb
 							    ident->uuid_set,
2b63fb
 							    c->homehost);
2b63fb
@@ -960,7 +964,7 @@ static int force_array(struct mdinfo *content,
2b63fb
 			continue;
2b63fb
 		}
2b63fb
 		content->events = devices[most_recent].i.events;
2b63fb
-		tst->ss->update_super(tst, content, "force-one",
2b63fb
+		tst->ss->update_super(tst, content, UOPT_SPEC_FORCE_ONE,
2b63fb
 				      devices[chosen_drive].devname, c->verbose,
2b63fb
 				      0, NULL);
2b63fb
 
2b63fb
@@ -1788,7 +1792,7 @@ try_again:
2b63fb
 		if (!(devices[j].i.array.state & 1))
2b63fb
 			clean = 0;
2b63fb
 
2b63fb
-		if (st->ss->update_super(st, &devices[j].i, "assemble", NULL,
2b63fb
+		if (st->ss->update_super(st, &devices[j].i, UOPT_SPEC_ASSEMBLE, NULL,
2b63fb
 					 c->verbose, 0, NULL)) {
2b63fb
 			if (c->force) {
2b63fb
 				if (c->verbose >= 0)
2b63fb
@@ -1811,7 +1815,7 @@ try_again:
2b63fb
 	if (c->force && !clean && !is_container(content->array.level) &&
2b63fb
 	    !enough(content->array.level, content->array.raid_disks,
2b63fb
 		    content->array.layout, clean, avail)) {
2b63fb
-		change += st->ss->update_super(st, content, "force-array",
2b63fb
+		change += st->ss->update_super(st, content, UOPT_SPEC_FORCE_ARRAY,
2b63fb
 					       devices[chosen_drive].devname, c->verbose,
2b63fb
 					       0, NULL);
2b63fb
 		was_forced = 1;
2b63fb
diff --git a/Examine.c b/Examine.c
2b63fb
index 9574a3cc..c9605a60 100644
2b63fb
--- a/Examine.c
2b63fb
+++ b/Examine.c
2b63fb
@@ -117,7 +117,7 @@ int Examine(struct mddev_dev *devlist,
2b63fb
 		}
2b63fb
 
2b63fb
 		if (c->SparcAdjust)
2b63fb
-			st->ss->update_super(st, NULL, "sparc2.2",
2b63fb
+			st->ss->update_super(st, NULL, UOPT_SPARC22,
2b63fb
 					     devlist->devname, 0, 0, NULL);
2b63fb
 		/* Ok, its good enough to try, though the checksum could be wrong */
2b63fb
 
2b63fb
diff --git a/Grow.c b/Grow.c
2b63fb
index b73ec2ae..82d5d2ea 100644
2b63fb
--- a/Grow.c
2b63fb
+++ b/Grow.c
2b63fb
@@ -196,7 +196,7 @@ int Grow_Add_device(char *devname, int fd, char *newdev)
2b63fb
 	info.disk.minor = minor(rdev);
2b63fb
 	info.disk.raid_disk = d;
2b63fb
 	info.disk.state = (1 << MD_DISK_SYNC) | (1 << MD_DISK_ACTIVE);
2b63fb
-	if (st->ss->update_super(st, &info, "linear-grow-new", newdev,
2b63fb
+	if (st->ss->update_super(st, &info, UOPT_SPEC_LINEAR_GROW_NEW, newdev,
2b63fb
 				 0, 0, NULL) != 0) {
2b63fb
 		pr_err("Preparing new metadata failed on %s\n", newdev);
2b63fb
 		close(nfd);
2b63fb
@@ -254,7 +254,7 @@ int Grow_Add_device(char *devname, int fd, char *newdev)
2b63fb
 		info.array.active_disks = nd+1;
2b63fb
 		info.array.working_disks = nd+1;
2b63fb
 
2b63fb
-		if (st->ss->update_super(st, &info, "linear-grow-update", dv,
2b63fb
+		if (st->ss->update_super(st, &info, UOPT_SPEC_LINEAR_GROW_UPDATE, dv,
2b63fb
 				     0, 0, NULL) != 0) {
2b63fb
 			pr_err("Updating metadata failed on %s\n", dv);
2b63fb
 			close(fd2);
2b63fb
@@ -668,7 +668,7 @@ int Grow_consistency_policy(char *devname, int fd, struct context *c, struct sha
2b63fb
 					goto free_info;
2b63fb
 				}
2b63fb
 
2b63fb
-				ret = st->ss->update_super(st, sra, "ppl",
2b63fb
+				ret = st->ss->update_super(st, sra, UOPT_PPL,
2b63fb
 							   devname,
2b63fb
 							   c->verbose, 0, NULL);
2b63fb
 				if (ret) {
2b63fb
@@ -4950,7 +4950,8 @@ int Grow_restart(struct supertype *st, struct mdinfo *info, int *fdlist,
2b63fb
 				continue;
2b63fb
 			st->ss->getinfo_super(st, &dinfo, NULL);
2b63fb
 			dinfo.reshape_progress = info->reshape_progress;
2b63fb
-			st->ss->update_super(st, &dinfo, "_reshape_progress",
2b63fb
+			st->ss->update_super(st, &dinfo,
2b63fb
+					     UOPT_SPEC__RESHAPE_PROGRESS,
2b63fb
 					     NULL,0, 0, NULL);
2b63fb
 			st->ss->store_super(st, fdlist[j]);
2b63fb
 			st->ss->free_super(st);
2b63fb
diff --git a/Manage.c b/Manage.c
2b63fb
index 5a9ea316..87b8aa0c 100644
2b63fb
--- a/Manage.c
2b63fb
+++ b/Manage.c
2b63fb
@@ -605,6 +605,7 @@ int attempt_re_add(int fd, int tfd, struct mddev_dev *dv,
2b63fb
 	struct mdinfo mdi;
2b63fb
 	int duuid[4];
2b63fb
 	int ouuid[4];
2b63fb
+	enum update_opt update_enum = map_name(update_options, update);
2b63fb
 
2b63fb
 	dev_st->ss->getinfo_super(dev_st, &mdi, NULL);
2b63fb
 	dev_st->ss->uuid_from_super(dev_st, ouuid);
2b63fb
@@ -666,23 +667,23 @@ int attempt_re_add(int fd, int tfd, struct mddev_dev *dv,
2b63fb
 
2b63fb
 			if (dv->writemostly == FlagSet)
2b63fb
 				rv = dev_st->ss->update_super(
2b63fb
-					dev_st, NULL, "writemostly",
2b63fb
+					dev_st, NULL, UOPT_SPEC_WRITEMOSTLY,
2b63fb
 					devname, verbose, 0, NULL);
2b63fb
 			if (dv->writemostly == FlagClear)
2b63fb
 				rv = dev_st->ss->update_super(
2b63fb
-					dev_st, NULL, "readwrite",
2b63fb
+					dev_st, NULL, UOPT_SPEC_READWRITE,
2b63fb
 					devname, verbose, 0, NULL);
2b63fb
 			if (dv->failfast == FlagSet)
2b63fb
 				rv = dev_st->ss->update_super(
2b63fb
-					dev_st, NULL, "failfast",
2b63fb
+					dev_st, NULL, UOPT_SPEC_FAILFAST,
2b63fb
 					devname, verbose, 0, NULL);
2b63fb
 			if (dv->failfast == FlagClear)
2b63fb
 				rv = dev_st->ss->update_super(
2b63fb
-					dev_st, NULL, "nofailfast",
2b63fb
+					dev_st, NULL, UOPT_SPEC_NOFAILFAST,
2b63fb
 					devname, verbose, 0, NULL);
2b63fb
 			if (update)
2b63fb
 				rv = dev_st->ss->update_super(
2b63fb
-					dev_st, NULL, update,
2b63fb
+					dev_st, NULL, update_enum,
2b63fb
 					devname, verbose, 0, NULL);
2b63fb
 			if (rv == 0)
2b63fb
 				rv = dev_st->ss->store_super(dev_st, tfd);
2b63fb
@@ -1731,6 +1732,7 @@ int Update_subarray(char *dev, char *subarray, char *update, struct mddev_ident
2b63fb
 	struct supertype supertype, *st = &supertype;
2b63fb
 	int fd, rv = 2;
2b63fb
 	struct mdinfo *info = NULL;
2b63fb
+	enum update_opt update_enum = map_name(update_options, update);
2b63fb
 
2b63fb
 	memset(st, 0, sizeof(*st));
2b63fb
 
2b63fb
@@ -1762,7 +1764,7 @@ int Update_subarray(char *dev, char *subarray, char *update, struct mddev_ident
2b63fb
 		goto free_super;
2b63fb
 	}
2b63fb
 
2b63fb
-	rv = st->ss->update_subarray(st, subarray, update, ident);
2b63fb
+	rv = st->ss->update_subarray(st, subarray, update_enum, ident);
2b63fb
 
2b63fb
 	if (rv) {
2b63fb
 		if (verbose >= 0)
2b63fb
diff --git a/maps.c b/maps.c
2b63fb
index c59036f1..b586679a 100644
2b63fb
--- a/maps.c
2b63fb
+++ b/maps.c
2b63fb
@@ -194,27 +194,6 @@ mapping_t update_options[] = {
2b63fb
 	{ "byteorder", UOPT_BYTEORDER },
2b63fb
 	{ "help", UOPT_HELP },
2b63fb
 	{ "?", UOPT_HELP },
2b63fb
-	/*
2b63fb
-	 * Those enries are temporary and will be removed in this patchset.
2b63fb
-	 *
2b63fb
-	 * Before update_super:update can be changed to enum,
2b63fb
-	 * all update_super sub-functions must be adapted first.
2b63fb
-	 * Update options will be passed as string (as it is for now),
2b63fb
-	 * and then mapped, so all options must be handled temporarily.
2b63fb
-	 *
2b63fb
-	 * Those options code specific and should not be accessible for user.
2b63fb
-	 */
2b63fb
-	{ "force-one", UOPT_SPEC_FORCE_ONE },
2b63fb
-	{ "force-array", UOPT_SPEC_FORCE_ARRAY },
2b63fb
-	{ "assemble", UOPT_SPEC_ASSEMBLE },
2b63fb
-	{ "linear-grow-new", UOPT_SPEC_LINEAR_GROW_NEW },
2b63fb
-	{ "linear-grow-update", UOPT_SPEC_LINEAR_GROW_UPDATE },
2b63fb
-	{ "_reshape_progress", UOPT_SPEC__RESHAPE_PROGRESS },
2b63fb
-	{ "writemostly", UOPT_SPEC_WRITEMOSTLY },
2b63fb
-	{ "readwrite", UOPT_SPEC_READWRITE },
2b63fb
-	{ "failfast", UOPT_SPEC_FAILFAST },
2b63fb
-	{ "nofailfast", UOPT_SPEC_NOFAILFAST },
2b63fb
-	{ "revert-reshape-nobackup", UOPT_SPEC_REVERT_RESHAPE_NOBACKUP },
2b63fb
 	{ NULL, UOPT_UNDEFINED}
2b63fb
 };
2b63fb
 
2b63fb
diff --git a/mdadm.h b/mdadm.h
2b63fb
index 31db25f5..5dc94390 100644
2b63fb
--- a/mdadm.h
2b63fb
+++ b/mdadm.h
2b63fb
@@ -1011,7 +1011,7 @@ extern struct superswitch {
2b63fb
 	 *                    it will resume going in the opposite direction.
2b63fb
 	 */
2b63fb
 	int (*update_super)(struct supertype *st, struct mdinfo *info,
2b63fb
-			    char *update,
2b63fb
+			    enum update_opt update,
2b63fb
 			    char *devname, int verbose,
2b63fb
 			    int uuid_set, char *homehost);
2b63fb
 
2b63fb
@@ -1137,9 +1137,15 @@ extern struct superswitch {
2b63fb
 	/* Permit subarray's to be deleted from inactive containers */
2b63fb
 	int (*kill_subarray)(struct supertype *st,
2b63fb
 			     char *subarray_id); /* optional */
2b63fb
-	/* Permit subarray's to be modified */
2b63fb
+	/**
2b63fb
+	 * update_subarray() - Permit subarray to be modified.
2b63fb
+	 * @st: Supertype.
2b63fb
+	 * @subarray: Subarray name.
2b63fb
+	 * @update: Update option.
2b63fb
+	 * @ident: Optional identifiers.
2b63fb
+	 */
2b63fb
 	int (*update_subarray)(struct supertype *st, char *subarray,
2b63fb
-			       char *update, struct mddev_ident *ident); /* optional */
2b63fb
+			       enum update_opt update, struct mddev_ident *ident);
2b63fb
 	/* Check if reshape is supported for this external format.
2b63fb
 	 * st is obtained from super_by_fd() where st->subarray[0] is
2b63fb
 	 * initialized to indicate if reshape is being performed at the
2b63fb
diff --git a/super-intel.c b/super-intel.c
2b63fb
index 85fb7f17..1f5f6eda 100644
2b63fb
--- a/super-intel.c
2b63fb
+++ b/super-intel.c
2b63fb
@@ -3893,8 +3893,8 @@ struct mdinfo *getinfo_super_disks_imsm(struct supertype *st)
2b63fb
 }
2b63fb
 
2b63fb
 static int update_super_imsm(struct supertype *st, struct mdinfo *info,
2b63fb
-			     char *update, char *devname, int verbose,
2b63fb
-			     int uuid_set, char *homehost)
2b63fb
+			     enum update_opt update, char *devname,
2b63fb
+			     int verbose, int uuid_set, char *homehost)
2b63fb
 {
2b63fb
 	/* For 'assemble' and 'force' we need to return non-zero if any
2b63fb
 	 * change was made.  For others, the return value is ignored.
2b63fb
@@ -3930,7 +3930,7 @@ static int update_super_imsm(struct supertype *st, struct mdinfo *info,
2b63fb
 
2b63fb
 	mpb = super->anchor;
2b63fb
 
2b63fb
-	switch (map_name(update_options, update)) {
2b63fb
+	switch (update) {
2b63fb
 	case UOPT_UUID:
2b63fb
 		/* We take this to mean that the family_num should be updated.
2b63fb
 		 * However that is much smaller than the uuid so we cannot really
2b63fb
@@ -6538,7 +6538,7 @@ static int validate_ppl_imsm(struct supertype *st, struct mdinfo *info,
2b63fb
 		if (mdmon_running(st->container_devnm))
2b63fb
 			st->update_tail = &st->updates;
2b63fb
 
2b63fb
-		if (st->ss->update_subarray(st, subarray, "ppl", NULL)) {
2b63fb
+		if (st->ss->update_subarray(st, subarray, UOPT_PPL, NULL)) {
2b63fb
 			pr_err("Failed to update subarray %s\n",
2b63fb
 			      subarray);
2b63fb
 		} else {
2b63fb
@@ -7916,13 +7916,13 @@ static int get_rwh_policy_from_update(enum update_opt update)
2b63fb
 }
2b63fb
 
2b63fb
 static int update_subarray_imsm(struct supertype *st, char *subarray,
2b63fb
-				char *update, struct mddev_ident *ident)
2b63fb
+				enum update_opt update, struct mddev_ident *ident)
2b63fb
 {
2b63fb
 	/* update the subarray currently referenced by ->current_vol */
2b63fb
 	struct intel_super *super = st->sb;
2b63fb
 	struct imsm_super *mpb = super->anchor;
2b63fb
 
2b63fb
-	if (map_name(update_options, update) == UOPT_NAME) {
2b63fb
+	if (update == UOPT_NAME) {
2b63fb
 		char *name = ident->name;
2b63fb
 		char *ep;
2b63fb
 		int vol;
2b63fb
@@ -7956,7 +7956,7 @@ static int update_subarray_imsm(struct supertype *st, char *subarray,
2b63fb
 			}
2b63fb
 			super->updates_pending++;
2b63fb
 		}
2b63fb
-	} else if (get_rwh_policy_from_update(map_name(update_options, update)) != UOPT_UNDEFINED) {
2b63fb
+	} else if (get_rwh_policy_from_update(update) != UOPT_UNDEFINED) {
2b63fb
 		int new_policy;
2b63fb
 		char *ep;
2b63fb
 		int vol = strtoul(subarray, &ep, 10);
2b63fb
@@ -7964,7 +7964,7 @@ static int update_subarray_imsm(struct supertype *st, char *subarray,
2b63fb
 		if (*ep != '\0' || vol >= super->anchor->num_raid_devs)
2b63fb
 			return 2;
2b63fb
 
2b63fb
-		new_policy = get_rwh_policy_from_update(map_name(update_options, update));
2b63fb
+		new_policy = get_rwh_policy_from_update(update);
2b63fb
 
2b63fb
 		if (st->update_tail) {
2b63fb
 			struct imsm_update_rwh_policy *u = xmalloc(sizeof(*u));
2b63fb
diff --git a/super0.c b/super0.c
2b63fb
index d9f5bff4..a7c5f813 100644
2b63fb
--- a/super0.c
2b63fb
+++ b/super0.c
2b63fb
@@ -491,7 +491,7 @@ static struct mdinfo *container_content0(struct supertype *st, char *subarray)
2b63fb
 }
2b63fb
 
2b63fb
 static int update_super0(struct supertype *st, struct mdinfo *info,
2b63fb
-			 char *update,
2b63fb
+			 enum update_opt update,
2b63fb
 			 char *devname, int verbose,
2b63fb
 			 int uuid_set, char *homehost)
2b63fb
 {
2b63fb
@@ -502,20 +502,19 @@ static int update_super0(struct supertype *st, struct mdinfo *info,
2b63fb
 	int rv = 0;
2b63fb
 	int uuid[4];
2b63fb
 	mdp_super_t *sb = st->sb;
2b63fb
-	enum update_opt update_enum = map_name(update_options, update);
2b63fb
 
2b63fb
-	if (update_enum == UOPT_HOMEHOST && homehost) {
2b63fb
+	if (update == UOPT_HOMEHOST && homehost) {
2b63fb
 		/*
2b63fb
 		 * note that 'homehost' is special as it is really
2b63fb
 		 * a "uuid" update.
2b63fb
 		 */
2b63fb
 		uuid_set = 0;
2b63fb
-		update_enum = UOPT_UUID;
2b63fb
+		update = UOPT_UUID;
2b63fb
 		info->uuid[0] = sb->set_uuid0;
2b63fb
 		info->uuid[1] = sb->set_uuid1;
2b63fb
 	}
2b63fb
 
2b63fb
-	switch (update_enum) {
2b63fb
+	switch (update) {
2b63fb
 	case UOPT_UUID:
2b63fb
 		if (!uuid_set && homehost) {
2b63fb
 			char buf[20];
2b63fb
diff --git a/super1.c b/super1.c
2b63fb
index b0a97016..f7020320 100644
2b63fb
--- a/super1.c
2b63fb
+++ b/super1.c
2b63fb
@@ -1208,7 +1208,7 @@ static struct mdinfo *container_content1(struct supertype *st, char *subarray)
2b63fb
 }
2b63fb
 
2b63fb
 static int update_super1(struct supertype *st, struct mdinfo *info,
2b63fb
-			 char *update, char *devname, int verbose,
2b63fb
+			 enum update_opt update, char *devname, int verbose,
2b63fb
 			 int uuid_set, char *homehost)
2b63fb
 {
2b63fb
 	/* NOTE: for 'assemble' and 'force' we need to return non-zero
2b63fb
@@ -1218,15 +1218,14 @@ static int update_super1(struct supertype *st, struct mdinfo *info,
2b63fb
 	int rv = 0;
2b63fb
 	struct mdp_superblock_1 *sb = st->sb;
2b63fb
 	bitmap_super_t *bms = (bitmap_super_t*)(((char*)sb) + MAX_SB_SIZE);
2b63fb
-	enum update_opt update_enum = map_name(update_options, update);
2b63fb
 
2b63fb
-	if (update_enum == UOPT_HOMEHOST && homehost) {
2b63fb
+	if (update == UOPT_HOMEHOST && homehost) {
2b63fb
 		/*
2b63fb
 		 * Note that 'homehost' is special as it is really
2b63fb
 		 * a "name" update.
2b63fb
 		 */
2b63fb
 		char *c;
2b63fb
-		update_enum = UOPT_NAME;
2b63fb
+		update = UOPT_NAME;
2b63fb
 		c = strchr(sb->set_name, ':');
2b63fb
 		if (c)
2b63fb
 			snprintf(info->name, sizeof(info->name), "%s", c+1);
2b63fb
@@ -1234,7 +1233,7 @@ static int update_super1(struct supertype *st, struct mdinfo *info,
2b63fb
 			snprintf(info->name, sizeof(info->name), "%s", sb->set_name);
2b63fb
 	}
2b63fb
 
2b63fb
-	switch (update_enum) {
2b63fb
+	switch (update) {
2b63fb
 	case UOPT_NAME: {
2b63fb
 		int namelen;
2b63fb
 
2b63fb
@@ -1534,7 +1533,7 @@ static int update_super1(struct supertype *st, struct mdinfo *info,
2b63fb
 			 * If that couldn't happen, the "-nobackup" version
2b63fb
 			 * will be used.
2b63fb
 			 */
2b63fb
-			if (update_enum == UOPT_SPEC_REVERT_RESHAPE_NOBACKUP &&
2b63fb
+			if (update == UOPT_SPEC_REVERT_RESHAPE_NOBACKUP &&
2b63fb
 			    sb->reshape_position == 0 &&
2b63fb
 			    (__le32_to_cpu(sb->delta_disks) > 0 ||
2b63fb
 			     (__le32_to_cpu(sb->delta_disks) == 0 &&
2b63fb
@@ -1618,14 +1617,14 @@ static int update_super1(struct supertype *st, struct mdinfo *info,
2b63fb
 	case UOPT_LAYOUT_UNSPECIFIED:
2b63fb
 		if (__le32_to_cpu(sb->level) != 0) {
2b63fb
 			pr_err("%s: %s only supported for RAID0\n",
2b63fb
-			       devname ?: "", map_num(update_options, update_enum));
2b63fb
+			       devname ?: "", map_num(update_options, update));
2b63fb
 			rv = -1;
2b63fb
-		} else if (update_enum == UOPT_LAYOUT_UNSPECIFIED) {
2b63fb
+		} else if (update == UOPT_LAYOUT_UNSPECIFIED) {
2b63fb
 			sb->feature_map &= ~__cpu_to_le32(MD_FEATURE_RAID0_LAYOUT);
2b63fb
 			sb->layout = 0;
2b63fb
 		} else {
2b63fb
 			sb->feature_map |= __cpu_to_le32(MD_FEATURE_RAID0_LAYOUT);
2b63fb
-			sb->layout = __cpu_to_le32(update_enum == UOPT_LAYOUT_ORIGINAL ? 1 : 2);
2b63fb
+			sb->layout = __cpu_to_le32(update == UOPT_LAYOUT_ORIGINAL ? 1 : 2);
2b63fb
 		}
2b63fb
 		break;
2b63fb
 	default:
2b63fb
-- 
2b63fb
2.38.1
2b63fb