*nix Documentation Project
·  Home
 +   man pages
·  Linux HOWTOs
·  FreeBSD Tips
·  *niX Forums

  man pages->Linux man pages -> signal (2)              
Title
Content
Arch
Section
 

SIGNAL(2)

Contents


NAME    [Toc]    [Back]

       signal - ANSI C signal handling

SYNOPSIS    [Toc]    [Back]

       #include <signal.h>

       typedef void (*sighandler_t)(int);


       sighandler_t signal(int signum, sighandler_t handler);

DESCRIPTION    [Toc]    [Back]

       The  signal()  system call installs a new signal handler for the signal
       with number signum.  The signal handler is set to sighandler which  may
       be a user specified function, or either SIG_IGN or SIG_DFL.

       Upon  arrival of a signal with number signum the following happens.  If
       the corresponding handler  is  set  to  SIG_IGN,  then  the  signal  is
       ignored.   If  the  handler  is set to SIG_DFL, then the default action
       associated to the signal (see signal(7)) occurs.  Finally, if the  handler
  is  set  to  a function sighandler then the signal is blocked and
       sighandler is called with argument signum.  The signal remains  blocked
       during the execution of the signal handler.

       Using  a  signal  handler function for a signal is called "catching the
       signal".  The signals SIGKILL and SIGSTOP cannot be caught or  ignored.

RETURN VALUE    [Toc]    [Back]

       The signal() function returns the previous value of the signal handler,
       or SIG_ERR on error.

PORTABILITY    [Toc]    [Back]

       The original Unix signal() would reset the handler to SIG_DFL, and System
  V  (and the Linux kernel and libc4,5) does the same.  On the other
       hand, BSD does not reset the handler, but blocks new instances of  this
       signal from occurring during a call of the handler.  The glibc2 library
       follows the BSD behaviour.

       In a libc5 system including <bsd/signal.h> instead of <signal.h>  makes
       signal  to  be  redefined as __bsd_signal and signal has the BSD semantics.
 This is not recommended.

       In a glibc2 system defining a feature test macro such as  _XOPEN_SOURCE
       or  using  a  separate sysv_signal function, the classical behaviour is
       obtained. This is not recommended.

       Trying to change the semantics of this call using defines and  includes
       is  not	a  good idea. It is better to avoid signal altogether, and use
       sigaction(2) instead.

NOTES    [Toc]    [Back]

       According to POSIX, the behaviour of a process is  undefined  after  it
       ignores	a  SIGFPE, SIGILL, or SIGSEGV signal that was not generated by
       the kill(2) or the raise(3) functions.  Integer division  by  zero  has
       undefined result.  On some architectures it will generate a SIGFPE signal.
  (Also dividing the most  negative	integer  by  -1  may  generate
       SIGFPE.)  Ignoring this signal might lead to an endless loop.

       According  to  POSIX  (3.3.1.3)	it  is	unspecified  what happens when
       SIGCHLD is set to SIG_IGN.  Here the BSD and  SYSV  behaviours  differ,
       causing	BSD  software  that  sets the action for SIGCHLD to SIG_IGN to
       fail on Linux.

       The use of the sighandler_t is a GNU extension.	 Various  versions  of
       libc  predefine	this type; libc4 and libc5 define SignalHandler, glibc
       defines sig_t and, when _GNU_SOURCE is defined, also sighandler_t.


CONFORMING TO    [Toc]    [Back]

       ANSI C

SEE ALSO    [Toc]    [Back]

      
      
       kill(1), kill(2), killpg(2),  pause(2),	raise(3),  sigaction(2),  sig-
       nal(7), sigsetops(3), sigvec(2), alarm(2)



Linux 2.2			  2000-04-28			     SIGNAL(2)
[ Back ]
 Similar pages
Name OS Title
sigaction Linux POSIX signal handling functions.
sigtrap IRIX Perl pragma to enable simple signal handling
acpp IRIX the ANSI C language preprocessor
c89 NetBSD ANSI (1989) C compiler
c89 Linux ANSI (1989) C compiler
ansitape IRIX ANSI standard tape handler
pcfof Tru64 Generic print filter for ANSI, PCL, and multi-language PostScript printers
pxfsigismember IRIX Determines if the specified signal is a member of the specified signal set
pxfsigaddset IRIX Adds an individual signal to the specified signal set
pxfsigdelset IRIX Deletes an individual signal in the specified signal set
Copyright © 2004-2005 DeniX Solutions SRL
newsletter delivery service