Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/aarch64/aarch64 Implement sigill_debug variable for...



details:   https://anonhg.NetBSD.org/src/rev/5d4fe2e2ef55
branches:  trunk
changeset: 991726:5d4fe2e2ef55
user:      ryo <ryo%NetBSD.org@localhost>
date:      Sat Jul 28 09:57:59 2018 +0000

description:
Implement sigill_debug variable for debug (with DDB). if sigill_debug = 1, illegal instruction will be logged.

e.g.) [ 75914.9966392] TRAP: pid 1422 (ssh), uid 1074: Unknown Reason (Illegal Instruction): pc=0x0000faa29ae35088: pmull v0.1q, v0.1d, v0.1d

diffstat:

 sys/arch/aarch64/aarch64/trap.c |  17 +++++++++++++++--
 1 files changed, 15 insertions(+), 2 deletions(-)

diffs (50 lines):

diff -r 74cdc1b55a46 -r 5d4fe2e2ef55 sys/arch/aarch64/aarch64/trap.c
--- a/sys/arch/aarch64/aarch64/trap.c   Sat Jul 28 09:54:32 2018 +0000
+++ b/sys/arch/aarch64/aarch64/trap.c   Sat Jul 28 09:57:59 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: trap.c,v 1.7 2018/07/19 18:30:28 christos Exp $ */
+/* $NetBSD: trap.c,v 1.8 2018/07/28 09:57:59 ryo Exp $ */
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -31,12 +31,13 @@
 
 #include <sys/cdefs.h>
 
-__KERNEL_RCSID(1, "$NetBSD: trap.c,v 1.7 2018/07/19 18:30:28 christos Exp $");
+__KERNEL_RCSID(1, "$NetBSD: trap.c,v 1.8 2018/07/28 09:57:59 ryo Exp $");
 
 #include "opt_arm_intr_impl.h"
 #include "opt_compat_netbsd32.h"
 
 #include <sys/param.h>
+#include <sys/kauth.h>
 #include <sys/types.h>
 #include <sys/atomic.h>
 #include <sys/cpu.h>
@@ -73,6 +74,9 @@
 #include <machine/db_machdep.h>
 #endif
 
+#ifdef DDB
+int sigill_debug = 0;
+#endif
 
 const char * const trap_names[] = {
        [ESR_EC_UNKNOWN]        = "Unknown Reason (Illegal Instruction)",
@@ -271,6 +275,15 @@
        default:
                /* XXX notyet */
        case ESR_EC_UNKNOWN:
+#ifdef DDB
+               if (sigill_debug) {
+                       /* show illegal instruction */
+                       printf("TRAP: pid %d (%s), uid %d: %s: pc=0x%016lx: %s\n",
+                           curlwp->l_proc->p_pid, curlwp->l_proc->p_comm,
+                           l->l_cred ? kauth_cred_geteuid(l->l_cred) : -1,
+                           eclass_trapname(eclass), tf->tf_pc, strdisasm(tf->tf_pc));
+               }
+#endif
                /* illegal or not implemented instruction */
                do_trapsignal(l, SIGILL, ILL_ILLTRP, (void *)tf->tf_pc, esr);
                userret(l);



Home | Main Index | Thread Index | Old Index