sd_event_add_child systemd More text Zbigniew Jędrzejewski-Szmek zbyszek@in.waw.pl sd_event_add_child 3 sd_event_add_child sd_event_source_get_child_pid Add a child state change event source to an event loop #include <systemd/sd-bus.h> int sd_event_add_child sd_event *event sd_event_source **source pid_t pid int options sd_event_child_handler_t handler void *userdata typedef int (*sd_event_child_handler_t) sd_event_source *s const siginfo_t *si void *userdata int sd_event_source_get_child_pid sd_event_source *source pid_t *pid Description sd_event_add_child() adds a new child state change event source to an event loop object. The event loop is specified in event, the event source is returned in the source parameter. The pid parameter specifies the process to watch. The handler must reference a function to call when the process changes state. The handler function will be passed the userdata pointer, which may be chosen freely by the caller. The handler also receives a pointer to a const siginfo_t structure containing the information about the event. The options parameter determines which state changes will be watched for. It must contain an OR-ed mask of WEXITED (watch for the child terminating), WSTOPPED (watch for the child being stopped by a signal), and WCONTINUED (watch for the child being resumed by a signal). See waitid2 for futher information. Only a single handler may be installed for a specific child. The handler is enabled for a single event (SD_EVENT_ONESHOT), but this may be changed with sd_event_source_set_enabled3. If the handler function returns a negative error code, it will be disabled after the invocation, even if SD_EVENT_ON mode is set. sd_event_source_get_child_pid() retrieves the configured pid of a child state change event source created previously with sd_event_add_child(). It takes the event source object as the source parameter and a pointer to pid_t to return the result in. Return Value On success, these functions return 0 or a positive integer. On failure, they return a negative errno-style error code. Errors Returned errors may indicate the following problems: -ENOMEM Not enough memory to allocate an object. -EINVAL An invalid argument has been passed. This includes specyfing an empty mask in options or a mask which constains values different than a combination of WEXITED, WSTOPPED, and WCONTINUED. -EBUSY An handler is already installed for this child. -ESTALE The event loop is already terminated. -ECHILD The event loop has been created in a different process. Notes sd_event_add_child() and the other functions described here are available as a shared library, which can be compiled and linked to with the libsystemd pkg-config1 file. See Also systemd1, sd-event3, sd_event_new3, sd_event_add_time3, sd_event_add_signal3, sd_event_add_defer3, sd_event_source_set_enabled3