diff options
| author | Dominik Brodowski <linux@dominikbrodowski.net> | 2005-08-04 18:06:21 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-08-04 21:32:46 -0700 | 
| commit | 43c34735524d5b1c9b9e5d63b49dd4c1b394bde4 (patch) | |
| tree | a61c11d4075f149be9c0aae6b6c0a935c94571af /arch/ppc/kernel/pci.c | |
| parent | fec59a711eef002d4ef9eb8de09dd0a26986eb77 (diff) | |
[PATCH] pci and yenta: pcibios_bus_to_resource
In yenta_socket, we default to using the resource setting of the CardBus
bridge.  However, this is a PCI-bus-centric view of resources and thus needs
to be converted to generic resources first.  Therefore, add a call to
pcibios_bus_to_resource() call in between.  This function is a mere wrapper on
x86 and friends, however on some others it already exists, is added in this
patch (alpha, arm, ppc, ppc64) or still needs to be provided (parisc -- where
is its pcibios_resource_to_bus() ?).
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/ppc/kernel/pci.c')
| -rw-r--r-- | arch/ppc/kernel/pci.c | 15 | 
1 files changed, 15 insertions, 0 deletions
| diff --git a/arch/ppc/kernel/pci.c b/arch/ppc/kernel/pci.c index 70cfb6ffd877..7b3586a3bf30 100644 --- a/arch/ppc/kernel/pci.c +++ b/arch/ppc/kernel/pci.c @@ -160,6 +160,21 @@ void pcibios_resource_to_bus(struct pci_dev *dev, struct pci_bus_region *region,  }  EXPORT_SYMBOL(pcibios_resource_to_bus); +void pcibios_bus_to_resource(struct pci_dev *dev, struct resource *res, +			     struct pci_bus_region *region) +{ +	unsigned long offset = 0; +	struct pci_controller *hose = dev->sysdata; + +	if (hose && res->flags & IORESOURCE_IO) +		offset = (unsigned long)hose->io_base_virt - isa_io_base; +	else if (hose && res->flags & IORESOURCE_MEM) +		offset = hose->pci_mem_offset; +	res->start = region->start + offset; +	res->end = region->end + offset; +} +EXPORT_SYMBOL(pcibios_bus_to_resource); +  /*   * We need to avoid collisions with `mirrored' VGA ports   * and other strange ISA hardware, so we always want the | 
