signal.h revision 1.15 1 1.15 thorpej /* $NetBSD: signal.h,v 1.15 1998/09/13 04:11:51 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.6 jtc extern __const char *__const sys_signame[_NSIG];
53 1.6 jtc extern __const char *__const sys_siglist[_NSIG];
54 1.1 cgd #endif
55 1.1 cgd
56 1.1 cgd __BEGIN_DECLS
57 1.1 cgd int raise __P((int));
58 1.1 cgd #ifndef _ANSI_SOURCE
59 1.1 cgd int kill __P((pid_t, int));
60 1.13 mycroft
61 1.15 thorpej #ifdef __LIBC12_SOURCE__
62 1.13 mycroft int sigaction __P((int, const struct sigaction13 *, struct sigaction13 *));
63 1.13 mycroft int __sigaction14 __P((int, const struct sigaction *, struct sigaction *));
64 1.13 mycroft int sigaddset __P((sigset13_t *, int));
65 1.13 mycroft int __sigaddset14 __P((sigset_t *, int));
66 1.13 mycroft int sigdelset __P((sigset13_t *, int));
67 1.13 mycroft int __sigdelset14 __P((sigset_t *, int));
68 1.13 mycroft int sigemptyset __P((sigset13_t *));
69 1.13 mycroft int __sigemptyset14 __P((sigset_t *));
70 1.13 mycroft int sigfillset __P((sigset13_t *));
71 1.13 mycroft int __sigfillset14 __P((sigset_t *));
72 1.13 mycroft int sigismember __P((const sigset13_t *, int));
73 1.13 mycroft int __sigismember14 __P((const sigset_t *, int));
74 1.13 mycroft int sigpending __P((sigset13_t *));
75 1.13 mycroft int __sigpending14 __P((sigset_t *));
76 1.13 mycroft int sigprocmask __P((int, const sigset13_t *, sigset13_t *));
77 1.13 mycroft int __sigprocmask14 __P((int, const sigset_t *, sigset_t *));
78 1.13 mycroft int sigsuspend __P((const sigset13_t *));
79 1.13 mycroft int __sigsuspend14 __P((const sigset_t *));
80 1.15 thorpej #else /* !__LIBC12_SOURCE__ */
81 1.13 mycroft int sigaction __P((int, const struct sigaction *, struct sigaction *)) __RENAME(__sigaction14);
82 1.13 mycroft int sigaddset __P((sigset_t *, int)) __RENAME(__sigaddset14);
83 1.13 mycroft int sigdelset __P((sigset_t *, int)) __RENAME(__sigdelset14);
84 1.13 mycroft int sigemptyset __P((sigset_t *)) __RENAME(__sigemptyset14);
85 1.13 mycroft int sigfillset __P((sigset_t *)) __RENAME(__sigfillset14);
86 1.13 mycroft int sigismember __P((const sigset_t *, int)) __RENAME(__sigismember14);
87 1.13 mycroft int sigpending __P((sigset_t *)) __RENAME(__sigpending14);
88 1.13 mycroft int sigprocmask __P((int, const sigset_t *, sigset_t *)) __RENAME(__sigprocmask14);
89 1.13 mycroft int sigsuspend __P((const sigset_t *)) __RENAME(__sigsuspend14);
90 1.4 jtc
91 1.4 jtc #if defined(__GNUC__) && defined(__STDC__)
92 1.14 mycroft extern __inline int
93 1.14 mycroft sigaddset(sigset_t *set, int signo)
94 1.14 mycroft {
95 1.4 jtc extern int errno;
96 1.4 jtc
97 1.6 jtc if (signo <= 0 || signo >= _NSIG) {
98 1.4 jtc errno = 22; /* EINVAL */
99 1.14 mycroft return (-1);
100 1.4 jtc }
101 1.13 mycroft __sigaddset(set, signo);
102 1.4 jtc return (0);
103 1.4 jtc }
104 1.4 jtc
105 1.14 mycroft extern __inline int
106 1.14 mycroft sigdelset(sigset_t *set, int signo)
107 1.14 mycroft {
108 1.4 jtc extern int errno;
109 1.4 jtc
110 1.6 jtc if (signo <= 0 || signo >= _NSIG) {
111 1.4 jtc errno = 22; /* EINVAL */
112 1.14 mycroft return (-1);
113 1.4 jtc }
114 1.13 mycroft __sigdelset(set, signo);
115 1.4 jtc return (0);
116 1.4 jtc }
117 1.4 jtc
118 1.14 mycroft extern __inline int
119 1.14 mycroft sigismember(const sigset_t *set, int signo)
120 1.14 mycroft {
121 1.4 jtc extern int errno;
122 1.4 jtc
123 1.6 jtc if (signo <= 0 || signo >= _NSIG) {
124 1.4 jtc errno = 22; /* EINVAL */
125 1.14 mycroft return (-1);
126 1.4 jtc }
127 1.13 mycroft return (__sigismember(set, signo));
128 1.4 jtc }
129 1.13 mycroft #endif /* __GNUC__ && __STDC__ */
130 1.4 jtc
131 1.4 jtc /* List definitions after function declarations, or Reiser cpp gets upset. */
132 1.13 mycroft #define sigemptyset(set) (__sigemptyset(set), 0)
133 1.13 mycroft #define sigfillset(set) (__sigfillset(set), 0)
134 1.15 thorpej #endif /* !__LIBC12_SOURCE__ */
135 1.5 jtc
136 1.12 kleink #if (!defined(_POSIX_C_SOURCE) && !defined(_XOPEN_SOURCE)) || \
137 1.12 kleink (defined(_XOPEN_SOURCE) && defined(_XOPEN_SOURCE_EXTENDED)) || \
138 1.12 kleink (_XOPEN_SOURCE - 0) >= 500
139 1.1 cgd int killpg __P((pid_t, int));
140 1.1 cgd int siginterrupt __P((int, int));
141 1.1 cgd int sigpause __P((int));
142 1.1 cgd int sigstack __P((const struct sigstack *, struct sigstack *));
143 1.11 kleink #ifdef __LIBC12_SOURCE__
144 1.11 kleink int sigaltstack __P((const struct sigaltstack13 *, struct sigaltstack13 *));
145 1.11 kleink int __sigaltstack14 __P((const stack_t *, stack_t *));
146 1.11 kleink #else
147 1.11 kleink int sigaltstack __P((const stack_t *, stack_t *)) __RENAME(__sigaltstack14);
148 1.11 kleink #endif
149 1.12 kleink #endif /* (!_POSIX_C_SOURCE && !_XOPEN_SOURCE) || ... */
150 1.12 kleink
151 1.12 kleink #if !defined(_POSIX_C_SOURCE) && !defined(_XOPEN_SOURCE)
152 1.12 kleink void psignal __P((unsigned int, const char *));
153 1.12 kleink int sigblock __P((int));
154 1.15 thorpej #ifdef __LIBC12_SOURCE__
155 1.13 mycroft int sigreturn __P((struct sigcontext13 *));
156 1.13 mycroft int __sigreturn14 __P((struct sigcontext *));
157 1.13 mycroft #else
158 1.13 mycroft int sigreturn __P((struct sigcontext *)) __RENAME(__sigreturn14);
159 1.13 mycroft #endif
160 1.12 kleink int sigsetmask __P((int));
161 1.12 kleink int sigvec __P((int, struct sigvec *, struct sigvec *));
162 1.12 kleink #endif /* !_POSIX_C_SOURCE && !_XOPEN_SOURCE */
163 1.12 kleink
164 1.1 cgd #endif /* !_ANSI_SOURCE */
165 1.1 cgd __END_DECLS
166 1.1 cgd
167 1.12 kleink #endif /* !_SIGNAL_H_ */
168