dcavalca / rpms / mdadm

Forked from rpms/mdadm 3 years ago
Clone

Blame SOURCES/util-Introduce3-md_get_disk_info.patch

2c1b57
From d97572f5a59ca1ddde9971a79d47c9ea4db5891b Mon Sep 17 00:00:00 2001
2c1b57
From: Jes Sorensen <Jes.Sorensen@gmail.com>
2c1b57
Date: Wed, 29 Mar 2017 15:23:50 -0400
2c1b57
Subject: [RHEL7.5 PATCH 039/169] util: Introduce md_get_disk_info()
2c1b57
2c1b57
This removes all the inline ioctl calls for GET_DISK_INFO, allowing us
2c1b57
to switch to sysfs in one place, and improves type checking.
2c1b57
2c1b57
Signed-off-by: Jes Sorensen <Jes.Sorensen@gmail.com>
2c1b57
---
2c1b57
 Detail.c  |  8 +++-----
2c1b57
 Grow.c    | 14 +++++++-------
2c1b57
 Manage.c  | 19 +++++++++----------
2c1b57
 Monitor.c |  2 +-
2c1b57
 Query.c   |  2 +-
2c1b57
 mdadm.h   |  1 +
2c1b57
 util.c    | 10 +++++++++-
2c1b57
 7 files changed, 31 insertions(+), 25 deletions(-)
