Commit 10527e80 authored by Aneesh Kumar K.V's avatar Aneesh Kumar K.V Committed by Michael Ellerman

powerpc/hash: Skip non initialized page size in init_hpte_page_sizes

One of the easiest way to test config with 4K HPTE is to disable 64K hardware
page size like below.

int __init htab_dt_scan_page_sizes(unsigned long node,

 		size -= 3; prop += 3;
 		base_idx = get_idx_from_shift(base_shift);
-		if (base_idx < 0) {
+		if (base_idx < 0 || base_idx == MMU_PAGE_64K) {
 			/* skip the pte encoding also */
 			prop += lpnum * 2; size -= lpnum * 2;

But then this results in error in other part of the code such as MPSS parsing
where we look at 4K base page size and 64K actual page size support.

This patch fix MPSS parsing by ignoring the actual page sizes marked
unsupported. In reality this can happen only with a corrupt device tree. But it
is good to tighten the error check.
Signed-off-by: default avatarAneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent 4afa0f3a
...@@ -608,7 +608,7 @@ static void init_hpte_page_sizes(void) ...@@ -608,7 +608,7 @@ static void init_hpte_page_sizes(void)
continue; /* not a supported page size */ continue; /* not a supported page size */
for (ap = bp; ap < MMU_PAGE_COUNT; ++ap) { for (ap = bp; ap < MMU_PAGE_COUNT; ++ap) {
penc = mmu_psize_defs[bp].penc[ap]; penc = mmu_psize_defs[bp].penc[ap];
if (penc == -1) if (penc == -1 || !mmu_psize_defs[ap].shift)
continue; continue;
shift = mmu_psize_defs[ap].shift - LP_SHIFT; shift = mmu_psize_defs[ap].shift - LP_SHIFT;
if (shift <= 0) if (shift <= 0)
......
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