mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-20 18:54:09 +08:00
c5611df968
Introduce 2 Kconfig symbols, CONFIG_PCI_DRIVERS_GENERIC & CONFIG_PCI_DRIVERS_LEGACY, which indicate whether the system should be built to for PCI drivers using the MIPS-specific struct pci_controller API (hereafter "legacy" drivers) or more generic drivers using only functionality provided by the PCI core (hereafter "generic" drivers). The Kconfig entries are created such that platforms have to select CONFIG_PCI_DRIVERS_GENERIC if they wish to use it - that is, the default is CONFIG_PCI_DRIVERS_LEGACY so that existing platforms need no modification. The functions declared in pci.h are rearranged with those provided only by pci-legacy.c being guarded by an #ifdef CONFIG_PCI_DRIVERS_LEGACY to ensure they are only used in configurations where they are implemented. Signed-off-by: Paul Burton <paul.burton@imgtec.com> Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/14345/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
53 lines
1.4 KiB
C
53 lines
1.4 KiB
C
/*
|
|
* Implement the default iomap interfaces
|
|
*
|
|
* (C) Copyright 2004 Linus Torvalds
|
|
* (C) Copyright 2006 Ralf Baechle <ralf@linux-mips.org>
|
|
* (C) Copyright 2007 MIPS Technologies, Inc.
|
|
* written by Ralf Baechle <ralf@linux-mips.org>
|
|
*/
|
|
#include <linux/pci.h>
|
|
#include <linux/export.h>
|
|
#include <asm/io.h>
|
|
|
|
#ifdef CONFIG_PCI_DRIVERS_LEGACY
|
|
|
|
void __iomem *__pci_ioport_map(struct pci_dev *dev,
|
|
unsigned long port, unsigned int nr)
|
|
{
|
|
struct pci_controller *ctrl = dev->bus->sysdata;
|
|
unsigned long base = ctrl->io_map_base;
|
|
|
|
/* This will eventually become a BUG_ON but for now be gentle */
|
|
if (unlikely(!ctrl->io_map_base)) {
|
|
struct pci_bus *bus = dev->bus;
|
|
char name[8];
|
|
|
|
while (bus->parent)
|
|
bus = bus->parent;
|
|
|
|
ctrl->io_map_base = base = mips_io_port_base;
|
|
|
|
sprintf(name, "%04x:%02x", pci_domain_nr(bus), bus->number);
|
|
printk(KERN_WARNING "io_map_base of root PCI bus %s unset. "
|
|
"Trying to continue but you better\nfix this issue or "
|
|
"report it to linux-mips@linux-mips.org or your "
|
|
"vendor.\n", name);
|
|
#ifdef CONFIG_PCI_DOMAINS
|
|
panic("To avoid data corruption io_map_base MUST be set with "
|
|
"multiple PCI domains.");
|
|
#endif
|
|
}
|
|
|
|
return (void __iomem *) (ctrl->io_map_base + port);
|
|
}
|
|
|
|
#endif /* CONFIG_PCI_DRIVERS_LEGACY */
|
|
|
|
void pci_iounmap(struct pci_dev *dev, void __iomem * addr)
|
|
{
|
|
iounmap(addr);
|
|
}
|
|
|
|
EXPORT_SYMBOL(pci_iounmap);
|