arm64: Move .hyp.rodata outside of the _sdata.._edata range
authorMarc Zyngier <maz@kernel.org>
Mon, 2 Aug 2021 12:38:29 +0000 (13:38 +0100)
committerMarc Zyngier <maz@kernel.org>
Wed, 4 Aug 2021 12:09:20 +0000 (13:09 +0100)
The HYP rodata section is currently lumped together with the BSS,
which isn't exactly what is expected (it gets registered with
kmemleak, for example).

Move it away so that it is actually marked RO. As an added
benefit, it isn't registered with kmemleak anymore.

Fixes: 380e18ade4a5 ("KVM: arm64: Introduce a BSS section for use at Hyp")
Suggested-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Cc: stable@vger.kernel.org #5.13
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Link: https://lore.kernel.org/r/20210802123830.2195174-2-maz@kernel.org
arch/arm64/kernel/vmlinux.lds.S

index 709d2c433c5e9affe395f7d64bf6b29652c4c749..f6b1a88245db2f01ad596ffb342db3e024d3a868 100644 (file)
@@ -181,6 +181,8 @@ SECTIONS
        /* everything from this point to __init_begin will be marked RO NX */
        RO_DATA(PAGE_SIZE)
 
+       HYPERVISOR_DATA_SECTIONS
+
        idmap_pg_dir = .;
        . += IDMAP_DIR_SIZE;
        idmap_pg_end = .;
@@ -260,8 +262,6 @@ SECTIONS
        _sdata = .;
        RW_DATA(L1_CACHE_BYTES, PAGE_SIZE, THREAD_ALIGN)
 
-       HYPERVISOR_DATA_SECTIONS
-
        /*
         * Data written with the MMU off but read with the MMU on requires
         * cache lines to be invalidated, discarding up to a Cache Writeback