Jump to content United States-English
HP.com Home Products and Services Support and Drivers Solutions How to Buy
» Contact HP
More options
HP.com home
HP-UX Reference > S

sigset(3C)

HP-UX 11i Version 3: February 2007
» 

Technical documentation

» Feedback
Content starts here

 » Table of Contents

 » Index

NAME

sigset(), sighold(), sigrelse(), sigignore() — signal management

SYNOPSIS

#include <signal.h>

void (*sigset(int sig, void (*func)(int)))(int);

int sighold(int sig);

int sigrelse(int sig);

int sigignore(int sig);

DESCRIPTION

The system defines a set of signals that can be delivered to a process. The set of signals is defined in signal(5), along with the meaning and side effects of each signal. An alternate mechanism for handling these signals is defined here. The facilities described here should not be used in conjunction with the other facilities described under signal(2) and sigspace(2).

sigset() allows the calling process to choose one of four ways to handle the receipt of a specific signal. sig specifies the signal and func specifies the action handler.

sig can be any one of the signals described under signal(5) except SIGKILL or SIGSTOP.

func is assigned one of four values: SIG_DFL, SIG_IGN, SIG_HOLD, or a function address. The actions prescribed by SIG_DFL and SIG_IGN are described under signal(5). The action prescribed by SIG_HOLD and function address are described below:

SIG_HOLD

Hold signal.

The signal sig is held upon receipt. Any pending signal of this signal type remains held. Only one signal of each type is held.

Note: the signals SIGKILL, SIGCONT, and SIGSTOP cannot be held.

function address

Catch signal.

func must be a pointer to a function, the signal-catching handler, that is called when signal sig occurs. sigset() specifies that the process calls this function upon receipt of signal sig. Any pending signal of this type is released. This handler address is retained across calls to the other signal management functions listed here. Upon receipt of signal sig, the receiving process executes the signal-catching function pointed to by func as described under signal(5) with the following differences:

Before calling the signal-catching handler, the defined action of sig is set to SIG_HOLD. During a normal return from the signal-catching handler, the defined action is restored to func and any held signal of this type is released. If a non-local goto ( longjmp(3C)) is taken, sigrelse() must be called to restore the defined action to func and release any held signal of this type.

sighold() holds the signal sig. sigrelse() restores the defined action of sig to that specified previously by sigset(). sighold() and sigrelse() are used to establish critical regions of code. sighold() is analogous to raising the priority level and deferring or holding a signal until the priority is lowered by sigrelse().

sigignore() sets the action for signal sig to SIG_IGN (see signal(5)).

RETURN VALUE

Upon successful completion, sigset() returns the previous value of the defined action for the specified signal sig. Otherwise, a value of SIG_ERR is returned and errno is set to indicate the error. SIG_ERR is defined in <signal.h>.

For the other functions, a 0 value indicates that the call succeeded. A -1 return value indicates an error occurred and errno is set to indicate the reason.

ERRORS

sigset() fails and the defined action for sig is not changed if any of the following occur:

EFAULT

The func argument points to memory that is not a valid part of the process address space. Reliable detection of this error is implementation dependent.

sigset(), sighold(), sigrelse(), and sigignore() and fail and the defined action for sig is not changed if any of the following occur:

EINVAL

sig is not a valid signal number.

EINVAL

An attempt is made to ignore, hold, or supply a handler for a signal that cannot be ignored, held, or caught; see signal(5).

WARNINGS

These signal facilities should not be used in conjunction with signal(2) and sigspace(2).

STANDARDS CONFORMANCE

sigset(): SVID2, SVID3

sighold(): SVID2, SVID3

sigignore(): SVID2, SVID3

sigrelse(): SVID2, SVID3

Printable version
Privacy statement Using this site means you accept its terms Feedback to webmaster
© 1983-2007 Hewlett-Packard Development Company, L.P.