On Thu, Apr 25, 2013 at 07:28:46PM +0200, Arnd Bergmann wrote: > The irqchip_init function is only available when building > with CONFIG_OF enabled, which causes this build failure for > bonito_defconfig: > > arch/arm/mach-shmobile/built-in.o: In function `r8a7740_init_irq_of': > :(.init.text+0x580): undefined reference to `irqchip_init' > > This makes both the OF and the ATAGS portion of the driver > conditional, which avoids the build error and also results > in smaller object code if not both are enabled, without the > need for an #ifdef. > > Signed-off-by: Arnd Bergmann <a...@arndb.de> > Cc: Bastian Hecht <hechtb+rene...@gmail.com> > Cc: Simon Horman <horms+rene...@verge.net.au> > Cc: Kuninori Morimoto <kuninori.morimoto...@renesas.com> > --- > arch/arm/mach-shmobile/intc-r8a7740.c | 13 +++++++++++-- > 1 file changed, 11 insertions(+), 2 deletions(-) > > diff --git a/arch/arm/mach-shmobile/intc-r8a7740.c > b/arch/arm/mach-shmobile/intc-r8a7740.c > index 8871f77..5dc57f1 100644 > --- a/arch/arm/mach-shmobile/intc-r8a7740.c > +++ b/arch/arm/mach-shmobile/intc-r8a7740.c > @@ -53,14 +53,23 @@ static void __init r8a7740_init_irq_common(void) > > void __init r8a7740_init_irq_of(void) > { > + if (!IS_ENABLED(CONFIG_OF)) > + return; > +
In other parts of the shmobile I believe that such code is guarded by #ifdef CONFIG_OF and I believe not guarding this code in some way was an oversight. The above change seems fine to me. > irqchip_init(); > r8a7740_init_irq_common(); > } > > void __init r8a7740_init_irq(void) > { > - void __iomem *gic_dist_base = ioremap_nocache(0xc2800000, 0x1000); > - void __iomem *gic_cpu_base = ioremap_nocache(0xc2000000, 0x1000); > + void __iomem *gic_dist_base; > + void __iomem *gic_cpu_base; > + > + if (!IS_ENABLED(CONFIG_ATAGS)) > + return; > + > + gic_dist_base = ioremap_nocache(0xc2800000, 0x1000); > + gic_cpu_base = ioremap_nocache(0xc2000000, 0x1000); > > /* initialize the Generic Interrupt Controller PL390 r0p0 */ > gic_init(0, 29, gic_dist_base, gic_cpu_base); This one seems broken as the armadillo800eva board currently uses it to initialise GIC even if CONFIG_ATAGS is not defined. I did test the above change on the armadillo800eva board with the above change and CONFIG_ATAGS disabled, the result was a boot failure. With the change reverted booting seems fine. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/