Commit 513f5bba authored by Christophe Leroy's avatar Christophe Leroy Committed by Michael Ellerman

powerpc/32: Remove __map_without_ltlbs

__map_without_ltlbs is used only for 40x, and only when
STRICT_KERNEL_RWX, KFENCE or DEBUG_PAGEALLOC is active.

Do the verification directly in 40x version of mmu_mapin_ram()
and remove __map_without_ltlbs from core ppc32.
Signed-off-by: default avatarChristophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/3422094db965d218c4c3d8580f526963a9ac897f.1655202721.git.christophe.leroy@csgroup.eu
parent 56e54b4e
...@@ -69,29 +69,9 @@ EXPORT_SYMBOL(agp_special_page); ...@@ -69,29 +69,9 @@ EXPORT_SYMBOL(agp_special_page);
void MMU_init(void); void MMU_init(void);
int __map_without_ltlbs;
/* max amount of low RAM to map in */ /* max amount of low RAM to map in */
unsigned long __max_low_memory = MAX_LOW_MEM; unsigned long __max_low_memory = MAX_LOW_MEM;
/*
* Check for command-line options that affect what MMU_init will do.
*/
static void __init MMU_setup(void)
{
if (IS_ENABLED(CONFIG_PPC_8xx))
return;
if (IS_ENABLED(CONFIG_KFENCE))
__map_without_ltlbs = 1;
if (debug_pagealloc_enabled())
__map_without_ltlbs = 1;
if (strict_kernel_rwx_enabled())
__map_without_ltlbs = 1;
}
/* /*
* MMU_init sets up the basic memory mappings for the kernel, * MMU_init sets up the basic memory mappings for the kernel,
* including both RAM and possibly some I/O regions, * including both RAM and possibly some I/O regions,
...@@ -102,9 +82,6 @@ void __init MMU_init(void) ...@@ -102,9 +82,6 @@ void __init MMU_init(void)
if (ppc_md.progress) if (ppc_md.progress)
ppc_md.progress("MMU:enter", 0x111); ppc_md.progress("MMU:enter", 0x111);
/* parse args from command line */
MMU_setup();
/* /*
* Reserve gigantic pages for hugetlb. This MUST occur before * Reserve gigantic pages for hugetlb. This MUST occur before
* lowmem_end_addr is initialized below. * lowmem_end_addr is initialized below.
......
...@@ -43,7 +43,6 @@ ...@@ -43,7 +43,6 @@
#include <mm/mmu_decl.h> #include <mm/mmu_decl.h>
extern int __map_without_ltlbs;
/* /*
* MMU_init_hw does the chip-specific initialization of the MMU hardware. * MMU_init_hw does the chip-specific initialization of the MMU hardware.
*/ */
...@@ -94,7 +93,13 @@ unsigned long __init mmu_mapin_ram(unsigned long base, unsigned long top) ...@@ -94,7 +93,13 @@ unsigned long __init mmu_mapin_ram(unsigned long base, unsigned long top)
p = 0; p = 0;
s = total_lowmem; s = total_lowmem;
if (__map_without_ltlbs) if (IS_ENABLED(CONFIG_KFENCE))
return 0;
if (debug_pagealloc_enabled())
return 0;
if (strict_kernel_rwx_enabled())
return 0; return 0;
while (s >= LARGE_PAGE_SIZE_16M) { while (s >= LARGE_PAGE_SIZE_16M) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment