Man Linux: Main Page and Category List

NAME

       sigaction - examine and change a signal action

SYNOPSIS

       #include <signal.h>

       int sigaction(int sig, const struct sigaction *restrict act,
              struct sigaction *restrict oact);

DESCRIPTION

       The  sigaction()  function allows the calling process to examine and/or
       specify the action  to  be  associated  with  a  specific  signal.  The
       argument  sig  specifies  the  signal; acceptable values are defined in
       <signal.h>.

       The structure sigaction, used to describe an action  to  be  taken,  is
       defined  in  the  <signal.h>  header  to include at least the following
       members:

           Member Type      Member Name    Description
           void(*) (int)    sa_handler     Pointer to a signal-catching
                                           function or one of the macros
                                           SIG_IGN or SIG_DFL.
           sigset_t         sa_mask        Additional set of signals to
                                           be blocked during execution of
                                           signal-catching function.
           int              sa_flags       Special flags to affect
                                           behavior of signal.
           void(*) (int,
             siginfo_t *,   sa_sigaction   Pointer to a signal-catching
           void *)                         function.

       The  storage occupied by sa_handler and sa_sigaction may overlap, and a
       conforming application shall not use both simultaneously.

       If the argument act is not a null pointer, it  points  to  a  structure
       specifying  the  action  to be associated with the specified signal. If
       the argument  oact  is  not  a  null  pointer,  the  action  previously
       associated  with the signal is stored in the location pointed to by the
       argument oact. If the argument act is a null pointer,  signal  handling
       is  unchanged;  thus, the call can be used to enquire about the current
       handling of a given signal. The SIGKILL and SIGSTOP signals  shall  not
       be  added  to  the  signal  mask using this mechanism; this restriction
       shall be enforced  by  the  system  without  causing  an  error  to  be
       indicated.

       If  the SA_SIGINFO flag (see below) is cleared in the sa_flags field of
       the sigaction structure, the sa_handler field identifies the action  to
       be  associated  with the specified signal.    If the SA_SIGINFO flag is
       set in the sa_flags field, and the implementation supports the Realtime
       Signals  Extension option or the XSI Extension option, the sa_sigaction
       field specifies a signal-catching function.  If the SA_SIGINFO  bit  is
       cleared  and the sa_handler field specifies a signal-catching function,
       or if the SA_SIGINFO bit is set, the sa_mask field identifies a set  of
       signals that shall be added to the signal mask of the thread before the
       signal-catching function is invoked. If the sa_handler field  specifies
       a  signal-catching  function,  the  sa_mask  field  identifies a set of
       signals that shall be added to the  process’  signal  mask  before  the
       signal-catching function is invoked.

       The  sa_flags field can be used to modify the behavior of the specified
       signal.

       The following flags, defined in the <signal.h> header, can  be  set  in
       sa_flags:

       SA_NOCLDSTOP
              Do  not  generate  SIGCHLD  when  children  stop     or  stopped
              children continue.

       If sig is SIGCHLD and the SA_NOCLDSTOP flag is not set in sa_flags, and
       the  implementation  supports the SIGCHLD signal, then a SIGCHLD signal
       shall be generated for the calling process whenever any  of  its  child
       processes stop    and a SIGCHLD signal may be generated for the calling
       process whenever any of its stopped child processes are continued.   If
       sig  is  SIGCHLD and the SA_NOCLDSTOP flag is set in sa_flags, then the
       implementation shall not generate a SIGCHLD signal in this way.

       SA_ONSTACK
              If set and an alternate signal  stack  has  been  declared  with
              sigaltstack(),  the  signal  shall  be  delivered to the calling
              process on that stack. Otherwise, the signal shall be  delivered
              on the current stack.

       SA_RESETHAND
              If  set, the disposition of the signal shall be reset to SIG_DFL
              and the SA_SIGINFO flag shall be cleared on entry to the  signal
              handler.

       Note:
              SIGILL and SIGTRAP cannot be automatically reset when delivered;
              the system silently enforces this restriction.

       Otherwise, the disposition of the signal shall not be modified on entry
       to the signal handler.

       In  addition,  if  this  flag  is  set,  sigaction()  behaves as if the
       SA_NODEFER flag were also set.

       SA_RESTART
              This flag affects the behavior of interruptible functions;  that
              is,  those  specified to fail with errno set to [EINTR]. If set,
              and a function specified as interruptible is interrupted by this
              signal,  the  function  shall  restart  and  shall not fail with
              [EINTR] unless otherwise specified. If  the  flag  is  not  set,
              interruptible  functions  interrupted  by this signal shall fail
              with errno set to [EINTR].

       SA_SIGINFO
              If  cleared  and  the  signal  is  caught,  the  signal-catching
              function shall be entered as:

              void func(int signo);

       where  signo  is the only argument to the signal-catching function.  In
       this case, the application shall use the sa_handler member to  describe
       the  signal-catching  function and the application shall not modify the
       sa_sigaction member.

       If SA_SIGINFO is set and the  signal  is  caught,  the  signal-catching
       function shall be entered as:

              void func(int signo, siginfo_t *info, void *context);

       where  two  additional  arguments  are  passed  to  the signal-catching
       function.  The second  argument  shall  point  to  an  object  of  type
       siginfo_t explaining the reason why the signal was generated; the third
       argument can be cast to a pointer to an object of  type  ucontext_t  to
       refer  to  the receiving process’ context that was interrupted when the
       signal was delivered. In this  case,  the  application  shall  use  the
       sa_sigaction  member  to  describe the signal-catching function and the
       application shall not modify the sa_handler member.

       The si_signo member contains the system-generated signal number.

       The si_errno member may contain implementation-defined additional error
       information;  if  non-zero, it contains an error number identifying the
       condition that caused the signal to be generated.

       The si_code member contains a code identifying the cause of the signal.

       If the value of si_code is less than or equal to 0, then the signal was
       generated by a process and si_pid and  si_uid,  respectively,  indicate
       the  process  ID  and  the  real user ID of the sender.  The <signal.h>
       header  description  contains  information  about  the  signal-specific
       contents of the elements of the siginfo_t type.

       SA_NOCLDWAIT
              If  set,  and sig equals SIGCHLD, child processes of the calling
              processes shall not be transformed into  zombie  processes  when
              they  terminate.  If  the calling process subsequently waits for
              its children, and the process has no unwaited-for children  that
              were transformed into zombie processes, it shall block until all
              of its children terminate, and wait(), waitid(),  and  waitpid()
              shall  fail  and  set  errno to [ECHILD]. Otherwise, terminating
              child processes shall  be  transformed  into  zombie  processes,
              unless SIGCHLD is set to SIG_IGN.

       SA_NODEFER
              If set and sig is caught, sig shall not be added to the process’
              signal mask on entry to the signal handler unless it is included
              in sa_mask. Otherwise, sig shall always be added to the process’
              signal mask on entry to the signal handler.

       When a signal is caught by  a  signal-catching  function  installed  by
       sigaction(),  a  new  signal  mask  is calculated and installed for the
       duration of the signal-catching function (or until  a  call  to  either
       sigprocmask()  or  sigsuspend() is made). This mask is formed by taking
       the union of the current signal mask and the value of the  sa_mask  for
       the signal being delivered    unless SA_NODEFER or SA_RESETHAND is set,
       and then including the signal being delivered. If and when  the  user’s
       signal  handler returns normally, the original signal mask is restored.

       Once an action is installed for a  specific  signal,  it  shall  remain
       installed until another action is explicitly requested (by another call
       to sigaction()),    until the SA_RESETHAND flag causes resetting of the
       handler,   or until one of the exec functions is called.

       If  the  previous  action for sig had been established by signal(), the
       values of the fields returned in the structure pointed to by  oact  are
       unspecified, and in particular oact-> sa_handler is not necessarily the
       same value passed to signal().  However,  if  a  pointer  to  the  same
       structure  or  a  copy  thereof  is  passed  to  a  subsequent  call to
       sigaction() via the act argument, handling of the signal shall be as if
       the original call to signal() were repeated.

       If sigaction() fails, no new signal handler is installed.

       It  is  unspecified  whether  an attempt to set the action for a signal
       that cannot be caught or ignored to SIG_DFL is  ignored  or  causes  an
       error to be returned with errno set to [EINVAL].

       If  SA_SIGINFO  is  not  set  in  sa_flags,  then  the  disposition  of
       subsequent  occurrences  of  sig  when  it  is   already   pending   is
       implementation-defined;  the  signal-catching function shall be invoked
       with a single argument.    If the implementation supports the  Realtime
       Signals  Extension  option,  and if SA_SIGINFO is set in sa_flags, then
       subsequent occurrences of sig generated by sigqueue() or as a result of
       any  signal-generating  function  that supports the specification of an
       application-defined value (when sig is already pending) shall be queued
       in FIFO order until delivered or accepted; the signal-catching function
       shall be invoked with three arguments. The application specified  value
       is passed to the signal-catching function as the si_value member of the
       siginfo_t structure.

       The  result  of  the  use  of  sigaction()  and  a  sigwait()  function
       concurrently within a process on the same signal is unspecified.

