summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSonny Rao <sonny@burdell.org>2006-06-27 14:46:09 +0200
committerPaul Mackerras <paulus@samba.org>2006-06-29 08:22:46 +0200
commitf86c9747fe1cd72b2c5c6bdf72d17aeb2a3c6cb0 (patch)
treec32ef71ff0e535a467e428d3d874b65232f76708
parent[POWERPC] mpc7448hpc2 (taiga) board config file (diff)
downloadlinux-f86c9747fe1cd72b2c5c6bdf72d17aeb2a3c6cb0.tar.xz
linux-f86c9747fe1cd72b2c5c6bdf72d17aeb2a3c6cb0.zip
[POWERPC] Fix idr locking in init_new_context
We always need to serialize accesses to mmu_context_idr. I hit this bug when testing with a small number of mmu contexts. Signed-off-by: Sonny Rao <sonny@burdell.org> Signed-off-by: Paul Mackerras <paulus@samba.org>
-rw-r--r--arch/powerpc/mm/mmu_context_64.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/powerpc/mm/mmu_context_64.c b/arch/powerpc/mm/mmu_context_64.c
index 65d18dca266f..e2051efa09c5 100644
--- a/arch/powerpc/mm/mmu_context_64.c
+++ b/arch/powerpc/mm/mmu_context_64.c
@@ -44,7 +44,9 @@ again:
return err;
if (index > MAX_CONTEXT) {
+ spin_lock(&mmu_context_lock);
idr_remove(&mmu_context_idr, index);
+ spin_unlock(&mmu_context_lock);
return -ENOMEM;
}