[PATCH v2 0/8] Raspberry Pi 2 support.

Alexander Aring alex.aring at gmail.com
Tue Dec 22 06:20:46 PST 2015


On Tue, Dec 22, 2015 at 12:11:32AM +0100, Arnd Bergmann wrote:
> On Sunday 20 December 2015, Alexander Aring wrote:
> > On Fri, Dec 18, 2015 at 11:08:26AM +0100, Alexander Aring wrote:
> > > [    0.000000] Memory policy: Data cache writeback
> > > [    0.000000] BUG: mapping for 0x3f201000 at 0xf0201000 out of vmalloc space
> 
> This is a separate bug, right?
> 

Yes, I can remove this BUG when setting:

VMSPLIT_2G

or some other option, was "VMSPLIT_3G" before and with this option I
will get the above message.

> > > [    0.000000] ------------[ cut here ]------------
> > > [    0.000000] WARNING: CPU: 0 PID: 0 at arch/arm/kernel/devtree.c:149 arm_dt_init_cpu_maps+0x100/0x1a4()
> > > [    0.000000] DT /cpu 2 nodes greater than max cores 1, capping them
> > > [    0.000000] Modules linked in:
> > > [    0.000000] CPU: 0 PID: 0 Comm: swapper Not tainted 4.4.0-rc5+ #989
> > > [    0.000000] Hardware name: BCM2835
> > > [    0.000000] [<c0016c4c>] (unwind_backtrace) from [<c0013e58>] (show_stack+0x20/0x24)
> > > [    0.000000] [<c0013e58>] (show_stack) from [<c0247620>] (dump_stack+0x20/0x28)
> > > [    0.000000] [<c0247620>] (dump_stack) from [<c0023a84>] (warn_slowpath_common+0x9c/0xc4)
> > > [    0.000000] [<c0023a84>] (warn_slowpath_common) from [<c0023aec>] (warn_slowpath_fmt+0x40/0x48)
> > > [    0.000000] [<c0023aec>] (warn_slowpath_fmt) from [<c074ef94>] (arm_dt_init_cpu_maps+0x100/0x1a4)
> > > [    0.000000] [<c074ef94>] (arm_dt_init_cpu_maps) from [<c074e60c>] (setup_arch+0x6f4/0x89c)
> > > [    0.000000] [<c074e60c>] (setup_arch) from [<c074b9cc>] (start_kernel+0x74/0x3a4)
> > > [    0.000000] [<c074b9cc>] (start_kernel) from [<00008078>] (0x8078)
> > > [    0.000000] ---[ end trace cb88537fdc8fa200 ]---
> > > [    0.000000] DT missing boot CPU MPIDR[23:0], fall back to default cpu_logical_map
> > > [    0.000000] CPU: All CPU(s) started in SVC mode.
> > 
> > I can remove this WARNING when I enable CONFIG_SMP.
> 
> I think we should try to change this in the code.
> 

mhhh, okay... I am not sure I think there is some missing
IS_ENABLED(CONFIG_SMP) check.

> > > [    0.000000] Virtual kernel memory layout:
> > > [    0.000000]     vector  : 0xffff0000 - 0xffff1000   (   4 kB)
> > > [    0.000000]     fixmap  : 0xffc00000 - 0xfff00000   (3072 kB)
> > > [    0.000000]     vmalloc : 0xf0800000 - 0xff800000   ( 240 MB)
> > > [    0.000000]     lowmem  : 0xc0000000 - 0xf0000000   ( 768 MB)
> > > [    0.000000]     modules : 0xbf000000 - 0xc0000000   (  16 MB)
> > > [    0.000000]       .text : 0xc0008000 - 0xc074a7cc   (7434 kB)
> > > [    0.000000]       .init : 0xc074b000 - 0xc07b4000   ( 420 kB)
> > > [    0.000000]       .data : 0xc07b4000 - 0xc081e910   ( 427 kB)
> > > [    0.000000]        .bss : 0xc081e910 - 0xc08ca80c   ( 688 kB)
> > > [    0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
> > > [    0.000000] NR_IRQS:16 nr_irqs:16 16
> > > [    0.000000] Kernel panic - not syncing: /soc/local_intc: unable to map local interrupt registers
> > > [    0.000000] 
> > > [    0.000000] CPU: 0 PID: 0 Comm: swapper Tainted: G        W       4.4.0-rc5+ #989
> > > [    0.000000] Hardware name: BCM2835
> > > [    0.000000] [<c0016c4c>] (unwind_backtrace) from [<c0013e58>] (show_stack+0x20/0x24)
> > > [    0.000000] [<c0013e58>] (show_stack) from [<c0247620>] (dump_stack+0x20/0x28)
> > > [    0.000000] [<c0247620>] (dump_stack) from [<c00c17c0>] (panic+0x84/0x210)
> > > [    0.000000] [<c00c17c0>] (panic) from [<c0771d5c>] (bcm2836_arm_irqchip_l1_intc_of_init+0x94/0x110)
> > > [    0.000000] [<c0771d5c>] (bcm2836_arm_irqchip_l1_intc_of_init) from [<c0779f04>] (of_irq_init+0x1a0/0x2a8)
> > > [    0.000000] [<c0779f04>] (of_irq_init) from [<c0771af4>] (irqchip_init+0x14/0x1c)
> > > [    0.000000] [<c0771af4>] (irqchip_init) from [<c074d7a8>] (init_IRQ+0x28/0x88)
> > > [    0.000000] [<c074d7a8>] (init_IRQ) from [<c074bb64>] (start_kernel+0x20c/0x3a4)
> > > [    0.000000] [<c074bb64>] (start_kernel) from [<00008078>] (0x8078)
> > > [    0.000000] ---[ end Kernel panic - not syncing: /soc/local_intc: unable to map local interrupt registers
> > > 
> > 
> > But still getting this panic, your patches does not contain some
> > defconfig, so I still try to figure out what I need to enable to get it
> > working. Maybe it is some missing config entry which should be enabled.
> > 
> > But, for me it looks like some devicetree issue, because of_iomem returns
> > NULL, at [0]. Don't know what I am doing wrong.
> 
> That is the most likely cause, yes. You can try replacing it with an ioremap with a
> hardcoded physical address to see if that works.
> 

When I changed to "VMSPLIT_2G" the above issue doesn't occur anymore.

Later while booting the kernel hangs forever, the solution on my side
was to enable:

CONFIG_HAVE_ARM_ARCH_TIMER

I think this doesn't use the BCM2835 timer anymore and some cortex-a7
related "generic timer", or?

btw:

After the RPi is booted succesful I get several:

[   35.048513] unexpected IRQ trap at vector 00

When I type something via uart (after each character).


Any ideas?

- Alex



More information about the linux-arm-kernel mailing list