RETURN VALUE

       Upon  successful  completion, sigaction() shall return 0; otherwise, -1
       shall be returned, errno shall be set to indicate the error, and no new
       signal-catching function shall be installed.

ERRORS

       The sigaction() function shall fail if:

       EINVAL The  sig  argument is not a valid signal number or an attempt is
              made to catch a signal that cannot be caught or ignore a  signal
              that cannot be ignored.

       ENOTSUP
              The  SA_SIGINFO  bit  flag  is  set in the sa_flags field of the
              sigaction structure, and the  implementation  does  not  support
              either  the  Realtime  Signals  Extension  option,  or  the  XSI
              Extension option.

       The sigaction() function may fail if:

       EINVAL An attempt was made to set the action to SIG_DFL  for  a  signal
              that cannot be caught or ignored (or both).

       The following sections are informative.

EXAMPLES

       None.

APPLICATION USAGE

       The  sigaction()  function supersedes the signal() function, and should
       be used in preference. In particular, sigaction() and  signal()  should
       not  be  used  in  the  same  process  to  control the same signal. The
       behavior of reentrant functions, as defined in the DESCRIPTION,  is  as
       specified   by  this  volume  of  IEEE Std 1003.1-2001,  regardless  of
       invocation from a signal-catching function. This is the  only  intended
       meaning  of  the  statement  that  reentrant  functions  may be used in
       signal-catching  functions  without  restrictions.   Applications  must
       still  consider  all  effects  of such functions on such things as data
       structures,  files,  and  process  state.  In  particular,  application
       writers   need  to  consider  the  restrictions  on  interactions  when
       interrupting sleep() and interactions among multiple handles for a file
       description. The fact that any specific function is listed as reentrant
       does not necessarily mean that  invocation  of  that  function  from  a
       signal-catching function is recommended.

       In  order  to  prevent  errors  arising from interrupting non-reentrant
       function calls, applications should protect calls  to  these  functions
       either  by  blocking the appropriate signals or through the use of some
       programmatic semaphore (see semget() , sem_init() , sem_open() , and so
       on).  Note  in  particular  that  even  the "safe" functions may modify
       errno; the signal-catching function, if not executing as an independent
       thread,  may  want  to  save and restore its value. Naturally, the same
       principles  apply  to  the  reentrancy  of  application  routines   and
       asynchronous  data access. Note that longjmp() and siglongjmp() are not
       in the list of reentrant functions.  This is because the code executing
       after longjmp() and siglongjmp() can call any unsafe functions with the
       same danger as calling those unsafe functions directly from the  signal
       handler.  Applications  that use longjmp() and siglongjmp() from within
       signal handlers require rigorous protection in order  to  be  portable.
       Many  of  the  other  functions  that  are  excluded  from the list are
       traditionally implemented using either malloc() or free() functions  or
       the  standard  I/O  library,  both  of  which  traditionally  use  data
       structures  in  a  non-reentrant  manner.  Since  any  combination   of
       different  functions using a common data structure can cause reentrancy
       problems, this volume  of  IEEE Std 1003.1-2001  does  not  define  the
       behavior  when  any  unsafe function is called in a signal handler that
       interrupts an unsafe function.

       If the signal occurs other than  as  the  result  of  calling  abort(),
       kill(),  or  raise(),  the  behavior is undefined if the signal handler
       calls any function in the  standard  library  other  than  one  of  the
       functions listed in the table above or refers to any object with static
       storage duration other than by assigning a value to  a  static  storage
       duration variable of type volatile sig_atomic_t. Furthermore, if such a
       call fails, the value of errno is unspecified.

       Usually, the signal is executed on the stack that was in effect  before
       the  signal  was  delivered.  An  alternate  stack  may be specified to
       receive a subset of the signals being caught.

       When  the  signal  handler  returns,  the  receiving  process   resumes
       execution  at  the  point  it was interrupted unless the signal handler
       makes other arrangements. If longjmp() or _longjmp() is used  to  leave
       the signal handler, then the signal mask must be explicitly restored by
       the process.

       This volume of IEEE Std 1003.1-2001 defines the  third  argument  of  a
       signal  handling function when SA_SIGINFO is set as a void * instead of
       a ucontext_t *, but without requiring type checking.  New  applications
       should  explicitly  cast  the  third  argument  of  the signal handling
       function to ucontext_t *.

       The  BSD  optional  four  argument  signal  handling  function  is  not
       supported  by  this volume of IEEE Std 1003.1-2001. The BSD declaration
       would be:

              void handler(int sig, int code, struct sigcontext *scp,
                  char *addr);

       where sig is the signal  number,  code  is  additional  information  on
       certain signals, scp is a pointer to the sigcontext structure, and addr
       is additional  address  information.   Much  the  same  information  is
       available  in  the  objects  pointed  to  by the second argument of the
       signal handler specified when SA_SIGINFO is set.

