CRIS: Add config for pausing a seg-faulting process
authorJesper Nilsson <jesper.nilsson@axis.com>
Wed, 4 Aug 2010 15:42:43 +0000 (17:42 +0200)
committerJesper Nilsson <jesper.nilsson@axis.com>
Wed, 4 Aug 2010 16:28:48 +0000 (18:28 +0200)
Put it on a wait queue, so we can attach gdb to the process
to debug it instead of just killing it.

Signed-off-by: Jesper Nilsson <jesper.nilsson@axis.com>
arch/cris/Kconfig.debug
arch/cris/mm/fault.c

index 0a1d62a23614884b82d8af1bef6d06f127fb629c..0b9a630dc812c1106522e5ce59e38c03201a8dcb 100644 (file)
@@ -32,4 +32,10 @@ config DEBUG_NMI_OOPS
          If the system locks up without any debug information you can say Y
          here to make it possible to dump an OOPS with an external NMI.
 
+config NO_SEGFAULT_TERMINATION
+       bool "Keep segfaulting processes"
+       help
+         Place segfaulting user mode processes on a wait queue instead of
+         delivering a terminating SIGSEGV to allow debugging with gdb.
+
 endmenu
index a2b4c0b8f0fdb6149ef4e031cd11627bcfc72cf2..7705cd7cef36b5f41069334b7fcbe8be4e5a59c8 100644 (file)
@@ -7,6 +7,7 @@
 #include <linux/mm.h>
 #include <linux/interrupt.h>
 #include <linux/module.h>
+#include <linux/wait.h>
 #include <asm/uaccess.h>
 
 extern int find_fixup_code(struct pt_regs *);
@@ -190,14 +191,20 @@ do_page_fault(unsigned long address, struct pt_regs *regs,
        /* User mode accesses just cause a SIGSEGV */
 
        if (user_mode(regs)) {
+               printk(KERN_NOTICE "%s (pid %d) segfaults for page "
+                       "address %08lx at pc %08lx\n",
+                       tsk->comm, tsk->pid,
+                       address, instruction_pointer(regs));
+#ifdef CONFIG_NO_SEGFAULT_TERMINATION
+               DECLARE_WAIT_QUEUE_HEAD(wq);
+               wait_event_interruptible(wq, 0 == 1);
+#else
                info.si_signo = SIGSEGV;
                info.si_errno = 0;
                /* info.si_code has been set above */
                info.si_addr = (void *)address;
                force_sig_info(SIGSEGV, &info, tsk);
-               printk(KERN_NOTICE "%s (pid %d) segfaults for page "
-                      "address %08lx at pc %08lx\n",
-                      tsk->comm, tsk->pid, address, instruction_pointer(regs));
+#endif
                return;
        }