Blame SOURCES/0059-Put-some-EFI-device-paths-into-the-debug-log.patch

4e0e09
From effecb5ce0baf2fae011dd61e45852cd2fb1ec19 Mon Sep 17 00:00:00 2001
4e0e09
From: Peter Jones <pjones@redhat.com>
4e0e09
Date: Tue, 15 Oct 2019 16:58:19 -0400
4e0e09
Subject: [PATCH 59/63] Put some EFI device paths into the debug log
4e0e09
4e0e09
Signed-off-by: Peter Jones <pjones@redhat.com>
4e0e09
---
4e0e09
 src/linux.c | 41 +++++++++++++++++++++++++++++++++++++++++
4e0e09
 1 file changed, 41 insertions(+)
4e0e09
4e0e09
diff --git a/src/linux.c b/src/linux.c
4e0e09
index 7dd8d4cd858..9d8480a94a9 100644
4e0e09
--- a/src/linux.c
4e0e09
+++ b/src/linux.c
4e0e09
@@ -336,6 +336,44 @@ device_free(struct device *dev)
4e0e09
 	free(dev);
4e0e09
 }
4e0e09
 
4e0e09
+static void
4e0e09
+print_dev_dp_node(struct device *dev, struct dev_probe *probe)
4e0e09
+{
4e0e09
+	ssize_t dpsz;
4e0e09
+	uint8_t *dp;
4e0e09
+	ssize_t bufsz;
4e0e09
+	uint8_t *buf;
4e0e09
+
4e0e09
+	dpsz = probe->create(dev, NULL, 0, 0);
4e0e09
+	if (dpsz <= 0)
4e0e09
+		return;
4e0e09
+
4e0e09
+	dp = alloca(dpsz + 4);
4e0e09
+	if (!dp)
4e0e09
+		return;
4e0e09
+
4e0e09
+	dpsz = probe->create(dev, dp, dpsz, 0);
4e0e09
+	if (dpsz <= 0)
4e0e09
+		return;
4e0e09
+
4e0e09
+	efidp_make_end_entire(dp + dpsz, 4);
4e0e09
+	bufsz = efidp_format_device_path(NULL, 0,
4e0e09
+					 (const_efidp)dp, dpsz + 4);
4e0e09
+	if (bufsz <= 0)
4e0e09
+		return;
4e0e09
+
4e0e09
+	buf = alloca(bufsz);
4e0e09
+	if (!buf)
4e0e09
+		return;
4e0e09
+
4e0e09
+	bufsz = efidp_format_device_path(buf, bufsz,
4e0e09
+			(const_efidp)dp, dpsz + 4);
4e0e09
+	if (bufsz <= 0)
4e0e09
+		return;
4e0e09
+
4e0e09
+	debug("Device path node is %s", buf);
4e0e09
+}
4e0e09
+
4e0e09
 struct device HIDDEN
4e0e09
 *device_get(int fd, int partition)
4e0e09
 {
4e0e09
@@ -512,6 +550,9 @@ struct device HIDDEN
4e0e09
 	                    probe->flags & DEV_ABBREV_ONLY)
4e0e09
 	                        needs_root = false;
4e0e09
 
4e0e09
+			if (probe->create)
4e0e09
+				print_dev_dp_node(dev, probe);
4e0e09
+
4e0e09
 	                dev->probes[n++] = dev_probes[i];
4e0e09
 	                current += pos;
4e0e09
 			if (current[0] == '\0')
4e0e09
-- 
4e0e09
2.26.2
4e0e09