RATIONALE

       Although this volume of IEEE Std 1003.1-2001 requires that signals that
       cannot  be ignored shall not be added to the signal mask when a signal-
       catching function is entered, there is  no  explicit  requirement  that
       subsequent  calls  to  sigaction()  reflect  this  in  the  information
       returned in the oact argument. In other words, if SIGKILL  is  included
       in  the  sa_mask  field  of  act,  it  is  unspecified whether or not a
       subsequent call to sigaction() returns with  SIGKILL  included  in  the
       sa_mask field of oact.

       The  SA_NOCLDSTOP  flag, when supplied in the act-> sa_flags parameter,
       allows overloading SIGCHLD with the System V semantics that each SIGCLD
       signal   indicates   a   single   terminated   child.  Most  conforming
       applications that catch SIGCHLD are expected to install signal-catching
       functions  that repeatedly call the waitpid() function with the WNOHANG
       flag set, acting on each child for  which  status  is  returned,  until
       waitpid()  returns  zero.  If stopped children are not of interest, the
       use of the SA_NOCLDSTOP flag can prevent the overhead from invoking the
       signal-catching routine when they stop.

       Some  historical  implementations  also  define  other  mechanisms  for
       stopping   processes,   such   as   the   ptrace()   function.    These
       implementations usually do not generate a SIGCHLD signal when processes
       stop due to this mechanism; however, that is beyond the scope  of  this
       volume of IEEE Std 1003.1-2001.

       This  volume of IEEE Std 1003.1-2001 requires that calls to sigaction()
       that supply a NULL act argument succeed, even in the  case  of  signals
       that  cannot  be  caught  or ignored (that is, SIGKILL or SIGSTOP). The
       System V signal() and BSD sigvec() functions return [EINVAL]  in  these
       cases and, in this respect, their behavior varies from sigaction().

       This  volume of IEEE Std 1003.1-2001 requires that sigaction() properly
       save and restore a signal action set up by the ISO C standard  signal()
       function.  However, there is no guarantee that the reverse is true, nor
       could there be given the greater amount of information conveyed by  the
       sigaction  structure.  Because of this, applications should avoid using
       both functions for the same signal in  the  same  process.  Since  this
       cannot  always  be avoided in case of general-purpose library routines,
       they should always be implemented with sigaction().

       It was intended that the signal() function should be implementable as a
       library routine using sigaction().

       The  POSIX  Realtime  Extension  extends  the  sigaction()  function as
       specified by the POSIX.1-1990 standard  to  allow  the  application  to
       request on a per-signal basis via an additional signal action flag that
       the extra parameters, including the application-defined  signal  value,
       if any, be passed to the signal-catching function.

