mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
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
This commit is contained in:
parent
fbee6ba2dc
commit
970d54f99c
@ -652,6 +652,7 @@ static void init_hpte_page_sizes(void)
|
|||||||
|
|
||||||
static void __init htab_init_page_sizes(void)
|
static void __init htab_init_page_sizes(void)
|
||||||
{
|
{
|
||||||
|
bool aligned = true;
|
||||||
init_hpte_page_sizes();
|
init_hpte_page_sizes();
|
||||||
|
|
||||||
if (!debug_pagealloc_enabled()) {
|
if (!debug_pagealloc_enabled()) {
|
||||||
@ -659,7 +660,15 @@ static void __init htab_init_page_sizes(void)
|
|||||||
* Pick a size for the linear mapping. Currently, we only
|
* Pick a size for the linear mapping. Currently, we only
|
||||||
* support 16M, 1M and 4K which is the default
|
* support 16M, 1M and 4K which is the default
|
||||||
*/
|
*/
|
||||||
if (mmu_psize_defs[MMU_PAGE_16M].shift)
|
if (IS_ENABLED(STRICT_KERNEL_RWX) &&
|
||||||
|
(unsigned long)_stext % 0x1000000) {
|
||||||
|
if (mmu_psize_defs[MMU_PAGE_16M].shift)
|
||||||
|
pr_warn("Kernel not 16M aligned, "
|
||||||
|
"disabling 16M linear map alignment");
|
||||||
|
aligned = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mmu_psize_defs[MMU_PAGE_16M].shift && aligned)
|
||||||
mmu_linear_psize = MMU_PAGE_16M;
|
mmu_linear_psize = MMU_PAGE_16M;
|
||||||
else if (mmu_psize_defs[MMU_PAGE_1M].shift)
|
else if (mmu_psize_defs[MMU_PAGE_1M].shift)
|
||||||
mmu_linear_psize = MMU_PAGE_1M;
|
mmu_linear_psize = MMU_PAGE_1M;
|
||||||
|
Loading…
Reference in New Issue
Block a user