Blame SOURCES/0250-RHBZ-1610867-rescan-change.patch

4728c8
---
4728c8
 libmultipath/structs_vec.c |  103 +++++++++------------------------------------
4728c8
 libmultipath/structs_vec.h |    6 ++
4728c8
 multipathd/main.c          |   50 +++++++++++++++++++++
4728c8
 3 files changed, 75 insertions(+), 84 deletions(-)
4728c8
4728c8
Index: multipath-tools-130222/libmultipath/structs_vec.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/structs_vec.c
4728c8
+++ multipath-tools-130222/libmultipath/structs_vec.c
4728c8
@@ -103,7 +103,7 @@ orphan_paths (vector pathvec, struct mul
4728c8
 	}
4728c8
 }
4728c8
 
4728c8
-static void
4728c8
+void
4728c8
 set_multipath_wwid (struct multipath * mpp)
4728c8
 {
4728c8
 	if (strlen(mpp->wwid))
4728c8
@@ -188,57 +188,36 @@ remove_maps_and_stop_waiters (struct vec
4728c8
 	_remove_maps(vecs, STOP_WAITER);
4728c8
 }
4728c8
 
4728c8
-static struct hwentry *
4728c8
+void
4728c8
 extract_hwe_from_path(struct multipath * mpp)
4728c8
 {
4728c8
 	struct path * pp = NULL;
4728c8
-	int pg_num = -1, p_num = -1, i;
4728c8
-	struct pathgroup * pgp = NULL;
4728c8
-
4728c8
-	condlog(3, "%s: searching paths for valid hwe", mpp->alias);
4728c8
+	int i;
4728c8
 
4728c8
-	if (mpp && mpp->pg) {
4728c8
-		vector_foreach_slot(mpp->pg, pgp, i) {
4728c8
-			if (pgp->status == PGSTATE_ACTIVE ||
4728c8
-			    pgp->status == PGSTATE_ENABLED) {
4728c8
-				pg_num = i;
4728c8
-				break;
4728c8
-			}
4728c8
-		}
4728c8
-		if (pg_num >= 0)
4728c8
-			pgp = VECTOR_SLOT(mpp->pg, pg_num);
4728c8
-	}
4728c8
+	if (mpp->hwe || !mpp->paths)
4728c8
+		return;
4728c8
 
4728c8
-	if (pgp && pgp->paths) {
4728c8
-		vector_foreach_slot(pgp->paths, pp, i) {
4728c8
-			if (pp->dmstate == PSTATE_FAILED)
4728c8
-				continue;
4728c8
-			if (strlen(pp->vendor_id) > 0 &&
4728c8
-			    strlen(pp->product_id) > 0 &&
4728c8
-			    strlen(pp->rev) > 0) {
4728c8
-				p_num = i;
4728c8
-				break;
4728c8
-			}
4728c8
+	condlog(3, "%s: searching paths for valid hwe", mpp->alias);
4728c8
+	/* doing this in two passes seems like paranoia to me */
4728c8
+	vector_foreach_slot(mpp->paths, pp, i) {
4728c8
+		if (pp->state != PATH_UP)
4728c8
+			continue;
4728c8
+		if (pp->hwe) {
4728c8
+			mpp->hwe = pp->hwe;
4728c8
+			return;
4728c8
 		}
4728c8
-		if (p_num >= 0)
4728c8
-			pp = VECTOR_SLOT(pgp->paths, i);
4728c8
 	}
4728c8
-
4728c8
-	if (pp) {
4728c8
-		condlog(3, "%s: vendor = %s", pp->dev, pp->vendor_id);
4728c8
-		condlog(3, "%s: product = %s", pp->dev, pp->product_id);
4728c8
-		condlog(3, "%s: rev = %s", pp->dev, pp->rev);
4728c8
-		if (!pp->hwe) {
4728c8
-			condlog(3, "searching hwtable");
4728c8
-			pp->hwe = find_hwe(conf->hwtable, pp->vendor_id,
4728c8
-					   pp->product_id, pp->rev);
4728c8
+	vector_foreach_slot(mpp->paths, pp, i) {
4728c8
+		if (pp->state == PATH_UP)
4728c8
+			continue;
4728c8
+		if (pp->hwe) {
4728c8
+			mpp->hwe = pp->hwe;
4728c8
+			return;
4728c8
 		}
4728c8
 	}
4728c8
-
4728c8
-	return pp?pp->hwe:NULL;
4728c8
 }
4728c8
 
4728c8
-static int
4728c8
+int
4728c8
 update_multipath_table (struct multipath *mpp, vector pathvec)
4728c8
 {
4728c8
 	char params[PARAMS_SIZE] = {0};
4728c8
@@ -259,7 +238,7 @@ update_multipath_table (struct multipath
4728c8
 	return 0;
4728c8
 }
4728c8
 
4728c8
-static int
4728c8
+int
4728c8
 update_multipath_status (struct multipath *mpp)
4728c8
 {
4728c8
 	char status[PARAMS_SIZE] = {0};
4728c8
@@ -371,21 +350,11 @@ __setup_multipath (struct vectors * vecs
4728c8
 		goto out;
4728c8
 	}
4728c8
 
4728c8
-	set_multipath_wwid(mpp);
4728c8
-	mpp->mpe = find_mpe(mpp->wwid);
4728c8
-	condlog(3, "%s: discover", mpp->alias);
4728c8
-
4728c8
 	if (update_multipath_strings(mpp, vecs->pathvec)) {
4728c8
 		condlog(0, "%s: failed to setup multipath", mpp->alias);
4728c8
 		goto out;
4728c8
 	}
4728c8
 
4728c8
-	if (!mpp->hwe)
4728c8
-		mpp->hwe = extract_hwe_from_path(mpp);
4728c8
-	if (!mpp->hwe) {
4728c8
-		condlog(3, "%s: no hardware entry found, using defaults",
4728c8
-			mpp->alias);
4728c8
-	}
4728c8
 	if (reset) {
4728c8
 		select_rr_weight(mpp);
4728c8
 		select_pgfailback(mpp);
4728c8
@@ -402,36 +371,6 @@ out:
4728c8
 	return 1;
4728c8
 }
4728c8
 
4728c8
-extern struct multipath *
4728c8
-add_map_without_path (struct vectors * vecs, char * alias)
4728c8
-{
4728c8
-	struct multipath * mpp = alloc_multipath();
4728c8
-
4728c8
-	if (!mpp || !alias)
4728c8
-		return NULL;
4728c8
-
4728c8
-	mpp->alias = STRDUP(alias);
4728c8
-
4728c8
-	if (setup_multipath(vecs, mpp))
4728c8
-		return NULL; /* mpp freed in setup_multipath */
4728c8
-
4728c8
-	if (adopt_paths(vecs->pathvec, mpp, 1))
4728c8
-		goto out;
4728c8
-
4728c8
-	if (!vector_alloc_slot(vecs->mpvec))
4728c8
-		goto out;
4728c8
-
4728c8
-	vector_set_slot(vecs->mpvec, mpp);
4728c8
-
4728c8
-	if (start_waiter_thread(mpp, vecs))
4728c8
-		goto out;
4728c8
-
4728c8
-	return mpp;
4728c8
-out:
4728c8
-	remove_map(mpp, vecs, PURGE_VEC);
4728c8
-	return NULL;
4728c8
-}
4728c8
-
4728c8
 static void
4728c8
 find_existing_alias (struct multipath * mpp,
4728c8
 		     struct vectors *vecs)
4728c8
Index: multipath-tools-130222/libmultipath/structs_vec.h
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/structs_vec.h
4728c8
+++ multipath-tools-130222/libmultipath/structs_vec.h
4728c8
@@ -31,11 +31,15 @@ void remove_map_and_stop_waiter (struct
4728c8
 void remove_maps (struct vectors * vecs);
4728c8
 void remove_maps_and_stop_waiters (struct vectors * vecs);
4728c8
 
4728c8
-struct multipath * add_map_without_path (struct vectors * vecs, char * alias);
4728c8
 struct multipath * add_map_with_path (struct vectors * vecs,
4728c8
 				struct path * pp, int add_vec);
4728c8
 int update_multipath (struct vectors *vecs, char *mapname, int reset);
4728c8
 void update_queue_mode_del_path(struct multipath *mpp);
4728c8
 void update_queue_mode_add_path(struct multipath *mpp);
4728c8
 
4728c8
+void extract_hwe_from_path(struct multipath * mpp);
4728c8
+void set_multipath_wwid (struct multipath * mpp);
4728c8
+int update_multipath_table (struct multipath *mpp, vector pathvec);
4728c8
+int update_multipath_status (struct multipath *mpp);
4728c8
+
4728c8
 #endif /* _STRUCTS_VEC_H */
4728c8
Index: multipath-tools-130222/multipathd/main.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/multipathd/main.c
4728c8
+++ multipath-tools-130222/multipathd/main.c
4728c8
@@ -273,6 +273,7 @@ retry:
4728c8
 	mpp->flush_on_last_del = FLUSH_UNDEF;
4728c8
 	mpp->action = ACT_RELOAD;
4728c8
 
4728c8
+	extract_hwe_from_path(mpp);
4728c8
 	if (setup_map(mpp, params, PARAMS_SIZE)) {
4728c8
 		condlog(0, "%s: failed to setup new map in update", mpp->alias);
4728c8
 		retries = -1;
4728c8
@@ -296,6 +297,49 @@ fail:
4728c8
 	return 0;
4728c8
 }
4728c8
 
4728c8
+static struct multipath *
4728c8
+add_map_without_path (struct vectors * vecs, char * alias)
4728c8
+{
4728c8
+	struct multipath * mpp = alloc_multipath();
4728c8
+
4728c8
+	if (!mpp)
4728c8
+		return NULL;
4728c8
+	if (!alias) {
4728c8
+		FREE(mpp);
4728c8
+		return NULL;
4728c8
+	}
4728c8
+
4728c8
+	mpp->alias = STRDUP(alias);
4728c8
+
4728c8
+	if (dm_get_info(mpp->alias, &mpp->dmi)) {
4728c8
+		condlog(3, "%s: cannot access table", mpp->alias);
4728c8
+		goto out;
4728c8
+	}
4728c8
+	set_multipath_wwid(mpp);
4728c8
+	mpp->mpe = find_mpe(mpp->wwid);
4728c8
+
4728c8
+	if (update_multipath_table(mpp, vecs->pathvec))
4728c8
+		 goto out;
4728c8
+	if (update_multipath_status(mpp))
4728c8
+		goto out;
4728c8
+
4728c8
+	if (!vector_alloc_slot(vecs->mpvec))
4728c8
+		goto out;
4728c8
+
4728c8
+	vector_set_slot(vecs->mpvec, mpp);
4728c8
+
4728c8
+	if (update_map(mpp, vecs) != 0) /* map removed */
4728c8
+		return NULL;
4728c8
+
4728c8
+	if (start_waiter_thread(mpp, vecs))
4728c8
+		goto out;
4728c8
+
4728c8
+	return mpp;
4728c8
+out:
4728c8
+	remove_map(mpp, vecs, 1);
4728c8
+	return NULL;
4728c8
+}
4728c8
+
4728c8
 static int
4728c8
 uev_add_map (struct uevent * uev, struct vectors * vecs)
4728c8
 {
4728c8
@@ -569,6 +613,7 @@ rescan:
4728c8
 		verify_paths(mpp, vecs, NULL);
4728c8
 		mpp->flush_on_last_del = FLUSH_UNDEF;
4728c8
 		mpp->action = ACT_RELOAD;
4728c8
+		extract_hwe_from_path(mpp);
4728c8
 	} else {
4728c8
 		if (!should_multipath(pp, vecs->pathvec)) {
4728c8
 			orphan_path(pp);
4728c8
@@ -855,8 +900,11 @@ map_discovery (struct vectors * vecs)
4728c8
 		return 1;
4728c8
 
4728c8
 	vector_foreach_slot (vecs->mpvec, mpp, i)
4728c8
-		if (setup_multipath(vecs, mpp))
4728c8
+		if (update_multipath_table(mpp, vecs->pathvec) ||
4728c8
+		    update_multipath_status(mpp)) {
4728c8
+			remove_map(mpp, vecs, 1);
4728c8
 			i--;
4728c8
+		}
4728c8
 
4728c8
 	return 0;
4728c8
 }