arch/tile: don't enable irqs unconditionally in page fault handler
authorChris Metcalf <cmetcalf@tilera.com>
Thu, 29 Mar 2012 19:40:50 +0000 (15:40 -0400)
committerChris Metcalf <cmetcalf@tilera.com>
Mon, 2 Apr 2012 16:13:09 +0000 (12:13 -0400)
If we took a page fault while we had interrupts disabled, we
shouldn't enable them in the page fault handler.

Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
arch/tile/mm/fault.c

index a1da473c855592fed2a024ba5bfaf4831b0bf052..22e58f51ed23eedd405e9dc0b719eddb9550f502 100644 (file)
@@ -342,9 +342,12 @@ static int handle_page_fault(struct pt_regs *regs,
        /*
         * If we're trying to touch user-space addresses, we must
         * be either at PL0, or else with interrupts enabled in the
-        * kernel, so either way we can re-enable interrupts here.
+        * kernel, so either way we can re-enable interrupts here
+        * unless we are doing atomic access to user space with
+        * interrupts disabled.
         */
-       local_irq_enable();
+       if (!(regs->flags & PT_FLAGS_DISABLE_IRQ))
+               local_irq_enable();
 
        mm = tsk->mm;