Blame SOURCES/0171-UPBZ-1356651-allow-zero-size.patch

4728c8
---
4728c8
 libmultipath/discovery.c   |    5 +++++
4728c8
 libmultipath/structs_vec.c |    2 +-
4728c8
 multipathd/main.c          |   26 +++++---------------------
4728c8
 3 files changed, 11 insertions(+), 22 deletions(-)
4728c8
4728c8
Index: multipath-tools-130222/libmultipath/discovery.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/discovery.c
4728c8
+++ multipath-tools-130222/libmultipath/discovery.c
4728c8
@@ -1188,6 +1188,11 @@ pathinfo (struct path *pp, vector hwtabl
4728c8
 			if (pp->state == PATH_UNCHECKED ||
4728c8
 			    pp->state == PATH_WILD)
4728c8
 				goto blank;
4728c8
+			if (pp->state == PATH_UP && !pp->size) {
4728c8
+				condlog(3, "%s: device size is 0, "
4728c8
+					"path unuseable", pp->dev);
4728c8
+				pp->state = PATH_GHOST;
4728c8
+			}
4728c8
 		} else {
4728c8
 			condlog(3, "%s: path inaccessible", pp->dev);
4728c8
 			pp->chkrstate = pp->state = path_state;
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
@@ -551,7 +551,7 @@ int update_multipath (struct vectors *ve
4728c8
 
4728c8
 			if (pp->state != PATH_DOWN) {
4728c8
 				int oldstate = pp->state;
4728c8
-				condlog(2, "%s: mark as failed", pp->dev_t);
4728c8
+				condlog(2, "%s: mark as failed", pp->dev);
4728c8
 				mpp->stat_path_failures++;
4728c8
 				pp->state = PATH_DOWN;
4728c8
 				if (oldstate == PATH_UP ||
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
@@ -538,15 +538,10 @@ ev_add_path (struct path * pp, struct ve
4728c8
 	pp->mpp = mpp;
4728c8
 rescan:
4728c8
 	if (mpp) {
4728c8
-		if ((!pp->size) || (mpp->size != pp->size)) {
4728c8
-			if (!pp->size)
4728c8
-				condlog(0, "%s: failed to add new path %s, "
4728c8
-					"device size is 0",
4728c8
-					mpp->alias, pp->dev);
4728c8
-			else
4728c8
-				condlog(0, "%s: failed to add new path %s, "
4728c8
-					"device size mismatch",
4728c8
-					mpp->alias, pp->dev);
4728c8
+		if (pp->size && mpp->size != pp->size) {
4728c8
+			condlog(0, "%s: failed to add new path %s, "
4728c8
+				"device size mismatch",
4728c8
+				mpp->alias, pp->dev);
4728c8
 			int i = find_slot(vecs->pathvec, (void *)pp);
4728c8
 			if (i != -1)
4728c8
 				vector_del_slot(vecs->pathvec, i);
4728c8
@@ -563,18 +558,7 @@ rescan:
4728c8
 		verify_paths(mpp, vecs, NULL);
4728c8
 		mpp->flush_on_last_del = FLUSH_UNDEF;
4728c8
 		mpp->action = ACT_RELOAD;
4728c8
-	}
4728c8
-	else {
4728c8
-		if (!pp->size) {
4728c8
-			condlog(0, "%s: failed to create new map,"
4728c8
-				" device size is 0 ", pp->dev);
4728c8
-			int i = find_slot(vecs->pathvec, (void *)pp);
4728c8
-			if (i != -1)
4728c8
-				vector_del_slot(vecs->pathvec, i);
4728c8
-			free_path(pp);
4728c8
-			return 1;
4728c8
-		}
4728c8
-
4728c8
+	} else {
4728c8
 		if (!should_multipath(pp, vecs->pathvec)) {
4728c8
 			orphan_path(pp);
4728c8
 			return 0;