Blame SOURCES/0054-Improve-consistency-of-debug-prints.patch

d5c737
From cb81253cc60d9641ee766fa2be691d82821710ca Mon Sep 17 00:00:00 2001
d5c737
From: Peter Jones <pjones@redhat.com>
d5c737
Date: Tue, 15 Oct 2019 16:26:30 -0400
d5c737
Subject: [PATCH 54/63] Improve consistency of debug prints
d5c737
d5c737
This changes debug prints in a couple of ways:
d5c737
- always calls the path we're parsing "current" in the output
d5c737
- always use ' not " for quoting in the debug output, so tools that
d5c737
  escape strings won't change the lenghts
d5c737
- everything that parses "current" has a debug print after each parse
d5c737
  attempt and before returning.
d5c737
d5c737
Signed-off-by: Peter Jones <pjones@redhat.com>
d5c737
---
d5c737
 src/dp-acpi.c         |  6 ++---
d5c737
 src/linux-acpi-root.c | 20 +++++++++--------
d5c737
 src/linux-acpi.c      |  4 ++--
d5c737
 src/linux-ata.c       |  6 ++---
d5c737
 src/linux-emmc.c      |  5 +++--
d5c737
 src/linux-i2o.c       |  8 +++----
d5c737
 src/linux-md.c        |  4 ++--
d5c737
 src/linux-nvme.c      |  8 +++++--
d5c737
 src/linux-pci-root.c  | 16 ++++++++------
d5c737
 src/linux-pci.c       | 17 +++++++--------
d5c737
 src/linux-pmem.c      | 19 +++++++++-------
d5c737
 src/linux-sas.c       |  3 +++
d5c737
 src/linux-sata.c      |  9 ++++----
d5c737
 src/linux-scsi.c      | 51 +++++++++++++++++++++++++++----------------
d5c737
 src/linux-soc-root.c  |  6 ++---
d5c737
 src/linux-virtblk.c   |  5 +++--
d5c737
 src/linux.c           | 27 ++++++++++++++---------
d5c737
 17 files changed, 125 insertions(+), 89 deletions(-)
