SIGNAL(II) 8/5/73 SIGNAL(II)
NAME
signal - catch or ignore signals
SYNOPSIS
(signal = 48.)
sys signal; sig; value
signal(sig, func)
int (*func)();
DESCRIPTION
When the signal defined by sig is sent to the current
process, it is to be treated according to value. The
following is the list of signals:
1 hangup
2 interrupt
3* quit
4* illegal instruction
5* trace trap
6* IOT instruction
7* EMT instruction
8* floating point exception
9 kill (cannot be caught or ignored)
10* bus error
11* segmentation violation
12* bad argument to sys call
If value is 0, the default system action applies to the
signal. This is processes termination with or without a
core dump. If value is odd, the signal is ignored. Any
other even value specifies an address in the process where
an interrupt is simulated. An RTI instruction will return
from the interrupt. As a signal is caught, it is reset to
0. Thus if it is desired to catch every such signal, the
catching routine must issue another signal call.
The starred signals in the list above cause core images if
not caught and not ignored. In C, if func is 0 or 1, the
action is as described above. If func is even, it is
assumed to be the address of a function entry point. When
the signal occurs, the function will be called. A return
from the function will simulate the RTI.
After a fork, the child inherits all signals. The exec call
resets all caught signals to default action.
SEE ALSO
kill (I, II)
DIAGNOSTICS
The error bit (c-bit) is set if the given signal is out of
range. In C, a -1 indicates an error; 0 indicates success.