Re-instate the behaviour of sending SIGKILL to a process if uvm_fault()

returns ENOMEM. SIGSEGV just doesn't cut it. The original code looks to
have been lost in revision 1.34.
This commit is contained in:
scw 2003-11-15 20:18:34 +00:00
parent 6fb817f5dd
commit 07acf64710

View File

@ -1,4 +1,4 @@
/* $NetBSD: fault.c,v 1.42 2003/11/14 21:22:08 briggs Exp $ */ /* $NetBSD: fault.c,v 1.43 2003/11/15 20:18:34 scw Exp $ */
/* /*
* Copyright 2003 Wasabi Systems, Inc. * Copyright 2003 Wasabi Systems, Inc.
@ -81,7 +81,7 @@
#include "opt_kgdb.h" #include "opt_kgdb.h"
#include <sys/types.h> #include <sys/types.h>
__KERNEL_RCSID(0, "$NetBSD: fault.c,v 1.42 2003/11/14 21:22:08 briggs Exp $"); __KERNEL_RCSID(0, "$NetBSD: fault.c,v 1.43 2003/11/15 20:18:34 scw Exp $");
#include <sys/param.h> #include <sys/param.h>
#include <sys/systm.h> #include <sys/systm.h>
@ -429,15 +429,17 @@ data_abort_handler(trapframe_t *tf)
dab_fatal(tf, fsr, far, l, NULL); dab_fatal(tf, fsr, far, l, NULL);
} }
KSI_INIT_TRAP(&ksi);
if (error == ENOMEM) { if (error == ENOMEM) {
printf("UVM: pid %d (%s), uid %d killed: " printf("UVM: pid %d (%s), uid %d killed: "
"out of swap\n", l->l_proc->p_pid, l->l_proc->p_comm, "out of swap\n", l->l_proc->p_pid, l->l_proc->p_comm,
(l->l_proc->p_cred && l->l_proc->p_ucred) ? (l->l_proc->p_cred && l->l_proc->p_ucred) ?
l->l_proc->p_ucred->cr_uid : -1); l->l_proc->p_ucred->cr_uid : -1);
} ksi.ksi_signo = SIGKILL;
} else
ksi.ksi_signo = SIGSEGV;
KSI_INIT_TRAP(&ksi);
ksi.ksi_signo = SIGSEGV;
ksi.ksi_code = (error == EACCES) ? SEGV_ACCERR : SEGV_MAPERR; ksi.ksi_code = (error == EACCES) ? SEGV_ACCERR : SEGV_MAPERR;
ksi.ksi_addr = (u_int32_t *)(intptr_t) far; ksi.ksi_addr = (u_int32_t *)(intptr_t) far;
ksi.ksi_trap = fsr; ksi.ksi_trap = fsr;
@ -750,15 +752,17 @@ prefetch_abort_handler(trapframe_t *tf)
if (__predict_true(error == 0)) if (__predict_true(error == 0))
goto out; goto out;
KSI_INIT_TRAP(&ksi);
if (error == ENOMEM) { if (error == ENOMEM) {
printf("UVM: pid %d (%s), uid %d killed: " printf("UVM: pid %d (%s), uid %d killed: "
"out of swap\n", l->l_proc->p_pid, l->l_proc->p_comm, "out of swap\n", l->l_proc->p_pid, l->l_proc->p_comm,
(l->l_proc->p_cred && l->l_proc->p_ucred) ? (l->l_proc->p_cred && l->l_proc->p_ucred) ?
l->l_proc->p_ucred->cr_uid : -1); l->l_proc->p_ucred->cr_uid : -1);
} ksi.ksi_signo = SIGKILL;
} else
ksi.ksi_signo = SIGSEGV;
KSI_INIT_TRAP(&ksi);
ksi.ksi_signo = SIGSEGV;
ksi.ksi_code = SEGV_MAPERR; ksi.ksi_code = SEGV_MAPERR;
ksi.ksi_addr = (u_int32_t *)(intptr_t) fault_pc; ksi.ksi_addr = (u_int32_t *)(intptr_t) fault_pc;
ksi.ksi_trap = fault_pc; ksi.ksi_trap = fault_pc;