pthread_kill — send a signal to a thread
The pthread_kill() function shall request that a signal be delivered to the specified thread. It shall not be an error if thread is a zombie thread.
Upon successful completion, the function shall return a value of zero. Otherwise, the function shall return an error number. If the pthread_kill() function fails, no signal shall be sent.
The pthread_kill() function may fail if:
- [EINVAL]
- The value of the sig argument is zero.
The pthread_kill() function shall fail if:
- [EINVAL]
- The value of the sig argument is non-zero and is an invalid or unsupported signal number.
The pthread_kill() function shall not return an error code of [EINTR].
None.
The pthread_kill() function provides a mechanism for asynchronously directing a signal at a thread in the calling process. This could be used, for example, by one thread to affect broadcast delivery of a signal to a set of threads.
Note that pthread_kill() only causes the signal to be handled in the context of the given thread; the signal action (termination or stopping) affects the process as a whole.
If an implementation detects use of a thread ID after the end of its lifetime, it is recommended that the function should fail and report an [ESRCH] error.
Historical implementations varied on the result of a pthread_kill() with a thread ID indicating a zombie thread. Some indicated success on such a call, while others gave an error of [ESRCH]. Since the definition of thread lifetime in this volume of POSIX.1-2024 covers zombie threads, the [ESRCH] error as described is inappropriate in this case and implementations that give this error do not conform. In particular, this means that an application cannot have one thread check for termination of another by calling pthread_kill() with a sig argument of zero, and implementations may indicate that it is not possible by returning [EINVAL] when sig is zero.
None.
XBD <signal.h>
First released in Issue 5. Included for alignment with the POSIX Threads Extension.
The pthread_kill() function is marked as part of the Threads option.
The APPLICATION USAGE section is added.
The pthread_kill() function is moved from the Threads option to the Base.
Austin Group Interpretation 1003.1-2001 #142 is applied, removing the [ESRCH] error condition.
POSIX.1-2008, Technical Corrigendum 2, XSH/TC2-2008/0277 [765] is applied.
Austin Group Defect 792 is applied, adding a requirement that passing the thread ID of a zombie thread to pthread_kill() is not treated as an error.
Austin Group Defect 1214 is applied, allowing pthread_kill() to fail with [EINVAL] when the sig argument is zero.
return to top of page