1 /* Copyright (C) 1998-2015 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
4 The GNU C Library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Lesser General Public
6 License as published by the Free Software Foundation; either
7 version 2.1 of the License, or (at your option) any later version.
9 The GNU C Library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Lesser General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public
15 License along with the GNU C Library; if not, see
16 <http://www.gnu.org/licenses/>. */
22 #include <string.h> /* For the real memset prototype. */
25 /* Set the disposition for SIG. */
32 struct sigaction oact
;
37 /* Handle SIG_HOLD first. */
40 /* Create an empty signal set. */
41 if (__sigemptyset (&set
) < 0)
44 /* Add the specified signal. */
45 if (__sigaddset (&set
, sig
) < 0)
48 /* Add the signal set to the current signal mask. */
49 if (__sigprocmask (SIG_BLOCK
, &set
, &oset
) < 0)
52 /* If the signal was already blocked signal this to the caller. */
53 if (__sigismember (&oset
, sig
))
56 /* We need to determine whether a specific handler is installed. */
57 if (__sigaction (sig
, NULL
, &oact
) < 0)
60 return oact
.sa_handler
;
64 /* Check signal extents to protect __sigismember. */
65 if (disp
== SIG_ERR
|| sig
< 1 || sig
>= NSIG
)
71 act
.sa_handler
= disp
;
72 if (__sigemptyset (&act
.sa_mask
) < 0)
75 if (__sigaction (sig
, &act
, &oact
) < 0)
78 /* Create an empty signal set. */
79 if (__sigemptyset (&set
) < 0)
82 /* Add the specified signal. */
83 if (__sigaddset (&set
, sig
) < 0)
86 /* Remove the signal set from the current signal mask. */
87 if (__sigprocmask (SIG_UNBLOCK
, &set
, &oset
) < 0)
90 /* If the signal was already blocked return SIG_HOLD. */
91 return __sigismember (&oset
, sig
) ? SIG_HOLD
: oact
.sa_handler
;