signal.h revision 1.19 1 1.19 thorpej /* $NetBSD: signal.h,v 1.19 1998/11/30 20:36:27 thorpej Exp $ */
2 1.3 cgd
3 1.1 cgd /*-
4 1.1 cgd * Copyright (c) 1991, 1993
5 1.1 cgd * The Regents of the University of California. All rights reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.1 cgd * 3. All advertising materials mentioning features or use of this software
16 1.1 cgd * must display the following acknowledgement:
17 1.1 cgd * This product includes software developed by the University of
18 1.1 cgd * California, Berkeley and its contributors.
19 1.1 cgd * 4. Neither the name of the University nor the names of its contributors
20 1.1 cgd * may be used to endorse or promote products derived from this software
21 1.1 cgd * without specific prior written permission.
22 1.1 cgd *
23 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.1 cgd * SUCH DAMAGE.
34 1.1 cgd *
35 1.1 cgd * @(#)signal.h 8.3 (Berkeley) 3/30/94
36 1.1 cgd */
37 1.1 cgd
38 1.12 kleink #ifndef _SIGNAL_H_
39 1.12 kleink #define _SIGNAL_H_
40 1.1 cgd
41 1.1 cgd #include <sys/cdefs.h>
42 1.12 kleink #include <sys/featuretest.h>
43 1.1 cgd
44 1.5 jtc #if !defined(_ANSI_SOURCE)
45 1.5 jtc #include <sys/types.h>
46 1.5 jtc #endif
47 1.9 kleink
48 1.9 kleink #include <sys/signal.h>
49 1.5 jtc
50 1.12 kleink #if !defined(_ANSI_SOURCE) && !defined(_POSIX_C_SOURCE) && \
51 1.12 kleink !defined(_XOPEN_SOURCE)
52 1.19 thorpej extern __const char *__const *sys_signame __RENAME(__sys_signame14);
53 1.19 thorpej extern __const char *__const *sys_siglist __RENAME(__sys_siglist14);
54 1.19 thorpej extern __const int sys_nsig __RENAME(__sys_nsig14);
55 1.1 cgd #endif
56 1.1 cgd
57 1.1 cgd __BEGIN_DECLS
58 1.1 cgd int raise __P((int));
59 1.1 cgd #ifndef _ANSI_SOURCE
60 1.1 cgd int kill __P((pid_t, int));
61 1.13 mycroft
62 1.15 thorpej #ifdef __LIBC12_SOURCE__
63 1.13 mycroft int sigaction __P((int, const struct sigaction13 *, struct sigaction13 *));
64 1.13 mycroft int __sigaction14 __P((int, const struct sigaction *, struct sigaction *));
65 1.13 mycroft int sigaddset __P((sigset13_t *, int));
66 1.13 mycroft int __sigaddset14 __P((sigset_t *, int));
67 1.13 mycroft int sigdelset __P((sigset13_t *, int));
68 1.13 mycroft int __sigdelset14 __P((sigset_t *, int));
69 1.13 mycroft int sigemptyset __P((sigset13_t *));
70 1.13 mycroft int __sigemptyset14 __P((sigset_t *));
71 1.13 mycroft int sigfillset __P((sigset13_t *));
72 1.13 mycroft int __sigfillset14 __P((sigset_t *));
73 1.13 mycroft int sigismember __P((const sigset13_t *, int));
74 1.13 mycroft int __sigismember14 __P((const sigset_t *, int));
75 1.13 mycroft int sigpending __P((sigset13_t *));
76 1.13 mycroft int __sigpending14 __P((sigset_t *));
77 1.13 mycroft int sigprocmask __P((int, const sigset13_t *, sigset13_t *));
78 1.13 mycroft int __sigprocmask14 __P((int, const sigset_t *, sigset_t *));
79 1.13 mycroft int sigsuspend __P((const sigset13_t *));
80 1.13 mycroft int __sigsuspend14 __P((const sigset_t *));
81 1.15 thorpej #else /* !__LIBC12_SOURCE__ */
82 1.13 mycroft int sigaction __P((int, const struct sigaction *, struct sigaction *)) __RENAME(__sigaction14);
83 1.13 mycroft int sigaddset __P((sigset_t *, int)) __RENAME(__sigaddset14);
84 1.13 mycroft int sigdelset __P((sigset_t *, int)) __RENAME(__sigdelset14);
85 1.13 mycroft int sigemptyset __P((sigset_t *)) __RENAME(__sigemptyset14);
86 1.13 mycroft int sigfillset __P((sigset_t *)) __RENAME(__sigfillset14);
87 1.13 mycroft int sigismember __P((const sigset_t *, int)) __RENAME(__sigismember14);
88 1.13 mycroft int sigpending __P((sigset_t *)) __RENAME(__sigpending14);
89 1.13 mycroft int sigprocmask __P((int, const sigset_t *, sigset_t *)) __RENAME(__sigprocmask14);
90 1.13 mycroft int sigsuspend __P((const sigset_t *)) __RENAME(__sigsuspend14);
91 1.4 jtc
92 1.4 jtc #if defined(__GNUC__) && defined(__STDC__)
93 1.14 mycroft extern __inline int
94 1.14 mycroft sigaddset(sigset_t *set, int signo)
95 1.14 mycroft {
96 1.18 kleink #ifdef _REENTRANT
97 1.17 kleink extern int *__errno __P((void));
98 1.17 kleink #else
99 1.4 jtc extern int errno;
100 1.17 kleink #endif
101 1.4 jtc
102 1.6 jtc if (signo <= 0 || signo >= _NSIG) {
103 1.18 kleink #ifdef _REENTRANT
104 1.17 kleink *__errno() = 22; /* EINVAL */
105 1.17 kleink #else
106 1.4 jtc errno = 22; /* EINVAL */
107 1.17 kleink #endif
108 1.14 mycroft return (-1);
109 1.4 jtc }
110 1.13 mycroft __sigaddset(set, signo);
111 1.4 jtc return (0);
112 1.4 jtc }
113 1.4 jtc
114 1.14 mycroft extern __inline int
115 1.14 mycroft sigdelset(sigset_t *set, int signo)
116 1.14 mycroft {
117 1.18 kleink #ifdef _REENTRANT
118 1.17 kleink extern int *__errno __P((void));
119 1.17 kleink #else
120 1.4 jtc extern int errno;
121 1.17 kleink #endif
122 1.4 jtc
123 1.6 jtc if (signo <= 0 || signo >= _NSIG) {
124 1.18 kleink #ifdef _REENTRANT
125 1.17 kleink *__errno() = 22; /* EINVAL */
126 1.17 kleink #else
127 1.4 jtc errno = 22; /* EINVAL */
128 1.17 kleink #endif
129 1.14 mycroft return (-1);
130 1.4 jtc }
131 1.13 mycroft __sigdelset(set, signo);
132 1.4 jtc return (0);
133 1.4 jtc }
134 1.4 jtc
135 1.14 mycroft extern __inline int
136 1.14 mycroft sigismember(const sigset_t *set, int signo)
137 1.14 mycroft {
138 1.18 kleink #ifdef _REENTRANT
139 1.17 kleink extern int *__errno __P((void));
140 1.17 kleink #else
141 1.4 jtc extern int errno;
142 1.17 kleink #endif
143 1.4 jtc
144 1.6 jtc if (signo <= 0 || signo >= _NSIG) {
145 1.18 kleink #ifdef _REENTRANT
146 1.17 kleink *__errno() = 22; /* EINVAL */
147 1.17 kleink #else
148 1.4 jtc errno = 22; /* EINVAL */
149 1.17 kleink #endif
150 1.14 mycroft return (-1);
151 1.4 jtc }
152 1.13 mycroft return (__sigismember(set, signo));
153 1.4 jtc }
154 1.13 mycroft #endif /* __GNUC__ && __STDC__ */
155 1.4 jtc
156 1.4 jtc /* List definitions after function declarations, or Reiser cpp gets upset. */
157 1.13 mycroft #define sigemptyset(set) (__sigemptyset(set), 0)
158 1.13 mycroft #define sigfillset(set) (__sigfillset(set), 0)
159 1.15 thorpej #endif /* !__LIBC12_SOURCE__ */
160 1.5 jtc
161 1.12 kleink #if (!defined(_POSIX_C_SOURCE) && !defined(_XOPEN_SOURCE)) || \
162 1.12 kleink (defined(_XOPEN_SOURCE) && defined(_XOPEN_SOURCE_EXTENDED)) || \
163 1.12 kleink (_XOPEN_SOURCE - 0) >= 500
164 1.1 cgd int killpg __P((pid_t, int));
165 1.1 cgd int siginterrupt __P((int, int));
166 1.1 cgd int sigpause __P((int));
167 1.1 cgd int sigstack __P((const struct sigstack *, struct sigstack *));
168 1.11 kleink #ifdef __LIBC12_SOURCE__
169 1.11 kleink int sigaltstack __P((const struct sigaltstack13 *, struct sigaltstack13 *));
170 1.11 kleink int __sigaltstack14 __P((const stack_t *, stack_t *));
171 1.11 kleink #else
172 1.11 kleink int sigaltstack __P((const stack_t *, stack_t *)) __RENAME(__sigaltstack14);
173 1.11 kleink #endif
174 1.12 kleink #endif /* (!_POSIX_C_SOURCE && !_XOPEN_SOURCE) || ... */
175 1.12 kleink
176 1.12 kleink #if !defined(_POSIX_C_SOURCE) && !defined(_XOPEN_SOURCE)
177 1.12 kleink void psignal __P((unsigned int, const char *));
178 1.12 kleink int sigblock __P((int));
179 1.15 thorpej #ifdef __LIBC12_SOURCE__
180 1.13 mycroft int sigreturn __P((struct sigcontext13 *));
181 1.13 mycroft int __sigreturn14 __P((struct sigcontext *));
182 1.13 mycroft #else
183 1.13 mycroft int sigreturn __P((struct sigcontext *)) __RENAME(__sigreturn14);
184 1.13 mycroft #endif
185 1.12 kleink int sigsetmask __P((int));
186 1.12 kleink int sigvec __P((int, struct sigvec *, struct sigvec *));
187 1.12 kleink #endif /* !_POSIX_C_SOURCE && !_XOPEN_SOURCE */
188 1.12 kleink
189 1.1 cgd #endif /* !_ANSI_SOURCE */
190 1.1 cgd __END_DECLS
191 1.1 cgd
192 1.12 kleink #endif /* !_SIGNAL_H_ */
193