projects
/
deliverable
/
linux.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
powerpc/mm: Fix some SMP issues with MMU context handling
[deliverable/linux.git]
/
arch
/
powerpc
/
mm
/
mmu_context_nohash.c
diff --git
a/arch/powerpc/mm/mmu_context_nohash.c
b/arch/powerpc/mm/mmu_context_nohash.c
index 030d0005b4d2c0682ca1adfd988b52000e73b7f2..c42858780cbd239565289bb572b5cbf2198744e2 100644
(file)
--- a/
arch/powerpc/mm/mmu_context_nohash.c
+++ b/
arch/powerpc/mm/mmu_context_nohash.c
@@
-73,7
+73,6
@@
static unsigned int steal_context_smp(unsigned int id)
struct mm_struct *mm;
unsigned int cpu, max;
struct mm_struct *mm;
unsigned int cpu, max;
- again:
max = last_context - first_context;
/* Attempt to free next_context first and then loop until we manage */
max = last_context - first_context;
/* Attempt to free next_context first and then loop until we manage */
@@
-108,7
+107,9
@@
static unsigned int steal_context_smp(unsigned int id)
spin_unlock(&context_lock);
cpu_relax();
spin_lock(&context_lock);
spin_unlock(&context_lock);
cpu_relax();
spin_lock(&context_lock);
- goto again;
+
+ /* This will cause the caller to try again */
+ return MMU_NO_CONTEXT;
}
#endif /* CONFIG_SMP */
}
#endif /* CONFIG_SMP */
@@
-194,6
+195,8
@@
void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next)
WARN_ON(prev->context.active < 1);
prev->context.active--;
}
WARN_ON(prev->context.active < 1);
prev->context.active--;
}
+
+ again:
#endif /* CONFIG_SMP */
/* If we already have a valid assigned context, skip all that */
#endif /* CONFIG_SMP */
/* If we already have a valid assigned context, skip all that */
@@
-212,7
+215,8
@@
void switch_mmu_context(struct mm_struct *prev, struct mm_struct *next)
#ifdef CONFIG_SMP
if (num_online_cpus() > 1) {
id = steal_context_smp(id);
#ifdef CONFIG_SMP
if (num_online_cpus() > 1) {
id = steal_context_smp(id);
- goto stolen;
+ if (id == MMU_NO_CONTEXT)
+ goto again;
}
#endif /* CONFIG_SMP */
id = steal_context_up(id);
}
#endif /* CONFIG_SMP */
id = steal_context_up(id);
@@
-286,8
+290,8
@@
void destroy_context(struct mm_struct *mm)
mm->context.id = MMU_NO_CONTEXT;
#ifdef DEBUG_MAP_CONSISTENCY
mm->context.active = 0;
mm->context.id = MMU_NO_CONTEXT;
#ifdef DEBUG_MAP_CONSISTENCY
mm->context.active = 0;
- context_mm[id] = NULL;
#endif
#endif
+ context_mm[id] = NULL;
nr_free_contexts++;
}
spin_unlock(&context_lock);
nr_free_contexts++;
}
spin_unlock(&context_lock);
This page took
0.033671 seconds
and
5
git commands to generate.