]> git.ipfire.org Git - thirdparty/glibc.git/blob - sysdeps/unix/sysv/linux/sparc/bits/siginfo.h
Update copyright notices with scripts/update-copyrights
[thirdparty/glibc.git] / sysdeps / unix / sysv / linux / sparc / bits / siginfo.h
1 /* siginfo_t, sigevent and constants. Linux/SPARC version.
2 Copyright (C) 1997-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 #if !defined _SIGNAL_H && !defined __need_siginfo_t \
20 && !defined __need_sigevent_t
21 # error "Never include this file directly. Use <signal.h> instead"
22 #endif
23
24 #include <bits/wordsize.h>
25
26 #if (!defined __have_sigval_t \
27 && (defined _SIGNAL_H || defined __need_siginfo_t \
28 || defined __need_sigevent_t))
29 # define __have_sigval_t 1
30
31 /* Type for data associated with a signal. */
32 typedef union sigval
33 {
34 int sival_int;
35 void *sival_ptr;
36 } sigval_t;
37 #endif
38
39 #if (!defined __have_siginfo_t \
40 && (defined _SIGNAL_H || defined __need_siginfo_t))
41 # define __have_siginfo_t 1
42
43 # define __SI_MAX_SIZE 128
44 # if __WORDSIZE == 64
45 # define __SI_PAD_SIZE ((__SI_MAX_SIZE / sizeof (int)) - 4)
46 # else
47 # define __SI_PAD_SIZE ((__SI_MAX_SIZE / sizeof (int)) - 3)
48 # endif
49
50 typedef struct
51 {
52 int si_signo; /* Signal number. */
53 int si_errno; /* If non-zero, an errno value associated with
54 this signal, as defined in <errno.h>. */
55 int si_code; /* Signal code. */
56
57 union
58 {
59 int _pad[__SI_PAD_SIZE];
60
61 /* kill(). */
62 struct
63 {
64 __pid_t si_pid; /* Sending process ID. */
65 __uid_t si_uid; /* Real user ID of sending process. */
66 } _kill;
67
68 /* POSIX.1b timers. */
69 struct
70 {
71 int si_tid; /* Timer ID. */
72 int si_overrun; /* Overrun count. */
73 sigval_t si_sigval; /* Signal value. */
74 } _timer;
75
76 /* POSIX.1b signals. */
77 struct
78 {
79 __pid_t si_pid; /* Sending process ID. */
80 __uid_t si_uid; /* Real user ID of sending process. */
81 sigval_t si_sigval; /* Signal value. */
82 } _rt;
83
84 /* SIGCHLD. */
85 struct
86 {
87 __pid_t si_pid; /* Which child. */
88 __uid_t si_uid; /* Real user ID of sending process. */
89 int si_status; /* Exit value or signal. */
90 __clock_t si_utime;
91 __clock_t si_stime;
92 } _sigchld;
93
94 /* SIGILL, SIGFPE, SIGSEGV, SIGBUS. */
95 struct
96 {
97 void *si_addr; /* Faulting insn/memory ref. */
98 int si_trapno;
99 short int si_addr_lsb; /* Valid LSB of the reported address. */
100 } _sigfault;
101
102 /* SIGPOLL. */
103 struct
104 {
105 int si_band; /* Band event for SIGPOLL. */
106 int si_fd;
107 } _sigpoll;
108
109 /* SIGSYS. */
110 struct
111 {
112 void *_call_addr; /* Calling user insn. */
113 int _syscall; /* Triggering system call number. */
114 unsigned int _arch; /* AUDIT_ARCH_* of syscall. */
115 } _sigsys;
116 } _sifields;
117 } siginfo_t;
118
119
120 /* X/Open requires some more fields with fixed names. */
121 # define si_pid _sifields._kill.si_pid
122 # define si_uid _sifields._kill.si_uid
123 # define si_timerid _sifields._timer.si_tid
124 # define si_overrun _sifields._timer.si_overrun
125 # define si_status _sifields._sigchld.si_status
126 # define si_utime _sifields._sigchld.si_utime
127 # define si_stime _sifields._sigchld.si_stime
128 # define si_value _sifields._rt.si_sigval
129 # define si_int _sifields._rt.si_sigval.sival_int
130 # define si_ptr _sifields._rt.si_sigval.sival_ptr
131 # define si_addr _sifields._sigfault.si_addr
132 # define si_trapno _sifields._sigfault.si_trapno
133 # define si_addr_lsb _sifields._sigfault.si_addr_lsb
134 # define si_band _sifields._sigpoll.si_band
135 # define si_fd _sifields._sigpoll.si_fd
136 # define si_call_addr _sifields._sigsys._call_addr
137 # define si_syscall _sifields._sigsys._syscall
138 # define si_arch _sifields._sigsys._arch
139
140
141 /* Values for `si_code'. Positive values are reserved for kernel-generated
142 signals. */
143 enum
144 {
145 SI_ASYNCNL = -60, /* Sent by asynch name lookup completion. */
146 # define SI_ASYNCNL SI_ASYNCNL
147 SI_TKILL = -6, /* Sent by tkill. */
148 # define SI_TKILL SI_TKILL
149 SI_SIGIO, /* Sent by queued SIGIO. */
150 # define SI_SIGIO SI_SIGIO
151 SI_ASYNCIO, /* Sent by AIO completion. */
152 # define SI_ASYNCIO SI_ASYNCIO
153 SI_MESGQ, /* Sent by real time mesq state change. */
154 # define SI_MESGQ SI_MESGQ
155 SI_TIMER, /* Sent by timer expiration. */
156 # define SI_TIMER SI_TIMER
157 SI_QUEUE, /* Sent by sigqueue. */
158 # define SI_QUEUE SI_QUEUE
159 SI_USER, /* Sent by kill, sigsend. */
160 # define SI_USER SI_USER
161 SI_KERNEL = 0x80 /* Send by kernel. */
162 #define SI_KERNEL SI_KERNEL
163 };
164
165
166 /* `si_code' values for SIGILL signal. */
167 enum
168 {
169 ILL_ILLOPC = 1, /* Illegal opcode. */
170 # define ILL_ILLOPC ILL_ILLOPC
171 ILL_ILLOPN, /* Illegal operand. */
172 # define ILL_ILLOPN ILL_ILLOPN
173 ILL_ILLADR, /* Illegal addressing mode. */
174 # define ILL_ILLADR ILL_ILLADR
175 ILL_ILLTRP, /* Illegal trap. */
176 # define ILL_ILLTRP ILL_ILLTRP
177 ILL_PRVOPC, /* Privileged opcode. */
178 # define ILL_PRVOPC ILL_PRVOPC
179 ILL_PRVREG, /* Privileged register. */
180 # define ILL_PRVREG ILL_PRVREG
181 ILL_COPROC, /* Coprocessor error. */
182 # define ILL_COPROC ILL_COPROC
183 ILL_BADSTK /* Internal stack error. */
184 # define ILL_BADSTK ILL_BADSTK
185 };
186
187 /* `si_code' values for SIGFPE signal. */
188 enum
189 {
190 FPE_INTDIV = 1, /* Integer divide by zero. */
191 # define FPE_INTDIV FPE_INTDIV
192 FPE_INTOVF, /* Integer overflow. */
193 # define FPE_INTOVF FPE_INTOVF
194 FPE_FLTDIV, /* Floating point divide by zero. */
195 # define FPE_FLTDIV FPE_FLTDIV
196 FPE_FLTOVF, /* Floating point overflow. */
197 # define FPE_FLTOVF FPE_FLTOVF
198 FPE_FLTUND, /* Floating point underflow. */
199 # define FPE_FLTUND FPE_FLTUND
200 FPE_FLTRES, /* Floating point inexact result. */
201 # define FPE_FLTRES FPE_FLTRES
202 FPE_FLTINV, /* Floating point invalid operation. */
203 # define FPE_FLTINV FPE_FLTINV
204 FPE_FLTSUB /* Subscript out of range. */
205 # define FPE_FLTSUB FPE_FLTSUB
206 };
207
208 /* `si_code' values for SIGSEGV signal. */
209 enum
210 {
211 SEGV_MAPERR = 1, /* Address not mapped to object. */
212 # define SEGV_MAPERR SEGV_MAPERR
213 SEGV_ACCERR /* Invalid permissions for mapped object. */
214 # define SEGV_ACCERR SEGV_ACCERR
215 };
216
217 /* `si_code' values for SIGBUS signal. */
218 enum
219 {
220 BUS_ADRALN = 1, /* Invalid address alignment. */
221 # define BUS_ADRALN BUS_ADRALN
222 BUS_ADRERR, /* Non-existant physical address. */
223 # define BUS_ADRERR BUS_ADRERR
224 BUS_OBJERR, /* Object specific hardware error. */
225 # define BUS_OBJERR BUS_OBJERR
226 BUS_MCEERR_AR, /* Hardware memory error: action required. */
227 # define BUS_MCEERR_AR BUS_MCEERR_AR
228 BUS_MCEERR_AO /* Hardware memory error: action optional. */
229 # define BUS_MCEERR_AO BUS_MCEERR_AO
230 };
231
232 /* `si_code' values for SIGTRAP signal. */
233 enum
234 {
235 TRAP_BRKPT = 1, /* Process breakpoint. */
236 # define TRAP_BRKPT TRAP_BRKPT
237 TRAP_TRACE /* Process trace trap. */
238 # define TRAP_TRACE TRAP_TRACE
239 };
240
241 /* `si_code' values for SIGCHLD signal. */
242 enum
243 {
244 CLD_EXITED = 1, /* Child has exited. */
245 # define CLD_EXITED CLD_EXITED
246 CLD_KILLED, /* Child was killed. */
247 # define CLD_KILLED CLD_KILLED
248 CLD_DUMPED, /* Child terminated abnormally. */
249 # define CLD_DUMPED CLD_DUMPED
250 CLD_TRAPPED, /* Traced child has trapped. */
251 # define CLD_TRAPPED CLD_TRAPPED
252 CLD_STOPPED, /* Child has stopped. */
253 # define CLD_STOPPED CLD_STOPPED
254 CLD_CONTINUED /* Stopped child has continued. */
255 # define CLD_CONTINUED CLD_CONTINUED
256 };
257
258 /* `si_code' values for SIGPOLL signal. */
259 enum
260 {
261 POLL_IN = 1, /* Data input available. */
262 # define POLL_IN POLL_IN
263 POLL_OUT, /* Output buffers available. */
264 # define POLL_OUT POLL_OUT
265 POLL_MSG, /* Input message available. */
266 # define POLL_MSG POLL_MSG
267 POLL_ERR, /* I/O error. */
268 # define POLL_ERR POLL_ERR
269 POLL_PRI, /* High priority input available. */
270 # define POLL_PRI POLL_PRI
271 POLL_HUP /* Device disconnected. */
272 # define POLL_HUP POLL_HUP
273 };
274
275 /* `si_code' values for SIGEMT signal. */
276 enum
277 {
278 EMT_TAGOVF = 1 /* Tag overflow. */
279 # define EMT_TAGOVF EMT_TAGOVF
280 };
281
282 # undef __need_siginfo_t
283 #endif /* !have siginfo_t && (have _SIGNAL_H || need siginfo_t). */
284
285
286 #if (defined _SIGNAL_H || defined __need_sigevent_t) \
287 && !defined __have_sigevent_t
288 # define __have_sigevent_t 1
289
290 /* Structure to transport application-defined values with signals. */
291 # define __SIGEV_MAX_SIZE 64
292 # if __WORDSIZE == 64
293 # define __SIGEV_PAD_SIZE ((__SIGEV_MAX_SIZE / sizeof (int)) - 4)
294 # else
295 # define __SIGEV_PAD_SIZE ((__SIGEV_MAX_SIZE / sizeof (int)) - 3)
296 # endif
297
298 /* Forward declaration. */
299 # ifndef __have_pthread_attr_t
300 typedef union pthread_attr_t pthread_attr_t;
301 # define __have_pthread_attr_t 1
302 # endif
303
304 typedef struct sigevent
305 {
306 sigval_t sigev_value;
307 int sigev_signo;
308 int sigev_notify;
309
310 union
311 {
312 int _pad[__SIGEV_PAD_SIZE];
313
314 /* When SIGEV_SIGNAL and SIGEV_THREAD_ID set, LWP ID of the
315 thread to receive the signal. */
316 __pid_t _tid;
317
318 struct
319 {
320 void (*_function) (sigval_t); /* Function to start. */
321 pthread_attr_t *_attribute; /* Thread attributes. */
322 } _sigev_thread;
323 } _sigev_un;
324 } sigevent_t;
325
326 /* POSIX names to access some of the members. */
327 # define sigev_notify_function _sigev_un._sigev_thread._function
328 # define sigev_notify_attributes _sigev_un._sigev_thread._attribute
329
330 /* `sigev_notify' values. */
331 enum
332 {
333 SIGEV_SIGNAL = 0, /* Notify via signal. */
334 # define SIGEV_SIGNAL SIGEV_SIGNAL
335 SIGEV_NONE, /* Other notification: meaningless. */
336 # define SIGEV_NONE SIGEV_NONE
337 SIGEV_THREAD, /* Deliver via thread creation. */
338 # define SIGEV_THREAD SIGEV_THREAD
339
340 SIGEV_THREAD_ID = 4 /* Send signal to specific thread. */
341 #define SIGEV_THREAD_ID SIGEV_THREAD_ID
342 };
343
344 #endif /* have _SIGNAL_H. */