[PATCH v2 4/6] arm64: mmu_change_region_attr() add an option not to break PTEs

Richard Henderson richard.henderson at linaro.org
Thu Feb 20 19:25:36 CET 2025


On 2/20/25 05:54, Ilias Apalodimas wrote:
> The ARM ARM on section 8.17.1 describes the cases where
> break-before-make is required when changing live page tables.
> Since we can use this function to tweak block and page permssions,
> where BBM is not required add an extra argument to the function.
> 
> While at it add a function description.
> 
> Signed-off-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>
> ---
>   arch/arm/cpu/armv8/cache_v8.c           |  6 +++++-
>   arch/arm/cpu/armv8/fsl-layerscape/cpu.c | 10 +++++-----
>   arch/arm/include/asm/system.h           | 11 ++++++++++-
>   arch/arm/mach-snapdragon/board.c        |  2 +-
>   4 files changed, 21 insertions(+), 8 deletions(-)
> 
> diff --git a/arch/arm/cpu/armv8/cache_v8.c b/arch/arm/cpu/armv8/cache_v8.c
> index c4b3da4a8da7..670379e17b7a 100644
> --- a/arch/arm/cpu/armv8/cache_v8.c
> +++ b/arch/arm/cpu/armv8/cache_v8.c
> @@ -972,11 +972,14 @@ void mmu_set_region_dcache_behaviour(phys_addr_t start, size_t size,
>    * The procecess is break-before-make. The target region will be marked as
>    * invalid during the process of changing.
>    */
> -void mmu_change_region_attr(phys_addr_t addr, size_t siz, u64 attrs)
> +void mmu_change_region_attr(phys_addr_t addr, size_t siz, u64 attrs, bool bbm)
>   {
>   	int level;
>   	u64 r, size, start;
>   
> +	if (!bbm)
> +		goto skip_break;
> +
>   	start = addr;
>   	size = siz;
>   	/*
> @@ -1001,6 +1004,7 @@ void mmu_change_region_attr(phys_addr_t addr, size_t siz, u64 attrs)
>   			   gd->arch.tlb_addr + gd->arch.tlb_size);
>   	__asm_invalidate_tlb_all();
>   
> +skip_break:
>   	/*
>   	 * Loop through the address range until we find a page granule that fits
>   	 * our alignment constraints, then set it to the new cache attributes

Because the 'bbm' argument is always constant in the callers,
better to split the function.  Perhaps

   mmu_change_region_attr
   mmu_change_region_attr_nobreak


r~


More information about the U-Boot mailing list