f8baf84c43308302d280795ff7768d2f2e26be7b
[platform/upstream/glibc.git] / sysdeps / unix / sysv / linux / s390 / bits / sigaction.h
1 /* Definitions for 31 & 64 bit S/390 sigaction.
2    Copyright (C) 2001-2014 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
9
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
14
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, see
17    <http://www.gnu.org/licenses/>.  */
18
19 #ifndef _SIGNAL_H
20 # error "Never include <bits/sigaction.h> directly; use <signal.h> instead."
21 #endif
22
23 #include <bits/wordsize.h>
24
25 #if __WORDSIZE == 64
26 /* Structure describing the action to be taken when a signal arrives.  */
27 struct sigaction
28   {
29     /* Signal handler.  */
30 #ifdef __USE_POSIX199309
31     union
32       {
33         /* Used if SA_SIGINFO is not set.  */
34         __sighandler_t sa_handler;
35         /* Used if SA_SIGINFO is set.  */
36         void (*sa_sigaction) (int, siginfo_t *, void *);
37       }
38     __sigaction_handler;
39 # define sa_handler     __sigaction_handler.sa_handler
40 # define sa_sigaction   __sigaction_handler.sa_sigaction
41 #else
42     __sighandler_t sa_handler;
43 #endif
44
45     /* Special flags.  */
46     unsigned long int sa_flags;
47
48     /* Restore handler.  */
49     void (*sa_restorer) (void);
50
51     /* Additional set of signals to be blocked.  */
52     __sigset_t sa_mask;
53   };
54 #else
55 /* Structure describing the action to be taken when a signal arrives.  */
56 struct sigaction
57   {
58     /* Signal handler.  */
59 #ifdef __USE_POSIX199309
60     union
61       {
62         /* Used if SA_SIGINFO is not set.  */
63         __sighandler_t sa_handler;
64         /* Used if SA_SIGINFO is set.  */
65         void (*sa_sigaction) (int, siginfo_t *, void *);
66       }
67     __sigaction_handler;
68 # define sa_handler     __sigaction_handler.sa_handler
69 # define sa_sigaction   __sigaction_handler.sa_sigaction
70 #else
71     __sighandler_t sa_handler;
72 #endif
73
74     /* Additional set of signals to be blocked.  */
75     __sigset_t sa_mask;
76
77     /* Special flags.  */
78     int sa_flags;
79
80     /* Restore handler.  */
81     void (*sa_restorer) (void);
82   };
83 #endif
84
85 /* Bits in `sa_flags'.  */
86 #define SA_NOCLDSTOP  1          /* Don't send SIGCHLD when children stop.  */
87 #define SA_NOCLDWAIT  2          /* Don't create zombie on child death.  */
88 #define SA_SIGINFO    4          /* Invoke signal-catching function with
89                                     three arguments instead of one.  */
90 #if defined __USE_UNIX98 || defined __USE_MISC
91 # define SA_ONSTACK   0x08000000 /* Use signal stack by using `sa_restorer'. */
92 #endif
93 #if defined __USE_UNIX98 || defined __USE_XOPEN2K8
94 # define SA_RESTART   0x10000000 /* Restart syscall on signal return.  */
95 # define SA_NODEFER   0x40000000 /* Don't automatically block the signal when
96                                     its handler is being executed.       */
97 # define SA_RESETHAND 0x80000000 /* Reset to SIG_DFL on entry to handler.  */
98 #endif
99 #ifdef __USE_MISC
100 # define SA_INTERRUPT 0x20000000 /* Historical no-op.  */
101
102 /* Some aliases for the SA_ constants.  */
103 # define SA_NOMASK    SA_NODEFER
104 # define SA_ONESHOT   SA_RESETHAND
105 # define SA_STACK     SA_ONSTACK
106 #endif
107
108 /* Values for the HOW argument to `sigprocmask'.  */
109 #define SIG_BLOCK     0          /* Block signals.  */
110 #define SIG_UNBLOCK   1          /* Unblock signals.  */
111 #define SIG_SETMASK   2          /* Set the set of blocked signals.  */