# HG changeset patch # User Yu Zhao # Date 1236910170 14400 # Node ID ebec1feb35c3a3efe319853a31acee72924453f3 # Parent 4bc56b3855d6449abcf402f3be106102ecd667de Backport: PCI: add a new function to map BAR offsets commit 613e7ed6f72b1a115f7ece8ce1b66cf095de1348 Author: Yu Zhao Date: Sat Nov 22 02:41:27 2008 +0800 PCI: add a new function to map BAR offsets Add a function to map a given resource number to a corresponding register so drivers can get the offset and type of device specific BARs. Signed-off-by: Yu Zhao Signed-off-by: Jesse Barnes Signed-off-by: Yu Zhao diff -r 4bc56b3855d6 -r ebec1feb35c3 drivers/pci/pci.c --- a/drivers/pci/pci.c Thu Mar 12 22:08:24 2009 -0400 +++ b/drivers/pci/pci.c Thu Mar 12 22:09:30 2009 -0400 @@ -949,6 +949,28 @@ } #endif +/** + * pci_resource_bar - get position of the BAR associated with a resource + * @dev: the PCI device + * @resno: the resource number + * @type: the BAR type to be filled in + * + * Returns BAR position in config space, or 0 if the BAR is invalid. + */ +int pci_resource_bar(struct pci_dev *dev, int resno, enum pci_bar_type *type) +{ + if (resno < PCI_ROM_RESOURCE) { + *type = pci_bar_unknown; + return PCI_BASE_ADDRESS_0 + 4 * resno; + } else if (resno == PCI_ROM_RESOURCE) { + *type = pci_bar_mem32; + return dev->rom_base_reg; + } + + dev_err(&dev->dev, "BAR: invalid resource #%d\n", resno); + return 0; +} + static int __devinit pci_init(void) { struct pci_dev *dev = NULL; diff -r 4bc56b3855d6 -r ebec1feb35c3 drivers/pci/pci.h --- a/drivers/pci/pci.h Thu Mar 12 22:08:24 2009 -0400 +++ b/drivers/pci/pci.h Thu Mar 12 22:09:30 2009 -0400 @@ -119,6 +119,8 @@ extern int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type, struct resource *res, unsigned int reg); +extern int pci_resource_bar(struct pci_dev *dev, int resno, + enum pci_bar_type *type); extern void pci_enable_ari(struct pci_dev *dev); /** * pci_ari_enabled - query ARI forwarding status diff -r 4bc56b3855d6 -r ebec1feb35c3 drivers/pci/setup-res.c --- a/drivers/pci/setup-res.c Thu Mar 12 22:08:24 2009 -0400 +++ b/drivers/pci/setup-res.c Thu Mar 12 22:09:30 2009 -0400 @@ -32,6 +32,7 @@ struct pci_bus_region region; u32 new, check, mask; int reg; + enum pci_bar_type type; struct resource *res = dev->resource + resno; /* Ignore resources for unimplemented BARs and unused resource slots @@ -52,17 +53,13 @@ else mask = (u32)PCI_BASE_ADDRESS_MEM_MASK; - if (resno < 6) { - reg = PCI_BASE_ADDRESS_0 + 4 * resno; - } else if (resno == PCI_ROM_RESOURCE) { + reg = pci_resource_bar(dev, resno, &type); + if (!reg) + return; + if (type != pci_bar_unknown) { if (!(res->flags & IORESOURCE_ROM_ENABLE)) return; new |= PCI_ROM_ADDRESS_ENABLE; - reg = dev->rom_base_reg; - } else { - /* Hmm, non-standard resource. */ - - return; /* kill uninitialised var warning */ } pci_write_config_dword(dev, reg, new);