c9d95fbe59
Convert PCIBIOS_MIN_IO and PCIBIOS_MIN_MEM to variables to allow multi-platform builds. This also removes the requirement for a platform to have a mach/hardware.h. The default values for i/o and mem are 0x1000 and 0x01000000, respectively. Per Arnd Bergmann, other values are likely to be incorrect, but this commit does not try to address that issue. Signed-off-by: Rob Herring <rob.herring@calxeda.com> Acked-by: Nicolas Pitre <nicolas.pitre@linaro.org> Reviewed-by: Arnd Bergmann <arnd@arndb.de>
51 lines
943 B
C
51 lines
943 B
C
/*
|
|
* linux/arch/arm/mach-shark/pci.c
|
|
*
|
|
* PCI bios-type initialisation for PCI machines
|
|
*
|
|
* Bits taken from various places.
|
|
*/
|
|
#include <linux/kernel.h>
|
|
#include <linux/pci.h>
|
|
#include <linux/init.h>
|
|
|
|
#include <asm/irq.h>
|
|
#include <asm/mach/pci.h>
|
|
#include <asm/mach-types.h>
|
|
|
|
static int __init shark_map_irq(struct pci_dev *dev, u8 slot, u8 pin)
|
|
{
|
|
if (dev->bus->number == 0)
|
|
if (dev->devfn == 0)
|
|
return 255;
|
|
else
|
|
return 11;
|
|
else
|
|
return 255;
|
|
}
|
|
|
|
extern void __init via82c505_preinit(void);
|
|
|
|
static struct hw_pci shark_pci __initdata = {
|
|
.setup = via82c505_setup,
|
|
.swizzle = pci_std_swizzle,
|
|
.map_irq = shark_map_irq,
|
|
.nr_controllers = 1,
|
|
.scan = via82c505_scan_bus,
|
|
.preinit = via82c505_preinit,
|
|
};
|
|
|
|
static int __init shark_pci_init(void)
|
|
{
|
|
if (!machine_is_shark())
|
|
return;
|
|
|
|
pcibios_min_io = 0x6000;
|
|
pcibios_min_mem = 0x50000000;
|
|
|
|
pci_common_init(&shark_pci);
|
|
|
|
return 0;
|
|
}
|
|
|
|
subsys_initcall(shark_pci_init);
|