]> www.infradead.org Git - users/hch/uuid.git/commitdiff
arm64: vmlinux.ld.S: add assertion for tramp_pg_dir offset
authorJoey Gouly <joey.gouly@arm.com>
Tue, 2 Feb 2021 12:36:58 +0000 (12:36 +0000)
committerWill Deacon <will@kernel.org>
Wed, 3 Feb 2021 20:43:45 +0000 (20:43 +0000)
Add TRAMP_SWAPPER_OFFSET and use that instead of hardcoding
the offset between swapper_pg_dir and tramp_pg_dir.

Then use TRAMP_SWAPPER_OFFSET to assert that the offset is
correct at link time.

Signed-off-by: Joey Gouly <joey.gouly@arm.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Tested-by: Mark Rutland <mark.rutland@arm.com>
Link: https://lore.kernel.org/r/20210202123658.22308-3-joey.gouly@arm.com
Signed-off-by: Will Deacon <will@kernel.org>
arch/arm64/include/asm/memory.h
arch/arm64/kernel/entry.S
arch/arm64/kernel/vmlinux.lds.S

index f6bf8a972a16ec020c68436c0b2862670ac2d146..6c26749376652b23d770b96f76de739ad44c3285 100644 (file)
  */
 #define RESERVED_SWAPPER_OFFSET        (PAGE_SIZE)
 
+/*
+ *  Open-coded (swapper_pg_dir - tramp_pg_dir) as this cannot be calculated
+ *  until link time.
+ */
+#define TRAMP_SWAPPER_OFFSET   (2 * PAGE_SIZE)
+
 #ifndef __ASSEMBLY__
 
 #include <linux/bitops.h>
index c9bae73f2621a345d9b590cf896a2e8ecc5d47c4..c6aee646eb6bf5d604001a20923a9fbf343da5cb 100644 (file)
@@ -805,7 +805,7 @@ SYM_CODE_END(ret_to_user)
        // Move from tramp_pg_dir to swapper_pg_dir
        .macro tramp_map_kernel, tmp
        mrs     \tmp, ttbr1_el1
-       add     \tmp, \tmp, #(2 * PAGE_SIZE)
+       add     \tmp, \tmp, #TRAMP_SWAPPER_OFFSET
        bic     \tmp, \tmp, #USER_ASID_FLAG
        msr     ttbr1_el1, \tmp
 #ifdef CONFIG_QCOM_FALKOR_ERRATUM_1003
@@ -825,7 +825,7 @@ alternative_else_nop_endif
        // Move from swapper_pg_dir to tramp_pg_dir
        .macro tramp_unmap_kernel, tmp
        mrs     \tmp, ttbr1_el1
-       sub     \tmp, \tmp, #(2 * PAGE_SIZE)
+       sub     \tmp, \tmp, #TRAMP_SWAPPER_OFFSET
        orr     \tmp, \tmp, #USER_ASID_FLAG
        msr     ttbr1_el1, \tmp
        /*
index a03a5300bce9f3de08822a9c48f1a7d165a46a1c..68f76a96c60b44a6150ea57c703f4803f955fc80 100644 (file)
@@ -319,3 +319,8 @@ ASSERT(_text == KIMAGE_VADDR, "HEAD is misaligned")
 
 ASSERT(swapper_pg_dir - reserved_pg_dir == RESERVED_SWAPPER_OFFSET,
        "RESERVED_SWAPPER_OFFSET is wrong!")
+
+#ifdef CONFIG_UNMAP_KERNEL_AT_EL0
+ASSERT(swapper_pg_dir - tramp_pg_dir == TRAMP_SWAPPER_OFFSET,
+       "TRAMP_SWAPPER_OFFSET is wrong!")
+#endif