Cc: Thomas Huth <thuth@xxxxxxxxxx> Cc: Andrew Jones <drjones@xxxxxxxxxx> Cc: Peter Xu <peterx@xxxxxxxxxx> Reviewed-by: Andrew Jones <drjones@xxxxxxxxxx> Reviewed-by: Thomas Huth <thuth@xxxxxxxxxx> Signed-off-by: Alexander Gordeev <agordeev@xxxxxxxxxx> --- lib/pci.c | 5 ++--- lib/x86/asm/pci.h | 38 ++++++++++++++++++++++++++++++++++++-- 2 files changed, 38 insertions(+), 5 deletions(-) diff --git a/lib/pci.c b/lib/pci.c index e0b4514244f6..b05ecfa3f3da 100644 --- a/lib/pci.c +++ b/lib/pci.c @@ -13,9 +13,8 @@ pcidevaddr_t pci_find_dev(uint16_t vendor_id, uint16_t device_id) pcidevaddr_t dev; for (dev = 0; dev < 256; ++dev) { - uint32_t id = pci_config_readl(dev, 0); - - if ((id & 0xFFFF) == vendor_id && (id >> 16) == device_id) + if (pci_config_readw(dev, PCI_VENDOR_ID) == vendor_id && + pci_config_readw(dev, PCI_DEVICE_ID) == device_id) return dev; } diff --git a/lib/x86/asm/pci.h b/lib/x86/asm/pci.h index d00438fe91e4..4862ab5b8955 100644 --- a/lib/x86/asm/pci.h +++ b/lib/x86/asm/pci.h @@ -9,11 +9,45 @@ #include "pci.h" #include "x86/asm/io.h" +#define PCI_CONF1_ADDRESS(dev, reg) ((0x1 << 31) | (dev << 8) | reg) + +static inline uint8_t pci_config_readb(pcidevaddr_t dev, uint8_t reg) +{ + outl(PCI_CONF1_ADDRESS(dev, reg), 0xCF8); + return inb(0xCFC); +} + +static inline uint16_t pci_config_readw(pcidevaddr_t dev, uint8_t reg) +{ + outl(PCI_CONF1_ADDRESS(dev, reg), 0xCF8); + return inw(0xCFC); +} + static inline uint32_t pci_config_readl(pcidevaddr_t dev, uint8_t reg) { - uint32_t index = reg | (dev << 8) | (0x1 << 31); - outl(index, 0xCF8); + outl(PCI_CONF1_ADDRESS(dev, reg), 0xCF8); return inl(0xCFC); } +static inline void pci_config_writeb(pcidevaddr_t dev, uint8_t reg, + uint8_t val) +{ + outl(PCI_CONF1_ADDRESS(dev, reg), 0xCF8); + outb(val, 0xCFC); +} + +static inline void pci_config_writew(pcidevaddr_t dev, uint8_t reg, + uint16_t val) +{ + outl(PCI_CONF1_ADDRESS(dev, reg), 0xCF8); + outw(val, 0xCFC); +} + +static inline void pci_config_writel(pcidevaddr_t dev, uint8_t reg, + uint32_t val) +{ + outl(PCI_CONF1_ADDRESS(dev, reg), 0xCF8); + outl(val, 0xCFC); +} + #endif -- 1.8.3.1 -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html