Path: blob/master/arch/arm/mach-footbridge/netwinder-pci.c
10817 views
/*1* linux/arch/arm/mach-footbridge/netwinder-pci.c2*3* PCI bios-type initialisation for PCI machines4*5* Bits taken from various places.6*/7#include <linux/kernel.h>8#include <linux/pci.h>9#include <linux/init.h>1011#include <asm/irq.h>12#include <asm/mach/pci.h>13#include <asm/mach-types.h>1415/*16* We now use the slot ID instead of the device identifiers to select17* which interrupt is routed where.18*/19static int __init netwinder_map_irq(struct pci_dev *dev, u8 slot, u8 pin)20{21switch (slot) {22case 0: /* host bridge */23return 0;2425case 9: /* CyberPro */26return IRQ_NETWINDER_VGA;2728case 10: /* DC21143 */29return IRQ_NETWINDER_ETHER100;3031case 12: /* Winbond 553 */32return IRQ_ISA_HARDDISK1;3334case 13: /* Winbond 89C940F */35return IRQ_NETWINDER_ETHER10;3637default:38printk(KERN_ERR "PCI: unknown device in slot %s\n",39pci_name(dev));40return 0;41}42}4344static struct hw_pci netwinder_pci __initdata = {45.swizzle = pci_std_swizzle,46.map_irq = netwinder_map_irq,47.nr_controllers = 1,48.setup = dc21285_setup,49.scan = dc21285_scan_bus,50.preinit = dc21285_preinit,51.postinit = dc21285_postinit,52};5354static int __init netwinder_pci_init(void)55{56if (machine_is_netwinder())57pci_common_init(&netwinder_pci);58return 0;59}6061subsys_initcall(netwinder_pci_init);626364