9abdc502cf
Rebased on top of additional commits staged for upstream * Previous patches 0048-0060 are now patches 0053-0054 & 0059-0069 Add 0048-libmultipath-add-device-to-hwtable.c.patch Add 0049-master-libmultipath-fix-use-after-free-when-iscsi-lo.patch Add 0050-libmultipath-warn-if-freeing-path-that-holds-mpp-hwe.patch Add 0051-libmultipath-warn-about-NULL-value-of-mpp-hwe.patch Add 0052-libmultipath-fix-mpp-hwe-handling-in-sync_paths.patch Add 0055-libmultipath-remove-code-duplication-in-path-countin.patch Add 0056-libmultipath-count-pending-paths-as-active-on-loads.patch Add 0057-libmultipath-deal-with-flushing-no-maps.patch Add 0058-multipath-deal-with-delegation-failures-correctly.patch Add 0070-multipath-add-libmpathvalid-library.patch * adds the libmpathvalid.so library to determine if devices are valid multipath paths. Add 0071-libmultipath-add-uid-failback-for-dasd-devices.patch Add 0072-libmultipath-add-ignore_udev_uid-option.patch
88 lines
2.4 KiB
Diff
88 lines
2.4 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Benjamin Marzinski <bmarzins@redhat.com>
|
|
Date: Thu, 11 Apr 2019 13:25:42 -0500
|
|
Subject: [PATCH] RH: attempt to get ANA info via sysfs first
|
|
|
|
When the ANA prioritizer is run, first see if the "ana_state" sysfs file
|
|
exists, and if it does, try to read the state from there. If that fails,
|
|
fallback to using an ioctl.
|
|
|
|
Signed-off-by: Benjamin Marzinski <bmarzins@redhat.com>
|
|
---
|
|
libmultipath/prioritizers/ana.c | 31 +++++++++++++++++++++++++++++--
|
|
1 file changed, 29 insertions(+), 2 deletions(-)
|
|
|
|
diff --git a/libmultipath/prioritizers/ana.c b/libmultipath/prioritizers/ana.c
|
|
index b5c7873d..e139360c 100644
|
|
--- a/libmultipath/prioritizers/ana.c
|
|
+++ b/libmultipath/prioritizers/ana.c
|
|
@@ -24,6 +24,7 @@
|
|
#include "prio.h"
|
|
#include "util.h"
|
|
#include "structs.h"
|
|
+#include "sysfs.h"
|
|
|
|
enum {
|
|
ANA_ERR_GETCTRL_FAILED = 1,
|
|
@@ -36,6 +37,7 @@ enum {
|
|
ANA_ERR_GETNS_FAILED,
|
|
ANA_ERR_NO_MEMORY,
|
|
ANA_ERR_NO_INFORMATION,
|
|
+ ANA_ERR_INVALID_STATE,
|
|
};
|
|
|
|
static const char *ana_errmsg[] = {
|
|
@@ -49,6 +51,7 @@ static const char *ana_errmsg[] = {
|
|
[ANA_ERR_GETNS_FAILED] = "couldn't get namespace info",
|
|
[ANA_ERR_NO_MEMORY] = "out of memory",
|
|
[ANA_ERR_NO_INFORMATION] = "invalid fd",
|
|
+ [ANA_ERR_INVALID_STATE] = "invalid state",
|
|
};
|
|
|
|
static const char *anas_string[] = {
|
|
@@ -107,6 +110,27 @@ static int get_ana_state(__u32 nsid, __u32 anagrpid, void *ana_log,
|
|
return -ANA_ERR_GETANAS_NOTFOUND;
|
|
}
|
|
|
|
+static int get_ana_info_sysfs(struct path *pp)
|
|
+{
|
|
+ char state[32];
|
|
+
|
|
+ if (!pp->udev || sysfs_attr_get_value(pp->udev, "ana_state", state,
|
|
+ sizeof(state)) <= 0)
|
|
+ return -ANA_ERR_NO_INFORMATION;
|
|
+
|
|
+ if (strcmp(state, "optimized") == 0)
|
|
+ return NVME_ANA_OPTIMIZED;
|
|
+ if (strcmp(state, "non-optimized") == 0)
|
|
+ return NVME_ANA_NONOPTIMIZED;
|
|
+ if (strcmp(state, "inaccessible") == 0)
|
|
+ return NVME_ANA_INACCESSIBLE;
|
|
+ if (strcmp(state, "persistent-loss") == 0)
|
|
+ return NVME_ANA_PERSISTENT_LOSS;
|
|
+ if (strcmp(state, "change") == 0)
|
|
+ return NVME_ANA_CHANGE;
|
|
+ return -ANA_ERR_INVALID_STATE;
|
|
+}
|
|
+
|
|
static int get_ana_info(struct path * pp)
|
|
{
|
|
int rc;
|
|
@@ -210,8 +234,11 @@ int getprio(struct path *pp, __attribute__((unused)) char *args,
|
|
|
|
if (pp->fd < 0)
|
|
rc = -ANA_ERR_NO_INFORMATION;
|
|
- else
|
|
- rc = get_ana_info(pp);
|
|
+ else {
|
|
+ rc = get_ana_info_sysfs(pp);
|
|
+ if (rc < 0)
|
|
+ rc = get_ana_info(pp);
|
|
+ }
|
|
|
|
switch (rc) {
|
|
case NVME_ANA_OPTIMIZED:
|
|
--
|
|
2.17.2
|
|
|