summaryrefslogtreecommitdiffstats
path: root/sys/kern/kern_sig.c
diff options
context:
space:
mode:
authorjhb <jhb@FreeBSD.org>2001-04-24 00:51:53 +0000
committerjhb <jhb@FreeBSD.org>2001-04-24 00:51:53 +0000
commit9c03a8ae91e06e47f0c59996ef0e2300e231e101 (patch)
treeec00c764b1eb58ed4297070edb5806ffd7ca4765 /sys/kern/kern_sig.c
parent383dd0a2656889604bb7eb71b993875024ddd832 (diff)
downloadFreeBSD-src-9c03a8ae91e06e47f0c59996ef0e2300e231e101.zip
FreeBSD-src-9c03a8ae91e06e47f0c59996ef0e2300e231e101.tar.gz
Change the pfind() and zpfind() functions to lock the process that they
find before releasing the allproc lock and returning. Reviewed by: -smp, dfr, jake
Diffstat (limited to 'sys/kern/kern_sig.c')
-rw-r--r--sys/kern/kern_sig.c43
1 files changed, 16 insertions, 27 deletions
diff --git a/sys/kern/kern_sig.c b/sys/kern/kern_sig.c
index e3f2fdb..b387237 100644
--- a/sys/kern/kern_sig.c
+++ b/sys/kern/kern_sig.c
@@ -898,19 +898,12 @@ killpg1(cp, sig, pgid, all)
PROC_UNLOCK(p);
continue;
}
- PROC_UNLOCK(p);
- /*
- * XXX: this locking needs work.. specifically the
- * session checks..
- */
- if (p_cansignal(cp, p, sig))
- continue;
- nfound++;
- if (sig) {
- PROC_LOCK(p);
- psignal(p, sig);
- PROC_UNLOCK(p);
+ if (p_cansignal(cp, p, sig) == 0) {
+ nfound++;
+ if (sig)
+ psignal(p, sig);
}
+ PROC_UNLOCK(p);
}
sx_sunlock(&allproc_lock);
} else {
@@ -930,22 +923,19 @@ killpg1(cp, sig, pgid, all)
PROC_UNLOCK(p);
continue;
}
- PROC_UNLOCK(p);
mtx_lock_spin(&sched_lock);
if (p->p_stat == SZOMB) {
mtx_unlock_spin(&sched_lock);
+ PROC_UNLOCK(p);
continue;
}
mtx_unlock_spin(&sched_lock);
- /* XXX: locking b0rked */
- if (p_cansignal(cp, p, sig))
- continue;
- nfound++;
- if (sig) {
- PROC_LOCK(p);
- psignal(p, sig);
- PROC_UNLOCK(p);
+ if (p_cansignal(cp, p, sig) == 0) {
+ nfound++;
+ if (sig)
+ psignal(p, sig);
}
+ PROC_UNLOCK(p);
}
}
return (nfound ? 0 : ESRCH);
@@ -971,14 +961,13 @@ kill(cp, uap)
/* kill single process */
if ((p = pfind(uap->pid)) == NULL)
return (ESRCH);
- /* XXX: locking b0rked */
- if (p_cansignal(cp, p, uap->signum))
- return (EPERM);
- if (uap->signum) {
- PROC_LOCK(p);
- psignal(p, uap->signum);
+ if (p_cansignal(cp, p, uap->signum)) {
PROC_UNLOCK(p);
+ return (EPERM);
}
+ if (uap->signum)
+ psignal(p, uap->signum);
+ PROC_UNLOCK(p);
return (0);
}
switch (uap->pid) {
OpenPOWER on IntegriCloud