1*2fe8fb19SBen Gras.\" $NetBSD: sigprocmask.2,v 1.22 2006/01/07 20:11:30 kleink Exp $ 2*2fe8fb19SBen Gras.\" 3*2fe8fb19SBen Gras.\" Copyright (c) 1983, 1991, 1993 4*2fe8fb19SBen Gras.\" The Regents of the University of California. All rights reserved. 5*2fe8fb19SBen Gras.\" 6*2fe8fb19SBen Gras.\" Redistribution and use in source and binary forms, with or without 7*2fe8fb19SBen Gras.\" modification, are permitted provided that the following conditions 8*2fe8fb19SBen Gras.\" are met: 9*2fe8fb19SBen Gras.\" 1. Redistributions of source code must retain the above copyright 10*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer. 11*2fe8fb19SBen Gras.\" 2. Redistributions in binary form must reproduce the above copyright 12*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer in the 13*2fe8fb19SBen Gras.\" documentation and/or other materials provided with the distribution. 14*2fe8fb19SBen Gras.\" 3. Neither the name of the University nor the names of its contributors 15*2fe8fb19SBen Gras.\" may be used to endorse or promote products derived from this software 16*2fe8fb19SBen Gras.\" without specific prior written permission. 17*2fe8fb19SBen Gras.\" 18*2fe8fb19SBen Gras.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 19*2fe8fb19SBen Gras.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20*2fe8fb19SBen Gras.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21*2fe8fb19SBen Gras.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 22*2fe8fb19SBen Gras.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 23*2fe8fb19SBen Gras.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 24*2fe8fb19SBen Gras.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 25*2fe8fb19SBen Gras.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 26*2fe8fb19SBen Gras.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 27*2fe8fb19SBen Gras.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 28*2fe8fb19SBen Gras.\" SUCH DAMAGE. 29*2fe8fb19SBen Gras.\" 30*2fe8fb19SBen Gras.\" @(#)sigprocmask.2 8.1 (Berkeley) 6/4/93 31*2fe8fb19SBen Gras.\" 32*2fe8fb19SBen Gras.Dd June 4, 1993 33*2fe8fb19SBen Gras.Dt SIGPROCMASK 2 34*2fe8fb19SBen Gras.Os 35*2fe8fb19SBen Gras.Sh NAME 36*2fe8fb19SBen Gras.Nm sigprocmask 37*2fe8fb19SBen Gras.Nd manipulate current signal mask 38*2fe8fb19SBen Gras.Sh LIBRARY 39*2fe8fb19SBen Gras.Lb libc 40*2fe8fb19SBen Gras.Sh SYNOPSIS 41*2fe8fb19SBen Gras.In signal.h 42*2fe8fb19SBen Gras.Ft int 43*2fe8fb19SBen Gras.Fn sigprocmask "int how" "const sigset_t * restrict set" "sigset_t * restrict oset" 44*2fe8fb19SBen Gras.Sh DESCRIPTION 45*2fe8fb19SBen GrasThe 46*2fe8fb19SBen Gras.Fn sigprocmask 47*2fe8fb19SBen Grasfunction examines and/or changes the current signal mask (those signals 48*2fe8fb19SBen Grasthat are blocked from delivery). 49*2fe8fb19SBen GrasSignals are blocked if they are members of the current signal mask set. 50*2fe8fb19SBen Gras.Pp 51*2fe8fb19SBen GrasIf 52*2fe8fb19SBen Gras.Fa set 53*2fe8fb19SBen Grasis not null, the action of 54*2fe8fb19SBen Gras.Fn sigprocmask 55*2fe8fb19SBen Grasdepends on the value of the parameter 56*2fe8fb19SBen Gras.Fa how . 57*2fe8fb19SBen GrasThe signal mask is changed as a function of the specified 58*2fe8fb19SBen Gras.Fa set 59*2fe8fb19SBen Grasand the current mask. 60*2fe8fb19SBen GrasThe function is specified by 61*2fe8fb19SBen Gras.Fa how 62*2fe8fb19SBen Grasusing one of the following values: 63*2fe8fb19SBen Gras.Bl -tag -width SIG_UNBLOCK 64*2fe8fb19SBen Gras.It Dv SIG_BLOCK 65*2fe8fb19SBen GrasThe new mask is the union of the current mask and the specified 66*2fe8fb19SBen Gras.Fa set . 67*2fe8fb19SBen Gras.It Dv SIG_UNBLOCK 68*2fe8fb19SBen GrasThe new mask is the intersection of the current mask 69*2fe8fb19SBen Grasand the complement of the specified 70*2fe8fb19SBen Gras.Fa set . 71*2fe8fb19SBen Gras.It Dv SIG_SETMASK 72*2fe8fb19SBen GrasThe current mask is replaced by the specified 73*2fe8fb19SBen Gras.Fa set . 74*2fe8fb19SBen Gras.El 75*2fe8fb19SBen Gras.Pp 76*2fe8fb19SBen GrasIf 77*2fe8fb19SBen Gras.Fa oset 78*2fe8fb19SBen Grasis not null, it is set to 79*2fe8fb19SBen Grasthe previous value of the signal mask. 80*2fe8fb19SBen Gras.Pp 81*2fe8fb19SBen GrasWhen 82*2fe8fb19SBen Gras.Fa set 83*2fe8fb19SBen Grasis null, 84*2fe8fb19SBen Grasthe value of 85*2fe8fb19SBen Gras.Ar how 86*2fe8fb19SBen Grasis insignificant and the mask remains unset 87*2fe8fb19SBen Grasproviding a way to examine the signal mask without modification. 88*2fe8fb19SBen Gras.Pp 89*2fe8fb19SBen GrasThe system 90*2fe8fb19SBen Grasquietly disallows 91*2fe8fb19SBen Gras.Dv SIGKILL 92*2fe8fb19SBen Grasor 93*2fe8fb19SBen Gras.Dv SIGSTOP 94*2fe8fb19SBen Grasto be blocked. 95*2fe8fb19SBen Gras.Sh RETURN VALUES 96*2fe8fb19SBen GrasA 0 value indicates that the call succeeded. 97*2fe8fb19SBen GrasA \-1 return value indicates an error occurred and 98*2fe8fb19SBen Gras.Va errno 99*2fe8fb19SBen Grasis set to indicate the reason. 100*2fe8fb19SBen Gras.Sh ERRORS 101*2fe8fb19SBen GrasThe 102*2fe8fb19SBen Gras.Fn sigprocmask 103*2fe8fb19SBen Grascall will fail and the signal mask will be unchanged if one 104*2fe8fb19SBen Grasof the following occurs: 105*2fe8fb19SBen Gras.Bl -tag -width Er 106*2fe8fb19SBen Gras.It Bq Er EINVAL 107*2fe8fb19SBen Gras.Fa how 108*2fe8fb19SBen Grashas a value other than those listed here. 109*2fe8fb19SBen Gras.El 110*2fe8fb19SBen Gras.Sh SEE ALSO 111*2fe8fb19SBen Gras.Xr kill 2 , 112*2fe8fb19SBen Gras.Xr sigaction 2 , 113*2fe8fb19SBen Gras.Xr sigsuspend 2 , 114*2fe8fb19SBen Gras.Xr pthread_sigmask 3 , 115*2fe8fb19SBen Gras.Xr sigsetops 3 , 116*2fe8fb19SBen Gras.Xr signal 7 117*2fe8fb19SBen Gras.Sh STANDARDS 118*2fe8fb19SBen GrasThe 119*2fe8fb19SBen Gras.Fn sigprocmask 120*2fe8fb19SBen Grasfunction conforms to 121*2fe8fb19SBen Gras.St -p1003.1-90 . 122