[PATCH v2 09/20] ARM: LPAE: Change setup_mm_for_reboot() to work with LPAE

Russell King - ARM Linux linux at arm.linux.org.uk
Mon Nov 22 08:11:14 EST 2010


On Fri, Nov 12, 2010 at 06:00:29PM +0000, Catalin Marinas wrote:
> diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c
> index 4147cc6..3784acc 100644
> --- a/arch/arm/mm/mmu.c
> +++ b/arch/arm/mm/mmu.c
> @@ -1098,13 +1098,16 @@ void setup_mm_for_reboot(char mode)
>  	if (cpu_architecture() <= CPU_ARCH_ARMv5TEJ && !cpu_is_xscale())
>  		base_pmdval |= PMD_BIT4;
>  
> -	for (i = 0; i < FIRST_USER_PGD_NR + USER_PTRS_PER_PGD; i++, pgd++) {
> +	for (i = 0; i < TASK_SIZE >> PMD_SHIFT; i++) {
>  		unsigned long pmdval = (i << PMD_SHIFT) | base_pmdval;
>  		pmd_t *pmd;
> +		unsigned long addr = i << PMD_SHIFT;
>  
> -		pmd = pmd_off(pgd, i << PMD_SHIFT);
> +		pmd = pmd_off(pgd + pgd_index(addr), addr);
>  		pmd[0] = __pmd(pmdval);
> +#ifndef CONFIG_ARM_LPAE
>  		pmd[1] = __pmd(pmdval + (1 << (PMD_SHIFT - 1)));
> +#endif
>  		flush_pmd_entry(pmd);
>  	}

The same is required for the identity mapping code.  If this uses that
code, the problem becomes localized there.



More information about the linux-arm-kernel mailing list