Updated: 2022/Sep/29

Please read Privacy Policy. It's for your privacy.


SIGINFO(2)                    System Calls Manual                   SIGINFO(2)

NAME
     siginfo - signal information

SYNOPSIS
     #include <signal.h>

DESCRIPTION
     siginfo is a structure type which contains information about a signal
     delivered to a process.

     siginfo includes the following members:

           int si_signo;
           int si_errno;
           int si_code;

     si_signo contains the signal number generated by the system.

     If si_errno is non-zero, then it contains a system specific error number
     associated with this signal.  This number is defined in errno(2).

     If si_code is less than or equal to zero, the signal was generated by a
     user process or a user requested service:

     SI_USER     The signal was generated via kill(2).  The siginfo structure
                 contains the following additional members:

                       pid_t si_pid;
                       uid_t si_uid;

                 The si_pid field contains the pid of the sending process and
                 the si_uid field contains the user id of the sending process.

     SI_QUEUE    The signal was generated via sigqueue(2).  The siginfo
                 structure contains the following additional members:

                       pid_t si_pid;
                       uid_t si_uid;
                       sigval_t si_value;

                 The si_pid field contains the pid of the sending process and
                 the si_uid field contains the user id of the sending process.
                 Finally, the si_value field contains the value sent via
                 sigqueue(2).

     SI_TIMER    The signal was generated because a timer set by
                 timer_settime(2) has expired.  The siginfo structure contains
                 the following additional members:

                       sigval_t si_value;

                 The si_value field contains the value set via
                 timer_create(2).

     SI_ASYNCIO  The signal was generated by completion of an asynchronous I/O
                 operation.  The siginfo structure contains the following
                 additional members:

                       int si_fd;
                       long si_band;

                 The si_fd argument contains the file descriptor number on
                 which the operation was completed and the si_band field
                 contains the side and priority of the operation.  If the
                 operation was a normal read, si_band will contain POLLIN |
                 POLLRDNORM; on an out-of-band read it will contain POLLPRI |
                 POLLRDBAND; on a normal write it will contain POLLOUT |
                 POLLWRNORM; on an out-of-band write it will contain POLLPRI |
                 POLLWRBAND.

     SI_MESGQ    The signal was generated because of the arrival of a message
                 on an empty message queue.  See mq_notify(3).

     SI_LWP      The signal was generated via _lwp_kill(2).  The siginfo
                 structure contains the following additional members:

                       pid_t si_pid;
                       uid_t si_uid;

                 The si_pid field contains the pid of the sending process and
                 the si_uid field contains the user id of the sending process.

     SI_NOINFO   The signal was generated without specific info available.

     If si_code is positive, then it contains a signal specific reason why the
     signal was generated:

     SIGILL

              ILL_BADSTK  Internal stack error

              ILL_COPROC  Coprocessor error

              ILL_ILLADR  Illegal addressing mode

              ILL_ILLOPC  Illegal opcode

              ILL_ILLOPN  Illegal operand

              ILL_ILLTRP  Illegal trap

              ILL_PRVOPC  Privileged opcode

              ILL_PRVREG  Privileged register

     SIGFPE

              FPE_FLTDIV  Floating-point divide by zero

              FPE_FLTINV  Invalid floating-point operation

              FPE_FLTOVF  Floating-point overflow

              FPE_FLTRES  Floating-point inexact result

              FPE_FLTUND  Floating-point underflow

              FPE_FLTSUB  Subscript out of range

              FPE_INTDIV  Integer divide by zero

              FPE_INTOVF  Integer overflow

     SIGSEGV

              SEGV_ACCERR  Invalid permissions for mapped object

              SEGV_MAPERR  Address not mapped to object

     SIGBUS

              BUS_ADRALN  Invalid address alignment

              BUS_ADRERR  Nonexistent physical address

              BUS_OBJERR  Object-specific hardware error

     SIGTRAP

              TRAP_BRKPT  Process breakpoint

              TRAP_CHLD   Process child trap

              TRAP_DBREG  Process hardware debug register trap

              TRAP_EXEC   Process exec trap

              TRAP_LWP    Process LWP trap

              TRAP_SCE    Process syscall entry trap

              TRAP_SCX    Process syscall exit trap

              TRAP_TRACE  Process trace trap

     SIGCHLD

              CLD_CONTINUED  Stopped child has continued

              CLD_DUMPED     Child has terminated abnormally and created a
                             core file

              CLD_EXITED     Child has exited

              CLD_KILLED     Child has terminated abnormally but did not
                             create a core file

              CLD_STOPPED    Child has stopped

              CLD_TRAPPED    Traced child has trapped

     SIGIO

              POLL_ERR  I/O error

              POLL_HUP  Device disconnected

              POLL_IN   Data input available

              POLL_MSG  Input message available

              POLL_OUT  Output buffers available

              POLL_PRI  High priority input available

     For SIGILL, SIGFPE, SIGBUS and SIGSEGV the siginfo structure contains the
     following additional members:

           void *si_addr;
           int si_trap;

     si_addr contains the address of the faulting instruction or data and
     si_trap contains a hardware specific reason.

     For SIGTRAP and TRAP_BRKPT, TRAP_TRACE or TRAP_DBREG the siginfo
     structure contains the following additional members:

           void *si_addr;
           int si_trap;

     si_addr contains the address of the faulting data and si_trap contains a
     hardware specific reason.

     For SIGTRAP and TRAP_SCE or TRAP_SCX the siginfo structure contains the
     following additional members:

           int si_sysnum;
           int si_retval[2];
           int si_error;
           uint64_t si_args[8];

     si_sysnum contains the syscall number, si_retval contains the syscall
     return value (meaningful for TRAP_SCX only), si_error contains the
     syscall error value (meaningful for TRAP_SCX only) and si_args[8]
     contains the syscall arguments,

     For SIGIO the siginfo structure contains the following additional
     members:

           int si_fd;
           long si_band;

     The si_fd argument contains the file descriptor number on which the
     operation was completed and the si_band field contains the side and
     priority of the operation as described above.

     Finally, for SIGCHLD the siginfo structure contains the following
     additional members:

           pid_t si_pid;
           uid_t si_uid;
           int si_status;
           clock_t si_utime;
           clock_t si_stime;

     The si_pid field contains the pid of the process who's status changed,
     the si_uid field contains the user id of the that process, the si_status
     field contains either the exit code of the process (for CLD_EXITED), or
     the signal number received by the process.  waitid(2), waitpid(2), and
     the si_utime and si_stime fields contain the user and system process
     accounting time.

STANDARDS
     The siginfo type conforms to X/Open System Interfaces and Headers Issue 5
     ("XSH5").

     Signals specifying SI_LWP or SI_NOINFO are NetBSD extensions.

     The TRAP_CHLD, TRAP_DBREG, TRAP_EXEC, TRAP_LWP, TRAP_SCE and TRAP_SCX
     signal specific reasons of SIGTRAP are NetBSD extensions.

HISTORY
     The siginfo functionality first appeared in AT&T System V Release 4 UNIX.

     TRAP_CHLD, TRAP_DBREG, TRAP_EXEC, TRAP_LWP, TRAP_SCE and TRAP_SCX first
     appeared in NetBSD 8.

     The additional parameters with syscall information in TRAP_SCE and
     TRAP_SCX first appeared in NetBSD 9.

NetBSD 10.99                     May 25, 2019                     NetBSD 10.99