Oliver Neukum ef2235
From 22ff2bcec704a7a8c43a998251e0757cd2de66e1 Mon Sep 17 00:00:00 2001
Oliver Neukum ef2235
From: Heiner Kallweit <hkallweit1@gmail.com>
Oliver Neukum ef2235
Date: Sun, 8 Aug 2021 19:21:02 +0200
Oliver Neukum ef2235
Subject: [PATCH] PCI/VPD: Remove struct pci_vpd.valid member
Oliver Neukum ef2235
Git-commit: 22ff2bcec704a7a8c43a998251e0757cd2de66e1
Oliver Neukum ef2235
References: jsc#SLE-19359
Oliver Neukum ef2235
Patch-mainline: v5.15-rc1
Oliver Neukum ef2235
Oliver Neukum ef2235
Instead of having a separate flag, use vp->len != 0 as indicator that VPD
Oliver Neukum ef2235
validity has been checked.  Now vpd->len == PCI_VPD_SZ_INVALID indicates
Oliver Neukum ef2235
that VPD is invalid.
Oliver Neukum ef2235
Oliver Neukum ef2235
Link: https://lore.kernel.org/r/9f777bc7-5316-e1b8-e5d4-f9f609bdb5dd@gmail.com
Oliver Neukum ef2235
Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
Oliver Neukum ef2235
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Oliver Neukum ef2235
Signed-off-by: Oliver Neukum <oneukum@suse.com>
Oliver Neukum ef2235
---
Oliver Neukum ef2235
 drivers/pci/vpd.c | 29 ++++++++++++-----------------
Oliver Neukum ef2235
 1 file changed, 12 insertions(+), 17 deletions(-)
Oliver Neukum ef2235
Oliver Neukum ef2235
diff --git a/drivers/pci/vpd.c b/drivers/pci/vpd.c
Oliver Neukum ef2235
index e2439547a691..9d9cff5f89e2 100644
Oliver Neukum ef2235
--- a/drivers/pci/vpd.c
Oliver Neukum ef2235
+++ b/drivers/pci/vpd.c
Oliver Neukum ef2235
@@ -17,7 +17,6 @@ struct pci_vpd {
Oliver Neukum ef2235
 	struct mutex	lock;
Oliver Neukum ef2235
 	unsigned int	len;
Oliver Neukum ef2235
 	u8		cap;
Oliver Neukum ef2235
-	unsigned int	valid:1;
Oliver Neukum ef2235
 };
Oliver Neukum ef2235
 
Oliver Neukum ef2235
 static struct pci_dev *pci_get_func0_dev(struct pci_dev *dev)
Oliver Neukum ef2235
@@ -25,7 +24,8 @@ static struct pci_dev *pci_get_func0_dev(struct pci_dev *dev)
Oliver Neukum ef2235
 	return pci_get_slot(dev->bus, PCI_DEVFN(PCI_SLOT(dev->devfn), 0));
Oliver Neukum ef2235
 }
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-#define PCI_VPD_MAX_SIZE (PCI_VPD_ADDR_MASK + 1)
Oliver Neukum ef2235
+#define PCI_VPD_MAX_SIZE	(PCI_VPD_ADDR_MASK + 1)
Oliver Neukum ef2235
+#define PCI_VPD_SZ_INVALID	UINT_MAX
Oliver Neukum ef2235
 
Oliver Neukum ef2235
 /**
Oliver Neukum ef2235
  * pci_vpd_size - determine actual size of Vital Product Data
Oliver Neukum ef2235
@@ -36,6 +36,9 @@ static size_t pci_vpd_size(struct pci_dev *dev)
Oliver Neukum ef2235
 	size_t off = 0, size;
Oliver Neukum ef2235
 	unsigned char tag, header[1+2];	/* 1 byte tag, 2 bytes length */
Oliver Neukum ef2235
 
Oliver Neukum ef2235
+	/* Otherwise the following reads would fail. */
Oliver Neukum ef2235
+	dev->vpd->len = PCI_VPD_MAX_SIZE;
Oliver Neukum ef2235
+
Oliver Neukum ef2235
 	while (pci_read_vpd(dev, off, 1, header) == 1) {
Oliver Neukum ef2235
 		size = 0;
Oliver Neukum ef2235
 
Oliver Neukum ef2235
@@ -47,7 +50,7 @@ static size_t pci_vpd_size(struct pci_dev *dev)
Oliver Neukum ef2235
 			if (pci_read_vpd(dev, off + 1, 2, &header[1]) != 2) {
Oliver Neukum ef2235
 				pci_warn(dev, "failed VPD read at offset %zu\n",
Oliver Neukum ef2235
 					 off + 1);
Oliver Neukum ef2235
-				return off;
Oliver Neukum ef2235
+				return off ?: PCI_VPD_SZ_INVALID;
Oliver Neukum ef2235
 			}
Oliver Neukum ef2235
 			size = pci_vpd_lrdt_size(header);
Oliver Neukum ef2235
 			if (off + size > PCI_VPD_MAX_SIZE)
Oliver Neukum ef2235
@@ -72,7 +75,7 @@ static size_t pci_vpd_size(struct pci_dev *dev)
Oliver Neukum ef2235
 	pci_info(dev, "invalid VPD tag %#04x (size %zu) at offset %zu%s\n",
Oliver Neukum ef2235
 		 header[0], size, off, off == 0 ?
Oliver Neukum ef2235
 		 "; assume missing optional EEPROM" : "");
Oliver Neukum ef2235
-	return off;
Oliver Neukum ef2235
+	return off ?: PCI_VPD_SZ_INVALID;
Oliver Neukum ef2235
 }