2c1b57
2c1b57
diff --git a/Detail.c b/Detail.c
2c1b57
index d7e886a..fa6d4c7 100644
2c1b57
--- a/Detail.c
2c1b57
+++ b/Detail.c
2c1b57
@@ -51,10 +51,8 @@ static int add_device(const char *dev, char ***p_devices,
2c1b57
 int Detail(char *dev, struct context *c)
2c1b57
 {
2c1b57
 	/*
2c1b57
-	 * Print out details for an md array by using
2c1b57
-	 * GET_ARRAY_INFO and GET_DISK_INFO ioctl calls
2c1b57
+	 * Print out details for an md array
2c1b57
 	 */
2c1b57
-
2c1b57
 	int fd = open(dev, O_RDONLY);
2c1b57
 	int vers;
2c1b57
 	mdu_array_info_t array;
2c1b57
@@ -165,7 +163,7 @@ int Detail(char *dev, struct context *c)
2c1b57
 			disk = subdev->disk;
2c1b57
 		else {
2c1b57
 			disk.number = d;
2c1b57
-			if (ioctl(fd, GET_DISK_INFO, &disk) < 0)
2c1b57
+			if (md_get_disk_info(fd, &disk) < 0)
2c1b57
 				continue;
2c1b57
 			if (d >= array.raid_disks &&
2c1b57
 			    disk.major == 0 &&
2c1b57
@@ -322,7 +320,7 @@ int Detail(char *dev, struct context *c)
2c1b57
 	} else for (d = 0; d < max_disks; d++) {
2c1b57
 		mdu_disk_info_t disk;
2c1b57
 		disk.number = d;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disk) < 0) {
2c1b57
+		if (md_get_disk_info(fd, &disk) < 0) {
2c1b57
 			if (d < array.raid_disks)
2c1b57
 				pr_err("cannot get device detail for device %d: %s\n",
2c1b57
 					d, strerror(errno));
2c1b57
diff --git a/Grow.c b/Grow.c
2c1b57
index 4eab5cc..1c90902 100755
2c1b57
--- a/Grow.c
2c1b57
+++ b/Grow.c
2c1b57
@@ -161,7 +161,7 @@ int Grow_Add_device(char *devname, int fd, char *newdev)
2c1b57
 		st->ss->free_super(st);
2c1b57
 
2c1b57
 		disk.number = d;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disk) < 0) {
2c1b57
+		if (md_get_disk_info(fd, &disk) < 0) {
2c1b57
 			pr_err("cannot get device detail for device %d\n",
2c1b57
 				d);
2c1b57
 			close(nfd);
2c1b57
@@ -232,7 +232,7 @@ int Grow_Add_device(char *devname, int fd, char *newdev)
2c1b57
 		char *dv;
2c1b57
 
2c1b57
 		disk.number = d;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disk) < 0) {
2c1b57
+		if (md_get_disk_info(fd, &disk) < 0) {
2c1b57
 			pr_err("cannot get device detail for device %d\n",
2c1b57
 				d);
2c1b57
 			return 1;
2c1b57
@@ -422,7 +422,7 @@ int Grow_addbitmap(char *devname, int fd, struct context *c, struct shape *s)
2c1b57
 			int fd2;
2c1b57
 
2c1b57
 			disk.number = d;
2c1b57
-			if (ioctl(fd, GET_DISK_INFO, &disk) < 0)
2c1b57
+			if (md_get_disk_info(fd, &disk) < 0)
2c1b57
 				continue;
2c1b57
 			if (disk.major == 0 && disk.minor == 0)
2c1b57
 				continue;
2c1b57
@@ -483,7 +483,7 @@ int Grow_addbitmap(char *devname, int fd, struct context *c, struct shape *s)
2c1b57
 			char *dv;
2c1b57
 			int fd2;
2c1b57
 			disk.number = d;
2c1b57
-			if (ioctl(fd, GET_DISK_INFO, &disk) < 0)
2c1b57
+			if (md_get_disk_info(fd, &disk) < 0)
2c1b57
 				continue;
2c1b57
 			if ((disk.major==0 && disk.minor == 0) ||
2c1b57
 			    (disk.state & (1 << MD_DISK_REMOVED)))
2c1b57
@@ -2908,7 +2908,7 @@ static int impose_level(int fd, int level, char *devname, int verbose)
2c1b57
 		     d++) {
2c1b57
 			mdu_disk_info_t disk;
2c1b57
 			disk.number = d;
2c1b57
-			if (ioctl(fd, GET_DISK_INFO, &disk) < 0)
2c1b57
+			if (md_get_disk_info(fd, &disk) < 0)
2c1b57
 				continue;
2c1b57
 			if (disk.major == 0 && disk.minor == 0)
2c1b57
 				continue;
2c1b57
@@ -2927,7 +2927,7 @@ static int impose_level(int fd, int level, char *devname, int verbose)
2c1b57
 		     d++) {
2c1b57
 			mdu_disk_info_t disk;
2c1b57
 			disk.number = d;
2c1b57
-			if (ioctl(fd, GET_DISK_INFO, &disk) < 0)
2c1b57
+			if (md_get_disk_info(fd, &disk) < 0)
2c1b57
 				continue;
2c1b57
 			if (disk.major == 0 && disk.minor == 0)
2c1b57
 				continue;
2c1b57
@@ -5011,7 +5011,7 @@ int Grow_continue_command(char *devname, int fd,
2c1b57
 				char *dv;
2c1b57
 				int err;
2c1b57
 				disk.number = d;
2c1b57
-				if (ioctl(fd, GET_DISK_INFO, &disk) < 0)
2c1b57
+				if (md_get_disk_info(fd, &disk) < 0)
2c1b57
 					continue;
2c1b57
 				if (disk.major == 0 && disk.minor == 0)
2c1b57
 					continue;
2c1b57
diff --git a/Manage.c b/Manage.c
2c1b57
index 24ed370..0ffb6c6 100644
2c1b57
--- a/Manage.c
2c1b57
+++ b/Manage.c
2c1b57
@@ -546,7 +546,7 @@ static void add_faulty(struct mddev_dev *dv, int fd, char disp)
2c1b57
 	for (i = 0; i < MAX_DISKS && remaining_disks > 0; i++) {
2c1b57
 		char buf[40];
2c1b57
 		disk.number = i;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disk) != 0)
2c1b57
+		if (md_get_disk_info(fd, &disk) != 0)
2c1b57
 			continue;
2c1b57
 		if (disk.major == 0 && disk.minor == 0)
2c1b57
 			continue;
2c1b57
@@ -573,7 +573,7 @@ static void add_detached(struct mddev_dev *dv, int fd, char disp)
2c1b57
 		char buf[40];
2c1b57
 		int sfd;
2c1b57
 		disk.number = i;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disk) != 0)
2c1b57
+		if (md_get_disk_info(fd, &disk) != 0)
2c1b57
 			continue;
2c1b57
 		if (disk.major == 0 && disk.minor == 0)
2c1b57
 			continue;
2c1b57
@@ -615,7 +615,7 @@ static void add_set(struct mddev_dev *dv, int fd, char set_char)
2c1b57
 	for (i = 0; i < MAX_DISKS && remaining_disks > 0; i++) {
2c1b57
 		char buf[40];
2c1b57
 		disk.number = i;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disk) != 0)
2c1b57
+		if (md_get_disk_info(fd, &disk) != 0)
2c1b57
 			continue;
2c1b57
 		if (disk.major == 0 && disk.minor == 0)
2c1b57
 			continue;
2c1b57
@@ -661,9 +661,8 @@ int attempt_re_add(int fd, int tfd, struct mddev_dev *dv,
2c1b57
 		    get_linux_version() <= 2006018)
2c1b57
 			goto skip_re_add;
2c1b57
 		disc.number = mdi.disk.number;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disc) != 0
