xref: /aosp_15_r20/bionic/libc/include/signal.h (revision 8d67ca893c1523eb926b9080dbe4e2ffd2a27ba1)
1*8d67ca89SAndroid Build Coastguard Worker /*
2*8d67ca89SAndroid Build Coastguard Worker  * Copyright (C) 2008 The Android Open Source Project
3*8d67ca89SAndroid Build Coastguard Worker  * All rights reserved.
4*8d67ca89SAndroid Build Coastguard Worker  *
5*8d67ca89SAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
6*8d67ca89SAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
7*8d67ca89SAndroid Build Coastguard Worker  * are met:
8*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions of source code must retain the above copyright
9*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
10*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions in binary form must reproduce the above copyright
11*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in
12*8d67ca89SAndroid Build Coastguard Worker  *    the documentation and/or other materials provided with the
13*8d67ca89SAndroid Build Coastguard Worker  *    distribution.
14*8d67ca89SAndroid Build Coastguard Worker  *
15*8d67ca89SAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16*8d67ca89SAndroid Build Coastguard Worker  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17*8d67ca89SAndroid Build Coastguard Worker  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18*8d67ca89SAndroid Build Coastguard Worker  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19*8d67ca89SAndroid Build Coastguard Worker  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20*8d67ca89SAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21*8d67ca89SAndroid Build Coastguard Worker  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22*8d67ca89SAndroid Build Coastguard Worker  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23*8d67ca89SAndroid Build Coastguard Worker  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24*8d67ca89SAndroid Build Coastguard Worker  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25*8d67ca89SAndroid Build Coastguard Worker  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*8d67ca89SAndroid Build Coastguard Worker  * SUCH DAMAGE.
27*8d67ca89SAndroid Build Coastguard Worker  */
28*8d67ca89SAndroid Build Coastguard Worker 
29*8d67ca89SAndroid Build Coastguard Worker #ifndef _SIGNAL_H_
30*8d67ca89SAndroid Build Coastguard Worker #define _SIGNAL_H_
31*8d67ca89SAndroid Build Coastguard Worker 
32*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h>
33*8d67ca89SAndroid Build Coastguard Worker #include <sys/types.h>
34*8d67ca89SAndroid Build Coastguard Worker 
35*8d67ca89SAndroid Build Coastguard Worker #include <asm/sigcontext.h>
36*8d67ca89SAndroid Build Coastguard Worker #include <bits/pthread_types.h>
37*8d67ca89SAndroid Build Coastguard Worker #include <bits/signal_types.h>
38*8d67ca89SAndroid Build Coastguard Worker #include <bits/timespec.h>
39*8d67ca89SAndroid Build Coastguard Worker #include <limits.h>
40*8d67ca89SAndroid Build Coastguard Worker 
41*8d67ca89SAndroid Build Coastguard Worker #include <sys/ucontext.h>
42*8d67ca89SAndroid Build Coastguard Worker #define __BIONIC_HAVE_UCONTEXT_T
43*8d67ca89SAndroid Build Coastguard Worker 
44*8d67ca89SAndroid Build Coastguard Worker __BEGIN_DECLS
45*8d67ca89SAndroid Build Coastguard Worker 
46*8d67ca89SAndroid Build Coastguard Worker /* The kernel headers define SIG_DFL (0) and SIG_IGN (1) but not SIG_HOLD, since
47*8d67ca89SAndroid Build Coastguard Worker  * SIG_HOLD is only used by the deprecated SysV signal API.
48*8d67ca89SAndroid Build Coastguard Worker  */
49*8d67ca89SAndroid Build Coastguard Worker #define SIG_HOLD __BIONIC_CAST(reinterpret_cast, sighandler_t, 2)
50*8d67ca89SAndroid Build Coastguard Worker 
51*8d67ca89SAndroid Build Coastguard Worker /* We take a few real-time signals for ourselves. May as well use the same names as glibc. */
52*8d67ca89SAndroid Build Coastguard Worker #define SIGRTMIN (__libc_current_sigrtmin())
53*8d67ca89SAndroid Build Coastguard Worker #define SIGRTMAX (__libc_current_sigrtmax())
54*8d67ca89SAndroid Build Coastguard Worker int __libc_current_sigrtmin(void);
55*8d67ca89SAndroid Build Coastguard Worker int __libc_current_sigrtmax(void);
56*8d67ca89SAndroid Build Coastguard Worker 
57*8d67ca89SAndroid Build Coastguard Worker extern const char* _Nonnull const sys_siglist[_NSIG];
58*8d67ca89SAndroid Build Coastguard Worker extern const char* _Nonnull const sys_signame[_NSIG]; /* BSD compatibility. */
59*8d67ca89SAndroid Build Coastguard Worker 
60*8d67ca89SAndroid Build Coastguard Worker #define si_timerid si_tid /* glibc compatibility. */
61*8d67ca89SAndroid Build Coastguard Worker 
62*8d67ca89SAndroid Build Coastguard Worker int sigaction(int __signal, const struct sigaction* _Nullable __new_action, struct sigaction* _Nullable __old_action);
63*8d67ca89SAndroid Build Coastguard Worker 
64*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
65*8d67ca89SAndroid Build Coastguard Worker int sigaction64(int __signal, const struct sigaction64* _Nullable __new_action, struct sigaction64* _Nullable __old_action) __INTRODUCED_IN(28);
66*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
67*8d67ca89SAndroid Build Coastguard Worker 
68*8d67ca89SAndroid Build Coastguard Worker 
69*8d67ca89SAndroid Build Coastguard Worker int siginterrupt(int __signal, int __flag);
70*8d67ca89SAndroid Build Coastguard Worker 
71*8d67ca89SAndroid Build Coastguard Worker sighandler_t _Nonnull signal(int __signal, sighandler_t _Nullable __handler);
72*8d67ca89SAndroid Build Coastguard Worker int sigaddset(sigset_t* _Nonnull __set, int __signal);
73*8d67ca89SAndroid Build Coastguard Worker 
74*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
75*8d67ca89SAndroid Build Coastguard Worker int sigaddset64(sigset64_t* _Nonnull __set, int __signal) __INTRODUCED_IN(28);
76*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
77*8d67ca89SAndroid Build Coastguard Worker 
78*8d67ca89SAndroid Build Coastguard Worker int sigdelset(sigset_t* _Nonnull __set, int __signal);
79*8d67ca89SAndroid Build Coastguard Worker 
80*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
81*8d67ca89SAndroid Build Coastguard Worker int sigdelset64(sigset64_t* _Nonnull __set, int __signal) __INTRODUCED_IN(28);
82*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
83*8d67ca89SAndroid Build Coastguard Worker 
84*8d67ca89SAndroid Build Coastguard Worker int sigemptyset(sigset_t* _Nonnull __set);
85*8d67ca89SAndroid Build Coastguard Worker 
86*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
87*8d67ca89SAndroid Build Coastguard Worker int sigemptyset64(sigset64_t* _Nonnull __set) __INTRODUCED_IN(28);
88*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
89*8d67ca89SAndroid Build Coastguard Worker 
90*8d67ca89SAndroid Build Coastguard Worker int sigfillset(sigset_t* _Nonnull __set);
91*8d67ca89SAndroid Build Coastguard Worker 
92*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
93*8d67ca89SAndroid Build Coastguard Worker int sigfillset64(sigset64_t* _Nonnull __set) __INTRODUCED_IN(28);
94*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
95*8d67ca89SAndroid Build Coastguard Worker 
96*8d67ca89SAndroid Build Coastguard Worker int sigismember(const sigset_t* _Nonnull __set, int __signal);
97*8d67ca89SAndroid Build Coastguard Worker 
98*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
99*8d67ca89SAndroid Build Coastguard Worker int sigismember64(const sigset64_t* _Nonnull __set, int __signal) __INTRODUCED_IN(28);
100*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
101*8d67ca89SAndroid Build Coastguard Worker 
102*8d67ca89SAndroid Build Coastguard Worker 
103*8d67ca89SAndroid Build Coastguard Worker int sigpending(sigset_t* _Nonnull __set);
104*8d67ca89SAndroid Build Coastguard Worker 
105*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
106*8d67ca89SAndroid Build Coastguard Worker int sigpending64(sigset64_t* _Nonnull __set) __INTRODUCED_IN(28);
107*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
108*8d67ca89SAndroid Build Coastguard Worker 
109*8d67ca89SAndroid Build Coastguard Worker int sigprocmask(int __how, const sigset_t* _Nullable __new_set, sigset_t* _Nullable __old_set);
110*8d67ca89SAndroid Build Coastguard Worker 
111*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
112*8d67ca89SAndroid Build Coastguard Worker int sigprocmask64(int __how, const sigset64_t* _Nullable __new_set, sigset64_t* _Nullable __old_set) __INTRODUCED_IN(28);
113*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
114*8d67ca89SAndroid Build Coastguard Worker 
115*8d67ca89SAndroid Build Coastguard Worker int sigsuspend(const sigset_t* _Nonnull __mask);
116*8d67ca89SAndroid Build Coastguard Worker 
117*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
118*8d67ca89SAndroid Build Coastguard Worker int sigsuspend64(const sigset64_t* _Nonnull __mask) __INTRODUCED_IN(28);
119*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
120*8d67ca89SAndroid Build Coastguard Worker 
121*8d67ca89SAndroid Build Coastguard Worker int sigwait(const sigset_t* _Nonnull __set, int* _Nonnull __signal);
122*8d67ca89SAndroid Build Coastguard Worker 
123*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
124*8d67ca89SAndroid Build Coastguard Worker int sigwait64(const sigset64_t* _Nonnull __set, int* _Nonnull __signal) __INTRODUCED_IN(28);
125*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
126*8d67ca89SAndroid Build Coastguard Worker 
127*8d67ca89SAndroid Build Coastguard Worker 
128*8d67ca89SAndroid Build Coastguard Worker 
129*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(26)
130*8d67ca89SAndroid Build Coastguard Worker int sighold(int __signal)
131*8d67ca89SAndroid Build Coastguard Worker   __attribute__((__deprecated__("use sigprocmask() or pthread_sigmask() instead")))
132*8d67ca89SAndroid Build Coastguard Worker   __INTRODUCED_IN(26);
133*8d67ca89SAndroid Build Coastguard Worker int sigignore(int __signal)
134*8d67ca89SAndroid Build Coastguard Worker   __attribute__((__deprecated__("use sigaction() instead"))) __INTRODUCED_IN(26);
135*8d67ca89SAndroid Build Coastguard Worker int sigpause(int __signal)
136*8d67ca89SAndroid Build Coastguard Worker   __attribute__((__deprecated__("use sigsuspend() instead"))) __INTRODUCED_IN(26);
137*8d67ca89SAndroid Build Coastguard Worker int sigrelse(int __signal)
138*8d67ca89SAndroid Build Coastguard Worker   __attribute__((__deprecated__("use sigprocmask() or pthread_sigmask() instead")))
139*8d67ca89SAndroid Build Coastguard Worker   __INTRODUCED_IN(26);
140*8d67ca89SAndroid Build Coastguard Worker sighandler_t _Nonnull sigset(int __signal, sighandler_t _Nullable __handler)
141*8d67ca89SAndroid Build Coastguard Worker   __attribute__((__deprecated__("use sigaction() instead"))) __INTRODUCED_IN(26);
142*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(26) */
143*8d67ca89SAndroid Build Coastguard Worker 
144*8d67ca89SAndroid Build Coastguard Worker 
145*8d67ca89SAndroid Build Coastguard Worker int raise(int __signal);
146*8d67ca89SAndroid Build Coastguard Worker int kill(pid_t __pid, int __signal);
147*8d67ca89SAndroid Build Coastguard Worker int killpg(int __pgrp, int __signal);
148*8d67ca89SAndroid Build Coastguard Worker int tgkill(int __tgid, int __tid, int __signal);
149*8d67ca89SAndroid Build Coastguard Worker 
150*8d67ca89SAndroid Build Coastguard Worker int sigaltstack(const stack_t* _Nullable __new_signal_stack, stack_t*  _Nullable __old_signal_stack);
151*8d67ca89SAndroid Build Coastguard Worker 
152*8d67ca89SAndroid Build Coastguard Worker void psiginfo(const siginfo_t* _Nonnull __info, const char* _Nullable __msg);
153*8d67ca89SAndroid Build Coastguard Worker void psignal(int __signal, const char* _Nullable __msg);
154*8d67ca89SAndroid Build Coastguard Worker 
155*8d67ca89SAndroid Build Coastguard Worker int pthread_kill(pthread_t __pthread, int __signal);
156*8d67ca89SAndroid Build Coastguard Worker #if defined(__USE_GNU)
157*8d67ca89SAndroid Build Coastguard Worker 
158*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(29)
159*8d67ca89SAndroid Build Coastguard Worker int pthread_sigqueue(pthread_t __pthread, int __signal, const union sigval __value) __INTRODUCED_IN(29);
160*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(29) */
161*8d67ca89SAndroid Build Coastguard Worker 
162*8d67ca89SAndroid Build Coastguard Worker #endif
163*8d67ca89SAndroid Build Coastguard Worker 
164*8d67ca89SAndroid Build Coastguard Worker int pthread_sigmask(int __how, const sigset_t* _Nullable __new_set, sigset_t* _Nullable __old_set);
165*8d67ca89SAndroid Build Coastguard Worker 
166*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
167*8d67ca89SAndroid Build Coastguard Worker int pthread_sigmask64(int __how, const sigset64_t* _Nullable __new_set, sigset64_t* _Nullable __old_set) __INTRODUCED_IN(28);
168*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
169*8d67ca89SAndroid Build Coastguard Worker 
170*8d67ca89SAndroid Build Coastguard Worker 
171*8d67ca89SAndroid Build Coastguard Worker 
172*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(23)
173*8d67ca89SAndroid Build Coastguard Worker int sigqueue(pid_t __pid, int __signal, const union sigval __value) __INTRODUCED_IN(23);
174*8d67ca89SAndroid Build Coastguard Worker int sigtimedwait(const sigset_t* _Nonnull __set, siginfo_t* _Nullable __info, const struct timespec* _Nullable __timeout) __INTRODUCED_IN(23);
175*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(23) */
176*8d67ca89SAndroid Build Coastguard Worker 
177*8d67ca89SAndroid Build Coastguard Worker 
178*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
179*8d67ca89SAndroid Build Coastguard Worker int sigtimedwait64(const sigset64_t* _Nonnull __set, siginfo_t* _Nullable __info, const struct timespec* _Nullable __timeout) __INTRODUCED_IN(28);
180*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
181*8d67ca89SAndroid Build Coastguard Worker 
182*8d67ca89SAndroid Build Coastguard Worker 
183*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(23)
184*8d67ca89SAndroid Build Coastguard Worker int sigwaitinfo(const sigset_t* _Nonnull __set, siginfo_t* _Nullable __info) __INTRODUCED_IN(23);
185*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(23) */
186*8d67ca89SAndroid Build Coastguard Worker 
187*8d67ca89SAndroid Build Coastguard Worker 
188*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(28)
189*8d67ca89SAndroid Build Coastguard Worker int sigwaitinfo64(const sigset64_t* _Nonnull __set, siginfo_t* _Nullable __info) __INTRODUCED_IN(28);
190*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(28) */
191*8d67ca89SAndroid Build Coastguard Worker 
192*8d67ca89SAndroid Build Coastguard Worker 
193*8d67ca89SAndroid Build Coastguard Worker /**
194*8d67ca89SAndroid Build Coastguard Worker  * Buffer size suitable for any call to sig2str().
195*8d67ca89SAndroid Build Coastguard Worker  */
196*8d67ca89SAndroid Build Coastguard Worker #define SIG2STR_MAX 32
197*8d67ca89SAndroid Build Coastguard Worker 
198*8d67ca89SAndroid Build Coastguard Worker /**
199*8d67ca89SAndroid Build Coastguard Worker  * [sig2str(3)](https://man7.org/linux/man-pages/man3/sig2str.3.html)
200*8d67ca89SAndroid Build Coastguard Worker  * converts the integer corresponding to SIGSEGV (say) into a string
201*8d67ca89SAndroid Build Coastguard Worker  * like "SEGV" (not including the "SIG" used in the constants).
202*8d67ca89SAndroid Build Coastguard Worker  * SIG2STR_MAX is a safe size to use for the buffer.
203*8d67ca89SAndroid Build Coastguard Worker  *
204*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 _without_ setting errno otherwise.
205*8d67ca89SAndroid Build Coastguard Worker  *
206*8d67ca89SAndroid Build Coastguard Worker  * Available since API level 36.
207*8d67ca89SAndroid Build Coastguard Worker  */
208*8d67ca89SAndroid Build Coastguard Worker 
209*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(36)
210*8d67ca89SAndroid Build Coastguard Worker int sig2str(int __signal, char* _Nonnull __buf) __INTRODUCED_IN(36);
211*8d67ca89SAndroid Build Coastguard Worker 
212*8d67ca89SAndroid Build Coastguard Worker /**
213*8d67ca89SAndroid Build Coastguard Worker  * [str2sig(3)](https://man7.org/linux/man-pages/man3/str2sig.3.html)
214*8d67ca89SAndroid Build Coastguard Worker  * converts a string like "SEGV" (not including the "SIG" used in the constants)
215*8d67ca89SAndroid Build Coastguard Worker  * into the integer corresponding to SIGSEGV.
216*8d67ca89SAndroid Build Coastguard Worker  *
217*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 _without_ setting errno otherwise.
218*8d67ca89SAndroid Build Coastguard Worker  *
219*8d67ca89SAndroid Build Coastguard Worker  * Available since API level 36.
220*8d67ca89SAndroid Build Coastguard Worker  */
221*8d67ca89SAndroid Build Coastguard Worker int str2sig(const char* _Nonnull __name, int* _Nonnull __signal) __INTRODUCED_IN(36);
222*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(36) */
223*8d67ca89SAndroid Build Coastguard Worker 
224*8d67ca89SAndroid Build Coastguard Worker 
225*8d67ca89SAndroid Build Coastguard Worker __END_DECLS
226*8d67ca89SAndroid Build Coastguard Worker 
227*8d67ca89SAndroid Build Coastguard Worker #endif
228