SIGPAUSE(2) System Calls Manual SIGPAUSE(2)

sigpauseatomically release blocked signals and wait for interrupt

Standard C Library (libc, -lc)

#include <signal.h>

sigpause(int sig);


() assigns sig to the set of masked signals and then waits for a signal to arrive; on return the set of masked signals is restored. Sig is usually 0, indicating that no signals are to be blocked. Sigpause() always terminates by being interrupted, returning -1 with errno set to EINTR.

sigpause() now takes a signal value and not a mask. This often appears as a hang in sigpause$UNIX2003 or with sigpause() returning with errno set to EINVAL. Use sigsuspend() with signal masks.

kill(2), sigaction(2), sigblock(2), sigprocmask(2), sigsuspend(2), sigvec(2)

The sigpause() function call appeared in 4.2BSD and has been deprecated.

June 2, 1993 macOS 14.4