IXP4xx: GTWX5715 platform only has two PCI IRQ lines, not four.
authorKrzysztof Hałasa <khc@pm.waw.pl>
Tue, 17 Nov 2009 23:39:01 +0000 (00:39 +0100)
committerKrzysztof Hałasa <khc@pm.waw.pl>
Sat, 5 Dec 2009 15:58:41 +0000 (16:58 +0100)
Signed-off-by: Krzysztof Hałasa <khc@pm.waw.pl>
arch/arm/mach-ixp4xx/gtwx5715-pci.c

index 276c6143785199a6a832ba8c72e487dad1f67750..25d2c333c2045f2e353b26ce3f74292a2cf69d4e 100644 (file)
 #include <asm/mach/pci.h>
 
 #define SLOT0_DEVID    0
-#define SLOT0_INTA     10
-#define SLOT0_INTB     11
-
 #define SLOT1_DEVID    1
-#define SLOT1_INTA     11
-#define SLOT1_INTB     10
-
-#define SLOT_COUNT     2
-#define INT_PIN_COUNT  2
+#define INTA           10 /* slot 1 has INTA and INTB crossed */
+#define INTB           11
 
 /*
  * Slot 0 isn't actually populated with a card connector but
  */
 void __init gtwx5715_pci_preinit(void)
 {
-       set_irq_type(IXP4XX_GPIO_IRQ(SLOT0_INTA), IRQ_TYPE_LEVEL_LOW);
-       set_irq_type(IXP4XX_GPIO_IRQ(SLOT0_INTB), IRQ_TYPE_LEVEL_LOW);
-       set_irq_type(IXP4XX_GPIO_IRQ(SLOT1_INTA), IRQ_TYPE_LEVEL_LOW);
-       set_irq_type(IXP4XX_GPIO_IRQ(SLOT1_INTB), IRQ_TYPE_LEVEL_LOW);
+       set_irq_type(IXP4XX_GPIO_IRQ(INTA), IRQ_TYPE_LEVEL_LOW);
+       set_irq_type(IXP4XX_GPIO_IRQ(INTB), IRQ_TYPE_LEVEL_LOW);
        ixp4xx_pci_preinit();
 }
 
 
 static int __init gtwx5715_map_irq(struct pci_dev *dev, u8 slot, u8 pin)
 {
-       int rc;
-       static int gtwx5715_irqmap[SLOT_COUNT][INT_PIN_COUNT] = {
-               {IXP4XX_GPIO_IRQ(SLOT0_INTA), IXP4XX_GPIO_IRQ(SLOT0_INTB)},
-               {IXP4XX_GPIO_IRQ(SLOT1_INTA), IXP4XX_GPIO_IRQ(SLOT1_INTB)},
-       };
+       int rc = -1;
 
-       if (slot >= SLOT_COUNT || pin >= INT_PIN_COUNT)
-               rc = -1;
-       else
-               rc = gtwx5715_irqmap[slot][pin - 1];
+       if ((slot == SLOT0_DEVID && pin == 1) ||
+           (slot == SLOT1_DEVID && pin == 2))
+               rc = IXP4XX_GPIO_IRQ(INTA);
+       else if ((slot == SLOT0_DEVID && pin == 2) ||
+                (slot == SLOT1_DEVID && pin == 1))
+               rc = IXP4XX_GPIO_IRQ(INTB);
 
        printk(KERN_INFO "%s: Mapped slot %d pin %d to IRQ %d\n",
               __func__, slot, pin, rc);