[SPARC64]: destroy_context() needs to disable interrupts.
authorDavid S. Miller <davem@sunset.davemloft.net>
Fri, 24 Feb 2006 05:40:15 +0000 (21:40 -0800)
committerDavid S. Miller <davem@sunset.davemloft.net>
Mon, 20 Mar 2006 09:14:01 +0000 (01:14 -0800)
get_new_mmu_context() can be invoked from interrupt context
now for the new SMP version wrap handling.

So disable interrupt while taking ctx_alloc_lock in destroy_context()
so we don't deadlock.

Signed-off-by: David S. Miller <davem@davemloft.net>
arch/sparc64/mm/tsb.c

index 353cb060561b280310a114c4ea358dd2828bbba9..534ac2819892f96daebef6fd4d46b86b7ddc8c4f 100644 (file)
@@ -373,6 +373,7 @@ int init_new_context(struct task_struct *tsk, struct mm_struct *mm)
 void destroy_context(struct mm_struct *mm)
 {
        unsigned long size = mm->context.tsb_nentries * sizeof(struct tsb);
+       unsigned long flags;
 
        free_pages((unsigned long) mm->context.tsb, get_order(size));
 
@@ -383,12 +384,12 @@ void destroy_context(struct mm_struct *mm)
        mm->context.tsb = NULL;
        mm->context.tsb_reg_val = 0UL;
 
-       spin_lock(&ctx_alloc_lock);
+       spin_lock_irqsave(&ctx_alloc_lock, flags);
 
        if (CTX_VALID(mm->context)) {
                unsigned long nr = CTX_NRBITS(mm->context);
                mmu_context_bmap[nr>>6] &= ~(1UL << (nr & 63));
        }
 
-       spin_unlock(&ctx_alloc_lock);
+       spin_unlock_irqrestore(&ctx_alloc_lock, flags);
 }