e377cc
From 7ce318610afcbb793e438332687c2f09844a86c2 Mon Sep 17 00:00:00 2001
e377cc
From: Karel Zak <kzak@redhat.com>
e377cc
Date: Thu, 25 Nov 2021 11:54:11 +0100
e377cc
Subject: [PATCH 71/74] libblkid: check UBI char device name
e377cc
e377cc
Addresses: https://bugzilla.redhat.com/show_bug.cgi?id=2026511
e377cc
Upstream: http://github.com/util-linux/util-linux/commit/7eb6d9ce4526b968e30f7e538cbbbdf9938e5891
e377cc
Signed-off-by: Karel Zak <kzak@redhat.com>
e377cc
---
e377cc
 libblkid/src/probe.c | 12 ++++++++++--
e377cc
 1 file changed, 10 insertions(+), 2 deletions(-)
e377cc
e377cc
diff --git a/libblkid/src/probe.c b/libblkid/src/probe.c
e377cc
index a6dc8416a..49a62c47f 100644
e377cc
--- a/libblkid/src/probe.c
e377cc
+++ b/libblkid/src/probe.c
e377cc
@@ -915,9 +915,17 @@ int blkid_probe_set_device(blkid_probe pr, int fd,
e377cc
 			DBG(LOWPROBE, ul_debug("failed to get device size"));
e377cc
 			goto err;
e377cc
 		}
e377cc
-	} else if (S_ISCHR(sb.st_mode))
e377cc
+	} else if (S_ISCHR(sb.st_mode)) {
e377cc
+		char buf[PATH_MAX];
e377cc
+
e377cc
+		if (!sysfs_chrdev_devno_to_devname(sb.st_rdev, buf, sizeof(buf))
e377cc
+		    || strncmp(buf, "ubi", 3) != 0) {
e377cc
+			DBG(LOWPROBE, ul_debug("no UBI char device"));
e377cc
+			errno = EINVAL;
e377cc
+			goto err;
e377cc
+		}
e377cc
 		devsiz = 1;		/* UBI devices are char... */
e377cc
-	else if (S_ISREG(sb.st_mode))
e377cc
+	} else if (S_ISREG(sb.st_mode))
e377cc
 		devsiz = sb.st_size;	/* regular file */
e377cc
 
e377cc
 	pr->size = size ? (uint64_t)size : devsiz;
e377cc
-- 
e377cc
2.31.1
e377cc