]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commit
powerpc/book3s64/hash: Disable 16M linear mapping size if not aligned
authorRussell Currey <ruscur@russell.cc>
Tue, 24 Dec 2019 06:41:25 +0000 (17:41 +1100)
committerMichael Ellerman <mpe@ellerman.id.au>
Thu, 16 Jan 2020 04:59:36 +0000 (14:59 +1000)
commit970d54f99ceac5bbf27929cb5ebfe18338ba1543
treed4a61eb30293e482c122096f300c1072bf684227
parentfbee6ba2dca30d302efe6bddb3a886f5e964a257
powerpc/book3s64/hash: Disable 16M linear mapping size if not aligned

With STRICT_KERNEL_RWX on in a relocatable kernel under the hash MMU,
if the position the kernel is loaded at is not 16M aligned things go
horribly wrong. Specifically hash__mark_initmem_nx() will call
hash__change_memory_range() which then aligns down the start address,
and due to the text not being 16M aligned causes some of the kernel
text to be marked non-executable.

We can avoid this when selecting the linear mapping size, so do so and
print a warning. I tested this for various alignments and as long as
the position is 64K aligned it's fine (the base requirement for
powerpc).

Signed-off-by: Russell Currey <ruscur@russell.cc>
[mpe: Add details of the failure mode]
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20191224064126.183670-1-ruscur@russell.cc
arch/powerpc/mm/book3s64/hash_utils.c