2 * linux/arch/arm/mach-footbridge/cats-pci.c
4 * PCI bios-type initialisation for PCI machines
6 * Bits taken from various places.
8 #include <linux/kernel.h>
10 #include <linux/init.h>
13 #include <asm/mach/pci.h>
14 #include <asm/mach-types.h>
16 /* cats host-specific stuff */
17 static int irqmap_cats
[] __initdata
= { IRQ_PCI
, IRQ_IN0
, IRQ_IN1
, IRQ_IN3
};
19 static u8
cats_no_swizzle(struct pci_dev
*dev
, u8
*pin
)
24 static int __init
cats_map_irq(const struct pci_dev
*dev
, u8 slot
, u8 pin
)
27 return -1; /* not a valid interrupt. */
30 return dev
->irq
& 0x1f;
32 if (dev
->irq
>= 1 && dev
->irq
<= 4)
33 return irqmap_cats
[dev
->irq
- 1];
36 printk("PCI: device %02x:%02x has unknown irq line %x\n",
37 dev
->bus
->number
, dev
->devfn
, dev
->irq
);
43 * why not the standard PCI swizzle? does this prevent 4-port tulip
44 * cards being used (ie, pci-pci bridge based cards)?
46 static struct hw_pci cats_pci __initdata
= {
47 .swizzle
= cats_no_swizzle
,
48 .map_irq
= cats_map_irq
,
51 .setup
= dc21285_setup
,
52 .preinit
= dc21285_preinit
,
53 .postinit
= dc21285_postinit
,
56 static int __init
cats_pci_init(void)
58 if (machine_is_cats())
59 pci_common_init(&cats_pci
);
63 subsys_initcall(cats_pci_init
);