Module Name:    src
Committed By:   matt
Date:           Thu Sep  3 00:10:19 UTC 2009

Modified Files:
        src/sys/arch/mips/mips [matt-nb5-mips64]: trap.c

Log Message:
If DEBUG, if a lwp gets a fatal signal, print signo, cause, pc, va and
a register dump.


To generate a diff of this commit:
cvs rdiff -u -r1.217.12.7 -r1.217.12.8 src/sys/arch/mips/mips/trap.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/arch/mips/mips/trap.c
diff -u src/sys/arch/mips/mips/trap.c:1.217.12.7 src/sys/arch/mips/mips/trap.c:1.217.12.8
--- src/sys/arch/mips/mips/trap.c:1.217.12.7	Wed Sep  2 01:35:22 2009
+++ src/sys/arch/mips/mips/trap.c	Thu Sep  3 00:10:18 2009
@@ -1,4 +1,4 @@
-/*	$NetBSD: trap.c,v 1.217.12.7 2009/09/02 01:35:22 matt Exp $	*/
+/*	$NetBSD: trap.c,v 1.217.12.8 2009/09/03 00:10:18 matt Exp $	*/
 
 /*
  * Copyright (c) 1992, 1993
@@ -78,7 +78,7 @@
 
 #include <sys/cdefs.h>			/* RCS ID & Copyright macro defns */
 
-__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.217.12.7 2009/09/02 01:35:22 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.217.12.8 2009/09/03 00:10:18 matt Exp $");
 
 #include "opt_cputype.h"	/* which mips CPU levels do we support? */
 #include "opt_ddb.h"
@@ -565,10 +565,18 @@
 	fp->f_regs[_R_CAUSE] = cause;
 	fp->f_regs[_R_BADVADDR] = vaddr;
 #if defined(DEBUG)
-	printf("trap: pid %d(%s): sig %d: cause=%#x pc=%#"PRIxREGISTER
-	    " ra=%#"PRIxREGISTER" va=%#"PRIxVADDR " gp=%#"PRIxREGISTER"\n",
-	    p->p_pid, p->p_comm, ksi.ksi_signo, cause, fp->f_regs[_R_PC],
-	    fp->f_regs[_R_RA], vaddr, fp->f_regs[_R_GP]);
+	printf("trap: pid %d(%s): sig %d: cause=%#x epc=%#"PRIxREGISTER
+	    " va=%#"PRIxVADDR"\n",
+	    p->p_pid, p->p_comm, ksi.ksi_signo, cause,
+	    fp->f_regs[_R_PC], vaddr);
+	printf("registers:\n");
+	for (size_t i = 0; i < 32; i += 4) {
+		printf(
+		    "[%2zu]=%08"PRIxREGISTER" [%2zu]=%08"PRIxREGISTER
+		    " [%2zu]=%08"PRIxREGISTER" [%2zu]=%08"PRIxREGISTER "\n",
+		    i+0, fp->f_regs[i+0], i+1, fp->f_regs[i+1],
+		    i+2, fp->f_regs[i+2], i+3, fp->f_regs[i+3]);
+	}
 #endif
 	(*p->p_emul->e_trapsignal)(l, &ksi);
 	if ((type & T_USER) == 0)

Reply via email to