FUTURE DIRECTIONS

       None.

SEE ALSO

       Signal  Concepts  ,  bsd_signal()  ,  kill() , _longjmp() , longjmp() ,
       raise()  ,  semget()  ,  sem_init()  ,  sem_open()  ,   sigaddset()   ,
       sigaltstack()   ,   sigdelset()   ,   sigemptyset()  ,  sigfillset()  ,
       sigismember() , signal() , sigprocmask()  ,  sigsuspend()  ,  wait()  ,
       waitid()    ,    waitpid()   ,   the   Base   Definitions   volume   of
       IEEE Std 1003.1-2001, <signal.h>, <ucontext.h>

COPYRIGHT

       Portions of this text are reprinted and reproduced in  electronic  form
       from IEEE Std 1003.1, 2003 Edition, Standard for Information Technology
       -- Portable Operating System Interface (POSIX),  The  Open  Group  Base
       Specifications  Issue  6,  Copyright  (C) 2001-2003 by the Institute of
       Electrical and Electronics Engineers, Inc and The Open  Group.  In  the
       event of any discrepancy between this version and the original IEEE and
       The Open Group Standard, the original IEEE and The Open Group  Standard
       is  the  referee document. The original Standard can be obtained online
       at http://www.opengroup.org/unix/online.html .