]> 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>
Sun, 11 Aug 2013 11:40:17 +0000 (17:10 +0530)
committerRalf Baechle <ralf@linux-mips.org>
Wed, 18 Sep 2013 18:27:22 +0000 (20:27 +0200)
commit7c4b2a06547c74db95cc09b3eb6f2fa188210759
tree7a9d3722d996f9e729b4ea21d4b8e23e98765aa0
parent788ff4763215358c16a405a9cd86d6d73ef595c0
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/5709/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/include/asm/mmu_context.h
arch/mips/mm/tlbex.c