942c9b6ed8
Update Source to upstream version 0.8.2 * Previoud patches 0001-0017 & 0027 are included in this commit Rename files * Previous patches 0018-0026 & 0028 are not patches 0021-0030 Add 0001-libmultipath-make-vector_foreach_slot_backwards-work.patch Add 0002-libmultipath-add-marginal-paths-and-groups-infrastru.patch Add 0003-tests-add-path-grouping-policy-unit-tests.patch Add 0004-libmultipath-add-wrapper-function-around-pgpolicyfn.patch Add 0005-tests-update-pgpolicy-tests-to-work-with-group_paths.patch Add 0006-libmultipath-fix-double-free-in-pgpolicyfn-error-pat.patch Add 0007-libmultipath-consolidate-group_by_-functions.patch Add 0008-libmultipath-make-pgpolicyfn-take-a-paths-vector.patch Add 0009-libmultipath-make-group_paths-handle-marginal-paths.patch Add 0010-tests-add-tests-for-grouping-marginal-paths.patch Add 0011-libmultipath-add-marginal_pathgroups-config-option.patch Add 0012-libmutipath-deprecate-delay_-_checks.patch Add 0013-multipathd-use-marginal_pathgroups.patch Add 0014-multipath-update-man-pages.patch * The above 13 patches add the marinal_pathgroups option Add 0015-multipath.conf-add-enable_foreign-parameter.patch Add 0016-multipath.conf.5-document-foreign-library-support.patch * The above 2 patches add the enable_foreign option Add 0017-mpathpersist-remove-broken-unused-code.patch Add 0018-libmultipath-EMC-PowerMax-NVMe-device-config.patch Add 0019-mpathpersist-fix-leaks.patch Add 0020-libmultipath-fix-mpcontext-initialization.patch * The above 20 patches have been submitted upstream
107 lines
4.4 KiB
Diff
107 lines
4.4 KiB
Diff
From 46cfd1a474d1c3e2724782c493d0ea72c8438807 Mon Sep 17 00:00:00 2001
|
|
From: Benjamin Marzinski <bmarzins@redhat.com>
|
|
Date: Wed, 2 Jul 2014 12:49:53 -0500
|
|
Subject: [PATCH] RH: Remove the property blacklist exception builtin
|
|
|
|
Multipath set the default property blacklist exceptions to
|
|
(ID_SCSI_VPD|ID_WWN). This has the effect of blacklisting some internal
|
|
devices. These devices may never have multiple paths, but it is nice
|
|
to be able to set multipath up on them all the same. This patch simply
|
|
removes the default, and makes it so that if no property
|
|
blacklist_exception is given, then devices aren't failed for not matching
|
|
it.
|
|
|
|
Signed-off-by: Benjamin Marzinski <bmarzins@redhat.com>
|
|
---
|
|
libmultipath/blacklist.c | 9 ++-------
|
|
multipath/multipath.conf.5 | 12 ++++++------
|
|
tests/blacklist.c | 6 ++----
|
|
3 files changed, 10 insertions(+), 17 deletions(-)
|
|
|
|
diff --git a/libmultipath/blacklist.c b/libmultipath/blacklist.c
|
|
index 00e8dbdb..d9691b17 100644
|
|
--- a/libmultipath/blacklist.c
|
|
+++ b/libmultipath/blacklist.c
|
|
@@ -204,12 +204,6 @@ setup_default_blist (struct config * conf)
|
|
if (store_ble(conf->blist_devnode, str, ORIGIN_DEFAULT))
|
|
return 1;
|
|
|
|
- str = STRDUP("(SCSI_IDENT_|ID_WWN)");
|
|
- if (!str)
|
|
- return 1;
|
|
- if (store_ble(conf->elist_property, str, ORIGIN_DEFAULT))
|
|
- return 1;
|
|
-
|
|
vector_foreach_slot (conf->hwtable, hwe, i) {
|
|
if (hwe->bl_product) {
|
|
if (find_blacklist_device(conf->blist_device,
|
|
@@ -411,7 +405,8 @@ filter_property(struct config *conf, struct udev_device *udev, int lvl,
|
|
*uid_attribute != '\0';
|
|
bool uid_attr_seen = false;
|
|
|
|
- r = MATCH_PROPERTY_BLIST_MISSING;
|
|
+ if (VECTOR_SIZE(conf->elist_property))
|
|
+ r = MATCH_PROPERTY_BLIST_MISSING;
|
|
udev_list_entry_foreach(list_entry,
|
|
udev_device_get_properties_list_entry(udev)) {
|
|
|
|
diff --git a/multipath/multipath.conf.5 b/multipath/multipath.conf.5
|
|
index 101e1a88..b4837b15 100644
|
|
--- a/multipath/multipath.conf.5
|
|
+++ b/multipath/multipath.conf.5
|
|
@@ -1287,9 +1287,14 @@ keywords. Both are regular expressions. For a full description of these keywords
|
|
Regular expression for an udev property. All
|
|
devices that have matching udev properties will be excluded/included.
|
|
The handling of the \fIproperty\fR keyword is special,
|
|
-because devices \fBmust\fR have at least one whitelisted udev property;
|
|
+because if a property blacklist_exception is set, devices \fBmust\fR have at
|
|
+least one whitelisted udev property;
|
|
otherwise they're treated as blacklisted, and the message
|
|
"\fIblacklisted, udev property missing\fR" is displayed in the logs.
|
|
+For example, setting the property blacklist_exception to
|
|
+\fB(SCSI_IDENT_|ID_WWN)\fR, will cause well-behaved SCSI devices and devices
|
|
+that provide a WWN (World Wide Number) to be included, and all others to be
|
|
+excluded. This works to exclude most non-multipathable devices.
|
|
.
|
|
.RS
|
|
.PP
|
|
@@ -1300,11 +1305,6 @@ Blacklisting by missing properties is only applied to devices which do have the
|
|
property specified by \fIuid_attribute\fR (e.g. \fIID_SERIAL\fR)
|
|
set. Previously, it was applied to every device, possibly causing devices to be
|
|
blacklisted because of temporary I/O error conditions.
|
|
-.PP
|
|
-The default \fIblacklist exception\fR is: \fB(SCSI_IDENT_|ID_WWN)\fR, causing
|
|
-well-behaved SCSI devices and devices that provide a WWN (World Wide Number)
|
|
-to be included, and all others to be excluded.
|
|
-.RE
|
|
.TP
|
|
.B protocol
|
|
Regular expression for the protocol of a device to be excluded/included.
|
|
diff --git a/tests/blacklist.c b/tests/blacklist.c
|
|
index 362c44d9..ea284939 100644
|
|
--- a/tests/blacklist.c
|
|
+++ b/tests/blacklist.c
|
|
@@ -291,7 +291,7 @@ static void test_property_missing(void **state)
|
|
conf.blist_property = blist_property_wwn;
|
|
expect_condlog(3, "sdb: blacklisted, udev property missing\n");
|
|
assert_int_equal(filter_property(&conf, &udev, 3, "ID_SERIAL"),
|
|
- MATCH_PROPERTY_BLIST_MISSING);
|
|
+ MATCH_NOTHING);
|
|
assert_int_equal(filter_property(&conf, &udev, 3, "ID_BLAH"),
|
|
MATCH_NOTHING);
|
|
assert_int_equal(filter_property(&conf, &udev, 3, ""),
|
|
@@ -383,9 +383,7 @@ static void test_filter_path_missing1(void **state)
|
|
conf.blist_device = blist_device_foo_bar;
|
|
conf.blist_protocol = blist_protocol_fcp;
|
|
conf.blist_wwid = blist_wwid_xyzzy;
|
|
- expect_condlog(3, "sdb: blacklisted, udev property missing\n");
|
|
- assert_int_equal(filter_path(&conf, &miss1_pp),
|
|
- MATCH_PROPERTY_BLIST_MISSING);
|
|
+ assert_int_equal(filter_path(&conf, &miss1_pp), MATCH_NOTHING);
|
|
}
|
|
|
|
/* This one matches the property whitelist, to test the other missing
|
|
--
|
|
2.17.2
|
|
|