![]() |
![]() |
![]() |
![]() |
Suspend the calling process
#include <sys/types.h> #include <sys/wait.h> pid_t waitpid( pid_t pid, int * stat_loc, int options );
libc
The waitpid() function suspends execution of the calling process until status information from one of its terminated child processes is available, or until the delivery of a signal whose action is either to terminate the process or execute a signal handler. If status information is available prior to the call to waitpid(), the return is immediate.
The waitpid() function behaves the same as the wait() function when passed a pid argument of -1, and the options argument has a value of zero.
The pid argument modifies the behavior of waitpid() in that it allows the calling process to specify a set of child processes for which status information is requested:
If the stat_loc variable is non-NULL, the terminating status of the child process is placed here. For information about macros that extract information from stat_loc, see "Status macros" in the description of wait().
The options argument is constructed from the bitwise inclusive OR of zero or more of the following flags:
Only one of the WIFEXITED(stat_val) and WIFSIGNALED(stat_val) macros can evaluate to a nonzero value.
The process ID of the terminating child process on success. If waitpid() is invoked with WNOHANG set in options, it has at least one child process specified by pid for which status isn't available, and status isn't available for any process specified by pid, a value of zero is returned. On delivery of a signal, waitpid() returns -1, and errno is set to EINTR.
Safety: | |
---|---|
Cancellation point | Yes |
Interrupt handler | No |
Signal handler | Yes |
Thread | Yes |
errno, spawn(), wait(), wait4(), waitid()
![]() |
![]() |
![]() |
![]() |