From 0a5cd498bb6e2c26ebfbc305786644d3e2a51ef9 Mon Sep 17 00:00:00 2001 From: David Xu Date: Sat, 7 Jan 2006 03:15:21 +0000 Subject: [PATCH] Add a new feature to thr_kill, if thread ID argument is -1, send signals to all threads except current sender. --- sys/kern/kern_thr.c | 39 +++++++++++++++++++++++++++------------ 1 file changed, 27 insertions(+), 12 deletions(-) diff --git a/sys/kern/kern_thr.c b/sys/kern/kern_thr.c index 6b676722ac37..2a20bb1197f0 100644 --- a/sys/kern/kern_thr.c +++ b/sys/kern/kern_thr.c @@ -310,19 +310,34 @@ thr_kill(struct thread *td, struct thr_kill_args *uap) p = td->td_proc; error = 0; PROC_LOCK(p); - ttd = thread_find(p, uap->id); - if (ttd == NULL) { - error = ESRCH; - goto out; + if (uap->id == -1) { + if (uap->sig != 0 && !_SIG_VALID(uap->sig)) { + error = EINVAL; + } else { + error = ESRCH; + FOREACH_THREAD_IN_PROC(p, ttd) { + if (ttd != td) { + error = 0; + if (uap->sig == 0) + break; + tdsignal(p, ttd, uap->sig, NULL); + } + } + } + } else { + if (uap->id != td->td_tid) + ttd = thread_find(p, uap->id); + else + ttd = td; + if (ttd == NULL) + error = ESRCH; + else if (uap->sig == 0) + ; + else if (!_SIG_VALID(uap->sig)) + error = EINVAL; + else + tdsignal(p, ttd, uap->sig, NULL); } - if (uap->sig == 0) - goto out; - if (!_SIG_VALID(uap->sig)) { - error = EINVAL; - goto out; - } - tdsignal(p, ttd, uap->sig, NULL); -out: PROC_UNLOCK(p); return (error); }