|
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 |
|