Failed to boot ARM64 boards for recent linux-next
Shawn Lin
shawn.lin at rock-chips.com
Tue Mar 20 02:32:50 PDT 2018
Hi Marc,
On 2018/3/20 17:01, Marc Zyngier wrote:
> Hi Shawn,
>
> On 20/03/18 08:48, Shawn Lin wrote:
>> Hi Marc,
>>
>> I was able to boot my RK3399 board with in linux-next-20180314,
>> but not today. My bisect robot shows me it was introduced by
>>
>> commit d6062a6d62c643a06c393745d032da3e6441d4bd
>> Author: Marc Zyngier <marc.zyngier at arm.com>
>> Date: Fri Mar 9 14:53:19 2018 +0000
>>
>> irqchip/gic-v3: Reset APgRn registers at boot time
>>
>> Booting a crash kernel while in an interrupt handler is likely
>> to leave the Active Priority Registers with some state that
>> is not relevant to the new kernel, and is likely to lead
>> to erratic behaviours such as interrupts not firing as their
>> priority is already active.
>>
>> As a sanity measure, wipe the APRs clean on startup. We make
>> sure to wipe both group 0 and 1 registers in order to avoid
>> any surprise.
>>
>>
>> The panic log is here:
>> https://paste.ubuntu.com/p/7WrJJDG6JQ/
>>
>> Is it a known issue or is there a coming patch for that?
>
> Interesting. No, that wasn't the intention, but I may have missed a key
> detail (group 0 access traps to EL3 if SCR_EL3.FIQ==1). Can you have a
> go at the following hack, just to narrow it down:
>
> diff --git a/drivers/irqchip/irq-gic-v3.c b/drivers/irqchip/irq-gic-v3.c
> index 5bb7bb22f1c1..f8ff43b1d4f8 100644
> --- a/drivers/irqchip/irq-gic-v3.c
> +++ b/drivers/irqchip/irq-gic-v3.c
> @@ -570,16 +570,12 @@ static void gic_cpu_sys_reg_init(void)
> switch(val + 1) {
> case 8:
> case 7:
> - write_gicreg(0, ICC_AP0R3_EL1);
> write_gicreg(0, ICC_AP1R3_EL1);
> - write_gicreg(0, ICC_AP0R2_EL1);
> write_gicreg(0, ICC_AP1R2_EL1);
> case 6:
> - write_gicreg(0, ICC_AP0R1_EL1);
> write_gicreg(0, ICC_AP1R1_EL1);
> case 5:
> case 4:
> - write_gicreg(0, ICC_AP0R0_EL1);
> write_gicreg(0, ICC_AP1R0_EL1);
> }
>
> Let me know if that helps.
>
It works for me. Thanks!
> Thanks,
>
> M.
>
More information about the linux-arm-kernel
mailing list