d5c737
d5c737
diff --git a/src/dp-acpi.c b/src/dp-acpi.c
d5c737
index 02ec70eec7a..4845410c2cf 100644
d5c737
--- a/src/dp-acpi.c
d5c737
+++ b/src/dp-acpi.c
d5c737
@@ -52,9 +52,9 @@ _format_acpi_hid_ex(unsigned char *buf, size_t size,
d5c737
 {
d5c737
 	ssize_t off = 0;
d5c737
 
d5c737
-	debug("hid:0x%08x hidstr:\"%s\"", dp->acpi_hid_ex.hid, hidstr);
d5c737
-	debug("cid:0x%08x cidstr:\"%s\"", dp->acpi_hid_ex.cid, cidstr);
d5c737
-	debug("uid:0x%08x uidstr:\"%s\"", dp->acpi_hid_ex.uid, uidstr);
d5c737
+	debug("hid:0x%08x hidstr:'%s'", dp->acpi_hid_ex.hid, hidstr);
d5c737
+	debug("cid:0x%08x cidstr:'%s'", dp->acpi_hid_ex.cid, cidstr);
d5c737
+	debug("uid:0x%08x uidstr:'%s'", dp->acpi_hid_ex.uid, uidstr);
d5c737
 
d5c737
 	if (!hidstr && !cidstr && (uidstr || dp->acpi_hid_ex.uid)) {
d5c737
 		format(buf, size, off, "AcpiExp",
d5c737
diff --git a/src/linux-acpi-root.c b/src/linux-acpi-root.c
d5c737
index 5ed4d7f5b86..57a648981b3 100644
d5c737
--- a/src/linux-acpi-root.c
d5c737
+++ b/src/linux-acpi-root.c
d5c737
@@ -44,7 +44,7 @@ static ssize_t
d5c737
 parse_acpi_root(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 {
d5c737
 	int rc;
d5c737
-	int pos = 0;
d5c737
+	int pos = -1;
d5c737
 	uint16_t pad0;
d5c737
 	uint8_t pad1;
d5c737
 	char *acpi_header = NULL;
d5c737
@@ -62,7 +62,7 @@ parse_acpi_root(struct device *dev, const char *current, const char *root UNUSED
d5c737
 	 * side in sscanf.
d5c737
 	 */
d5c737
 	rc = sscanf(devpart, "../../devices/platform/%n", &pos;;
d5c737
-	debug("devpart:\"%s\" rc:%d pos:%d", devpart, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d", devpart, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	if (rc != 0 || pos < 1)
d5c737
 		return 0;
d5c737
@@ -94,16 +94,16 @@ parse_acpi_root(struct device *dev, const char *current, const char *root UNUSED
d5c737
 		return -1;
d5c737
 	}
d5c737
 	dev->acpi_root.acpi_hid_str[pos] = 0;
d5c737
-	debug("acpi_hid_str:\"%s\"", dev->acpi_root.acpi_hid_str);
d5c737
+	debug("acpi_hid_str:'%s'", dev->acpi_root.acpi_hid_str);
d5c737
 
d5c737
 	pos -= 4;
d5c737
-	debug("devpart:\"%s\" rc:%d pos:%d", devpart, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d", devpart, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	acpi_header = strndupa(devpart, pos);
d5c737
 	if (!acpi_header)
d5c737
 		return 0;
d5c737
 	acpi_header[pos] = 0;
d5c737
-	debug("devpart:\"%s\" acpi_header:\"%s\"", devpart, acpi_header);
d5c737
+	debug("current:'%s' acpi_header:'%s'", devpart, acpi_header);
d5c737
 	devpart += pos;
d5c737
 
d5c737
 	/*
d5c737
@@ -114,7 +114,7 @@ parse_acpi_root(struct device *dev, const char *current, const char *root UNUSED
d5c737
 		efi_error("Could not parse ACPI path \"%s\"", devpart);
d5c737
 		return 0;
d5c737
 	}
d5c737
-	debug("devpart:\"%s\" parsed:%04hx:%02hhx pos:%d rc:%d",
d5c737
+	debug("current:'%s' parsed:%04hx:%02hhx pos:%d rc:%d",
d5c737
 	      devpart, pad0, pad1, pos, rc);
d5c737
 	dbgmk("         ", pos);
d5c737
 
d5c737
@@ -134,12 +134,14 @@ parse_acpi_root(struct device *dev, const char *current, const char *root UNUSED
d5c737
 		efi_error("Could not parse hid/uid");
d5c737
 		return rc;
d5c737
 	}
d5c737
-	debug("Parsed HID:0x%08x UID:0x%"PRIx64" uidstr:\"%s\" path:\"%s\"",
d5c737
+	debug("Parsed HID:0x%08x UID:0x%"PRIx64" uidstr:'%s' path:'%s'",
d5c737
 	      dev->acpi_root.acpi_hid, dev->acpi_root.acpi_uid,
d5c737
 	      dev->acpi_root.acpi_uid_str,
d5c737
 	      dev->acpi_root.acpi_cid_str);
d5c737
 
d5c737
-	return devpart - current;
d5c737
+	size_t sz = devpart - current;
d5c737
+	debug("current:'%s' sz:%zd", devpart, sz);
d5c737
+	return sz;
d5c737
 }
d5c737
 
d5c737
 static ssize_t
d5c737
@@ -151,7 +153,7 @@ dp_create_acpi_root(struct device *dev,
d5c737
 	debug("entry buf:%p size:%zd off:%zd", buf, size, off);
d5c737
 
d5c737
 	if (dev->acpi_root.acpi_uid_str || dev->acpi_root.acpi_cid_str) {
d5c737
-		debug("creating acpi_hid_ex dp hid:0x%08x uid:0x%"PRIx64" uidstr:\"%s\" cidstr:\"%s\"",
d5c737
+		debug("creating acpi_hid_ex dp hid:0x%08x uid:0x%"PRIx64" uidstr:'%s' cidstr:'%s'",
d5c737
 		      dev->acpi_root.acpi_hid, dev->acpi_root.acpi_uid,
d5c737
 		      dev->acpi_root.acpi_uid_str, dev->acpi_root.acpi_cid_str);
d5c737
 		new = efidp_make_acpi_hid_ex(buf + off, size ? size - off : 0,
d5c737
diff --git a/src/linux-acpi.c b/src/linux-acpi.c
d5c737
index 919f4654ae3..70161ca7b9e 100644
d5c737
--- a/src/linux-acpi.c
d5c737
+++ b/src/linux-acpi.c
d5c737
@@ -54,7 +54,7 @@ parse_acpi_hid_uid(struct device *dev, const char *fmt, ...)
d5c737
 		if (l > 1) {
d5c737
 			fbuf[l-1] = 0;
d5c737
 			dev->acpi_root.acpi_cid_str = strdup(fbuf);
d5c737
-			debug("Setting ACPI root path to \"%s\"", fbuf);
d5c737
+			debug("Setting ACPI root path to '%s'", fbuf);
d5c737
 		}
d5c737
 	}
d5c737
 
d5c737
@@ -111,7 +111,7 @@ hid_err:
d5c737
 			}
d5c737
 		}
d5c737
 	}
d5c737
-	debug("acpi root UID:0x%"PRIx64" uidstr:\"%s\"",
d5c737
+	debug("acpi root UID:0x%"PRIx64" uidstr:'%s'",
d5c737
 	      dev->acpi_root.acpi_uid, dev->acpi_root.acpi_uid_str);
d5c737
 
d5c737
 	errno = 0;
d5c737
diff --git a/src/linux-ata.c b/src/linux-ata.c
d5c737
index b6a7c2dcf8a..7bb23da60f5 100644
d5c737
--- a/src/linux-ata.c
d5c737
+++ b/src/linux-ata.c
d5c737
@@ -126,9 +126,9 @@ parse_ata(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	dev->ata_info.scsi_lun = scsi_lun;
d5c737
 
d5c737
 	char *block = strstr(current, "/block/");
d5c737
-	if (!block)
d5c737
-		return -1;
d5c737
-	return block + 1 - current;
d5c737
+	ssize_t sz = block ? block + 1 - current : -1;
d5c737
+	debug("current:'%s' sz:%zd", current, sz);
d5c737
+	return sz;
d5c737
 }
d5c737
 
d5c737
 static ssize_t
d5c737
diff --git a/src/linux-emmc.c b/src/linux-emmc.c
d5c737
index 59ef8e7524d..74cf54aa336 100644
d5c737
--- a/src/linux-emmc.c
d5c737
+++ b/src/linux-emmc.c
d5c737
@@ -49,7 +49,7 @@ parse_emmc(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 {
d5c737
 	int rc;
d5c737
 	int32_t tosser0, tosser1, tosser2, tosser3, slot_id, partition;
d5c737
-	int pos0 = 0, pos1 = 0;
d5c737
+	int pos0 = -1, pos1 = -1;
d5c737
 
d5c737
 	debug("entry");
d5c737
 
d5c737
@@ -57,7 +57,7 @@ parse_emmc(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	rc = sscanf(current, "mmc_host/mmc%d/mmc%d:%d/block/mmcblk%d%n/mmcblk%dp%d%n",
d5c737
 	            &tosser0, &tosser1, &tosser2, &slot_id,
d5c737
 	            &pos0, &tosser3, &partition, &pos1);
d5c737
-	debug("current:\"%s\" rc:%d pos0:%d pos1:%d\n", current, rc, pos0, pos1);
d5c737
+	debug("current:'%s' rc:%d pos0:%d pos1:%d\n", current, rc, pos0, pos1);
d5c737
 	dbgmk("         ", pos0, pos1);
d5c737
 	/*
d5c737
 	 * If it isn't of that form, it's not one of our emmc devices.
d5c737
@@ -75,6 +75,7 @@ parse_emmc(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	        pos0 = pos1;
d5c737
 	}
d5c737
 
d5c737
+	debug("current:'%s' sz:%d\n", current, pos0);
d5c737
 	return pos0;
d5c737
 }
d5c737
 
d5c737
diff --git a/src/linux-i2o.c b/src/linux-i2o.c
d5c737
index ebd92aeeb53..76b3d4d5d39 100644
d5c737
--- a/src/linux-i2o.c
d5c737
+++ b/src/linux-i2o.c
d5c737
@@ -33,7 +33,7 @@
d5c737
  * ... probably doesn't work.
d5c737
  */
d5c737
 static ssize_t
d5c737
-parse_i2o(struct device *dev, const char *current UNUSED, const char *root UNUSED)
d5c737
+parse_i2o(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 {
d5c737
 	debug("entry");
d5c737
 	/* I2O disks can have up to 16 partitions, or 4 bits worth. */
d5c737
@@ -47,9 +47,9 @@ parse_i2o(struct device *dev, const char *current UNUSED, const char *root UNUSE
d5c737
 	}
d5c737
 
d5c737
 	char *block = strstr(current, "/block/");
d5c737
-	if (!block)
d5c737
-	        return -1;
d5c737
-	return block + 1 - current;
d5c737
+	ssize_t sz = block ? block + 1 - current : -1;
d5c737
+	debug("current:'%s' sz:%zd", current, sz);
d5c737
+	return sz;
d5c737
 }
d5c737
 
d5c737
 enum interface_type i2o_iftypes[] = { i2o, unknown };
d5c737
diff --git a/src/linux-md.c b/src/linux-md.c
d5c737
index 1d7bd3195c0..ded7cbd169c 100644
d5c737
--- a/src/linux-md.c
d5c737
+++ b/src/linux-md.c
d5c737
@@ -50,7 +50,7 @@ parse_md(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	debug("searching for mdM/mdMpN");
d5c737
 	rc = sscanf(current, "md%d/%nmd%dp%d%n",
d5c737
 	            &md, &pos0, &tosser0, &part, &pos1);
d5c737
-	debug("current:\"%s\" rc:%d pos0:%d pos1:%d\n", current, rc, pos0, pos1);
d5c737
+	debug("current:'%s' rc:%d pos0:%d pos1:%d\n", current, rc, pos0, pos1);
d5c737
 	dbgmk("         ", pos0, pos1);
d5c737
 	/*
d5c737
 	 * If it isn't of that form, it's not one of our partitioned md devices.
d5c737
@@ -63,10 +63,10 @@ parse_md(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	if (dev->part == -1)
d5c737
 	        dev->part = part;
d5c737
 
d5c737
+	debug("current:'%s' sz:%d\n", current, pos1);
d5c737
 	return pos1;
d5c737
 }
d5c737
 
d5c737
-
d5c737
 static char *
d5c737
 make_part_name(struct device *dev)
d5c737
 {
d5c737
diff --git a/src/linux-nvme.c b/src/linux-nvme.c
d5c737
index 0b4eae74f79..7b18d7990ac 100644
d5c737
--- a/src/linux-nvme.c
d5c737
+++ b/src/linux-nvme.c
d5c737
@@ -53,6 +53,7 @@ parse_nvme(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	int rc;
d5c737
 	int32_t tosser0, tosser1, tosser2, ctrl_id, ns_id, partition;
d5c737
 	uint8_t *filebuf = NULL;
d5c737
+	ssize_t sz = 0;
d5c737
 	int pos0 = 0, pos1 = 0;
d5c737
 
d5c737
 	debug("entry");
d5c737
@@ -61,7 +62,7 @@ parse_nvme(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	rc = sscanf(current, "nvme/nvme%d/nvme%dn%d%n/nvme%dn%dp%d%n",
d5c737
 	            &tosser0, &ctrl_id, &ns_id, &pos0,
d5c737
 	            &tosser1, &tosser2, &partition, &pos1);
d5c737
-	debug("current:\"%s\" rc:%d pos0:%d pos1:%d\n", current, rc, pos0, pos1);
d5c737
+	debug("current:'%s' rc:%d pos0:%d pos1:%d\n", current, rc, pos0, pos1);
d5c737
 	dbgmk("         ", pos0, pos1);
d5c737
 	/*
d5c737
 	 * If it isn't of that form, it's not one of our nvme devices.
d5c737
@@ -81,6 +82,8 @@ parse_nvme(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	        pos0 = pos1;
d5c737
 	}
d5c737
 
d5c737
+	sz += pos0;
d5c737
+
d5c737
 	/*
d5c737
 	 * now fish the eui out of sysfs is there is one...
d5c737
 	 */
d5c737
@@ -111,7 +114,8 @@ parse_nvme(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	        memcpy(dev->nvme_info.eui, eui, sizeof(eui));
d5c737
 	}
d5c737
 
d5c737
-	return pos0;
d5c737
+	debug("current:'%s' sz:%zd\n", current, sz);
d5c737
+	return sz;
d5c737
 }
d5c737
 
d5c737
 static ssize_t
d5c737
diff --git a/src/linux-pci-root.c b/src/linux-pci-root.c
d5c737
index c84b639cbfe..c7e279118f5 100644
d5c737
--- a/src/linux-pci-root.c
d5c737
+++ b/src/linux-pci-root.c
d5c737
@@ -44,7 +44,7 @@ static ssize_t
d5c737
 parse_pci_root(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 {
d5c737
 	int rc;
d5c737
-	int pos = 0;
d5c737
+	int pos0 = -1, pos1 = -1;
d5c737
 	uint16_t root_domain;
d5c737
 	uint8_t root_bus;
d5c737
 	const char *devpart = current;
d5c737
@@ -56,15 +56,16 @@ parse_pci_root(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	 * pci0000:00/
d5c737
 	 *    ^d   ^p
d5c737
 	 */
d5c737
-	rc = sscanf(devpart, "../../devices/pci%hx:%hhx/%n", &root_domain, &root_bus, &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d", devpart, rc, pos);
d5c737
-	dbgmk("         ", pos);
d5c737
+	rc = sscanf(devpart, "%n../../devices/pci%hx:%hhx/%n", &pos0, &root_domain, &root_bus, &pos1);
d5c737
+	debug("current:'%s' rc:%d pos0:%d pos1:%d", devpart, rc, pos0, pos1);
d5c737
+	dbgmk("         ", pos0, pos1);
d5c737
+
d5c737
 	/*
d5c737
 	 * If we can't find that, it's not a PCI device.
d5c737
 	 */
d5c737
 	if (rc != 2)
d5c737
 	        return 0;
d5c737
-	devpart += pos;
d5c737
+	devpart += pos1;
d5c737
 
d5c737
 	dev->pci_root.pci_domain = root_domain;
d5c737
 	dev->pci_root.pci_bus = root_bus;
d5c737
@@ -75,7 +76,8 @@ parse_pci_root(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	        return -1;
d5c737
 
d5c737
 	errno = 0;
d5c737
-	return devpart - current;
d5c737
+	debug("current:'%s' sz:%d\n", devpart, pos1);
d5c737
+	return pos1;
d5c737
 }
d5c737
 
d5c737
 static ssize_t
d5c737
@@ -86,7 +88,7 @@ dp_create_pci_root(struct device *dev UNUSED,
d5c737
 	debug("entry buf:%p size:%zd off:%zd", buf, size, off);
d5c737
 	debug("returning 0");
d5c737
 	if (dev->acpi_root.acpi_uid_str) {
d5c737
-	        debug("creating acpi_hid_ex dp hid:0x%08x uid:\"%s\"",
d5c737
+	        debug("creating acpi_hid_ex dp hid:0x%08x uid:'%s'",
d5c737
 	              dev->acpi_root.acpi_hid,
d5c737
 	              dev->acpi_root.acpi_uid_str);
d5c737
 	        new = efidp_make_acpi_hid_ex(buf + off, size ? size - off : 0,
d5c737
diff --git a/src/linux-pci.c b/src/linux-pci.c
d5c737
index 0de330db628..a3a0dc28afd 100644
d5c737
--- a/src/linux-pci.c
d5c737
+++ b/src/linux-pci.c
d5c737
@@ -46,7 +46,7 @@ static ssize_t
d5c737
 parse_pci(struct device *dev, const char *current, const char *root)
d5c737
 {
d5c737
 	int rc;
d5c737
-	int pos = 0;
d5c737
+	int pos0 = -1, pos1 = -1;
d5c737
 	const char *devpart = current;
d5c737
 
d5c737
 	debug("entry");
d5c737
@@ -62,16 +62,15 @@ parse_pci(struct device *dev, const char *current, const char *root)
d5c737
 	        unsigned int i = dev->n_pci_devs;
d5c737
 	        struct stat statbuf;
d5c737
 
d5c737
-	        debug("devpart is \"%s\"", devpart);
d5c737
-	        pos = 0;
d5c737
+	        pos0 = pos1 = -1;
d5c737
 	        debug("searching for 0000:00:00.0/");
d5c737
-	        rc = sscanf(devpart, "%hx:%hhx:%hhx.%hhx/%n",
d5c737
-	                    &domain, &bus, &device, &function, &pos;;
d5c737
-	        debug("current:\"%s\" rc:%d pos:%d", devpart, rc, pos);
d5c737
-		dbgmk("         ", pos);
d5c737
+	        rc = sscanf(devpart, "%n%hx:%hhx:%hhx.%hhx/%n",
d5c737
+	                    &pos0, &domain, &bus, &device, &function, &pos1);
d5c737
+	        debug("current:'%s' rc:%d pos0:%d pos1:%d", devpart, rc, pos0, pos1);
d5c737
+		dbgmk("         ", pos0, pos1);
d5c737
 	        if (rc != 4)
d5c737
 	                break;
d5c737
-	        devpart += pos;
d5c737
+	        devpart += pos1;
d5c737
 
d5c737
 	        debug("found pci domain %04hx:%02hhx:%02hhx.%02hhx",
d5c737
 	              domain, bus, device, function);
d5c737
@@ -115,7 +114,7 @@ parse_pci(struct device *dev, const char *current, const char *root)
d5c737
 	        dev->n_pci_devs += 1;
d5c737
 	}
d5c737
 
d5c737
-	debug("next:\"%s\"", devpart);
d5c737
+	debug("current:'%s' sz:%zd\n", devpart, devpart - current);
d5c737
 	return devpart - current;
d5c737
 }
d5c737
 
d5c737
diff --git a/src/linux-pmem.c b/src/linux-pmem.c
d5c737
index 18eb7dce5e3..49db24560fa 100644
d5c737
--- a/src/linux-pmem.c
d5c737
+++ b/src/linux-pmem.c
d5c737
@@ -75,7 +75,7 @@ parse_pmem(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	uint8_t *filebuf = NULL;
d5c737
 	uint8_t system, sysbus, acpi_id;
d5c737
 	uint16_t pnp_id;
d5c737
-	int ndbus, region, btt_region_id, btt_id, rc, pos;
d5c737
+	int ndbus, region, btt_region_id, btt_id, rc, pos0, pos1;
d5c737
 	char *namespace = NULL;
d5c737
 
d5c737
 	debug("entry");
d5c737
@@ -101,14 +101,16 @@ parse_pmem(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	 *
d5c737
 	 * 259:0 -> ../../devices/LNXSYSTM:00/LNXSYBUS:00/ACPI0012:00/ndbus0/region12/btt12.1/block/pmem12s
d5c737
 	 */
d5c737
+	pos0 = pos1 = -1;
d5c737
 	rc = sscanf(current,
d5c737
-	            "../../devices/LNXSYSTM:%hhx/LNXSYBUS:%hhx/ACPI%hx:%hhx/ndbus%d/region%d/btt%d.%d/%n",
d5c737
-	            &system, &sysbus, &pnp_id, &acpi_id, &ndbus, &region,
d5c737
-	            &btt_region_id, &btt_id, &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d", current, rc, pos);
d5c737
-	dbgmk("         ", pos);
d5c737
+	            "../../devices/%nLNXSYSTM:%hhx/LNXSYBUS:%hhx/ACPI%hx:%hhx/ndbus%d/region%d/btt%d.%d/%n",
d5c737
+	            &pos0, &system, &sysbus, &pnp_id, &acpi_id, &ndbus,
d5c737
+		    &region, &btt_region_id, &btt_id, &pos1);
d5c737
+	debug("current:'%s' rc:%d pos0:%d pos1:%d", current, rc, pos0, pos1);
d5c737
+	dbgmk("         ", pos0, pos1);
d5c737
 	if (rc < 8)
d5c737
 	        return 0;
d5c737
+	current += pos1;
d5c737
 
d5c737
 	/*
d5c737
 	 * but the UUID we really do need to have.
d5c737
@@ -123,7 +125,7 @@ parse_pmem(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	        return -1;
d5c737
 
d5c737
 	filebuf = NULL;
d5c737
-	debug("nvdimm namespace is \"%s\"", namespace);
d5c737
+	debug("nvdimm namespace is '%s'", namespace);
d5c737
 	rc = read_sysfs_file(&filebuf, "bus/nd/devices/%s/uuid", namespace);
d5c737
 	free(namespace);
d5c737
 	if (rc < 0 || filebuf == NULL)
d5c737
@@ -158,7 +160,8 @@ parse_pmem(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 
d5c737
 	dev->interface_type = nd_pmem;
d5c737
 
d5c737
-	return pos;
d5c737
+	debug("current:'%s' sz:%d\n", current, pos1);
d5c737
+	return pos1;
d5c737
 }
d5c737
 
d5c737
 static ssize_t
d5c737
diff --git a/src/linux-sas.c b/src/linux-sas.c
d5c737
index f985deeaa3f..d14fcfb231a 100644
d5c737
--- a/src/linux-sas.c
d5c737
+++ b/src/linux-sas.c
d5c737
@@ -172,6 +172,7 @@ parse_sas(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	 */
d5c737
 	if (pos < 0)
d5c737
 	        return 0;
d5c737
+	current += pos;
d5c737
 
d5c737
 	/*
d5c737
 	 * Make sure it has the actual /SAS/ bits before we continue
d5c737
@@ -236,6 +237,8 @@ parse_sas(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	dev->scsi_info.scsi_target = scsi_target;
d5c737
 	dev->scsi_info.scsi_lun = scsi_lun;
d5c737
 	dev->interface_type = sas;
d5c737
+
d5c737
+	debug("current:'%s' sz:%zd\n", current, pos);
d5c737
 	return pos;
d5c737
 }
d5c737
 
d5c737
diff --git a/src/linux-sata.c b/src/linux-sata.c
d5c737
index b0caa3fa401..4f4e983568e 100644
d5c737
--- a/src/linux-sata.c
d5c737
+++ b/src/linux-sata.c
d5c737
@@ -161,7 +161,7 @@ parse_sata(struct device *dev, const char *devlink, const char *root UNUSED)
d5c737
 	 */
d5c737
 	debug("searching for ata1/");
d5c737
 	rc = sscanf(current, "ata%"PRIu32"/%n", &print_id, &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d\n", current, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d\n", current, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	/*
d5c737
 	 * If we don't find this one, it isn't an ata device, so return 0 not
d5c737
@@ -175,7 +175,7 @@ parse_sata(struct device *dev, const char *devlink, const char *root UNUSED)
d5c737
 
d5c737
 	debug("searching for host0/");
d5c737
 	rc = sscanf(current, "host%"PRIu32"/%n", &scsi_bus, &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d\n", current, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d\n", current, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	if (rc != 1)
d5c737
 	        return -1;
d5c737
@@ -185,7 +185,7 @@ parse_sata(struct device *dev, const char *devlink, const char *root UNUSED)
d5c737
 	debug("searching for target0:0:0:0/");
d5c737
 	rc = sscanf(current, "target%"PRIu32":%"PRIu32":%"PRIu64"/%n",
d5c737
 	            &scsi_device, &scsi_target, &scsi_lun, &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d\n", current, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d\n", current, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	if (rc != 3)
d5c737
 	        return -1;
d5c737
@@ -195,7 +195,7 @@ parse_sata(struct device *dev, const char *devlink, const char *root UNUSED)
d5c737
 	debug("searching for 0:0:0:0/");
d5c737
 	rc = sscanf(current, "%"PRIu32":%"PRIu32":%"PRIu32":%"PRIu64"/%n",
d5c737
 	            &tosser0, &tosser1, &tosser2, &tosser3, &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d\n", current, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d\n", current, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	if (rc != 4)
d5c737
 	        return -1;
d5c737
@@ -213,6 +213,7 @@ parse_sata(struct device *dev, const char *devlink, const char *root UNUSED)
d5c737
 	if (dev->interface_type == unknown)
d5c737
 	        dev->interface_type = sata;
d5c737
 
d5c737
+	debug("current:'%s' sz:%zd\n", current, current - devlink);
d5c737
 	return current - devlink;
d5c737
 }
d5c737
 
d5c737
diff --git a/src/linux-scsi.c b/src/linux-scsi.c
d5c737
index 96fde7e15fa..6b92908d6bc 100644
d5c737
--- a/src/linux-scsi.c
d5c737
+++ b/src/linux-scsi.c
d5c737
@@ -43,7 +43,7 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	        uint32_t *remote_target_id)
d5c737
 {
d5c737
 	int rc;
d5c737
-	int sz = 0;
d5c737
+	ssize_t sz = 0;
d5c737
 	int pos0 = 0, pos1 = 0;
d5c737
 
d5c737
 	debug("entry");
d5c737
@@ -100,10 +100,11 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	 */
d5c737
 	debug("searching for host4/");
d5c737
 	rc = sscanf(current, "host%d/%n", scsi_host, &pos0);
d5c737
-	debug("current:\"%s\" rc:%d pos0:%d\n", current+sz, rc, pos0);
d5c737
+	debug("current:'%s' rc:%d pos0:%d\n", current, rc, pos0);
d5c737
 	dbgmk("         ", pos0);
d5c737
 	if (rc != 1)
d5c737
 	        return -1;
d5c737
+	current += pos0;
d5c737
 	sz += pos0;
d5c737
 	pos0 = 0;
d5c737
 
d5c737
@@ -116,11 +117,12 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	 * port-2:0:2/end_device-2:0:2/target2:0:0/2:0:0:0/block/sda/sda1
d5c737
 	 */
d5c737
 	debug("searching for port-4:0 or port-4:0:0");
d5c737
-	rc = sscanf(current+sz, "port-%d:%d%n:%d%n", &tosser0,
d5c737
+	rc = sscanf(current, "port-%d:%d%n:%d%n", &tosser0,
d5c737
 	            &tosser1, &pos0, &tosser2, &pos1);
d5c737
-	debug("current:\"%s\" rc:%d pos0:%d pos1:%d\n", current+sz, rc, pos0, pos1);
d5c737
+	debug("current:'%s' rc:%d pos0:%d pos1:%d\n", current, rc, pos0, pos1);
d5c737
 	dbgmk("         ", pos0, pos1);
d5c737
 	if (rc == 2 || rc == 3) {
d5c737
+		current += pos0;
d5c737
 	        sz += pos0;
d5c737
 	        pos0 = 0;
d5c737
 	        if (local_port_id && rc == 2)
d5c737
@@ -128,8 +130,10 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	        if (remote_port_id && rc == 3)
d5c737
 	                *remote_port_id = tosser2;
d5c737
 
d5c737
-	        if (current[sz] == '/')
d5c737
+	        if (current[0] == '/') {
d5c737
+			current += 1;
d5c737
 	                sz += 1;
d5c737
+		}
d5c737
 
d5c737
 	        /*
d5c737
 	         * We might have this next:
d5c737
@@ -143,8 +147,8 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	         * to get past it.
d5c737
 	         */
d5c737
 	        debug("searching for expander-4:0/");
d5c737
-	        rc = sscanf(current+sz, "expander-%d:%d/%n", &tosser0, &tosser1, &pos0);
d5c737
-	        debug("current:\"%s\" rc:%d pos0:%d\n", current+sz, rc, pos0);
d5c737
+	        rc = sscanf(current, "expander-%d:%d/%n", &tosser0, &tosser1, &pos0);
d5c737
+	        debug("current:'%s' rc:%d pos0:%d\n", current, rc, pos0);
d5c737
 		dbgmk("         ", pos0);
d5c737
 	        if (rc == 2) {
d5c737
 	                if (!remote_target_id) {
d5c737
@@ -152,6 +156,7 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	                        return -1;
d5c737
 	                }
d5c737
 	                *remote_target_id = tosser1;
d5c737
+			current += pos0;
d5c737
 	                sz += pos0;
d5c737
 	                pos0 = 0;
d5c737
 
d5c737
@@ -159,13 +164,14 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	                 * if we have that, we should have a 3-part port next
d5c737
 	                 */
d5c737
 	                debug("searching for port-2:0:2/");
d5c737
-	                rc = sscanf(current+sz, "port-%d:%d:%d/%n", &tosser0, &tosser1, &tosser2, &pos0);
d5c737
-	                debug("current:\"%s\" rc:%d pos0:%d\n", current+sz, rc, pos0);
d5c737
+	                rc = sscanf(current, "port-%d:%d:%d/%n", &tosser0, &tosser1, &tosser2, &pos0);
d5c737
+	                debug("current:'%s' rc:%d pos0:%d\n", current, rc, pos0);
d5c737
 			dbgmk("         ", pos0);
d5c737
 	                if (rc != 3) {
d5c737
 	                        efi_error("Couldn't parse port expander port string");
d5c737
 	                        return -1;
d5c737
 	                }
d5c737
+			current += pos0;
d5c737
 	                sz += pos0;
d5c737
 	        }
d5c737
 	        pos0 = 0;
d5c737
@@ -177,13 +183,13 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	         * but we don't care for now about any of them anyway.
d5c737
 	         */
d5c737
 	        debug("searching for end_device-4:0/ or end_device-4:0:0/");
d5c737
-	        rc = sscanf(current + sz, "end_device-%d:%d%n", &tosser0, &tosser1, &pos0);
d5c737
-	        debug("current:\"%s\" rc:%d pos0:%d\n", current+sz, rc, pos0);
d5c737
+	        rc = sscanf(current, "end_device-%d:%d%n", &tosser0, &tosser1, &pos0);
d5c737
+	        debug("current:'%s' rc:%d pos0:%d\n", current, rc, pos0);
d5c737
 	        if (rc != 2)
d5c737
 	                return -1;
d5c737
 
d5c737
 	        pos1 = 0;
d5c737
-	        rc = sscanf(current + sz + pos0, ":%d%n", &tosser2, &pos1);
d5c737
+	        rc = sscanf(current + pos0, ":%d%n", &tosser2, &pos1);
d5c737
 	        if (rc != 0 && rc != 1)
d5c737
 	                return -1;
d5c737
 		dbgmk("         ", pos0, pos0+pos1);
d5c737
@@ -191,11 +197,14 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	                *remote_port_id = tosser2;
d5c737
 	        if (local_port_id && rc == 0)
d5c737
 	                *local_port_id = tosser1;
d5c737
+		current += pos0 + pos1;
d5c737
 	        sz += pos0 + pos1;
d5c737
 	        pos0 = pos1 = 0;
d5c737
 
d5c737
-	        if (current[sz] == '/')
d5c737
+	        if (current[0] == '/') {
d5c737
+			current += sz;
d5c737
 	                sz += 1;
d5c737
+		}
d5c737
 	} else if (rc != 0) {
d5c737
 	        return -1;
d5c737
 	}
d5c737
@@ -205,12 +214,13 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	 */
d5c737
 	uint64_t tosser3;
d5c737
 	debug("searching for target4:0:0/");
d5c737
-	rc = sscanf(current + sz, "target%d:%d:%"PRIu64"/%n", &tosser0, &tosser1,
d5c737
+	rc = sscanf(current, "target%d:%d:%"PRIu64"/%n", &tosser0, &tosser1,
d5c737
 	            &tosser3, &pos0);
d5c737
-	debug("current:\"%s\" rc:%d pos0:%d\n", current+sz, rc, pos0);
d5c737
+	debug("current:'%s' rc:%d pos0:%d\n", current, rc, pos0);
d5c737
 	dbgmk("         ", pos0);
d5c737
 	if (rc != 3)
d5c737
 	        return -1;
d5c737
+	current += pos0;
d5c737
 	sz += pos0;
d5c737
 	pos0 = 0;
d5c737
 
d5c737
@@ -218,15 +228,16 @@ parse_scsi_link(const char *current, uint32_t *scsi_host,
d5c737
 	 * %d:%d:%d:%llu/
d5c737
 	 */
d5c737
 	debug("searching for 4:0:0:0/");
d5c737
-	rc = sscanf(current + sz, "%d:%d:%d:%"PRIu64"/%n",
d5c737
+	rc = sscanf(current, "%d:%d:%d:%"PRIu64"/%n",
d5c737
 	            scsi_bus, scsi_device, scsi_target, scsi_lun, &pos0);
d5c737
-	debug("current:\"%s\" rc:%d pos0:%d\n", current+sz, rc, pos0);
d5c737
+	debug("current:'%s' rc:%d pos0:%d\n", current, rc, pos0);
d5c737
 	dbgmk("         ", pos0);
d5c737
 	if (rc != 4)
d5c737
 	        return -1;
d5c737
+	current += pos0;
d5c737
 	sz += pos0;
d5c737
 
d5c737
-	debug("returning %d", sz);
d5c737
+	debug("current:'%s' sz:%zd\n", current, sz);
d5c737
 	return sz;
d5c737
 }
d5c737
 
d5c737
@@ -248,7 +259,7 @@ parse_scsi(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	            &dev->scsi_info.scsi_target,
d5c737
 	            &dev->scsi_info.scsi_lun,
d5c737
 	            &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d\n", dev->device, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d\n", dev->device, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	if (rc != 4)
d5c737
 	        return 0;
d5c737
@@ -259,6 +270,7 @@ parse_scsi(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	                      NULL, NULL, NULL);
d5c737
 	if (sz < 0)
d5c737
 	        return 0;
d5c737
+	current += sz;
d5c737
 
d5c737
 	/*
d5c737
 	 * SCSI disks can have up to 16 partitions, or 4 bits worth
d5c737
@@ -281,6 +293,7 @@ parse_scsi(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 	        return -1;
d5c737
 	}
d5c737
 
d5c737
+	debug("current:'%s' sz:%zd\n", current, sz);
d5c737
 	return sz;
d5c737
 }
d5c737
 
d5c737
diff --git a/src/linux-soc-root.c b/src/linux-soc-root.c
d5c737
index c932670ef15..9c9e9573dcd 100644
d5c737
--- a/src/linux-soc-root.c
d5c737
+++ b/src/linux-soc-root.c
d5c737
@@ -49,12 +49,12 @@ parse_soc_root(struct device *dev UNUSED, const char *current, const char *root
d5c737
 	rc = sscanf(devpart, "../../devices/platform/soc/%*[^/]/%n", &pos;;
d5c737
 	if (rc != 0)
d5c737
 	        return 0;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d", current, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d", current, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	devpart += pos;
d5c737
-	debug("new position is \"%s\"", devpart);
d5c737
 
d5c737
-	return devpart - current;
d5c737
+	debug("current:'%s' sz:%d\n", devpart, pos);
d5c737
+	return pos;
d5c737
 }
d5c737
 
d5c737
 enum interface_type soc_root_iftypes[] = { soc_root, unknown };
d5c737
diff --git a/src/linux-virtblk.c b/src/linux-virtblk.c
d5c737
index 7517db55555..df14673dac8 100644
d5c737
--- a/src/linux-virtblk.c
d5c737
+++ b/src/linux-virtblk.c
d5c737
@@ -48,14 +48,14 @@ static ssize_t
d5c737
 parse_virtblk(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 {
d5c737
 	uint32_t tosser;
d5c737
-	int pos = 0;
d5c737
+	int pos = -1;
d5c737
 	int rc;
d5c737
 
d5c737
 	debug("entry");
d5c737
 
d5c737
 	debug("searching for virtio0/");
d5c737
 	rc = sscanf(current, "virtio%x/%n", &tosser, &pos;;
d5c737
-	debug("current:\"%s\" rc:%d pos:%d\n", current, rc, pos);
d5c737
+	debug("current:'%s' rc:%d pos:%d\n", current, rc, pos);
d5c737
 	dbgmk("         ", pos);
d5c737
 	/*
d5c737
 	 * If we couldn't find virtioX/ then it isn't a virtio device.
d5c737
@@ -65,6 +65,7 @@ parse_virtblk(struct device *dev, const char *current, const char *root UNUSED)
d5c737
 
d5c737
 	dev->interface_type = virtblk;
d5c737
 
d5c737
+	debug("current:'%s' sz:%d\n", current, pos);
d5c737
 	return pos;
d5c737
 }
d5c737
 
d5c737
diff --git a/src/linux.c b/src/linux.c
d5c737
index 45b1ee2d96f..45f07d3913c 100644
d5c737
--- a/src/linux.c
d5c737
+++ b/src/linux.c
d5c737
@@ -182,10 +182,10 @@ set_disk_and_part_name(struct device *dev)
d5c737
 	errno = 0;
d5c737
 	debug("dev->disk_name:%p dev->part_name:%p", dev->disk_name, dev->part_name);
d5c737
 	debug("dev->part:%d", dev->part);
d5c737
-	debug("ultimate:\"%s\"", ultimate ? : "");
d5c737
-	debug("penultimate:\"%s\"", penultimate ? : "");
d5c737
-	debug("approximate:\"%s\"", approximate ? : "");
d5c737
-	debug("proximate:\"%s\"", proximate ? : "");
d5c737
+	debug("ultimate:'%s'", ultimate ? : "");
d5c737
+	debug("penultimate:'%s'", penultimate ? : "");
d5c737
+	debug("approximate:'%s'", approximate ? : "");
d5c737
+	debug("proximate:'%s'", proximate ? : "");
d5c737
 
d5c737
 	if (ultimate && penultimate &&
d5c737
 	    ((proximate && !strcmp(proximate, "nvme")) ||
d5c737
@@ -455,7 +455,11 @@ struct device HIDDEN
d5c737
 	                efi_error("parsing %s failed", probe->name);
d5c737
 	                goto err;
d5c737
 	        } else if (pos > 0) {
d5c737
-	                debug("%s matched %s", probe->name, current);
d5c737
+			char match[pos+1];
d5c737
+
d5c737
+			strncpy(match, current, pos);
d5c737
+			match[pos] = '\0';
d5c737
+	                debug("%s matched '%s'", probe->name, match);
d5c737
 	                dev->flags |= probe->flags;
d5c737
 
d5c737
 	                if (probe->flags & DEV_PROVIDES_HD ||
d5c737
@@ -465,7 +469,10 @@ struct device HIDDEN
d5c737
 
d5c737
 	                dev->probes[n++] = dev_probes[i];
d5c737
 	                current += pos;
d5c737
-	                debug("current:%s", current);
d5c737
+			if (current[0] == '\0')
d5c737
+				debug("finished");
d5c737
+			else
d5c737
+				debug("current:'%s'", current);
d5c737
 	                last_successful_probe = i;
d5c737
 
d5c737
 	                if (!*current || !strncmp(current, "block/", 6))
d5c737
@@ -474,8 +481,8 @@ struct device HIDDEN
d5c737
 	                continue;
d5c737
 	        }
d5c737
 
d5c737
-	        debug("dev_probes[i+1]: %p dev->interface_type: %d\n",
d5c737
-	              dev_probes[i+1], dev->interface_type);
d5c737
+	        debug("dev_probes[%d]: %p dev->interface_type: %d\n",
d5c737
+	              i+1, dev_probes[i+1], dev->interface_type);
d5c737
 	        if (dev_probes[i+1] == NULL && dev->interface_type == unknown) {
d5c737
 	                pos = 0;
d5c737
 	                rc = sscanf(current, "%*[^/]/%n", &pos;;
d5c737
@@ -491,8 +498,8 @@ slash_err:
d5c737
 	                if (!current[pos])
d5c737
 	                        goto slash_err;
d5c737
 
d5c737
-	                debug("Cannot parse device link segment \"%s\"", current);
d5c737
-	                debug("Skipping to \"%s\"", current + pos);
d5c737
+	                debug("Cannot parse device link segment '%s'", current);
d5c737
+	                debug("Skipping to '%s'", current + pos);
d5c737
 	                debug("This means we can only create abbreviated paths");
d5c737
 	                dev->flags |= DEV_ABBREV_ONLY;
d5c737
 	                i = last_successful_probe;
d5c737
-- 
d5c737
2.26.2
d5c737