summaryrefslogtreecommitdiffstats
path: root/0172-RHBZ-1350931-no-active-add.patch
blob: 4e79e325d14563fd3dcf861e200cf5ae20da4de7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
---
 multipathd/main.c |   15 +++++++++++----
 1 file changed, 11 insertions(+), 4 deletions(-)

Index: multipath-tools-130222/multipathd/main.c
===================================================================
--- multipath-tools-130222.orig/multipathd/main.c
+++ multipath-tools-130222/multipathd/main.c
@@ -530,9 +530,15 @@ ev_add_path (struct path * pp, struct ve
 	}
 	mpp = find_mp_by_wwid(vecs->mpvec, pp->wwid);
 	if (mpp && mpp->wait_for_udev) {
-		mpp->wait_for_udev = 2;
-		orphan_path(pp);
-		return 0;
+		if (pathcount(mpp, PATH_UP) == 0 &&
+		    (pathcount(mpp, PATH_GHOST) == 0 ||
+		     pp->tpgs == TPGS_IMPLICIT))
+			mpp->force_udev_reload = 1;
+		else {
+			mpp->wait_for_udev = 2;
+			orphan_path(pp);
+			return 0;
+		}
 	}
 
 	pp->mpp = mpp;
@@ -551,7 +557,8 @@ rescan:
 
 		condlog(4,"%s: adopting all paths for path %s",
 			mpp->alias, pp->dev);
-		mpp->force_udev_reload = !pathcount(mpp, PATH_WILD);
+		if (pathcount(mpp, PATH_WILD) == 0)
+			mpp->force_udev_reload = 1;
 		if (adopt_paths(vecs->pathvec, mpp, 1))
 			goto fail; /* leave path added to pathvec */