]> git.karo-electronics.de Git - karo-tx-linux.git/commit
MIPS: mm: Use scratch for PGD when !CONFIG_MIPS_PGD_C0_CONTEXT
authorJayachandran C <jchandra@broadcom.com>
Tue, 18 Jun 2013 11:45:15 +0000 (11:45 +0000)
committerRalf Baechle <ralf@linux-mips.org>
Tue, 18 Jun 2013 12:59:06 +0000 (14:59 +0200)
commit89460ce8912200429c8ed141a01eabd226683614
tree8bf389e41e3cd42f7a993408f4a870e14d09434e
parent6c3a2d140d3b67e1564ee94727f0d43a2cdeb9f5
MIPS: mm: Use scratch for PGD when !CONFIG_MIPS_PGD_C0_CONTEXT

Allow usage of scratch register for current pgd even when
MIPS_PGD_C0_CONTEXT is not configured. MIPS_PGD_C0_CONTEXT is set
for 64r2 platforms to indicate availability of Xcontext for saving
cpuid, thus freeing Context to be used for saving PGD. This option
was also tied to using a scratch register for storing PGD.

This commit will allow usage of scratch register to store the current
pgd if one can be allocated for the platform, even when
MIPS_PGD_C0_CONTEXT is not set. The cpuid will be kept in the CP0
Context register in this case.

The code to store the current pgd for the TLB miss handler is now
generated in all cases. When scratch register is available, the PGD
is also stored in the scratch register.

Signed-off-by: Jayachandran C <jchandra@broadcom.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/5491/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/include/asm/mmu_context.h
arch/mips/mm/tlbex.c