[PATCH] ARM: mm: fix kexec and hibernation with CONFIG_CPU_TTBR0_PAN

Florian Fainelli florian.fainelli at broadcom.com
Mon May 25 11:15:20 PDT 2026



On 5/25/2026 6:35 AM, Linus Walleij wrote:
> Hi Florian,
> 
> thanks for digging in and finding this!
> 
> On Sat, May 23, 2026 at 2:08 AM Florian Fainelli
> <florian.fainelli at broadcom.com> wrote:
> 
>> Commit 7af5b901e847 ("ARM: 9358/2: Implement PAN for LPAE by TTBR0
>> page table walks disablement") implemented PAN for LPAE kernels by
>> setting TTBCR.EPD0 on every kernel entry, disabling TTBR0 page-table
>> walks while running in kernel mode. The commit correctly updated
>> cpu_suspend() in arch/arm/kernel/suspend.c, but missed two other code
>> paths that switch the CPU to the identity mapping before jumping to
>> low-PA (TTBR0-range) physical addresses:
>>
>> 1. setup_mm_for_reboot() in arch/arm/mm/idmap.c, used by the kexec
>>     reboot path. With TTBCR.EPD0 still set, the subsequent branch to
>>     the identity-mapped cpu_v7_reset causes a PrefetchAbort because the
>>     TTBR0 page-table walk needed to resolve the identity-mapped address
>>     is disabled. This manifests as a hard hang or "bad PC value" panic
>>     on LPAE kernels booted on CPUs that strictly enforce EPD0 for
>>     instruction fetch (e.g. Cortex-A53 in AArch32 mode) while the same
>>     image may accidentally work on Cortex-A15 due to microarchitectural
>>     differences in EPD0 enforcement.
>>
>> 2. arch_restore_image() in arch/arm/kernel/hibernate.c, which calls
>>     cpu_switch_mm(idmap_pgd, &init_mm) directly without going through
>>     setup_mm_for_reboot(), leaving TTBCR.EPD0 set while the identity
>>     mapping is active.
>>
>> Fix both sites by calling uaccess_save_and_enable() before switching
>> to the identity mapping, mirroring what the original commit did for
>> cpu_suspend().
>>
>> Fixes: 7af5b901e847 ("ARM: 9358/2: Implement PAN for LPAE by TTBR0 page table walks disablement")
>> Cc: Catalin Marinas <catalin.marinas at arm.com>
>> Cc: Linus Walleij <linus.walleij at linaro.org>
>> Assisted-by: Cursor:claude-sonnet-4.6
>> Signed-off-by: Florian Fainelli <florian.fainelli at broadcom.com>
> 
> Reviewed-by: Linus Walleij <linusw at kernel.org>
> 
> Please put this patch into Russell's patch tracker.

Thank you, now done:

https://www.armlinux.org.uk/developer/patches/viewpatch.php?id=9476/1
-- 
Florian




More information about the linux-arm-kernel mailing list