diff options
author | Vineet Gupta <vgupta@synopsys.com> | 2014-11-13 14:57:24 +0100 |
---|---|---|
committer | Vineet Gupta <vgupta@synopsys.com> | 2019-10-28 20:12:31 +0100 |
commit | cfd9d70a855edf6adb37d0ed88be9e35274dbe49 (patch) | |
tree | 3be75666a3101764e58a227672dbf5e25f945da4 /arch/arc/mm/tlbex.S | |
parent | ARC: nSIM_700: remove unused network options (diff) | |
download | linux-cfd9d70a855edf6adb37d0ed88be9e35274dbe49.tar.xz linux-cfd9d70a855edf6adb37d0ed88be9e35274dbe49.zip |
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/mm/tlbex.S')
-rw-r--r-- | arch/arc/mm/tlbex.S | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/arc/mm/tlbex.S b/arch/arc/mm/tlbex.S index c55d95dd2f39..d6fbdeda400a 100644 --- a/arch/arc/mm/tlbex.S +++ b/arch/arc/mm/tlbex.S @@ -193,7 +193,7 @@ ex_saved_reg1: lr r2, [efa] -#ifndef CONFIG_SMP +#ifdef ARC_USE_SCRATCH_REG lr r1, [ARC_REG_SCRATCH_DATA0] ; current pgd #else GET_CURR_TASK_ON_CPU r1 |