Module Name: src Committed By: riz Date: Sat Jul 21 00:00:14 UTC 2012
Modified Files: src/sys/kern [netbsd-6]: sys_sig.c Log Message: Pull up following revision(s) (requested by christos in ticket #430): sys/kern/sys_sig.c: revision 1.38 >From Roger Pau Monne: kill(2) called for a zombie process should return 0, according to: http://pubs.opengroup.org/onlinepubs/9699919799/functions/kill.html To generate a diff of this commit: cvs rdiff -u -r1.36 -r1.36.6.1 src/sys/kern/sys_sig.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/kern/sys_sig.c diff -u src/sys/kern/sys_sig.c:1.36 src/sys/kern/sys_sig.c:1.36.6.1 --- src/sys/kern/sys_sig.c:1.36 Fri Nov 18 03:34:13 2011 +++ src/sys/kern/sys_sig.c Sat Jul 21 00:00:13 2012 @@ -1,4 +1,4 @@ -/* $NetBSD: sys_sig.c,v 1.36 2011/11/18 03:34:13 christos Exp $ */ +/* $NetBSD: sys_sig.c,v 1.36.6.1 2012/07/21 00:00:13 riz Exp $ */ /*- * Copyright (c) 2006, 2007, 2008 The NetBSD Foundation, Inc. @@ -66,7 +66,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: sys_sig.c,v 1.36 2011/11/18 03:34:13 christos Exp $"); +__KERNEL_RCSID(0, "$NetBSD: sys_sig.c,v 1.36.6.1 2012/07/21 00:00:13 riz Exp $"); #include <sys/param.h> #include <sys/kernel.h> @@ -242,10 +242,11 @@ kill1(struct lwp *l, pid_t pid, ksiginfo if (pid > 0) { /* kill single process */ mutex_enter(proc_lock); - p = proc_find(pid); - if (p == NULL) { + p = proc_find_raw(pid); + if (p == NULL || (p->p_stat != SACTIVE && p->p_stat != SSTOP)) { mutex_exit(proc_lock); - return ESRCH; + /* IEEE Std 1003.1-2001: return success for zombies */ + return p ? 0 : ESRCH; } mutex_enter(p->p_lock); error = kauth_authorize_process(l->l_cred,