Oliver Neukum ef2235
 
Oliver Neukum ef2235
 /*
Oliver Neukum ef2235
@@ -127,12 +130,10 @@ static ssize_t pci_vpd_read(struct pci_dev *dev, loff_t pos, size_t count,
Oliver Neukum ef2235
 	if (pos < 0)
Oliver Neukum ef2235
 		return -EINVAL;
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-	if (!vpd->valid) {
Oliver Neukum ef2235
-		vpd->valid = 1;
Oliver Neukum ef2235
+	if (!vpd->len)
Oliver Neukum ef2235
 		vpd->len = pci_vpd_size(dev);
Oliver Neukum ef2235
-	}
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-	if (vpd->len == 0)
Oliver Neukum ef2235
+	if (vpd->len == PCI_VPD_SZ_INVALID)
Oliver Neukum ef2235
 		return -EIO;
Oliver Neukum ef2235
 
Oliver Neukum ef2235
 	if (pos > vpd->len)
Oliver Neukum ef2235
@@ -196,12 +197,10 @@ static ssize_t pci_vpd_write(struct pci_dev *dev, loff_t pos, size_t count,
Oliver Neukum ef2235
 	if (pos < 0 || (pos & 3) || (count & 3))
Oliver Neukum ef2235
 		return -EINVAL;
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-	if (!vpd->valid) {
Oliver Neukum ef2235
-		vpd->valid = 1;
Oliver Neukum ef2235
+	if (!vpd->len)
Oliver Neukum ef2235
 		vpd->len = pci_vpd_size(dev);
Oliver Neukum ef2235
-	}
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-	if (vpd->len == 0)
Oliver Neukum ef2235
+	if (vpd->len == PCI_VPD_SZ_INVALID)
Oliver Neukum ef2235
 		return -EIO;
Oliver Neukum ef2235
 
Oliver Neukum ef2235
 	if (end > vpd->len)
Oliver Neukum ef2235
@@ -250,10 +249,8 @@ void pci_vpd_init(struct pci_dev *dev)
Oliver Neukum ef2235
 	if (!vpd)
Oliver Neukum ef2235
 		return;
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-	vpd->len = PCI_VPD_MAX_SIZE;
Oliver Neukum ef2235
 	mutex_init(&vpd->lock);
Oliver Neukum ef2235
 	vpd->cap = cap;
Oliver Neukum ef2235
-	vpd->valid = 0;
Oliver Neukum ef2235
 	dev->vpd = vpd;
Oliver Neukum ef2235
 }
Oliver Neukum ef2235
 
Oliver Neukum ef2235
@@ -422,8 +419,7 @@ DECLARE_PCI_FIXUP_CLASS_EARLY(PCI_VENDOR_ID_INTEL, PCI_ANY_ID,
Oliver Neukum ef2235
 static void quirk_blacklist_vpd(struct pci_dev *dev)
Oliver Neukum ef2235
 {
Oliver Neukum ef2235
 	if (dev->vpd) {
Oliver Neukum ef2235
-		dev->vpd->len = 0;
Oliver Neukum ef2235
-		dev->vpd->valid = 1;
Oliver Neukum ef2235
+		dev->vpd->len = PCI_VPD_SZ_INVALID;
Oliver Neukum ef2235
 		pci_warn(dev, FW_BUG "disabling VPD access (can't determine size of non-standard VPD format)\n");
Oliver Neukum ef2235
 	}
Oliver Neukum ef2235
 }
Oliver Neukum ef2235
@@ -454,7 +450,6 @@ static void pci_vpd_set_size(struct pci_dev *dev, size_t len)
Oliver Neukum ef2235
 	if (!vpd || len == 0 || len > PCI_VPD_MAX_SIZE)
Oliver Neukum ef2235
 		return;
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-	vpd->valid = 1;
Oliver Neukum ef2235
 	vpd->len = len;
Oliver Neukum ef2235
 }
Oliver Neukum ef2235
 
Oliver Neukum ef2235
-- 
Oliver Neukum ef2235
2.26.2
Oliver Neukum ef2235