提交 c865c955 编写于 作者: C Christophe Leroy 提交者: Michael Ellerman

powerpc/mm: Remove stale_map[] handling on non SMP processors

stale_map[] bits are only set in steal_context_smp() so
on UP processors this map is useless. Only manage it for SMP
processors.
Signed-off-by: NChristophe Leroy <christophe.leroy@c-s.fr>
Signed-off-by: NMichael Ellerman <mpe@ellerman.id.au>
上级 9e4f02e2
...@@ -84,7 +84,9 @@ ...@@ -84,7 +84,9 @@
static unsigned int next_context, nr_free_contexts; static unsigned int next_context, nr_free_contexts;
static unsigned long *context_map; static unsigned long *context_map;
#ifdef CONFIG_SMP
static unsigned long *stale_map[NR_CPUS]; static unsigned long *stale_map[NR_CPUS];
#endif
static struct mm_struct **context_mm; static struct mm_struct **context_mm;
static DEFINE_RAW_SPINLOCK(context_lock); static DEFINE_RAW_SPINLOCK(context_lock);
...@@ -165,7 +167,9 @@ static unsigned int steal_context_smp(unsigned int id) ...@@ -165,7 +167,9 @@ static unsigned int steal_context_smp(unsigned int id)
static unsigned int steal_all_contexts(void) static unsigned int steal_all_contexts(void)
{ {
struct mm_struct *mm; struct mm_struct *mm;
#ifdef CONFIG_SMP
int cpu = smp_processor_id(); int cpu = smp_processor_id();
#endif
unsigned int id; unsigned int id;
for (id = FIRST_CONTEXT; id <= LAST_CONTEXT; id++) { for (id = FIRST_CONTEXT; id <= LAST_CONTEXT; id++) {
...@@ -183,7 +187,9 @@ static unsigned int steal_all_contexts(void) ...@@ -183,7 +187,9 @@ static unsigned int steal_all_contexts(void)
mm->context.active = 0; mm->context.active = 0;
#endif #endif
} }
#ifdef CONFIG_SMP
__clear_bit(id, stale_map[cpu]); __clear_bit(id, stale_map[cpu]);
#endif
} }
/* Flush the TLB for all contexts (not to be used on SMP) */ /* Flush the TLB for all contexts (not to be used on SMP) */
...@@ -202,7 +208,9 @@ static unsigned int steal_all_contexts(void) ...@@ -202,7 +208,9 @@ static unsigned int steal_all_contexts(void)
static unsigned int steal_context_up(unsigned int id) static unsigned int steal_context_up(unsigned int id)
{ {
struct mm_struct *mm; struct mm_struct *mm;
#ifdef CONFIG_SMP
int cpu = smp_processor_id(); int cpu = smp_processor_id();
#endif
/* Pick up the victim mm */ /* Pick up the victim mm */
mm = context_mm[id]; mm = context_mm[id];
...@@ -216,7 +224,9 @@ static unsigned int steal_context_up(unsigned int id) ...@@ -216,7 +224,9 @@ static unsigned int steal_context_up(unsigned int id)
mm->context.id = MMU_NO_CONTEXT; mm->context.id = MMU_NO_CONTEXT;
/* XXX This clear should ultimately be part of local_flush_tlb_mm */ /* XXX This clear should ultimately be part of local_flush_tlb_mm */
#ifdef CONFIG_SMP
__clear_bit(id, stale_map[cpu]); __clear_bit(id, stale_map[cpu]);
#endif
return id; return id;
} }
...@@ -255,7 +265,10 @@ static void context_check_map(void) { } ...@@ -255,7 +265,10 @@ static void context_check_map(void) { }
void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next, void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next,
struct task_struct *tsk) struct task_struct *tsk)
{ {
unsigned int i, id, cpu = smp_processor_id(); unsigned int id;
#ifdef CONFIG_SMP
unsigned int i, cpu = smp_processor_id();
#endif
unsigned long *map; unsigned long *map;
/* No lockless fast path .. yet */ /* No lockless fast path .. yet */
...@@ -329,6 +342,7 @@ void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next, ...@@ -329,6 +342,7 @@ void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next,
/* If that context got marked stale on this CPU, then flush the /* If that context got marked stale on this CPU, then flush the
* local TLB for it and unmark it before we use it * local TLB for it and unmark it before we use it
*/ */
#ifdef CONFIG_SMP
if (test_bit(id, stale_map[cpu])) { if (test_bit(id, stale_map[cpu])) {
pr_hardcont(" | stale flush %d [%d..%d]", pr_hardcont(" | stale flush %d [%d..%d]",
id, cpu_first_thread_sibling(cpu), id, cpu_first_thread_sibling(cpu),
...@@ -343,6 +357,7 @@ void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next, ...@@ -343,6 +357,7 @@ void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next,
__clear_bit(id, stale_map[i]); __clear_bit(id, stale_map[i]);
} }
} }
#endif
/* Flick the MMU and release lock */ /* Flick the MMU and release lock */
pr_hardcont(" -> %d\n", id); pr_hardcont(" -> %d\n", id);
...@@ -448,9 +463,7 @@ void __init mmu_context_init(void) ...@@ -448,9 +463,7 @@ void __init mmu_context_init(void)
*/ */
context_map = memblock_virt_alloc(CTX_MAP_SIZE, 0); context_map = memblock_virt_alloc(CTX_MAP_SIZE, 0);
context_mm = memblock_virt_alloc(sizeof(void *) * (LAST_CONTEXT + 1), 0); context_mm = memblock_virt_alloc(sizeof(void *) * (LAST_CONTEXT + 1), 0);
#ifndef CONFIG_SMP #ifdef CONFIG_SMP
stale_map[0] = memblock_virt_alloc(CTX_MAP_SIZE, 0);
#else
stale_map[boot_cpuid] = memblock_virt_alloc(CTX_MAP_SIZE, 0); stale_map[boot_cpuid] = memblock_virt_alloc(CTX_MAP_SIZE, 0);
cpuhp_setup_state_nocalls(CPUHP_POWERPC_MMU_CTX_PREPARE, cpuhp_setup_state_nocalls(CPUHP_POWERPC_MMU_CTX_PREPARE,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册