arm64: head: drop idmap_ptrs_per_pgd
authorArd Biesheuvel <ardb@kernel.org>
Fri, 24 Jun 2022 15:06:34 +0000 (17:06 +0200)
committerWill Deacon <will@kernel.org>
Fri, 24 Jun 2022 16:18:09 +0000 (17:18 +0100)
The assignment of idmap_ptrs_per_pgd lacks any cache invalidation, even
though it is updated with the MMU and caches disabled. However, we never
bother to read the value again except in the very next instruction, and
so we can just drop the variable entirely.

Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Reviewed-by: Anshuman Khandual <anshuman.khandual@arm.com>
Link: https://lore.kernel.org/r/20220624150651.1358849-5-ardb@kernel.org
Signed-off-by: Will Deacon <will@kernel.org>
arch/arm64/include/asm/mmu_context.h
arch/arm64/kernel/head.S
arch/arm64/mm/mmu.c

index 6ac0086ebb1afb3c5a43153a90aaa8d08d109eaf..7b387c3b312ab55162342692e1c8df533721f879 100644 (file)
@@ -61,7 +61,6 @@ static inline void cpu_switch_mm(pgd_t *pgd, struct mm_struct *mm)
  * physical memory, in which case it will be smaller.
  */
 extern int idmap_t0sz;
-extern u64 idmap_ptrs_per_pgd;
 
 /*
  * Ensure TCR.T0SZ is set to the provided value.
index 7f361bc72d12b402af29e3da54e01fd3ca44f46c..53126a35d73c820c014d627c722ca0dbbcac5949 100644 (file)
@@ -300,6 +300,7 @@ SYM_FUNC_START_LOCAL(__create_page_tables)
         * range in that case, and configure an additional translation level
         * if needed.
         */
+       mov     x4, #PTRS_PER_PGD
        idmap_get_t0sz x5
        cmp     x5, TCR_T0SZ(VA_BITS_MIN) // default T0SZ small enough?
        b.ge    1f                      // .. then skip VA range extension
@@ -319,18 +320,16 @@ SYM_FUNC_START_LOCAL(__create_page_tables)
 #error "Mismatch between VA_BITS and page size/number of translation levels"
 #endif
 
-       mov     x4, EXTRA_PTRS
-       create_table_entry x0, x3, EXTRA_SHIFT, x4, x5, x6
+       mov     x2, EXTRA_PTRS
+       create_table_entry x0, x3, EXTRA_SHIFT, x2, x5, x6
 #else
        /*
         * If VA_BITS == 48, we don't have to configure an additional
         * translation level, but the top-level table has more entries.
         */
        mov     x4, #1 << (PHYS_MASK_SHIFT - PGDIR_SHIFT)
-       str_l   x4, idmap_ptrs_per_pgd, x5
 #endif
 1:
-       ldr_l   x4, idmap_ptrs_per_pgd
        adr_l   x6, __idmap_text_end            // __pa(__idmap_text_end)
 
        map_memory x0, x1, x3, x6, x7, x3, x4, x10, x11, x12, x13, x14
index 9b4fc78f7a4d8ab51936e4bbd426559fac80b0f7..63732ca0ccf55f0c903cfa30a5a9b82591091890 100644 (file)
@@ -44,7 +44,6 @@
 #define NO_EXEC_MAPPINGS       BIT(2)  /* assumes FEAT_HPDS is not used */
 
 int idmap_t0sz __ro_after_init;
-u64 idmap_ptrs_per_pgd = PTRS_PER_PGD;
 
 #if VA_BITS > 48
 u64 vabits_actual __ro_after_init = VA_BITS_MIN;