35f5570500
Update Source to upstream version 0.8.0 * Previous patches 0006 & 0007 are included in this commit Rename files * Previous patches 0008-0016 & 0100 are now patches 0018-0027 Add 0006-multipathd-Fix-miscounting-active-paths.patch Add 0007-multipathd-ignore-failed-wwid-recheck.patch * multipathd will no longer disable paths if it is unable to get their wwid on a change event Add 0008-libmutipath-continue-to-use-old-state-on-PATH_PENDIN.patch Add 0009-multipathd-use-update_path_groups-instead-of-reload_.patch Add 0010-multipath.conf-add-missing-options-to-man-page.patch Add 0011-libmultipath-add-get_uid-fallback-code-for-NVMe-devi.patch Add 0012-libmulitpath-cleanup-uid_fallback-code.patch Add 0013-multipathd-handle-changed-wwids-by-removal-and-addit.patch * if a path device changes wwid, it will now be removed and re-added to the correct multipath device. Add 0014-multipathd-remove-wwid_changed-path-attribute.patch Add 0015-multipathd-ignore-disable_changed_wwids.patch Add 0016-multipathd-Don-t-use-fallback-code-after-getting-wwi.patch Add 0017-libmultipath-silence-dm_is_mpath-error-messages.patch * The above 12 patches have been submitted upstream
72 lines
2.6 KiB
Diff
72 lines
2.6 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Benjamin Marzinski <bmarzins@redhat.com>
|
|
Date: Wed, 20 Feb 2019 17:05:08 -0600
|
|
Subject: [PATCH] multipathd: ignore failed wwid recheck
|
|
|
|
If disable_changed_wwids is set, when multipathd gets a change event on
|
|
a path, it verifies that the wwid hasn't changed in uev_update_path().
|
|
If get_uid() failed, uev_update_path treated this as a wwid change to 0.
|
|
This could cause paths to suddenly be dropped due to an issue with
|
|
getting the wwid. Even if get_uid() failed because the path was down,
|
|
it no change uevent happend when it later became active, multipathd
|
|
would continue to ignore the path. Also, scsi_uid_fallback() clears the
|
|
failure return if it doesn't attempt to fallback, causing get_uid()
|
|
to return success, when it actually failed.
|
|
|
|
Multipathd should neither set nor clear wwid_changed if get_uid()
|
|
returned failure. Also, scsi_uid_fallback() should retain the old return
|
|
value if it doesn't attempt to fallback.
|
|
|
|
Signed-off-by: Benjamin Marzinski <bmarzins@redhat.com>
|
|
---
|
|
libmultipath/discovery.c | 6 +++---
|
|
multipathd/main.c | 6 ++++--
|
|
2 files changed, 7 insertions(+), 5 deletions(-)
|
|
|
|
diff --git a/libmultipath/discovery.c b/libmultipath/discovery.c
|
|
index 729bcb9..b08cb2d 100644
|
|
--- a/libmultipath/discovery.c
|
|
+++ b/libmultipath/discovery.c
|
|
@@ -1755,9 +1755,9 @@ get_vpd_uid(struct path * pp)
|
|
}
|
|
|
|
static ssize_t scsi_uid_fallback(struct path *pp, int path_state,
|
|
- const char **origin)
|
|
+ const char **origin, ssize_t old_len)
|
|
{
|
|
- ssize_t len = 0;
|
|
+ ssize_t len = old_len;
|
|
int retrigger;
|
|
struct config *conf;
|
|
|
|
@@ -1828,7 +1828,7 @@ get_uid (struct path * pp, int path_state, struct udev_device *udev)
|
|
origin = "sysfs";
|
|
}
|
|
if (len <= 0 && pp->bus == SYSFS_BUS_SCSI)
|
|
- len = scsi_uid_fallback(pp, path_state, &origin);
|
|
+ len = scsi_uid_fallback(pp, path_state, &origin, len);
|
|
}
|
|
if ( len < 0 ) {
|
|
condlog(1, "%s: failed to get %s uid: %s",
|
|
diff --git a/multipathd/main.c b/multipathd/main.c
|
|
index 678ecf8..fd83a6a 100644
|
|
--- a/multipathd/main.c
|
|
+++ b/multipathd/main.c
|
|
@@ -1234,9 +1234,11 @@ uev_update_path (struct uevent *uev, struct vectors * vecs)
|
|
goto out;
|
|
|
|
strcpy(wwid, pp->wwid);
|
|
- get_uid(pp, pp->state, uev->udev);
|
|
+ rc = get_uid(pp, pp->state, uev->udev);
|
|
|
|
- if (strncmp(wwid, pp->wwid, WWID_SIZE) != 0) {
|
|
+ if (rc != 0)
|
|
+ strcpy(pp->wwid, wwid);
|
|
+ else if (strncmp(wwid, pp->wwid, WWID_SIZE) != 0) {
|
|
condlog(0, "%s: path wwid changed from '%s' to '%s'. %s",
|
|
uev->kernel, wwid, pp->wwid,
|
|
(disable_changed_wwids ? "disallowing" :
|
|
--
|
|
2.17.2
|
|
|