Module Name: src
Committed By: rmind
Date: Sun Mar 29 04:40:01 UTC 2009
Modified Files:
src/sys/kern: kern_descrip.c
Log Message:
fownsignal: pre-check for zero pgid, avoids locking of proc_lock.
To generate a diff of this commit:
cvs rdiff -u -r1.188 -r1.189 src/sys/kern/kern_descrip.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/kern_descrip.c
diff -u src/sys/kern/kern_descrip.c:1.188 src/sys/kern/kern_descrip.c:1.189
--- src/sys/kern/kern_descrip.c:1.188 Wed Mar 11 06:05:29 2009
+++ src/sys/kern/kern_descrip.c Sun Mar 29 04:40:01 2009
@@ -1,4 +1,4 @@
-/* $NetBSD: kern_descrip.c,v 1.188 2009/03/11 06:05:29 mrg Exp $ */
+/* $NetBSD: kern_descrip.c,v 1.189 2009/03/29 04:40:01 rmind Exp $ */
/*-
* Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -67,7 +67,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_descrip.c,v 1.188 2009/03/11 06:05:29 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_descrip.c,v 1.189 2009/03/29 04:40:01 rmind Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -1635,22 +1635,36 @@
void
fownsignal(pid_t pgid, int signo, int code, int band, void *fdescdata)
{
- struct proc *p1;
- struct pgrp *pgrp;
ksiginfo_t ksi;
KASSERT(!cpu_intr_p());
+ if (pgid == 0) {
+ return;
+ }
+
KSI_INIT(&ksi);
ksi.ksi_signo = signo;
ksi.ksi_code = code;
ksi.ksi_band = band;
mutex_enter(proc_lock);
- if (pgid > 0 && (p1 = p_find(pgid, PFIND_LOCKED)))
- kpsignal(p1, &ksi, fdescdata);
- else if (pgid < 0 && (pgrp = pg_find(-pgid, PFIND_LOCKED)))
- kpgsignal(pgrp, &ksi, fdescdata, 0);
+ if (pgid > 0) {
+ struct proc *p1;
+
+ p1 = p_find(pgid, PFIND_LOCKED);
+ if (p1 != NULL) {
+ kpsignal(p1, &ksi, fdescdata);
+ }
+ } else {
+ struct pgrp *pgrp;
+
+ KASSERT(pgid < 0);
+ pgrp = pg_find(-pgid, PFIND_LOCKED);
+ if (pgrp != NULL) {
+ kpgsignal(pgrp, &ksi, fdescdata, 0);
+ }
+ }
mutex_exit(proc_lock);
}