From 8652c1f1c9087a2a043b1aacaca6cfeb86e0e532 Mon Sep 17 00:00:00 2001 From: florian Date: Mon, 11 Jun 2007 10:07:52 +0000 Subject: Fix the irq mapping for routerboard devices (#1843) git-svn-id: svn://svn.openwrt.org/openwrt/trunk@7560 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- target/linux/adm5120-2.6/files/arch/mips/pci/fixup-adm5120.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) (limited to 'target') diff --git a/target/linux/adm5120-2.6/files/arch/mips/pci/fixup-adm5120.c b/target/linux/adm5120-2.6/files/arch/mips/pci/fixup-adm5120.c index 9f65e350a..07119ef3a 100644 --- a/target/linux/adm5120-2.6/files/arch/mips/pci/fixup-adm5120.c +++ b/target/linux/adm5120-2.6/files/arch/mips/pci/fixup-adm5120.c @@ -66,11 +66,7 @@ int __init pcibios_map_irq(struct pci_dev *dev, u8 slot, u8 pin) int irq; irq = -1; -#if 1 - /* FIXME: this code should be working on all boards? */ - if (slot > 0 && slot < 4) - irq = ADM5120_IRQ_PCI0+slot-1; -#else + switch (mips_machtype) { case MACH_ADM5120_RB_111: case MACH_ADM5120_RB_112: @@ -78,14 +74,14 @@ int __init pcibios_map_irq(struct pci_dev *dev, u8 slot, u8 pin) case MACH_ADM5120_RB_133C: case MACH_ADM5120_RB_153: if (slot > 0 && slot < 4) - irq = ADM5120_IRQ_PCI0+slot-1; + irq = slot + 5; break; default: if (slot > 1 && slot < 5) - irq = ADM5120_IRQ_PCI0+slot-2; + irq = ADM5120_IRQ_PCI0+slot-1; break; } -#endif + printk(KERN_INFO "PCI: mapping irq for device %s, slot:%u, pin:%u, " "irq:%d\n", pci_name(dev), slot, pin, irq); -- cgit v1.2.3