X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=arch%2Fx86%2Fcpu%2Fpci.c;h=c6218250e161f12e65d190daa3f5b9f3344b6e3e;hb=83d290c56fab2d38cd1ab4c4cc7099559c1d5046;hp=ab1aaaa0599e0e195f910fd3c27e2fe3c28b9b6f;hpb=8f9052fd98e2e97e33b0e5ccf57f028e595abb5d;p=platform%2Fkernel%2Fu-boot.git diff --git a/arch/x86/cpu/pci.c b/arch/x86/cpu/pci.c index ab1aaaa..c621825 100644 --- a/arch/x86/cpu/pci.c +++ b/arch/x86/cpu/pci.c @@ -1,3 +1,4 @@ +// SPDX-License-Identifier: GPL-2.0+ /* * Copyright (c) 2011 The Chromium OS Authors. * (C) Copyright 2008,2009 @@ -5,109 +6,80 @@ * * (C) Copyright 2002 * Daniel Engström, Omicron Ceti AB, - * - * SPDX-License-Identifier: GPL-2.0+ */ #include +#include #include #include #include +#include #include -DECLARE_GLOBAL_DATA_PTR; - -static struct pci_controller x86_hose; - -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); - hose->last_busno = pci_hose_scan(hose); - gd->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) +void pci_assign_irqs(int bus, int device, u8 irq[4]) { - struct pci_controller *hose = &x86_hose; + pci_dev_t bdf; + int func; + u16 vendor; + u8 pin, line; - /* Stop using the early hose */ - gd->hose = NULL; + 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; - board_pci_setup_hose(hose); - pci_setup_type1(hose); - pci_register_hose(hose); + pci_read_config8(bdf, PCI_INTERRUPT_PIN, &pin); - board_pci_pre_scan(hose); - hose->last_busno = pci_hose_scan(hose); - board_pci_post_scan(hose); -} + /* PCI spec says all values except 1..4 are reserved */ + if ((pin < 1) || (pin > 4)) + continue; -static struct pci_controller *get_hose(void) -{ - if (gd->hose) - return gd->hose; - - return pci_bus_to_hose(0); -} - -unsigned int pci_read_config8(pci_dev_t dev, unsigned where) -{ - uint8_t value; - - pci_hose_read_config_byte(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); -unsigned int pci_read_config16(pci_dev_t dev, unsigned where) -{ - uint16_t value; - - pci_hose_read_config_word(get_hose(), dev, where, &value); - - return value; -} - -unsigned int pci_read_config32(pci_dev_t dev, unsigned where) -{ - uint32_t value; - - pci_hose_read_config_dword(get_hose(), dev, where, &value); - - return value; -} - -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); + } }