Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/powerpc/ibm4xx Return correct signo and si_code to ...



details:   https://anonhg.NetBSD.org/src/rev/6009e256535e
branches:  trunk
changeset: 1011115:6009e256535e
user:      rin <rin%NetBSD.org@localhost>
date:      Fri Jun 19 07:24:41 2020 +0000

description:
Return correct signo and si_code to userland when page fault.
Taken from powerpc/trap.c. Found by tests in lib/libc/sys.

diffstat:

 sys/arch/powerpc/ibm4xx/trap.c |  34 ++++++++++++++++++++++------------
 1 files changed, 22 insertions(+), 12 deletions(-)

diffs (67 lines):

diff -r e65c285f79d6 -r 6009e256535e sys/arch/powerpc/ibm4xx/trap.c
--- a/sys/arch/powerpc/ibm4xx/trap.c    Fri Jun 19 07:19:19 2020 +0000
+++ b/sys/arch/powerpc/ibm4xx/trap.c    Fri Jun 19 07:24:41 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: trap.c,v 1.79 2020/06/19 07:19:19 rin Exp $    */
+/*     $NetBSD: trap.c,v 1.80 2020/06/19 07:24:41 rin Exp $    */
 
 /*
  * Copyright 2001 Wasabi Systems, Inc.
@@ -67,7 +67,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.79 2020/06/19 07:19:19 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.80 2020/06/19 07:24:41 rin Exp $");
 
 #include "opt_altivec.h"
 #include "opt_ddb.h"
@@ -247,16 +247,28 @@
                        break;
                }
                KSI_INIT_TRAP(&ksi);
-               ksi.ksi_signo = SIGSEGV;
                ksi.ksi_trap = EXC_DSI;
                ksi.ksi_addr = (void *)tf->tf_dear;
-               if (rv == ENOMEM) {
-                       printf("UVM: pid %d (%s) lid %d, uid %d killed: "
-                           "out of swap\n",
-                           p->p_pid, p->p_comm, l->l_lid,
-                           l->l_cred ?
-                           kauth_cred_geteuid(l->l_cred) : -1);
+vm_signal:
+               switch (rv) {
+               case EINVAL:
+                       ksi.ksi_signo = SIGBUS;
+                       ksi.ksi_code = BUS_ADRERR;
+                       break;
+               case EACCES:
+                       ksi.ksi_signo = SIGSEGV;
+                       ksi.ksi_code = SEGV_ACCERR;
+                       break;
+               case ENOMEM:
                        ksi.ksi_signo = SIGKILL;
+                       printf("UVM: pid %d.%d (%s), uid %d killed: "
+                              "out of swap\n", p->p_pid, l->l_lid, p->p_comm,
+                              l->l_cred ? kauth_cred_geteuid(l->l_cred) : -1);
+                       break;
+               default:
+                       ksi.ksi_signo = SIGSEGV;
+                       ksi.ksi_code = SEGV_MAPERR;
+                       break;
                }
                trapsignal(l, &ksi);
                break;
@@ -274,11 +286,9 @@
                        break;
                }
                KSI_INIT_TRAP(&ksi);
-               ksi.ksi_signo = SIGSEGV;
                ksi.ksi_trap = EXC_ISI;
                ksi.ksi_addr = (void *)tf->tf_srr0;
-               ksi.ksi_code = (rv == EACCES ? SEGV_ACCERR : SEGV_MAPERR);
-               trapsignal(l, &ksi);
+               goto vm_signal;
                break;
 
        case EXC_AST|EXC_USER:



Home | Main Index | Thread Index | Old Index