2c1b57
-		    || disc.major != 0 || disc.minor != 0
2c1b57
-			)
2c1b57
+		if (md_get_disk_info(fd, &disc) != 0 ||
2c1b57
+		    disc.major != 0 || disc.minor != 0)
2c1b57
 			goto skip_re_add;
2c1b57
 		disc.major = major(rdev);
2c1b57
 		disc.minor = minor(rdev);
2c1b57
@@ -805,7 +804,7 @@ int Manage_add(int fd, int tfd, struct mddev_dev *dv,
2c1b57
 				char *dev;
2c1b57
 				int dfd;
2c1b57
 				disc.number = j;
2c1b57
-				if (ioctl(fd, GET_DISK_INFO, &disc))
2c1b57
+				if (md_get_disk_info(fd, &disc))
2c1b57
 					continue;
2c1b57
 				if (disc.major==0 && disc.minor==0)
2c1b57
 					continue;
2c1b57
@@ -888,7 +887,7 @@ int Manage_add(int fd, int tfd, struct mddev_dev *dv,
2c1b57
 
2c1b57
 			for (d = 0; d < MAX_DISKS && found < array->nr_disks; d++) {
2c1b57
 				disc.number = d;
2c1b57
-				if (ioctl(fd, GET_DISK_INFO, &disc))
2c1b57
+				if (md_get_disk_info(fd, &disc))
2c1b57
 					continue;
2c1b57
 				if (disc.major == 0 && disc.minor == 0)
2c1b57
 					continue;
2c1b57
@@ -929,7 +928,7 @@ int Manage_add(int fd, int tfd, struct mddev_dev *dv,
2c1b57
 	 */
2c1b57
 	for (j = array->raid_disks; j < tst->max_devs; j++) {
2c1b57
 		disc.number = j;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disc))
2c1b57
+		if (md_get_disk_info(fd, &disc))
2c1b57
 			break;
2c1b57
 		if (disc.major==0 && disc.minor==0)
2c1b57
 			break;
2c1b57
@@ -994,7 +993,7 @@ int Manage_add(int fd, int tfd, struct mddev_dev *dv,
2c1b57
 		for (j = 0; j < tst->max_devs; j++) {
2c1b57
 			mdu_disk_info_t disc2;
2c1b57
 			disc2.number = j;
2c1b57
-			if (ioctl(fd, GET_DISK_INFO, &disc2))
2c1b57
+			if (md_get_disk_info(fd, &disc2))
2c1b57
 				continue;
2c1b57
 			if (disc2.major==0 && disc2.minor==0)
2c1b57
 				continue;
2c1b57
diff --git a/Monitor.c b/Monitor.c
2c1b57
index 0a0a1e2..2c0f717 100644
2c1b57
--- a/Monitor.c
2c1b57
+++ b/Monitor.c
2c1b57
@@ -608,7 +608,7 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
2c1b57
 	     i++) {
2c1b57
 		mdu_disk_info_t disc;
2c1b57
 		disc.number = i;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disc) >= 0) {
2c1b57
+		if (md_get_disk_info(fd, &disc) >= 0) {
2c1b57
 			info[i].state = disc.state;
2c1b57
 			info[i].major = disc.major;
2c1b57
 			info[i].minor = disc.minor;
2c1b57
diff --git a/Query.c b/Query.c
2c1b57
index cae75d1..a2c839c 100644
2c1b57
--- a/Query.c
2c1b57
+++ b/Query.c
2c1b57
@@ -102,7 +102,7 @@ int Query(char *dev)
2c1b57
 			if (mddev && (fd = open(mddev, O_RDONLY))>=0) {
2c1b57
 				if (md_get_version(fd) >= 9000 &&
2c1b57
 				    md_get_array_info(fd, &array) >= 0) {
2c1b57
-					if (ioctl(fd, GET_DISK_INFO, &disc) >= 0 &&
2c1b57
+					if (md_get_disk_info(fd, &disc) >= 0 &&
2c1b57
 					    makedev((unsigned)disc.major,(unsigned)disc.minor) == stb.st_rdev)
2c1b57
 						activity = "active";
2c1b57
 					else
2c1b57
diff --git a/mdadm.h b/mdadm.h
2c1b57
index 7770585..3ab548f 100644
2c1b57
--- a/mdadm.h
2c1b57
+++ b/mdadm.h
2c1b57
@@ -1406,6 +1406,7 @@ extern int Restore_metadata(char *dev, char *dir, struct context *c,
2c1b57
 
2c1b57
 extern int md_get_version(int fd);
2c1b57
 int md_get_array_info(int fd, struct mdu_array_info_s *array);
2c1b57
+int md_get_disk_info(int fd, struct mdu_disk_info_s *disk);
2c1b57
 extern int get_linux_version(void);
2c1b57
 extern int mdadm_version(char *version);
2c1b57
 extern unsigned long long parse_size(char *size);
2c1b57
diff --git a/util.c b/util.c
2c1b57
index 725877d..aa27e59 100644
2c1b57
--- a/util.c
2c1b57
+++ b/util.c
2c1b57
@@ -221,6 +221,14 @@ int md_get_array_info(int fd, struct mdu_array_info_s *array)
2c1b57
 }
2c1b57
 
2c1b57
 /*
2c1b57
+ * Get disk info from the kernel.
2c1b57
+ */
2c1b57
+int md_get_disk_info(int fd, struct mdu_disk_info_s *disk)
2c1b57
+{
2c1b57
+	return ioctl(fd, GET_DISK_INFO, disk);
2c1b57
+}
2c1b57
+
2c1b57
+/*
2c1b57
  * Parse a 128 bit uuid in 4 integers
2c1b57
  * format is 32 hexx nibbles with options :.<space> separator
2c1b57
  * If not exactly 32 hex digits are found, return 0
2c1b57
@@ -553,7 +561,7 @@ int enough_fd(int fd)
2c1b57
 	avail = xcalloc(array.raid_disks, 1);
2c1b57
 	for (i = 0; i < MAX_DISKS && array.nr_disks > 0; i++) {
2c1b57
 		disk.number = i;
2c1b57
-		if (ioctl(fd, GET_DISK_INFO, &disk) != 0)
2c1b57
+		if (md_get_disk_info(fd, &disk) != 0)
2c1b57
 			continue;
2c1b57
 		if (disk.major == 0 && disk.minor == 0)
2c1b57
 			continue;
2c1b57
-- 
2c1b57
2.7.4
2c1b57