[PATCH v2] ARM: entry: expand comment in __switch_to

Mark Rutland mark.rutland at arm.com
Tue Dec 16 07:21:38 PST 2025


Hi Linus,

On Tue, Dec 16, 2025 at 03:27:37PM +0100, Linus Walleij wrote:
> From: Linus Walleij <linus.walleij at linaro.org>
> 
> As per discussion between the developers in the mail thread
> linked, expand the comment in __switch_to so that readers
> of the code understand what is going on.
> 
> Link: https://lore.kernel.org/linux-arm-kernel/ZxDh9biUbf9W8gNN@J2N7QTR9R3/
> Suggested-by: Mark Rutland <mark.rutland at arm.com>
> Signed-off-by: Linus Walleij <linus.walleij at linaro.org>

This looks fine to me, with two minor nits noted below. With those
fixed, feel free to add:

  Acked-by: Mark Rutland <mark.rutland at arm.com>

... and I'd recommend dropping this into the patch system.

> ---
> Changes in v2:
> - Rebased on v6.19-rc1
> - Link to v1: https://lore.kernel.org/r/20241028-comments-in-switch-to-v1-0-7280d09671a8@linaro.org
> ---
>  arch/arm/kernel/entry-armv.S | 13 ++++++++++---
>  1 file changed, 10 insertions(+), 3 deletions(-)
> 
> diff --git a/arch/arm/kernel/entry-armv.S b/arch/arm/kernel/entry-armv.S
> index ef6a657c8d13..5c016c68b5a3 100644
> --- a/arch/arm/kernel/entry-armv.S
> +++ b/arch/arm/kernel/entry-armv.S
> @@ -557,9 +557,16 @@ ENTRY(__switch_to)
>  	ldmia	r4, {r4 - sl, fp, ip, lr}	@ Load all regs saved previously
>  #ifdef CONFIG_VMAP_STACK
>  	@
> -	@ Do a dummy read from the new stack while running from the old one so
> -	@ that we can rely on do_translation_fault() to fix up any stale PMD
> -	@ entries covering the vmalloc region.
> +	@ For a non-lazy mm switch, check_vmalloc_seq() has ensured that
> +	@ that the active mm's page tables have mappings for the prev
> +	@ task's stack and the next task's stack.
> +	@
> +	@ For a lazy mm switch the active mm's page tables have mappings
> +	@ for the prev task's stack but might not have mappings for the
> +	@ new taks stack. Do a dummy read from the new stack while

Typo: s/task/task's/

> +	@ running from the old stack so that we can rely on
> +	@ do_translation_fault() to fix up any stale PMD entries
> +	@ covering the vmalloc region.

Ard requested in:

  https://lore.kernel.org/linux-arm-kernel/CAMj1kXFn=pfJqTrMrnqT+OLi3UqAq0PieROQhbC2M3B2uAzyEQ@mail.gmail.com/

That we change this last part from:

  to fix up any stale PMD entries covering the vmalloc region.

... to:

  to populate missing PMD entries covering the new task's stack in the
  old task's page tables.

... and I think that'd be worthwhile.

Mark.

>  	@
>  	ldr	r2, [ip]
>  #ifdef CONFIG_KASAN_VMALLOC
> 
> ---
> base-commit: 8f0b4cce4481fb22653697cced8d0d04027cb1e8
> change-id: 20241028-comments-in-switch-to-0e24480e8495
> 
> Best regards,
> -- 
> Linus Walleij <linusw at kernel.org>
> 



More information about the linux-arm-kernel mailing list