Commit 57306c66 authored by Michael Ellerman's avatar Michael Ellerman

powerpc/mm/radix: Remove the retry in the split mapping logic

When we have CONFIG_STRICT_KERNEL_RWX enabled, we want to split the
linear mapping at the text/data boundary so we can map the kernel
text read only.

The current logic uses a goto inside the for loop, which works, but is
hard to reason about.

When we hit the goto retry case we set max_mapping_size to PMD_SIZE
and go back to the start.

Setting max_mapping_size means we skip the PUD case and go to the PMD
case.

We know we will pass the alignment and gap checks because the only
reason we are there is we hit the goto retry, and that is guarded by
mapping_size == PUD_SIZE, which means addr is PUD aligned and gap is
greater or equal to PUD_SIZE.

So the only part of the check that can fail is the mmu_psize_defs
check for the 2M page size.

If we just duplicate that check we can avoid the goto, and we get the
same result.
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent 81d1b54d
...@@ -261,7 +261,6 @@ static int __meminit create_physical_mapping(unsigned long start, ...@@ -261,7 +261,6 @@ static int __meminit create_physical_mapping(unsigned long start,
{ {
unsigned long vaddr, addr, mapping_size = 0; unsigned long vaddr, addr, mapping_size = 0;
pgprot_t prot; pgprot_t prot;
unsigned long max_mapping_size;
#ifdef CONFIG_STRICT_KERNEL_RWX #ifdef CONFIG_STRICT_KERNEL_RWX
int split_text_mapping = 1; int split_text_mapping = 1;
#else #else
...@@ -276,12 +275,9 @@ static int __meminit create_physical_mapping(unsigned long start, ...@@ -276,12 +275,9 @@ static int __meminit create_physical_mapping(unsigned long start,
gap = end - addr; gap = end - addr;
previous_size = mapping_size; previous_size = mapping_size;
max_mapping_size = PUD_SIZE;
retry:
if (IS_ALIGNED(addr, PUD_SIZE) && gap >= PUD_SIZE && if (IS_ALIGNED(addr, PUD_SIZE) && gap >= PUD_SIZE &&
mmu_psize_defs[MMU_PAGE_1G].shift && mmu_psize_defs[MMU_PAGE_1G].shift) {
PUD_SIZE <= max_mapping_size) {
mapping_size = PUD_SIZE; mapping_size = PUD_SIZE;
psize = MMU_PAGE_1G; psize = MMU_PAGE_1G;
} else if (IS_ALIGNED(addr, PMD_SIZE) && gap >= PMD_SIZE && } else if (IS_ALIGNED(addr, PMD_SIZE) && gap >= PMD_SIZE &&
...@@ -296,8 +292,10 @@ static int __meminit create_physical_mapping(unsigned long start, ...@@ -296,8 +292,10 @@ static int __meminit create_physical_mapping(unsigned long start,
if (split_text_mapping && (mapping_size == PUD_SIZE) && if (split_text_mapping && (mapping_size == PUD_SIZE) &&
(addr < __pa_symbol(__init_begin)) && (addr < __pa_symbol(__init_begin)) &&
(addr + mapping_size) > __pa_symbol(__init_begin)) { (addr + mapping_size) > __pa_symbol(__init_begin)) {
max_mapping_size = PMD_SIZE; if (mmu_psize_defs[MMU_PAGE_2M].shift)
goto retry; mapping_size = PMD_SIZE;
else
mapping_size = PAGE_SIZE;
} }
if (split_text_mapping && (mapping_size == PMD_SIZE) && if (split_text_mapping && (mapping_size == PMD_SIZE) &&
......
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