On Fri, Mar 05, 2010 at 01:45:54PM -0700, Dave Kleikamp wrote:
>+config ISS4xx
>+      bool "ISS 4xx Simulator"
>+      depends on (44x || 40x)
>+      default n
>+      select 405GP if 40x
>+      select 440GP if 44x && !PPC_47x
>+      select PPC_FPU
>+      select OF_RTC
>+      help
>+        This option enables support for the IBM ISS simulation environment

This looks like how we want to do this, however...

>+/* We can have either UICs or MPICs */
>+static void __init iss4xx_init_irq(void)
>+{
>+      struct device_node *np;
>+
>+      /* Find top level interrupt controller */
>+      for_each_node_with_property(np, "interrupt-controller") {
>+              if (of_get_property(np, "interrupts", NULL) == NULL)
>+                      break;
>+      }
>+      if (np == NULL)
>+              panic("Can't find top level interrupt controller");
>+
>+      /* Check type and do appropriate initialization */
>+      if (of_device_is_compatible(np, "ibm,uic")) {
>+              uic_init_tree();
>+              ppc_md.get_irq = uic_get_irq;
>+      } else if (of_device_is_compatible(np, "chrp,open-pic")) {
>+              /* The MPIC driver will get everything it needs from the
>+               * device-tree, just pass 0 to all arguments
>+               */
>+              struct mpic *mpic = mpic_alloc(np, 0, MPIC_PRIMARY, 0, 0,
>+                                             " MPIC     ");
>+              BUG_ON(mpic == NULL);
>+              mpic_init(mpic);
>+              ppc_md.get_irq = mpic_get_irq;
>+      } else
>+              panic("Unrecognized top level interrupt controller");
>+}

.. on non-476 builds we get link errors:

arch/powerpc/platforms/built-in.o: In function `as1_writeb':
(.init.text+0x5d4): undefined reference to `mpic_alloc'
arch/powerpc/platforms/built-in.o: In function `as1_writeb':
(.init.text+0x5e4): undefined reference to `mpic_init'
arch/powerpc/platforms/built-in.o: In function `as1_writeb':
(.init.text+0x5ea): undefined reference to `mpic_get_irq'
arch/powerpc/platforms/built-in.o: In function `as1_writeb':
(.init.text+0x5ee): undefined reference to `mpic_get_irq'
make: *** [.tmp_vmlinux1] Error 1

because we don't have CONFIG_MPIC turned on for these.  I'd suggest we guard
the mpic else chunk in this file behind CONFIG_MPIC.  Agreed?

I'm less worried about the mpic references that are already guarded behind the
CONFIG_SMP sections.  Nobody has been crazy enough to make an SMP 440 or 460 SoC
yet, so CONFIG_SMP should only get selected for 476, and that already selects
MPIC in the Kconfig.

josh
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to