Added code to support 2.6.18 PCI changes in u-boot
authorAndy Fleming <afleming@freescale.com>
Wed, 13 Sep 2006 15:33:56 +0000 (10:33 -0500)
committerJon Loeliger <jdl@freescale.com>
Tue, 19 Sep 2006 14:41:08 +0000 (09:41 -0500)
* Added code to swizzle the IRQ map for the PCI

board/cds/common/ft_board.c

index 77d1d851d90860b4d36a67209a1bf44ee3356b01..a897d045a0a35b4aa88dcf448c2df5408ceb7a8c 100644 (file)
 
 #if defined(CONFIG_OF_FLAT_TREE)
 #include <ft_build.h>
+#include "cadmus.h"
+
 extern void ft_cpu_setup(void *blob, bd_t *bd);
-#endif
 
+static void cds_pci_fixup(void *blob)
+{
+       int len;
+       u32 *map;
+       int slot;
+       int i;
+
+       map = ft_get_prop(blob, "/" OF_SOC "/pci@8000/interrupt-map", &len);
+
+       len /= sizeof(u32);
+
+       slot = get_pci_slot();
+
+       for (i=0;i<len;i+=7) {
+               /* We rotate the interrupt pins so that the mapping
+                * changes depending on the slot the carrier card is in.
+                */
+               int j;
+
+               map[3] = ((map[3] + slot - 2) % 4) + 1;
+
+               map+=7;
+       }
+}
+#endif
 
 #if defined(CONFIG_OF_FLAT_TREE) && defined(CONFIG_OF_BOARD_SETUP)
 void
@@ -45,5 +71,7 @@ ft_board_setup(void *blob, bd_t *bd)
                *p++ = cpu_to_be32(bd->bi_memstart);
                *p = cpu_to_be32(bd->bi_memsize);
        }
+
+       cds_pci_fixup(blob);
 }
 #endif