Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 410f1483 authored by Catalin Marinas's avatar Catalin Marinas Committed by Russell King
Browse files

ARM: 6667/1: Fix early_pte_alloc() assumption about the Linux PTE



With LPAE we no longer have software bits in a separate Linux PTE and
the early_pte_alloc() function should pass PTE_HWTABLE_OFF +
PTE_HWTABLE_SIZE to early_alloc() to avoid allocating extra memory.

Signed-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 36bb94ba
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -532,7 +532,7 @@ static void __init *early_alloc(unsigned long sz)
static pte_t * __init early_pte_alloc(pmd_t *pmd, unsigned long addr, unsigned long prot)
static pte_t * __init early_pte_alloc(pmd_t *pmd, unsigned long addr, unsigned long prot)
{
{
	if (pmd_none(*pmd)) {
	if (pmd_none(*pmd)) {
		pte_t *pte = early_alloc(2 * PTRS_PER_PTE * sizeof(pte_t));
		pte_t *pte = early_alloc(PTE_HWTABLE_OFF + PTE_HWTABLE_SIZE);
		__pmd_populate(pmd, __pa(pte), prot);
		__pmd_populate(pmd, __pa(pte), prot);
	}
	}
	BUG_ON(pmd_bad(*pmd));
	BUG_ON(pmd_bad(*pmd));