X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=arch%2Fx86%2Fcpu%2Fpci.c;h=c9c7637fa7d761f8a8e2da8d686510e9a8d81c6c;hb=b9eaeae19eb93993e18149f119fa360b13c5643f;hp=f3492c3851f079703d61dd03594148eca878ff61;hpb=e94ea6f656641e30392cf76089b65ea9aecde160;p=oweals%2Fu-boot.git diff --git a/arch/x86/cpu/pci.c b/arch/x86/cpu/pci.c index f3492c3851..c9c7637fa7 100644 --- a/arch/x86/cpu/pci.c +++ b/arch/x86/cpu/pci.c @@ -10,101 +10,79 @@ */ #include +#include #include #include #include +#include #include -static struct pci_controller x86_hose; +DECLARE_GLOBAL_DATA_PTR; -int pci_early_init_hose(struct pci_controller **hosep) +int pci_x86_read_config(struct udevice *bus, pci_dev_t bdf, uint offset, + ulong *valuep, enum pci_size_t size) { - struct pci_controller *hose; - - hose = calloc(1, sizeof(struct pci_controller)); - if (!hose) - return -ENOMEM; - - board_pci_setup_hose(hose); - pci_setup_type1(hose); - gd->arch.hose = hose; - *hosep = hose; + outl(bdf | (offset & 0xfc) | PCI_CFG_EN, PCI_REG_ADDR); + switch (size) { + case PCI_SIZE_8: + *valuep = inb(PCI_REG_DATA + (offset & 3)); + break; + case PCI_SIZE_16: + *valuep = inw(PCI_REG_DATA + (offset & 2)); + break; + case PCI_SIZE_32: + *valuep = inl(PCI_REG_DATA); + break; + } return 0; } -__weak int board_pci_pre_scan(struct pci_controller *hose) +int pci_x86_write_config(struct udevice *bus, pci_dev_t bdf, uint offset, + ulong value, enum pci_size_t size) { - return 0; -} + outl(bdf | (offset & 0xfc) | PCI_CFG_EN, PCI_REG_ADDR); + switch (size) { + case PCI_SIZE_8: + outb(value, PCI_REG_DATA + (offset & 3)); + break; + case PCI_SIZE_16: + outw(value, PCI_REG_DATA + (offset & 2)); + break; + case PCI_SIZE_32: + outl(value, PCI_REG_DATA); + break; + } -__weak int board_pci_post_scan(struct pci_controller *hose) -{ return 0; } -void pci_init_board(void) -{ - struct pci_controller *hose = &x86_hose; - - /* Stop using the early hose */ - gd->arch.hose = NULL; - - board_pci_setup_hose(hose); - pci_setup_type1(hose); - pci_register_hose(hose); - - board_pci_pre_scan(hose); - hose->last_busno = pci_hose_scan(hose); - board_pci_post_scan(hose); -} - -static struct pci_controller *get_hose(void) -{ - if (gd->arch.hose) - return gd->arch.hose; - - return pci_bus_to_hose(0); -} - -unsigned int pci_read_config8(pci_dev_t dev, unsigned where) +void pci_assign_irqs(int bus, int device, u8 irq[4]) { - uint8_t value; + pci_dev_t bdf; + int func; + u16 vendor; + u8 pin, line; - pci_hose_read_config_byte(get_hose(), dev, where, &value); + for (func = 0; func < 8; func++) { + bdf = PCI_BDF(bus, device, func); + pci_read_config16(bdf, PCI_VENDOR_ID, &vendor); + if (vendor == 0xffff || vendor == 0x0000) + continue; - return value; -} - -unsigned int pci_read_config16(pci_dev_t dev, unsigned where) -{ - uint16_t value; - - pci_hose_read_config_word(get_hose(), dev, where, &value); + pci_read_config8(bdf, PCI_INTERRUPT_PIN, &pin); - return value; -} - -unsigned int pci_read_config32(pci_dev_t dev, unsigned where) -{ - uint32_t value; + /* PCI spec says all values except 1..4 are reserved */ + if ((pin < 1) || (pin > 4)) + continue; - pci_hose_read_config_dword(get_hose(), dev, where, &value); + line = irq[pin - 1]; + if (!line) + continue; - return value; -} + debug("Assigning IRQ %d to PCI device %d.%x.%d (INT%c)\n", + line, bus, device, func, 'A' + pin - 1); -void pci_write_config8(pci_dev_t dev, unsigned where, unsigned value) -{ - pci_hose_write_config_byte(get_hose(), dev, where, value); -} - -void pci_write_config16(pci_dev_t dev, unsigned where, unsigned value) -{ - pci_hose_write_config_word(get_hose(), dev, where, value); -} - -void pci_write_config32(pci_dev_t dev, unsigned where, unsigned value) -{ - pci_hose_write_config_dword(get_hose(), dev, where, value); + pci_write_config8(bdf, PCI_INTERRUPT_LINE, line); + } }