Blame SOURCES/0244-RHBZ-1562247-remove-rbd.patch

4728c8
---
4728c8
 libmultipath/checkers.c              |   23 -
4728c8
 libmultipath/checkers.h              |    5 
4728c8
 libmultipath/checkers/Makefile       |    7 
4728c8
 libmultipath/checkers/cciss_tur.c    |    5 
4728c8
 libmultipath/checkers/directio.c     |    5 
4728c8
 libmultipath/checkers/emc_clariion.c |    5 
4728c8
 libmultipath/checkers/hp_sw.c        |    5 
4728c8
 libmultipath/checkers/rbd.c          |  652 -----------------------------------
4728c8
 libmultipath/checkers/rdac.c         |    5 
4728c8
 libmultipath/checkers/readsector0.c  |    5 
4728c8
 libmultipath/checkers/tur.c          |    5 
4728c8
 libmultipath/discovery.c             |  112 ------
4728c8
 libmultipath/hwtable.c               |   14 
4728c8
 libmultipath/structs.h               |    1 
4728c8
 multipath.conf.annotated             |    4 
4728c8
 multipath/multipath.conf.5           |    3 
4728c8
 multipathd/main.c                    |   13 
4728c8
 17 files changed, 18 insertions(+), 851 deletions(-)
4728c8
4728c8
Index: multipath-tools-130222/libmultipath/checkers/rbd.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/rbd.c
4728c8
+++ /dev/null
4728c8
@@ -1,652 +0,0 @@
4728c8
-/*
4728c8
- * Copyright (c) 2016 Red Hat
4728c8
- * Copyright (c) 2004 Christophe Varoqui
4728c8
- *
4728c8
- * Code based off of tur.c and ceph's krbd.cc
4728c8
- */
4728c8
-#define _GNU_SOURCE
4728c8
-#include <stdio.h>
4728c8
-#include <stdlib.h>
4728c8
-#include <string.h>
4728c8
-#include <unistd.h>
4728c8
-#include <fcntl.h>
4728c8
-#include <errno.h>
4728c8
-#include <pthread.h>
4728c8
-#include <libudev.h>
4728c8
-#include <ifaddrs.h>
4728c8
-#include <sys/types.h>
4728c8
-#include <sys/stat.h>
4728c8
-#include <sys/ioctl.h>
4728c8
-#include <sys/time.h>
4728c8
-#include <sys/wait.h>
4728c8
-
4728c8
-#include "rados/librados.h"
4728c8
-
4728c8
-#include "structs.h"
4728c8
-#include "checkers.h"
4728c8
-
4728c8
-#include "../libmultipath/debug.h"
4728c8
-#include "../libmultipath/uevent.h"
4728c8
-#include "../libmultipath/util.h"
4728c8
-
4728c8
-struct rbd_checker_context;
4728c8
-typedef int (thread_fn)(struct rbd_checker_context *ct, char *msg);
4728c8
-
4728c8
-#define RBD_MSG(msg, fmt, args...) snprintf(msg, CHECKER_MSG_LEN, fmt, ##args);
4728c8
-
4728c8
-#define RBD_FEATURE_EXCLUSIVE_LOCK	(1 << 2)
4728c8
-
4728c8
-struct rbd_checker_context {
4728c8
-	int rbd_bus_id;
4728c8
-	char *client_addr;
4728c8
-	char *config_info;
4728c8
-	char *snap;
4728c8
-	char *pool;
4728c8
-	char *image;
4728c8
-	char *username;
4728c8
-	int remapped;
4728c8
-	int blacklisted;
4728c8
-	int lock_on_read:1;
4728c8
-
4728c8
-	rados_t cluster;
4728c8
-
4728c8
-	int state;
4728c8
-	int running;
4728c8
-	time_t time;
4728c8
-	thread_fn *fn;
4728c8
-	pthread_t thread;
4728c8
-	pthread_mutex_t lock;
4728c8
-	pthread_cond_t active;
4728c8
-	pthread_spinlock_t hldr_lock;
4728c8
-	int holders;
4728c8
-	char message[CHECKER_MSG_LEN];
4728c8
-};
4728c8
-
4728c8
-int libcheck_init(struct checker * c)
4728c8
-{
4728c8
-	struct rbd_checker_context *ct;
4728c8
-	struct udev_device *block_dev;
4728c8
-	struct udev_device *bus_dev;
4728c8
-	struct udev *udev;
4728c8
-	struct stat sb;
4728c8
-	const char *block_name, *addr, *config_info, *features_str;
4728c8
-	const char *image, *pool, *snap, *username;
4728c8
-	uint64_t features = 0;
4728c8
-	char sysfs_path[PATH_SIZE];
4728c8
-	int ret;
4728c8
-
4728c8
-	ct = malloc(sizeof(struct rbd_checker_context));
4728c8
-	if (!ct)
4728c8
-		return 1;
4728c8
-	memset(ct, 0, sizeof(struct rbd_checker_context));
4728c8
-	ct->holders = 1;
4728c8
-	pthread_cond_init(&ct->active, NULL);
4728c8
-	pthread_mutex_init(&ct->lock, NULL);
4728c8
-	pthread_spin_init(&ct->hldr_lock, PTHREAD_PROCESS_PRIVATE);
4728c8
-	c->context = ct;
4728c8
-
4728c8
-	/*
4728c8
-	 * The rbd block layer sysfs device is not linked to the rbd bus
4728c8
-	 * device that we interact with, so figure that out now.
4728c8
-	 */
4728c8
-	if (fstat(c->fd, &sb) != 0)
4728c8
-		goto free_ct;
4728c8
-
4728c8
-	udev = udev_new();
4728c8
-	if (!udev)
4728c8
-		goto free_ct;
4728c8
-
4728c8
-	block_dev = udev_device_new_from_devnum(udev, 'b', sb.st_rdev);
4728c8
-	if (!block_dev)
4728c8
-		goto free_udev;
4728c8
-
4728c8
-	block_name  = udev_device_get_sysname(block_dev);
4728c8
-	ret = sscanf(block_name, "rbd%d", &ct->rbd_bus_id);
4728c8
-
4728c8
-	udev_device_unref(block_dev);
4728c8
-	if (ret != 1)
4728c8
-		goto free_udev;
4728c8
-
4728c8
-	snprintf(sysfs_path, sizeof(sysfs_path), "/sys/bus/rbd/devices/%d",
4728c8
-		 ct->rbd_bus_id);
4728c8
-	bus_dev = udev_device_new_from_syspath(udev, sysfs_path);
4728c8
-	if (!bus_dev)
4728c8
-		goto free_udev;
4728c8
-
4728c8
-	addr = udev_device_get_sysattr_value(bus_dev, "client_addr");
4728c8
-	if (!addr) {
4728c8
-		condlog(0, "rbd%d: Could not find client_addr in rbd sysfs. "
4728c8
-			"Try updating kernel", ct->rbd_bus_id);
4728c8
-		goto free_dev;
4728c8
-	}
4728c8
-
4728c8
-	ct->client_addr = strdup(addr);
4728c8
-	if (!ct->client_addr)
4728c8
-		goto free_dev;
4728c8
-
4728c8
-	features_str = udev_device_get_sysattr_value(bus_dev, "features");
4728c8
-	if (!features_str)
4728c8
-		goto free_addr;
4728c8
-	features = strtoll(features_str, NULL, 16);
4728c8
-	if (!(features & RBD_FEATURE_EXCLUSIVE_LOCK)) {
4728c8
-		condlog(3, "rbd%d: Exclusive lock not set.", ct->rbd_bus_id);
4728c8
-		goto free_addr;
4728c8
-	}
4728c8
-
4728c8
-	config_info = udev_device_get_sysattr_value(bus_dev, "config_info");
4728c8
-	if (!config_info)
4728c8
-		goto free_addr;
4728c8
-
4728c8
-	if (!strstr(config_info, "noshare")) {
4728c8
-		condlog(3, "rbd%d: Only nonshared clients supported.",
4728c8
-			ct->rbd_bus_id);
4728c8
-		goto free_addr;
4728c8
-	}
4728c8
-
4728c8
-	if (strstr(config_info, "lock_on_read"))
4728c8
-		ct->lock_on_read = 1;
4728c8
-
4728c8
-	ct->config_info = strdup(config_info);
4728c8
-	if (!ct->config_info)
4728c8
-		goto free_addr;
4728c8
-
4728c8
-	username = strstr(config_info, "name=");
4728c8
-	if (username) {
4728c8
-		char *end;
4728c8
-		int len;
4728c8
-
4728c8
-		username += 5;
4728c8
-		end = strchr(username, ',');
4728c8
-		if (!end)
4728c8
-			goto free_info;
4728c8
-		len = end - username;
4728c8
-
4728c8
-		ct->username = malloc(len + 1);
4728c8
-		if (!ct->username)
4728c8
-			goto free_info;
4728c8
-		strncpy(ct->username, username, len);
4728c8
-		ct->username[len] = '\0';
4728c8
-	}
4728c8
-
4728c8
-	image = udev_device_get_sysattr_value(bus_dev, "name");
4728c8
-	if (!image)
4728c8
-		goto free_username;
4728c8
-
4728c8
-	ct->image = strdup(image);
4728c8
-	if (!ct->image)
4728c8
-		goto free_info;
4728c8
-
4728c8
-	pool = udev_device_get_sysattr_value(bus_dev, "pool");
4728c8
-	if (!pool)
4728c8
-		goto free_image;
4728c8
-
4728c8
-	ct->pool = strdup(pool);
4728c8
-	if (!ct->pool)
4728c8
-		goto free_image;
4728c8
-
4728c8
-	snap = udev_device_get_sysattr_value(bus_dev, "current_snap");
4728c8
-	if (!snap)
4728c8
-		goto free_pool;
4728c8
-
4728c8
-	if (strcmp("-", snap)) {
4728c8
-		ct->snap = strdup(snap);
4728c8
-		if (!ct->snap)
4728c8
-			goto free_pool;
4728c8
-	}
4728c8
-
4728c8
-	if (rados_create(&ct->cluster, NULL) < 0) {
4728c8
-		condlog(0, "rbd%d: Could not create rados cluster",
4728c8
-			ct->rbd_bus_id);
4728c8
-		goto free_snap;
4728c8
-	}
4728c8
-
4728c8
-	if (rados_conf_read_file(ct->cluster, NULL) < 0) {
4728c8
-		condlog(0, "rbd%d: Could not read rados conf", ct->rbd_bus_id);
4728c8
-		goto shutdown_rados;
4728c8
-	}
4728c8
-
4728c8
-	ret = rados_connect(ct->cluster);
4728c8
-	if (ret < 0) {
4728c8
-		condlog(0, "rbd%d: Could not connect to rados cluster",
4728c8
-			ct->rbd_bus_id);
4728c8
-		goto shutdown_rados;
4728c8
-	}
4728c8
-
4728c8
-	udev_device_unref(bus_dev);
4728c8
-	udev_unref(udev);
4728c8
-
4728c8
-	condlog(3, "rbd%d checker init %s %s/%s@%s %s", ct->rbd_bus_id,
4728c8
-		ct->client_addr, ct->pool, ct->image, ct->snap ? ct->snap : "-",
4728c8
-		ct->username ? ct->username : "none");
4728c8
-	return 0;
4728c8
-
4728c8
-shutdown_rados:
4728c8
-	rados_shutdown(ct->cluster);
4728c8
-free_snap:
4728c8
-	if (ct->snap)
4728c8
-		free(ct->snap);
4728c8
-free_pool:
4728c8
-	free(ct->pool);
4728c8
-free_image:
4728c8
-	free(ct->image);
4728c8
-free_username:
4728c8
-	if (ct->username)
4728c8
-		free(ct->username);
4728c8
-free_info:
4728c8
-	free(ct->config_info);
4728c8
-free_addr:
4728c8
-	free(ct->client_addr);
4728c8
-free_dev:
4728c8
-	udev_device_unref(bus_dev);
4728c8
-free_udev:
4728c8
-	udev_unref(udev);
4728c8
-free_ct:
4728c8
-	free(ct);
4728c8
-	return 1;
4728c8
-}
4728c8
-
4728c8
-void cleanup_context(struct rbd_checker_context *ct)
4728c8
-{
4728c8
-	pthread_mutex_destroy(&ct->lock);
4728c8
-	pthread_cond_destroy(&ct->active);
4728c8
-	pthread_spin_destroy(&ct->hldr_lock);
4728c8
-
4728c8
-	rados_shutdown(ct->cluster);
4728c8
-
4728c8
-	if (ct->username)
4728c8
-		free(ct->username);
4728c8
-	if (ct->snap)
4728c8
-		free(ct->snap);
4728c8
-	free(ct->pool);
4728c8
-	free(ct->image);
4728c8
-	free(ct->config_info);
4728c8
-	free(ct->client_addr);
4728c8
-	free(ct);
4728c8
-}
4728c8
-
4728c8
-void libcheck_free(struct checker * c)
4728c8
-{
4728c8
-	if (c->context) {
4728c8
-		struct rbd_checker_context *ct = c->context;
4728c8
-		int holders;
4728c8
-		pthread_t thread;
4728c8
-
4728c8
-		pthread_spin_lock(&ct->hldr_lock);
4728c8
-		ct->holders--;
4728c8
-		holders = ct->holders;
4728c8
-		thread = ct->thread;
4728c8
-		pthread_spin_unlock(&ct->hldr_lock);
4728c8
-		if (holders)
4728c8
-			pthread_cancel(thread);
4728c8
-		else
4728c8
-			cleanup_context(ct);
4728c8
-		c->context = NULL;
4728c8
-	}
4728c8
-}
4728c8
-
4728c8
-static int rbd_is_blacklisted(struct rbd_checker_context *ct, char *msg)
4728c8
-{
4728c8
-	char *addr_tok, *start, *save;
4728c8
-	char *cmd[2];
4728c8
-	char *blklist, *stat;
4728c8
-	size_t blklist_len, stat_len;
4728c8
-	int ret;
4728c8
-	char *end;
4728c8
-
4728c8
-	cmd[0] = "{\"prefix\": \"osd blacklist ls\"}";
4728c8
-	cmd[1] = NULL;
4728c8
-
4728c8
-	ret = rados_mon_command(ct->cluster, (const char **)cmd, 1, "", 0,
4728c8
-				&blklist, &blklist_len, &stat, &stat_len);
4728c8
-	if (ret < 0) {
4728c8
-		RBD_MSG(msg, "checker failed: mon command failed %d", ret);
4728c8
-		return ret;
4728c8
-	}
4728c8
-
4728c8
-	if (!blklist || !blklist_len)
4728c8
-		goto free_bufs;
4728c8
-
4728c8
-	/*
4728c8
-	 * parse list of addrs with the format
4728c8
-	 * ipv4:port/nonce date time\n
4728c8
-	 * or
4728c8
-	 * [ipv6]:port/nonce date time\n
4728c8
-	 */
4728c8
-	ret = 0;
4728c8
-	for (start = blklist; ; start = NULL) {
4728c8
-		addr_tok = strtok_r(start, "\n", &save);
4728c8
-		if (!addr_tok || !strlen(addr_tok))
4728c8
-			break;
4728c8
-
4728c8
-		end = strchr(addr_tok, ' ');
4728c8
-		if (!end) {
4728c8
-			RBD_MSG(msg, "checker failed: invalid blacklist %s",
4728c8
-				 addr_tok);
4728c8
-			break;
4728c8
-		}
4728c8
-		*end = '\0';
4728c8
-
4728c8
-		if (!strcmp(addr_tok, ct->client_addr)) {
4728c8
-			ct->blacklisted = 1;
4728c8
-			RBD_MSG(msg, "%s is blacklisted", ct->client_addr);
4728c8
-			ret = 1;
4728c8
-			break;
4728c8
-		}
4728c8
-	}
4728c8
-
4728c8
-free_bufs:
4728c8
-	rados_buffer_free(blklist);
4728c8
-	rados_buffer_free(stat);
4728c8
-	return ret;
4728c8
-}
4728c8
-
4728c8
-int rbd_check(struct rbd_checker_context *ct, char *msg)
4728c8
-{
4728c8
-	if (ct->blacklisted || rbd_is_blacklisted(ct, msg) == 1)
4728c8
-		return PATH_DOWN;
4728c8
-
4728c8
-	RBD_MSG(msg, "checker reports path is up");
4728c8
-	/*
4728c8
-	 * Path may have issues, but the ceph cluster is at least
4728c8
-	 * accepting IO, so we can attempt to do IO.
4728c8
-	 *
4728c8
-	 * TODO: in future versions, we can run other tests to
4728c8
-	 * verify OSDs and networks.
4728c8
-	 */
4728c8
-	return PATH_UP;
4728c8
-}
4728c8
-
4728c8
-static int sysfs_write_rbd_bus(const char *which, const char *buf,
4728c8
-			       size_t buf_len)
4728c8
-{
4728c8
-	char sysfs_path[PATH_SIZE];
4728c8
-	int fd;
4728c8
-	int r;
4728c8
-
4728c8
-	/* we require newer kernels so single_major should alwayws be there */
4728c8
-	snprintf(sysfs_path, sizeof(sysfs_path),
4728c8
-		 "/sys/bus/rbd/%s_single_major", which);
4728c8
-	fd = open(sysfs_path, O_WRONLY);
4728c8
-	if (fd < 0)
4728c8
-		return -errno;
4728c8
-
4728c8
-	r = safe_write(fd, buf, buf_len);
4728c8
-	close(fd);
4728c8
-	return r;
4728c8
-}
4728c8
-
4728c8
-static int rbd_remap(struct rbd_checker_context *ct)
4728c8
-{
4728c8
-	char *argv[11];
4728c8
-	pid_t pid;
4728c8
-	int ret = 0, i = 0;
4728c8
-	int status;
4728c8
-
4728c8
-	pid = fork();
4728c8
-	switch (pid) {
4728c8
-	case 0:
4728c8
-		argv[i++] = "rbd";
4728c8
-		argv[i++] = "map";
4728c8
-		if (ct->lock_on_read)
4728c8
-			argv[i++] = "-o noshare,lock_on_read";
4728c8
-		else
4728c8
-			argv[i++] = "-o noshare";
4728c8
-		if (ct->username) {
4728c8
-			argv[i++] = "--id";
4728c8
-			argv[i++] = ct->username;
4728c8
-		}
4728c8
-		argv[i++] = "--pool";
4728c8
-		argv[i++] = ct->pool;
4728c8
-		if (ct->snap) {
4728c8
-			argv[i++] = "--snap";
4728c8
-			argv[i++] = ct->snap;
4728c8
-		}
4728c8
-		argv[i++] = ct->image;
4728c8
-		argv[i] = NULL;
4728c8
-
4728c8
-		ret = execvp(argv[0], argv);
4728c8
-		condlog(0, "rbd%d: Error executing rbd: %s", ct->rbd_bus_id,
4728c8
-			strerror(errno));
4728c8
-		exit(-1);
4728c8
-	case -1:
4728c8
-		condlog(0, "rbd%d: fork failed: %s", ct->rbd_bus_id,
4728c8
-			strerror(errno));
4728c8
-		return -1;
4728c8
-	default:
4728c8
-		ret = -1;
4728c8
-		wait(&status);
4728c8
-		if (WIFEXITED(status)) {
4728c8
-			status = WEXITSTATUS(status);
4728c8
-			if (status == 0)
4728c8
-				ret = 0;
4728c8
-			else
4728c8
-				condlog(0, "rbd%d: failed with %d",
4728c8
-					ct->rbd_bus_id, status);
4728c8
-		}
4728c8
-	}
4728c8
-
4728c8
-	return ret;
4728c8
-}
4728c8
-
4728c8
-static int sysfs_write_rbd_remove(const char *buf, int buf_len)
4728c8
-{
4728c8
-	return sysfs_write_rbd_bus("remove", buf, buf_len);
4728c8
-}
4728c8
-
4728c8
-static int rbd_rm_blacklist(struct rbd_checker_context *ct)
4728c8
-{
4728c8
-	char *cmd[2];
4728c8
-	char *stat, *cmd_str;
4728c8
-	size_t stat_len;
4728c8
-	int ret;
4728c8
-
4728c8
-	ret = asprintf(&cmd_str, "{\"prefix\": \"osd blacklist\", \"blacklistop\": \"rm\", \"addr\": \"%s\"}",
4728c8
-		       ct->client_addr);
4728c8
-	if (ret == -1)
4728c8
-		return -ENOMEM;
4728c8
-
4728c8
-	cmd[0] = cmd_str;
4728c8
-	cmd[1] = NULL;
4728c8
-
4728c8
-	ret = rados_mon_command(ct->cluster, (const char **)cmd, 1, "", 0,
4728c8
-				NULL, 0, &stat, &stat_len);
4728c8
-	if (ret < 0) {
4728c8
-		condlog(1, "rbd%d: repair failed to remove blacklist for %s %d",
4728c8
-			ct->rbd_bus_id, ct->client_addr, ret);
4728c8
-		goto free_cmd;
4728c8
-	}
4728c8
-
4728c8
-	condlog(1, "rbd%d: repair rm blacklist for %s",
4728c8
-	       ct->rbd_bus_id, ct->client_addr);
4728c8
-	free(stat);
4728c8
-free_cmd:
4728c8
-	free(cmd_str);
4728c8
-	return ret;
4728c8
-}
4728c8
-
4728c8
-static int rbd_repair(struct rbd_checker_context *ct, char *msg)
4728c8
-{
4728c8
-	char del[17];
4728c8
-	int ret;
4728c8
-
4728c8
-	if (!ct->blacklisted)
4728c8
-		return PATH_UP;
4728c8
-
4728c8
-	if (!ct->remapped) {
4728c8
-		ret = rbd_remap(ct);
4728c8
-		if (ret) {
4728c8
-			RBD_MSG(msg, "repair failed to remap. Err %d", ret);
4728c8
-			return PATH_DOWN;
4728c8
-		}
4728c8
-	}
4728c8
-	ct->remapped = 1;
4728c8
-
4728c8
-	snprintf(del, sizeof(del), "%d force", ct->rbd_bus_id);
4728c8
-	ret = sysfs_write_rbd_remove(del, strlen(del) + 1);
4728c8
-	if (ret) {
4728c8
-		RBD_MSG(msg, "repair failed to clean up. Err %d", ret);
4728c8
-		return PATH_DOWN;
4728c8
-	}
4728c8
-
4728c8
-	ret = rbd_rm_blacklist(ct);
4728c8
-	if (ret) {
4728c8
-		RBD_MSG(msg, "repair could not remove blacklist entry. Err %d",
4728c8
-			ret);
4728c8
-		return PATH_DOWN;
4728c8
-	}
4728c8
-
4728c8
-	ct->remapped = 0;
4728c8
-	ct->blacklisted = 0;
4728c8
-
4728c8
-	RBD_MSG(msg, "has been repaired");
4728c8
-	return PATH_UP;
4728c8
-}
4728c8
-
4728c8
-#define rbd_thread_cleanup_push(ct) pthread_cleanup_push(cleanup_func, ct)
4728c8
-#define rbd_thread_cleanup_pop(ct) pthread_cleanup_pop(1)
4728c8
-
4728c8
-void cleanup_func(void *data)
4728c8
-{
4728c8
-	int holders;
4728c8
-	struct rbd_checker_context *ct = data;
4728c8
-	pthread_spin_lock(&ct->hldr_lock);
4728c8
-	ct->holders--;
4728c8
-	holders = ct->holders;
4728c8
-	ct->thread = 0;
4728c8
-	pthread_spin_unlock(&ct->hldr_lock);
4728c8
-	if (!holders)
4728c8
-		cleanup_context(ct);
4728c8
-}
4728c8
-
4728c8
-void *rbd_thread(void *ctx)
4728c8
-{
4728c8
-	struct rbd_checker_context *ct = ctx;
4728c8
-	int state;
4728c8
-
4728c8
-	condlog(3, "rbd%d: thread starting up", ct->rbd_bus_id);
4728c8
-
4728c8
-	ct->message[0] = '\0';
4728c8
-	/* This thread can be canceled, so setup clean up */
4728c8
-	rbd_thread_cleanup_push(ct)
4728c8
-
4728c8
-	/* checker start up */
4728c8
-	pthread_mutex_lock(&ct->lock);
4728c8
-	ct->state = PATH_PENDING;
4728c8
-	pthread_mutex_unlock(&ct->lock);
4728c8
-
4728c8
-	state = ct->fn(ct, ct->message);
4728c8
-
4728c8
-	/* checker done */
4728c8
-	pthread_mutex_lock(&ct->lock);
4728c8
-	ct->state = state;
4728c8
-	pthread_mutex_unlock(&ct->lock);
4728c8
-	pthread_cond_signal(&ct->active);
4728c8
-
4728c8
-	condlog(3, "rbd%d: thead finished, state %s", ct->rbd_bus_id,
4728c8
-		checker_state_name(state));
4728c8
-	rbd_thread_cleanup_pop(ct);
4728c8
-	return ((void *)0);
4728c8
-}
4728c8
-
4728c8
-static void rbd_timeout(struct timespec *tsp)
4728c8
-{
4728c8
-	struct timeval now;
4728c8
-
4728c8
-	gettimeofday(&now, NULL);
4728c8
-	tsp->tv_sec = now.tv_sec;
4728c8
-	tsp->tv_nsec = now.tv_usec * 1000;
4728c8
-	tsp->tv_nsec += 1000000; /* 1 millisecond */
4728c8
-}
4728c8
-
4728c8
-static int rbd_exec_fn(struct checker *c, thread_fn *fn)
4728c8
-{
4728c8
-	struct rbd_checker_context *ct = c->context;
4728c8
-	struct timespec tsp;
4728c8
-	pthread_attr_t attr;
4728c8
-	int rbd_status, r;
4728c8
-
4728c8
-	if (c->sync)
4728c8
-		return fn(ct, c->message);
4728c8
-	/*
4728c8
-	 * Async mode
4728c8
-	 */
4728c8
-	r = pthread_mutex_lock(&ct->lock);
4728c8
-	if (r != 0) {
4728c8
-		condlog(2, "rbd%d: mutex lock failed with %d", ct->rbd_bus_id,
4728c8
-			r);
4728c8
-		MSG(c, "rbd%d: thread failed to initialize", ct->rbd_bus_id);
4728c8
-		return PATH_WILD;
4728c8
-	}
4728c8
-
4728c8
-	if (ct->running) {
4728c8
-		/* Check if checker is still running */
4728c8
-		if (ct->thread) {
4728c8
-			condlog(3, "rbd%d: thread not finished",
4728c8
-				ct->rbd_bus_id);
4728c8
-			rbd_status = PATH_PENDING;
4728c8
-		} else {
4728c8
-			/* checker done */
4728c8
-			ct->running = 0;
4728c8
-			rbd_status = ct->state;
4728c8
-			strncpy(c->message, ct->message, CHECKER_MSG_LEN);
4728c8
-			c->message[CHECKER_MSG_LEN - 1] = '\0';
4728c8
-		}
4728c8
-		pthread_mutex_unlock(&ct->lock);
4728c8
-	} else {
4728c8
-		/* Start new checker */
4728c8
-		ct->state = PATH_UNCHECKED;
4728c8
-		ct->fn = fn;
4728c8
-		pthread_spin_lock(&ct->hldr_lock);
4728c8
-		ct->holders++;
4728c8
-		pthread_spin_unlock(&ct->hldr_lock);
4728c8
-		setup_thread_attr(&attr, 32 * 1024, 1);
4728c8
-		r = pthread_create(&ct->thread, &attr, rbd_thread, ct);
4728c8
-		if (r) {
4728c8
-			pthread_mutex_unlock(&ct->lock);
4728c8
-			ct->thread = 0;
4728c8
-			ct->holders--;
4728c8
-			condlog(3, "rbd%d failed to start rbd thread, using sync mode",
4728c8
-				ct->rbd_bus_id);
4728c8
-			return fn(ct, c->message);
4728c8
-		}
4728c8
-		pthread_attr_destroy(&attr);
4728c8
-		rbd_timeout(&tsp;;
4728c8
-		r = pthread_cond_timedwait(&ct->active, &ct->lock, &tsp;;
4728c8
-		rbd_status = ct->state;
4728c8
-		strncpy(c->message, ct->message,CHECKER_MSG_LEN);
4728c8
-		c->message[CHECKER_MSG_LEN -1] = '\0';
4728c8
-		pthread_mutex_unlock(&ct->lock);
4728c8
-
4728c8
-		if (ct->thread &&
4728c8
-		    (rbd_status == PATH_PENDING || rbd_status == PATH_UNCHECKED)) {
4728c8
-			condlog(3, "rbd%d: thread still running",
4728c8
-				ct->rbd_bus_id);
4728c8
-			ct->running = 1;
4728c8
-			rbd_status = PATH_PENDING;
4728c8
-		}
4728c8
-	}
4728c8
-
4728c8
-	return rbd_status;
4728c8
-}
4728c8
-
4728c8
-void libcheck_repair(struct checker * c)
4728c8
-{
4728c8
-	struct rbd_checker_context *ct = c->context;
4728c8
-
4728c8
-	if (!ct || !ct->blacklisted)
4728c8
-		return;
4728c8
-	rbd_exec_fn(c, rbd_repair);
4728c8
-}
4728c8
-
4728c8
-int libcheck_check(struct checker * c)
4728c8
-{
4728c8
-	struct rbd_checker_context *ct = c->context;
4728c8
-
4728c8
-	if (!ct)
4728c8
-		return PATH_UNCHECKED;
4728c8
-
4728c8
-	if (ct->blacklisted)
4728c8
-		return PATH_DOWN;
4728c8
-
4728c8
-	return rbd_exec_fn(c, rbd_check);
4728c8
-}
4728c8
Index: multipath-tools-130222/multipathd/main.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/multipathd/main.c
4728c8
+++ multipath-tools-130222/multipathd/main.c
4728c8
@@ -1291,16 +1291,6 @@ int update_path_groups(struct multipath
4728c8
 	return 0;
4728c8
 }
4728c8
 
4728c8
-void repair_path(struct path * pp)
4728c8
-{
4728c8
-	if (pp->state != PATH_DOWN)
4728c8
-		return;
4728c8
-
4728c8
-	checker_repair(&pp->checker);
4728c8
-	if (strlen(checker_message(&pp->checker)))
4728c8
-		LOG_MSG(1, checker_message(&pp->checker));
4728c8
-}
4728c8
-
4728c8
 void
4728c8
 check_path (struct vectors * vecs, struct path * pp)
4728c8
 {
4728c8
@@ -1421,7 +1411,6 @@ check_path (struct vectors * vecs, struc
4728c8
 			pp->mpp->failback_tick = 0;
4728c8
 
4728c8
 			pp->mpp->stat_path_failures++;
4728c8
-			repair_path(pp);
4728c8
 			return;
4728c8
 		}
4728c8
 
4728c8
@@ -1501,7 +1490,7 @@ check_path (struct vectors * vecs, struc
4728c8
 	}
4728c8
 
4728c8
 	pp->state = newstate;
4728c8
-	repair_path(pp);
4728c8
+
4728c8
 
4728c8
 	if (pp->mpp->wait_for_udev)
4728c8
 		return;
4728c8
Index: multipath-tools-130222/libmultipath/checkers.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers.c
4728c8
@@ -139,13 +139,6 @@ struct checker * add_checker (char * nam
4728c8
 	if (!c->free)
4728c8
 		goto out;
4728c8
 
4728c8
-	c->repair = (void (*)(struct checker *)) dlsym(c->handle,
4728c8
-						       "libcheck_repair");
4728c8
-	errstr = dlerror();
4728c8
-	if (errstr != NULL)
4728c8
-		condlog(0, "A dynamic linking error occurred: (%s)", errstr);
4728c8
-	if (!c->repair)
4728c8
-		goto out;
4728c8
 done:
4728c8
 	c->fd = 0;
4728c8
 	c->sync = 1;
4728c8
@@ -214,21 +207,6 @@ void checker_put (struct checker * dst)
4728c8
 	free_checker(src);
4728c8
 }
4728c8
 
4728c8
-void checker_repair (struct checker * c)
4728c8
-{
4728c8
-	if (!c || !checker_selected(c))
4728c8
-		return;
4728c8
-
4728c8
-	c->message[0] = '\0';
4728c8
-	if (c->disable) {
4728c8
-		MSG(c, "checker disabled");
4728c8
-		return;
4728c8
-	}
4728c8
-
4728c8
-	if (c->repair)
4728c8
-		c->repair(c);
4728c8
-}
4728c8
-
4728c8
 int checker_check (struct checker * c, int path_state)
4728c8
 {
4728c8
 	int r;
4728c8
@@ -297,7 +275,6 @@ void checker_get (struct checker * dst,
4728c8
 	dst->sync = src->sync;
4728c8
 	strncpy(dst->name, src->name, CHECKER_NAME_LEN);
4728c8
 	strncpy(dst->message, src->message, CHECKER_MSG_LEN);
4728c8
-	dst->repair = src->repair;
4728c8
 	dst->check = src->check;
4728c8
 	dst->init = src->init;
4728c8
 	dst->free = src->free;
4728c8
Index: multipath-tools-130222/libmultipath/hwtable.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/hwtable.c
4728c8
+++ multipath-tools-130222/libmultipath/hwtable.c
4728c8
@@ -1171,20 +1171,6 @@ static struct hwentry default_hw[] = {
4728c8
 		.checker_name  = TUR,
4728c8
 		.dev_loss      = 30,
4728c8
 	},
4728c8
-	{
4728c8
-	/*
4728c8
-	 * Red Hat
4728c8
-	 *
4728c8
-	 * Maintainer: Mike Christie
4728c8
-	 * Mail: mchristi@redhat.com
4728c8
-	 */
4728c8
-		.vendor        = "Ceph",
4728c8
-		.product       = "RBD",
4728c8
-		.pgpolicy      = FAILOVER,
4728c8
-		.no_path_retry = NO_PATH_RETRY_FAIL,
4728c8
-		.checker_name  = RBD,
4728c8
-		.deferred_remove = DEFERRED_REMOVE_ON,
4728c8
-	},
4728c8
 	/*
4728c8
 	 *  Generic NVMe devices
4728c8
 	 */
4728c8
Index: multipath-tools-130222/libmultipath/checkers/Makefile
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/Makefile
4728c8
+++ multipath-tools-130222/libmultipath/checkers/Makefile
4728c8
@@ -14,17 +14,10 @@ LIBS= \
4728c8
 	libcheckhp_sw.so \
4728c8
 	libcheckrdac.so
4728c8
 
4728c8
-ifeq ($(shell test -r /usr/include/rados/librados.h && echo 1),1)
4728c8
-LIBS += libcheckrbd.so
4728c8
-endif
4728c8
-
4728c8
 CFLAGS += -fPIC -I..
4728c8
 
4728c8
 all: $(LIBS)
4728c8
 
4728c8
-libcheckrbd.so: rbd.o
4728c8
-	$(CC) $(LDFLAGS) $(SHARED_FLAGS) -o $@ $^ -lrados -ludev
4728c8
-
4728c8
 libcheckdirectio.so: libsg.o directio.o
4728c8
 	$(CC) $(LDFLAGS) $(SHARED_FLAGS) -o $@ $^ -laio
4728c8
 
4728c8
Index: multipath-tools-130222/multipath.conf.annotated
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/multipath.conf.annotated
4728c8
+++ multipath-tools-130222/multipath.conf.annotated
4728c8
@@ -97,7 +97,7 @@
4728c8
 #	# scope   : multipath & multipathd
4728c8
 #	# desc    : the default method used to determine the paths' state
4728c8
 #	# values  : readsector0|tur|emc_clariion|hp_sw|directio|rdac|
4728c8
-#	            cciss_tur|hp_tur|rbd
4728c8
+#	            cciss_tur|hp_tur
4728c8
 #	# default : directio
4728c8
 #	#
4728c8
 #	path_checker	directio
4728c8
@@ -493,7 +493,7 @@
4728c8
 #		# scope   : multipathd & multipathd
4728c8
 #		# desc    : path checking algorithm to use to check path state
4728c8
 #		# values  : readsector0|tur|emc_clariion|hp_sw|directio|rdac|
4728c8
-#		#           cciss_tur|hp_tur|rbd
4728c8
+#		#           cciss_tur|hp_tur
4728c8
 #		#
4728c8
 #		path_checker		directio
4728c8
 #
4728c8
Index: multipath-tools-130222/multipath/multipath.conf.5
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/multipath/multipath.conf.5
4728c8
+++ multipath-tools-130222/multipath/multipath.conf.5
4728c8
@@ -287,9 +287,6 @@ Read the first sector with direct I/O.
4728c8
 .B none
4728c8
 Do not check the device, fallback to use the values retrieved from sysfs
4728c8
 .TP
4728c8
-.B rbd
4728c8
-Check if the path is in the Ceph blacklist.
4728c8
-.TP
4728c8
 Default value is \fIdirectio\fR.
4728c8
 .RE
4728c8
 .TP
4728c8
Index: multipath-tools-130222/libmultipath/checkers.h
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers.h
4728c8
+++ multipath-tools-130222/libmultipath/checkers.h
4728c8
@@ -76,7 +76,6 @@ enum path_check_state {
4728c8
 #define READSECTOR0  "readsector0"
4728c8
 #define CCISS_TUR    "cciss_tur"
4728c8
 #define NONE         "none"
4728c8
-#define RBD          "rbd"
4728c8
 
4728c8
 #define DEFAULT_CHECKER DIRECTIO
4728c8
 
4728c8
@@ -107,9 +106,6 @@ struct checker {
4728c8
 						multipath-wide. Use MALLOC if
4728c8
 						you want to stuff data in. */
4728c8
 	int (*check)(struct checker *);
4728c8
-	void (*repair)(struct checker *);     /* called if check returns
4728c8
-					        PATH_DOWN to bring path into
4728c8
-						usable state */
4728c8
 	int (*init)(struct checker *);       /* to allocate the context */
4728c8
 	void (*free)(struct checker *);      /* to free the context */
4728c8
 };
4728c8
@@ -129,7 +125,6 @@ void checker_set_async (struct checker *
4728c8
 void checker_set_fd (struct checker *, int);
4728c8
 void checker_enable (struct checker *);
4728c8
 void checker_disable (struct checker *);
4728c8
-void checker_repair (struct checker *);
4728c8
 int checker_check (struct checker *, int);
4728c8
 int checker_selected (struct checker *);
4728c8
 char * checker_name (struct checker *);
4728c8
Index: multipath-tools-130222/libmultipath/checkers/cciss_tur.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/cciss_tur.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers/cciss_tur.c
4728c8
@@ -63,11 +63,6 @@ void libcheck_free (struct checker * c)
4728c8
 	return;
4728c8
 }
4728c8
 
4728c8
-void libcheck_repair (struct checker * c)
4728c8
-{
4728c8
-	return;
4728c8
-}
4728c8
-
4728c8
 extern int
4728c8
 libcheck_check (struct checker * c)
4728c8
 {
4728c8
Index: multipath-tools-130222/libmultipath/checkers/directio.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/directio.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers/directio.c
4728c8
@@ -116,11 +116,6 @@ void libcheck_free (struct checker * c)
4728c8
 	free(ct);
4728c8
 }
4728c8
 
4728c8
-void libcheck_repair (struct checker * c)
4728c8
-{
4728c8
-	return;
4728c8
-}
4728c8
-
4728c8
 static int
4728c8
 check_state(int fd, struct directio_context *ct, int sync, int timeout_secs)
4728c8
 {
4728c8
Index: multipath-tools-130222/libmultipath/checkers/emc_clariion.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/emc_clariion.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers/emc_clariion.c
4728c8
@@ -90,11 +90,6 @@ void libcheck_free (struct checker * c)
4728c8
 	free(c->context);
4728c8
 }
4728c8
 
4728c8
-void libcheck_repair (struct checker * c)
4728c8
-{
4728c8
-	return;
4728c8
-}
4728c8
-
4728c8
 int libcheck_check (struct checker * c)
4728c8
 {
4728c8
 	unsigned char sense_buffer[128] = { 0, };
4728c8
Index: multipath-tools-130222/libmultipath/checkers/hp_sw.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/hp_sw.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers/hp_sw.c
4728c8
@@ -44,11 +44,6 @@ void libcheck_free (struct checker * c)
4728c8
 	return;
4728c8
 }
4728c8
 
4728c8
-void libcheck_repair (struct checker * c)
4728c8
-{
4728c8
-	return;
4728c8
-}
4728c8
-
4728c8
 static int
4728c8
 do_inq(int sg_fd, int cmddt, int evpd, unsigned int pg_op,
4728c8
        void *resp, int mx_resp_len, int noisy, unsigned int timeout)
4728c8
Index: multipath-tools-130222/libmultipath/checkers/rdac.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/rdac.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers/rdac.c
4728c8
@@ -139,11 +139,6 @@ void libcheck_free (struct checker * c)
4728c8
 	return;
4728c8
 }
4728c8
 
4728c8
-void libcheck_repair (struct checker * c)
4728c8
-{
4728c8
-	return;
4728c8
-}
4728c8
-
4728c8
 static int
4728c8
 do_inq(int sg_fd, unsigned int pg_op, void *resp, int mx_resp_len,
4728c8
        unsigned int timeout)
4728c8
Index: multipath-tools-130222/libmultipath/checkers/readsector0.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/readsector0.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers/readsector0.c
4728c8
@@ -23,11 +23,6 @@ void libcheck_free (struct checker * c)
4728c8
 	return;
4728c8
 }
4728c8
 
4728c8
-void libcheck_repair (struct checker * c)
4728c8
-{
4728c8
-	return;
4728c8
-}
4728c8
-
4728c8
 int libcheck_check (struct checker * c)
4728c8
 {
4728c8
 	unsigned char buf[4096];
4728c8
Index: multipath-tools-130222/libmultipath/checkers/tur.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/checkers/tur.c
4728c8
+++ multipath-tools-130222/libmultipath/checkers/tur.c
4728c8
@@ -187,11 +187,6 @@ void libcheck_free (struct checker * c)
4728c8
 	return;
4728c8
 }
4728c8
 
4728c8
-void libcheck_repair (struct checker * c)
4728c8
-{
4728c8
-	return;
4728c8
-}
4728c8
-
4728c8
 #define TUR_MSG(msg, fmt, args...) snprintf(msg, CHECKER_MSG_LEN, fmt, ##args);
4728c8
 
4728c8
 int
4728c8
Index: multipath-tools-130222/libmultipath/discovery.c
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/discovery.c
4728c8
+++ multipath-tools-130222/libmultipath/discovery.c
4728c8
@@ -922,21 +922,6 @@ nvme_sysfs_pathinfo (struct path * pp)
4728c8
 }
4728c8
 
4728c8
 static int
4728c8
-rbd_sysfs_pathinfo (struct path * pp)
4728c8
-{
4728c8
-	sprintf(pp->vendor_id, "Ceph");
4728c8
-	sprintf(pp->product_id, "RBD");
4728c8
-
4728c8
-	condlog(3, "%s: vendor = %s product = %s", pp->dev, pp->vendor_id,
4728c8
-		pp->product_id);
4728c8
-	/*
4728c8
-	 * set the hwe configlet pointer
4728c8
-	 */
4728c8
-	pp->hwe = find_hwe(conf->hwtable, pp->vendor_id, pp->product_id, NULL);
4728c8
-	return 0;
4728c8
-}
4728c8
-
4728c8
-static int
4728c8
 ccw_sysfs_pathinfo (struct path * pp)
4728c8
 {
4728c8
 	struct udev_device *parent;
4728c8
@@ -1151,8 +1136,6 @@ sysfs_pathinfo(struct path * pp)
4728c8
 		pp->bus = SYSFS_BUS_CCW;
4728c8
 	if (!strncmp(pp->dev,"sd", 2))
4728c8
 		pp->bus = SYSFS_BUS_SCSI;
4728c8
-	if (!strncmp(pp->dev,"rbd", 3))
4728c8
-		pp->bus = SYSFS_BUS_RBD;
4728c8
 	if (!strncmp(pp->dev,"nvme", 4))
4728c8
 		pp->bus = SYSFS_BUS_NVME;
4728c8
 
4728c8
@@ -1167,9 +1150,6 @@ sysfs_pathinfo(struct path * pp)
4728c8
 	} else if (pp->bus == SYSFS_BUS_CCISS) {
4728c8
 		if (cciss_sysfs_pathinfo(pp))
4728c8
 			return 1;
4728c8
-	} else if (pp->bus == SYSFS_BUS_RBD) {
4728c8
-		if (rbd_sysfs_pathinfo(pp))
4728c8
-			return 1;
4728c8
 	} else if (pp->bus == SYSFS_BUS_NVME) {
4728c8
 		if (nvme_sysfs_pathinfo(pp))
4728c8
 			return 1;
4728c8
@@ -1275,55 +1255,6 @@ get_prio (struct path * pp)
4728c8
 	return 0;
4728c8
 }
4728c8
 
4728c8
-static int
4728c8
-get_rbd_uid(struct path * pp)
4728c8
-{
4728c8
-	struct udev_device *rbd_bus_dev;
4728c8
-	int ret, rbd_bus_id;
4728c8
-	const char *pool, *image, *snap;
4728c8
-	char sysfs_path[PATH_SIZE];
4728c8
-	uint64_t snap_id, max_snap_id = -3;
4728c8
-
4728c8
-	ret = sscanf(pp->dev, "rbd%d", &rbd_bus_id);
4728c8
-	if (ret != 1)
4728c8
-		return -EINVAL;
4728c8
-
4728c8
-	snprintf(sysfs_path, sizeof(sysfs_path), "/sys/bus/rbd/devices/%d",
4728c8
-		 rbd_bus_id);
4728c8
-	rbd_bus_dev = udev_device_new_from_syspath(conf->udev, sysfs_path);
4728c8
-	if (!rbd_bus_dev)
4728c8
-		return -ENODEV;
4728c8
-
4728c8
-	ret = -EINVAL;
4728c8
-	pool = udev_device_get_sysattr_value(rbd_bus_dev, "pool_id");
4728c8
-	if (!pool)
4728c8
-		goto free_dev;
4728c8
-
4728c8
-	image = udev_device_get_sysattr_value(rbd_bus_dev, "image_id");
4728c8
-	if (!image)
4728c8
-		goto free_dev;
4728c8
-
4728c8
-	snap = udev_device_get_sysattr_value(rbd_bus_dev, "snap_id");
4728c8
-	if (!snap)
4728c8
-		goto free_dev;
4728c8
-	snap_id = strtoull(snap, NULL, 19);
4728c8
-	if (snap_id >= max_snap_id)
4728c8
-		ret = snprintf(pp->wwid, WWID_SIZE, "%s-%s", pool, image);
4728c8
-	else
4728c8
-		ret = snprintf(pp->wwid, WWID_SIZE, "%s-%s-%s", pool,
4728c8
-			       image, snap);
4728c8
-	if (ret < WWID_SIZE) {
4728c8
-		ret = 0;
4728c8
-	} else {
4728c8
-		condlog(0, "%s: wwid overflow", pp->dev);
4728c8
-		ret = -EOVERFLOW;
4728c8
-	}
4728c8
-
4728c8
-free_dev:
4728c8
-	udev_device_unref(rbd_bus_dev);	
4728c8
-	return ret;
4728c8
-}
4728c8
-
4728c8
 /*
4728c8
  * Mangle string of length *len starting at start
4728c8
  * by removing character sequence "00" (hex for a 0 byte),
4728c8
@@ -1405,7 +1336,6 @@ get_uid (struct path * pp, struct udev_d
4728c8
 {
4728c8
 	char *c;
4728c8
 	const char *value;
4728c8
-	int ret;
4728c8
 
4728c8
 	if (!pp->uid_attribute)
4728c8
 		select_getuid(pp);
4728c8
@@ -1416,34 +1346,22 @@ get_uid (struct path * pp, struct udev_d
4728c8
 	}
4728c8
 
4728c8
 	memset(pp->wwid, 0, WWID_SIZE);
4728c8
-	if (pp->bus == SYSFS_BUS_RBD) {
4728c8
-		ret = get_rbd_uid(pp);
4728c8
-		if (ret) {
4728c8
-			condlog(1, "%s: failed to get sysfs uid: %s",
4728c8
-				pp->dev, strerror(-ret));
4728c8
-			pp->missing_udev_info = INFO_MISSING;
4728c8
-			pp->tick = conf->retrigger_delay;
4728c8
-		}
4728c8
+	value = udev_device_get_property_value(udev, pp->uid_attribute);
4728c8
+	if ((!value || strlen(value) == 0) && conf->cmd == CMD_VALID_PATH)
4728c8
+		value = getenv(pp->uid_attribute);
4728c8
+	if (value && strlen(value)) {
4728c8
+		size_t len = strlcpy(pp->wwid, value, WWID_SIZE);
4728c8
+		if (len > WWID_SIZE &&
4728c8
+		    !fix_broken_nvme_wwid(pp, value, WWID_SIZE))
4728c8
+			condlog(0, "%s: wwid overflow", pp->dev);
4728c8
+		condlog(4, "%s: got wwid of '%s'", pp->dev, pp->wwid);
4728c8
+		pp->missing_udev_info = INFO_OK;
4728c8
+		pp->tick = 0;
4728c8
 	} else {
4728c8
-		value = udev_device_get_property_value(udev,
4728c8
-						       pp->uid_attribute);
4728c8
-		if ((!value || strlen(value) == 0) &&
4728c8
-		     conf->cmd == CMD_VALID_PATH)
4728c8
-			value = getenv(pp->uid_attribute);
4728c8
-		if (value && strlen(value)) {
4728c8
-			size_t len = strlcpy(pp->wwid, value, WWID_SIZE);
4728c8
-			if (len > WWID_SIZE &&
4728c8
-			    !fix_broken_nvme_wwid(pp, value, WWID_SIZE))
4728c8
-				condlog(0, "%s: wwid overflow", pp->dev);
4728c8
-			condlog(4, "%s: got wwid of '%s'", pp->dev, pp->wwid);
4728c8
-			pp->missing_udev_info = INFO_OK;
4728c8
-			pp->tick = 0;
4728c8
-		} else {
4728c8
-			condlog(3, "%s: no %s attribute", pp->dev,
4728c8
-				pp->uid_attribute);
4728c8
-			pp->missing_udev_info = INFO_MISSING;
4728c8
-			pp->tick = conf->retrigger_delay;
4728c8
-		}
4728c8
+		condlog(3, "%s: no %s attribute", pp->dev,
4728c8
+			pp->uid_attribute);
4728c8
+		pp->missing_udev_info = INFO_MISSING;
4728c8
+		pp->tick = conf->retrigger_delay;
4728c8
 	}
4728c8
 
4728c8
 	/* Strip any trailing blanks */
4728c8
Index: multipath-tools-130222/libmultipath/structs.h
4728c8
===================================================================
4728c8
--- multipath-tools-130222.orig/libmultipath/structs.h
4728c8
+++ multipath-tools-130222/libmultipath/structs.h
4728c8
@@ -60,7 +60,6 @@ enum sysfs_buses {
4728c8
 	SYSFS_BUS_IDE,
4728c8
 	SYSFS_BUS_CCW,
4728c8
 	SYSFS_BUS_CCISS,
4728c8
-	SYSFS_BUS_RBD,
4728c8
 	SYSFS_BUS_NVME,
4728c8
 };
4728c8