Blame SOURCES/0030-Monitor-use-snprintf-to-fill-device-name.patch

fdf7c0
From 84d969be8f6d8a345b75f558fad26e4f62a558f6 Mon Sep 17 00:00:00 2001
fdf7c0
From: Kinga Tanska <kinga.tanska@intel.com>
fdf7c0
Date: Thu, 14 Jul 2022 09:02:11 +0200
01ff50
Subject: [PATCH 30/83] Monitor: use snprintf to fill device name
fdf7c0
fdf7c0
Safe string functions are propagated in Monitor.c.
fdf7c0
fdf7c0
Signed-off-by: Kinga Tanska <kinga.tanska@intel.com>
fdf7c0
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
fdf7c0
---
fdf7c0
 Monitor.c | 37 ++++++++++++++-----------------------
fdf7c0
 1 file changed, 14 insertions(+), 23 deletions(-)
fdf7c0
fdf7c0
diff --git a/Monitor.c b/Monitor.c
fdf7c0
index a5b11ae2..93f36ac0 100644
fdf7c0
--- a/Monitor.c
fdf7c0
+++ b/Monitor.c
fdf7c0
@@ -33,8 +33,8 @@
fdf7c0
 #endif
fdf7c0
 
fdf7c0
 struct state {
fdf7c0
-	char *devname;
fdf7c0
-	char devnm[32];	/* to sync with mdstat info */
fdf7c0
+	char devname[MD_NAME_MAX + sizeof("/dev/md/")];	/* length of "/dev/md/" + device name + terminating byte*/
fdf7c0
+	char devnm[MD_NAME_MAX];	/* to sync with mdstat info */
fdf7c0
 	unsigned int utime;
fdf7c0
 	int err;
fdf7c0
 	char *spare_group;
fdf7c0
@@ -45,9 +45,9 @@ struct state {
fdf7c0
 	int devstate[MAX_DISKS];
fdf7c0
 	dev_t devid[MAX_DISKS];
fdf7c0
 	int percent;
fdf7c0
-	char parent_devnm[32]; /* For subarray, devnm of parent.
fdf7c0
-				* For others, ""
fdf7c0
-				*/
fdf7c0
+	char parent_devnm[MD_NAME_MAX]; /* For subarray, devnm of parent.
fdf7c0
+					* For others, ""
fdf7c0
+					*/
fdf7c0
 	struct supertype *metadata;
fdf7c0
 	struct state *subarray;/* for a container it is a link to first subarray
fdf7c0
 				* for a subarray it is a link to next subarray
fdf7c0
@@ -187,15 +187,8 @@ int Monitor(struct mddev_dev *devlist,
fdf7c0
 				continue;
fdf7c0
 
fdf7c0
 			st = xcalloc(1, sizeof *st);
fdf7c0
-			if (mdlist->devname[0] == '/')
fdf7c0
-				st->devname = xstrdup(mdlist->devname);
fdf7c0
-			else {
fdf7c0
-				/* length of "/dev/md/" + device name + terminating byte */
fdf7c0
-				size_t _len = sizeof("/dev/md/") + strnlen(mdlist->devname, PATH_MAX);
fdf7c0
-
fdf7c0
-				st->devname = xcalloc(_len, sizeof(char));
fdf7c0
-				snprintf(st->devname, _len, "/dev/md/%s", mdlist->devname);
fdf7c0
-			}
fdf7c0
+			snprintf(st->devname, MD_NAME_MAX + sizeof("/dev/md/"),
fdf7c0
+				 "/dev/md/%s", basename(mdlist->devname));
fdf7c0
 			if (!is_mddev(mdlist->devname))
fdf7c0
 				return 1;
fdf7c0
 			st->next = statelist;
fdf7c0
@@ -218,7 +211,7 @@ int Monitor(struct mddev_dev *devlist,
fdf7c0
 
fdf7c0
 			st = xcalloc(1, sizeof *st);
fdf7c0
 			mdlist = conf_get_ident(dv->devname);
fdf7c0
-			st->devname = xstrdup(dv->devname);
fdf7c0
+			snprintf(st->devname, MD_NAME_MAX + sizeof("/dev/md/"), "%s", dv->devname);
fdf7c0
 			st->next = statelist;
fdf7c0
 			st->devnm[0] = 0;
fdf7c0
 			st->percent = RESYNC_UNKNOWN;
fdf7c0
@@ -301,7 +294,6 @@ int Monitor(struct mddev_dev *devlist,
fdf7c0
 		for (stp = &statelist; (st = *stp) != NULL; ) {
fdf7c0
 			if (st->from_auto && st->err > 5) {
fdf7c0
 				*stp = st->next;
fdf7c0
-				free(st->devname);
fdf7c0
 				free(st->spare_group);
fdf7c0
 				free(st);
fdf7c0
 			} else
fdf7c0
@@ -554,7 +546,7 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
fdf7c0
 		goto disappeared;
fdf7c0
 
fdf7c0
 	if (st->devnm[0] == 0)
fdf7c0
-		strcpy(st->devnm, fd2devnm(fd));
fdf7c0
+		snprintf(st->devnm, MD_NAME_MAX, "%s", fd2devnm(fd));
fdf7c0
 
fdf7c0
 	for (mse2 = mdstat; mse2; mse2 = mse2->next)
fdf7c0
 		if (strcmp(mse2->devnm, st->devnm) == 0) {
fdf7c0
@@ -684,7 +676,7 @@ static int check_array(struct state *st, struct mdstat_ent *mdstat,
fdf7c0
 	    strncmp(mse->metadata_version, "external:", 9) == 0 &&
fdf7c0
 	    is_subarray(mse->metadata_version+9)) {
fdf7c0
 		char *sl;
fdf7c0
-		strcpy(st->parent_devnm, mse->metadata_version + 10);
fdf7c0
+		snprintf(st->parent_devnm, MD_NAME_MAX, "%s", mse->metadata_version + 10);
fdf7c0
 		sl = strchr(st->parent_devnm, '/');
fdf7c0
 		if (sl)
fdf7c0
 			*sl = 0;
fdf7c0
@@ -772,14 +764,13 @@ static int add_new_arrays(struct mdstat_ent *mdstat, struct state **statelist,
fdf7c0
 				continue;
fdf7c0
 			}
fdf7c0
 
fdf7c0
-			st->devname = xstrdup(name);
fdf7c0
+			snprintf(st->devname, MD_NAME_MAX + sizeof("/dev/md/"), "%s", name);
fdf7c0
 			if ((fd = open(st->devname, O_RDONLY)) < 0 ||
fdf7c0
 			    md_get_array_info(fd, &array) < 0) {
fdf7c0
 				/* no such array */
fdf7c0
 				if (fd >= 0)
fdf7c0
 					close(fd);
fdf7c0
 				put_md_name(st->devname);
fdf7c0
-				free(st->devname);
fdf7c0
 				if (st->metadata) {
fdf7c0
 					st->metadata->ss->free_super(st->metadata);
fdf7c0
 					free(st->metadata);
fdf7c0
@@ -791,7 +782,7 @@ static int add_new_arrays(struct mdstat_ent *mdstat, struct state **statelist,
fdf7c0
 			st->next = *statelist;
fdf7c0
 			st->err = 1;
fdf7c0
 			st->from_auto = 1;
fdf7c0
-			strcpy(st->devnm, mse->devnm);
fdf7c0
+			snprintf(st->devnm, MD_NAME_MAX, "%s", mse->devnm);
fdf7c0
 			st->percent = RESYNC_UNKNOWN;
fdf7c0
 			st->expected_spares = -1;
fdf7c0
 			if (mse->metadata_version &&
fdf7c0
@@ -799,8 +790,8 @@ static int add_new_arrays(struct mdstat_ent *mdstat, struct state **statelist,
fdf7c0
 				    "external:", 9) == 0 &&
fdf7c0
 			    is_subarray(mse->metadata_version+9)) {
fdf7c0
 				char *sl;
fdf7c0
-				strcpy(st->parent_devnm,
fdf7c0
-					mse->metadata_version+10);
fdf7c0
+				snprintf(st->parent_devnm, MD_NAME_MAX,
fdf7c0
+					 "%s", mse->metadata_version + 10);
fdf7c0
 				sl = strchr(st->parent_devnm, '/');
fdf7c0
 				*sl = 0;
fdf7c0
 			} else
fdf7c0
-- 
01ff50
2.38.1
fdf7c0