summaryrefslogtreecommitdiffstats
path: root/pcidev.c
diff options
context:
space:
mode:
authorEdward O'Callaghan <quasisec@google.com>2021-11-13 17:56:20 +1100
committerEdward O'Callaghan <quasisec@chromium.org>2022-03-22 05:52:27 +0000
commit855b8983319f24835e72669469669f270fffa1db (patch)
tree002e3e54b43a38cf55a279b2ca6238881a31f7b1 /pcidev.c
parentd69c30766e2ddcd8439b32b80b0d03f2ae0b9bc2 (diff)
downloadflashrom-855b8983319f24835e72669469669f270fffa1db.tar.gz
flashrom-855b8983319f24835e72669469669f270fffa1db.tar.bz2
flashrom-855b8983319f24835e72669469669f270fffa1db.zip
pcidev: Move pci_card_find() from internal to canonical place
Also rename to `pcidev_card_find()` in fitting with pcidev.c helpers. BUG=b:220950271 TEST=```sudo ./flashrom -p internal -r /tmp/bios <snip> Found Programmer flash chip "Opaque flash chip" (16384 kB, Programmer-specific) mapped at physical address 0x0000000000000000. Reading flash... done. ``` Change-Id: I026bfbecba114411728d4ad1ed8969b469fa7d2d Signed-off-by: Edward O'Callaghan <quasisec@google.com> Reviewed-on: https://review.coreboot.org/c/flashrom/+/59279 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Thomas Heijligen <src@posteo.de> Reviewed-by: Nikolai Artemiev <nartemiev@google.com> Reviewed-by: Anastasia Klimchuk <aklm@chromium.org>
Diffstat (limited to 'pcidev.c')
-rw-r--r--pcidev.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/pcidev.c b/pcidev.c
index 8b8b47886..0049f0ca5 100644
--- a/pcidev.c
+++ b/pcidev.c
@@ -157,6 +157,25 @@ struct pci_dev *pcidev_scandev(struct pci_filter *filter, struct pci_dev *start)
return NULL;
}
+struct pci_dev *pcidev_card_find(uint16_t vendor, uint16_t device,
+ uint16_t card_vendor, uint16_t card_device)
+{
+ struct pci_dev *temp = NULL;
+ struct pci_filter filter;
+
+ pci_filter_init(NULL, &filter);
+ filter.vendor = vendor;
+ filter.device = device;
+
+ while ((temp = pcidev_scandev(&filter, temp))) {
+ if ((card_vendor == pci_read_word(temp, PCI_SUBSYSTEM_VENDOR_ID))
+ && (card_device == pci_read_word(temp, PCI_SUBSYSTEM_ID)))
+ return temp;
+ }
+
+ return NULL;
+}
+
struct pci_dev *pcidev_getdevfn(struct pci_dev *dev, const int func)
{
#if !defined(OLD_PCI_GET_DEV)