diff options
author | Ulrich Drepper <drepper@redhat.com> | 2003-02-21 10:00:33 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2003-02-21 10:00:33 +0000 |
commit | 8c2e9a29b1fbda33e57b2d33c7bfcb0de666b1fb (patch) | |
tree | aa445512e4f44e9d00ee5624417f7ee5417c4b75 /nptl/sysdeps/unix/sysv/linux/pthread_kill.c | |
parent | 8b1a8bb409508906737ec41ed79bb88398cb5dba (diff) | |
download | glibc-8c2e9a29b1fbda33e57b2d33c7bfcb0de666b1fb.tar glibc-8c2e9a29b1fbda33e57b2d33c7bfcb0de666b1fb.tar.gz glibc-8c2e9a29b1fbda33e57b2d33c7bfcb0de666b1fb.tar.bz2 glibc-8c2e9a29b1fbda33e57b2d33c7bfcb0de666b1fb.zip |
Update.
* pthreadP.h: Define INVALID_TD_P and INVALID_NOT_TERMINATED_TD_P.
* pthread_cancel.c: Use INVALID_TD_P.
* pthread_detach.c: Likewise.
* pthread_getschedparam.c: Likewise.
* pthread_setschedparam.c: Likewise.
* sysdeps/pthread/pthread_getcpuclockid.c: Likewise.
* sysdeps/unix/sysv/linux/pthread_kill.c: Likewise.
* pthread_join.c: Use INVALID_NOT_TERMINATED_TD_P.
* pthread_timedjoin.c: Likewise.
* tst-basic7.c: Include <signal.h>.
Diffstat (limited to 'nptl/sysdeps/unix/sysv/linux/pthread_kill.c')
-rw-r--r-- | nptl/sysdeps/unix/sysv/linux/pthread_kill.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/nptl/sysdeps/unix/sysv/linux/pthread_kill.c b/nptl/sysdeps/unix/sysv/linux/pthread_kill.c index ca6dfd887a..2caa72882f 100644 --- a/nptl/sysdeps/unix/sysv/linux/pthread_kill.c +++ b/nptl/sysdeps/unix/sysv/linux/pthread_kill.c @@ -31,14 +31,14 @@ __pthread_kill (threadid, signo) { struct pthread *pd = (struct pthread *) threadid; + /* Make sure the descriptor is valid. */ + if (INVALID_TD_P (pd)) + /* Not a valid thread handle. */ + return ESRCH; + /* We have a special syscall to do the work. */ INTERNAL_SYSCALL_DECL (err); - /* The kernel returns EINVAL for PIDs <= 0. This is not nice since - the user would expect ESRCH. Correct it here. */ - if (pd->tid <= 0) - return ESRCH; - int val = INTERNAL_SYSCALL (tkill, err, 2, pd->tid, signo); return (INTERNAL_SYSCALL_ERROR_P (val, err) |