summaryrefslogtreecommitdiffstats
path: root/arch/arc/include/asm/mmu_context.h
diff options
context:
space:
mode:
authorVineet Gupta <vgupta@synopsys.com>2014-11-13 19:27:24 +0530
committerVineet Gupta <vgupta@synopsys.com>2019-10-28 12:12:31 -0700
commitcfd9d70a855edf6adb37d0ed88be9e35274dbe49 (patch)
tree3be75666a3101764e58a227672dbf5e25f945da4 /arch/arc/include/asm/mmu_context.h
parent7b491c0b62594a21cab357e0118603830a500de3 (diff)
downloadlinux-cfd9d70a855edf6adb37d0ed88be9e35274dbe49.tar.bz2
ARCv2: mm: TLB Miss optim: SMP builds can cache pgd pointer in mmu scratch reg
ARC700 exception (and intr handling) didn't have auto stack switching thus had to rely on stashing a reg temporarily (to free it up) at a known place in memory, allowing to code up the low level stack switching. This however was not re-entrant in SMP which thus had to repurpose the per-cpu MMU SCRATCH DATA register otherwise used to "cache" the task pdg pointer (vs. reading it from mm struct) The newer HS cores do have auto-stack switching and thus even SMP builds can use the MMU SCRATCH reg as originally intended. This patch fixes the restriction to ARC700 SMP builds only Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
Diffstat (limited to 'arch/arc/include/asm/mmu_context.h')
-rw-r--r--arch/arc/include/asm/mmu_context.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/arc/include/asm/mmu_context.h b/arch/arc/include/asm/mmu_context.h
index 035470816be5..3a5e6a5b9ed6 100644
--- a/arch/arc/include/asm/mmu_context.h
+++ b/arch/arc/include/asm/mmu_context.h
@@ -144,7 +144,7 @@ static inline void switch_mm(struct mm_struct *prev, struct mm_struct *next,
*/
cpumask_set_cpu(cpu, mm_cpumask(next));
-#ifndef CONFIG_SMP
+#ifdef ARC_USE_SCRATCH_REG
/* PGD cached in MMU reg to avoid 3 mem lookups: task->mm->pgd */
write_aux_reg(ARC_REG_SCRATCH_DATA0, next->pgd);
#endif