diff options
author | Rich Felker <dalias@aerifal.cx> | 2018-05-04 13:18:51 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2018-05-04 13:18:51 -0400 |
commit | 4df42163511182bfd6fc55e85250b93786dcce7e (patch) | |
tree | 7ba21ccd873265550a2043a5b904cc94e358b179 | |
parent | 9e2d820a555e150df462f88c901fcbe25d692a8b (diff) | |
download | musl-4df42163511182bfd6fc55e85250b93786dcce7e.tar.gz musl-4df42163511182bfd6fc55e85250b93786dcce7e.tar.bz2 musl-4df42163511182bfd6fc55e85250b93786dcce7e.tar.xz musl-4df42163511182bfd6fc55e85250b93786dcce7e.zip |
remove incorrect ESRCH error from pthread_kill
posix documents in the rationale and future directions for
pthread_kill that, since the lifetime of the thread id for a joinable
thread lasts until it is joined, ESRCH is not a correct error for
pthread_kill to produce when the target thread has exited but not yet
been joined, and that conforming applications cannot attempt to detect
this state. future versions of the standard may explicitly require
that ESRCH not be returned for this case.
-rw-r--r-- | src/thread/pthread_kill.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/thread/pthread_kill.c b/src/thread/pthread_kill.c index f0903420..0a139231 100644 --- a/src/thread/pthread_kill.c +++ b/src/thread/pthread_kill.c @@ -4,7 +4,8 @@ int pthread_kill(pthread_t t, int sig) { int r; LOCK(t->killlock); - r = t->dead ? ESRCH : -__syscall(SYS_tkill, t->tid, sig); + r = t->dead ? (sig+0U >= _NSIG ? EINVAL : 0) + : -__syscall(SYS_tkill, t->tid, sig); UNLOCK(t->killlock); return r; } |