multipath-tools/0007-fix-lun-expansion-failure-when-there-is-offline-path.patch

58 lines
1.9 KiB
Diff
Raw Normal View History

2024-02-05 16:52:45 +08:00
From 9fab4f0956292141a72f7144f1d4157d353c0299 Mon Sep 17 00:00:00 2001
2020-11-04 21:19:44 +08:00
From: renmingshuai <renmingshuai@huawei.com>
Date: Thu, 28 Jan 2021 22:26:58 +0800
2024-02-05 16:52:45 +08:00
Subject: [PATCH] fix lun expansion failure when there is offline path
2020-11-04 21:19:44 +08:00
---
2021-11-23 21:49:34 +08:00
libmultipath/configure.c | 10 ++++++++++
2020-11-04 21:19:44 +08:00
libmultipath/structs_vec.c | 5 +++--
2021-11-23 21:49:34 +08:00
2 files changed, 13 insertions(+), 2 deletions(-)
2020-11-04 21:19:44 +08:00
2020-01-10 17:13:17 +08:00
diff --git a/libmultipath/configure.c b/libmultipath/configure.c
2024-02-05 16:52:45 +08:00
index 4956d32..ce5bd8b 100644
2020-01-10 17:13:17 +08:00
--- a/libmultipath/configure.c
+++ b/libmultipath/configure.c
2024-02-05 16:52:45 +08:00
@@ -1151,6 +1151,13 @@ int coalesce_paths (struct vectors *vecs, vector mpvec, char *refwwid,
orphan_path(pp1, "nvme:tcp path not allowed with request queue_mode multipath device");
2020-01-10 17:13:17 +08:00
continue;
}
+
+ /* if path is offline */
+ if (pp1->state == PATH_DOWN) {
+ orphan_path(pp1, "skip offline path");
+ continue;
+ }
+
2021-11-23 21:49:34 +08:00
/* if path is handled before */
if (pp1->handled) {
condlog(3, "%s: skip handled path.", pp1->dev_t);
2024-02-05 16:52:45 +08:00
@@ -1182,6 +1189,9 @@ int coalesce_paths (struct vectors *vecs, vector mpvec, char *refwwid,
2020-01-10 17:13:17 +08:00
if (strcmp(pp1->wwid, pp2->wwid))
continue;
+ if (!pp2->size || pp2->state == PATH_DOWN)
+ continue;
+
if (!mpp->size && pp2->size)
mpp->size = pp2->size;
diff --git a/libmultipath/structs_vec.c b/libmultipath/structs_vec.c
2024-02-05 16:52:45 +08:00
index 61001aa..317d172 100644
2020-01-10 17:13:17 +08:00
--- a/libmultipath/structs_vec.c
+++ b/libmultipath/structs_vec.c
2024-02-05 16:52:45 +08:00
@@ -742,8 +742,9 @@ int verify_paths(struct multipath *mpp)
2020-01-10 17:13:17 +08:00
/*
* see if path is in sysfs
*/
2020-11-04 21:19:44 +08:00
- if (!pp->udev || sysfs_attr_get_value(pp->udev, "dev",
2020-01-10 17:13:17 +08:00
- pp->dev_t, BLK_DEV_SIZE) < 0) {
2020-11-04 21:19:44 +08:00
+ if (!pp->udev || (sysfs_attr_get_value(pp->udev, "dev",
2020-01-10 17:13:17 +08:00
+ pp->dev_t, BLK_DEV_SIZE) < 0) ||
+ (pp->state == PATH_DOWN && pp->size != mpp->size)) {
if (pp->state != PATH_DOWN) {
condlog(1, "%s: removing valid path %s in state %d",
mpp->alias, pp->dev, pp->state);
2020-11-04 21:19:44 +08:00
--
2024-02-05 16:52:45 +08:00
2.33.0
2020-11-04 21:19:44 +08:00