Annotation of 43BSDReno/lib/libc/compat-43/sigvec.2, revision 1.1.1.1

1.1       root        1: .\" Copyright (c) 1980 The Regents of the University of California.
                      2: .\" All rights reserved.
                      3: .\"
                      4: .\" Redistribution and use in source and binary forms are permitted provided
                      5: .\" that: (1) source distributions retain this entire copyright notice and
                      6: .\" comment, and (2) distributions including binaries display the following
                      7: .\" acknowledgement:  ``This product includes software developed by the
                      8: .\" University of California, Berkeley and its contributors'' in the
                      9: .\" documentation or other materials provided with the distribution and in
                     10: .\" all advertising materials mentioning features or use of this software.
                     11: .\" Neither the name of the University nor the names of its contributors may
                     12: .\" be used to endorse or promote products derived from this software without
                     13: .\" specific prior written permission.
                     14: .\" THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
                     15: .\" WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
                     16: .\" MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
                     17: .\"
                     18: .\"    @(#)sigvec.2    6.6 (Berkeley) 7/1/90
                     19: .\"
                     20: .TH SIGVEC 2 "July 1, 1990"
                     21: .UC 4
                     22: .ie t .ds d \(dg
                     23: .el .ds d \z'|+'
                     24: .ie t .ds b \(bu
                     25: .el .ds b @
                     26: .SH NAME
                     27: sigvec \- software signal facilities
                     28: .SH SYNOPSIS
                     29: .nf
                     30: .B #include <signal.h>
                     31: .PP
                     32: .B struct sigvec {
                     33: .B     void    (*sv_handler)();
                     34: .B     int     sv_mask;
                     35: .B     int     sv_flags;
                     36: .B };
                     37: .PP
                     38: .B sigvec(sig, vec, ovec)
                     39: .B int sig;
                     40: .B struct sigvec *vec, *ovec;
                     41: .fi
                     42: .SH DESCRIPTION
                     43: .B "This interface is made obsolete by sigaction(2).
                     44: .LP
                     45: The system defines a set of signals that may be delivered to a process.
                     46: Signal delivery resembles the occurence of a hardware interrupt:
                     47: the signal is blocked from further occurrence, the current process 
                     48: context is saved, and a new one is built.  A process may specify a
                     49: .I handler
                     50: to which a signal is delivered, or specify that a signal is to be 
                     51: .I blocked
                     52: or
                     53: .IR ignored .
                     54: A process may also specify that a default action is to be taken
                     55: by the system when a signal occurs.
                     56: Normally, signal handlers execute on the current stack
                     57: of the process.  This may be changed, on a per-handler basis,
                     58: so that signals are taken on a special
                     59: .IR "signal stack" .
                     60: .PP
                     61: All signals have the same
                     62: .IR priority .
                     63: Signal routines execute with the signal that caused their
                     64: invocation
                     65: .IR blocked ,
                     66: but other signals may yet occur.
                     67: A global 
                     68: .I "signal mask"
                     69: defines the set of signals currently blocked from delivery
                     70: to a process.  The signal mask for a process is initialized
                     71: from that of its parent (normally 0).  It
                     72: may be changed with a
                     73: .IR sigblock (2)
                     74: or
                     75: .IR sigsetmask (2)
                     76: call, or when a signal is delivered to the process.
                     77: .PP
                     78: When a signal
                     79: condition arises for a process, the signal is added to a set of
                     80: signals pending for the process.  If the signal is not currently
                     81: .I blocked
                     82: by the process then it is delivered to the process.  When a signal
                     83: is delivered, the current state of the process is saved,
                     84: a new signal mask is calculated (as described below), 
                     85: and the signal handler is invoked.  The call to the handler
                     86: is arranged so that if the signal handling routine returns
                     87: normally the process will resume execution in the context
                     88: from before the signal's delivery.
                     89: If the process wishes to resume in a different context, then it
                     90: must arrange to restore the previous context itself.
                     91: .PP
                     92: When a signal is delivered to a process a new signal mask is
                     93: installed for the duration of the process' signal handler
                     94: (or until a
                     95: .I sigblock
                     96: or
                     97: .I sigsetmask
                     98: call is made).
                     99: This mask is formed by taking the current signal mask,
                    100: adding the signal to be delivered, and 
                    101: .IR or 'ing
                    102: in the signal mask associated with the handler to be invoked.
                    103: .PP
                    104: .I Sigvec
                    105: assigns a handler for a specific signal.  If
                    106: .I vec
                    107: is non-zero, it
                    108: specifies a handler routine and mask
                    109: to be used when delivering the specified signal.
                    110: Further, if the SV_ONSTACK bit is set in
                    111: .I sv_flags,
                    112: the system will deliver the signal to the process on a
                    113: .IR "signal stack" ,
                    114: specified with
                    115: .IR sigstack (2).
                    116: If 
                    117: .I ovec
                    118: is non-zero, the previous handling information for the signal
                    119: is returned to the user.
                    120: .PP
                    121: The following is a list of all signals
                    122: with names as in the include file
                    123: .RI < signal.h >:
                    124: .LP
                    125: .nf
                    126: .ta \w'SIGVTALRM 'u +\w'15*  'u
                    127: SIGHUP 1       hangup
                    128: SIGINT 2       interrupt
                    129: SIGQUIT        3*      quit
                    130: SIGILL 4*      illegal instruction
                    131: SIGTRAP        5*      trace trap
                    132: SIGIOT 6*      IOT instruction
                    133: SIGEMT 7*      EMT instruction
                    134: SIGFPE 8*      floating point exception
                    135: SIGKILL        9       kill (cannot be caught, blocked, or ignored)
                    136: SIGBUS 10*     bus error
                    137: SIGSEGV        11*     segmentation violation
                    138: SIGSYS 12*     bad argument to system call
                    139: SIGPIPE        13      write on a pipe with no one to read it
                    140: SIGALRM        14      alarm clock
                    141: SIGTERM        15      software termination signal
                    142: SIGURG 16\*b   urgent condition present on socket
                    143: SIGSTOP        17\*d   stop (cannot be caught, blocked, or ignored)
                    144: SIGTSTP        18\*d   stop signal generated from keyboard
                    145: SIGCONT        19\*b   continue after stop
                    146: SIGCHLD        20\*b   child status has changed
                    147: SIGTTIN        21\*d   background read attempted from control terminal
                    148: SIGTTOU        22\*d   background write attempted to control terminal
                    149: SIGIO  23\*b   i/o is possible on a descriptor (see \fIfcntl\fP(2))
                    150: SIGXCPU        24      cpu time limit exceeded (see \fIsetrlimit\fP(2))
                    151: SIGXFSZ        25      file size limit exceeded (see \fIsetrlimit\fP(2))
                    152: SIGVTALRM      26      virtual time alarm (see \fIsetitimer\fP(2))
                    153: SIGPROF        27      profiling timer alarm (see \fIsetitimer\fP(2))
                    154: SIGWINCH       28\*b   window size change
                    155: SIGINFO        29\*b   status request from keyboard
                    156: SIGUSR1        30      user defined signal 1
                    157: SIGUSR2        31      user defined signal 2
                    158: .fi
                    159: .PP
                    160: The starred signals in the list above cause a core image
                    161: if not caught or ignored.
                    162: .PP
                    163: Once a signal handler is installed, it remains installed
                    164: until another
                    165: .I sigvec
                    166: call is made, or an 
                    167: .IR execve (2)
                    168: is performed.
                    169: The default action for a signal may be reinstated by setting
                    170: .I sv_handler
                    171: to SIG_DFL; this default is termination
                    172: (with a core image for starred signals)
                    173: except for signals marked with \*b or \*d.
                    174: Signals marked with \*b are discarded if the action
                    175: is SIG_DFL; signals marked
                    176: with \*d cause the process to stop.
                    177: If
                    178: .I sv_handler
                    179: is SIG_IGN the signal is subsequently ignored,
                    180: and pending instances of the signal are discarded.
                    181: .PP
                    182: If a caught signal occurs during certain system calls,
                    183: the call is normally restarted.
                    184: The call can be forced to terminate prematurely with an
                    185: EINTR error return by setting the SV_INTERRUPT bit in
                    186: .I sv_flags.
                    187: The affected system calls include
                    188: .IR read (2),
                    189: .IR write (2),
                    190: .IR sendto (2),
                    191: .IR recvfrom (2),
                    192: .IR sendmsg (2)
                    193: and
                    194: .IR recvmsg (2)
                    195: on a communications channel or a slow device (such as a terminal,
                    196: but not a regular file)
                    197: and during a
                    198: .IR wait (2)
                    199: or
                    200: .IR ioctl (2).
                    201: However, calls that have already committed are not restarted,
                    202: but instead return a partial success (for example, a short read count).
                    203: .PP
                    204: After a
                    205: .IR fork (2)
                    206: or
                    207: .IR vfork (2)
                    208: the child inherits
                    209: all signals, the signal mask, the signal stack,
                    210: and the restart/interrupt flags.
                    211: .PP
                    212: .IR  Execve (2)
                    213: resets all
                    214: caught signals to default action and
                    215: resets all signals to be caught on the user stack.
                    216: Ignored signals remain ignored;
                    217: the signal mask remains the same;
                    218: signals that interrupt system calls continue to do so.
                    219: .SH NOTES
                    220: The mask specified in 
                    221: .I vec
                    222: is not allowed to block SIGKILL or SIGSTOP.
                    223: This is done silently by the system.
                    224: .PP
                    225: The SV_INTERRUPT flag is not available in 4.2BSD,
                    226: hence it should not be used if backward compatibility is needed.
                    227: .SH "RETURN VALUE
                    228: A 0 value indicated that the call succeeded.  A \-1 return value
                    229: indicates an error occurred and
                    230: .I errno
                    231: is set to indicated the reason.
                    232: .SH ERRORS
                    233: .I Sigvec
                    234: will fail and no new signal handler will be installed if one
                    235: of the following occurs:
                    236: .TP 15
                    237: [EFAULT]
                    238: Either
                    239: .I vec
                    240: or 
                    241: .I ovec
                    242: points to memory that is not a valid part of the process
                    243: address space.
                    244: .TP 15
                    245: [EINVAL]
                    246: .I Sig
                    247: is not a valid signal number.
                    248: .TP 15
                    249: [EINVAL]
                    250: An attempt is made to ignore or supply a handler for SIGKILL
                    251: or SIGSTOP.
                    252: .SH "SEE ALSO"
                    253: sigaction(2), kill(1), ptrace(2), kill(2),
                    254: sigprocmask(2), sigsuspend(2),
                    255: sigblock(2), sigsetmask(2), sigpause(2),
                    256: sigstack(2), sigvec(2), sigsetops(3), setjmp(3), siginterrupt(3), tty(4)
                    257: .SH "NOTES  (VAX-11)"
                    258: The handler routine can be declared:
                    259: .PP
                    260:     void handler(sig, code, scp)
                    261:     int sig, code;
                    262:     struct sigcontext *scp;
                    263: .PP
                    264: Here
                    265: .I sig
                    266: is the signal number, into which the hardware faults and traps are
                    267: mapped as defined below. 
                    268: .I Code
                    269: is a parameter that is either a constant
                    270: as given below or, for compatibility mode faults, the code provided by
                    271: the hardware (Compatibility mode faults are distinguished from the
                    272: other SIGILL traps by having PSL_CM set in the psl).
                    273: .I Scp
                    274: is a pointer to the
                    275: .I sigcontext
                    276: structure (defined in
                    277: .RI < signal.h >),
                    278: used to restore the context from before the signal.
                    279: .PP
                    280: The following defines the mapping of hardware traps to signals
                    281: and codes.  All of these symbols are defined in
                    282: .RI < signal.h >:
                    283: .LP
                    284: .ta \w'     Floating/decimal divide by zero   'u +\w'15*  'u +8n
                    285: .nf
                    286:    Hardware condition  Signal  Code
                    287: 
                    288: Arithmetic traps:
                    289:    Integer overflow    SIGFPE  FPE_INTOVF_TRAP
                    290:    Integer division by zero    SIGFPE  FPE_INTDIV_TRAP
                    291:    Floating overflow trap      SIGFPE  FPE_FLTOVF_TRAP
                    292:    Floating/decimal division by zero   SIGFPE  FPE_FLTDIV_TRAP
                    293:    Floating underflow trap     SIGFPE  FPE_FLTUND_TRAP
                    294:    Decimal overflow trap       SIGFPE  FPE_DECOVF_TRAP
                    295:    Subscript-range     SIGFPE  FPE_SUBRNG_TRAP
                    296:    Floating overflow fault     SIGFPE  FPE_FLTOVF_FAULT
                    297:    Floating divide by zero fault       SIGFPE  FPE_FLTDIV_FAULT
                    298:    Floating underflow fault    SIGFPE  FPE_FLTUND_FAULT
                    299: Length access control  SIGSEGV
                    300: Protection violation   SIGBUS
                    301: Reserved instruction   SIGILL  ILL_RESAD_FAULT
                    302: Customer-reserved instr.       SIGEMT
                    303: Reserved operand       SIGILL  ILL_PRIVIN_FAULT
                    304: Reserved addressing    SIGILL  ILL_RESOP_FAULT
                    305: Trace pending  SIGTRAP
                    306: Bpt instruction        SIGTRAP
                    307: Compatibility-mode     SIGILL  hardware supplied code
                    308: Chme   SIGSEGV
                    309: Chms   SIGSEGV
                    310: Chmu   SIGSEGV
                    311: .fi
                    312: .SH BUGS
                    313: This manual page is still confusing.

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.