siginfo.h 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. /* siginfo_t, sigevent and constants. Linux/MIPS version.
  2. Copyright (C) 1997, 1998, 2000, 2001, 2002, 2003, 2004, 2005
  3. Free Software Foundation, Inc.
  4. This file is part of the GNU C Library.
  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. The GNU C Library is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. Lesser General Public License for more details.
  13. You should have received a copy of the GNU Lesser General Public
  14. License along with the GNU C Library; if not, see
  15. <http://www.gnu.org/licenses/>. */
  16. #if !defined _SIGNAL_H && !defined __need_siginfo_t \
  17. && !defined __need_sigevent_t
  18. # error "Never include this file directly. Use <signal.h> instead"
  19. #endif
  20. #include <bits/wordsize.h>
  21. #if (!defined __have_sigval_t \
  22. && (defined _SIGNAL_H || defined __need_siginfo_t \
  23. || defined __need_sigevent_t))
  24. # define __have_sigval_t 1
  25. /* Type for data associated with a signal. */
  26. typedef union sigval
  27. {
  28. int sival_int;
  29. void *sival_ptr;
  30. } sigval_t;
  31. #endif
  32. #if (!defined __have_siginfo_t \
  33. && (defined _SIGNAL_H || defined __need_siginfo_t))
  34. # define __have_siginfo_t 1
  35. # define __SI_MAX_SIZE 128
  36. # if __WORDSIZE == 64
  37. # define __SI_PAD_SIZE ((__SI_MAX_SIZE / sizeof (int)) - 4)
  38. # else
  39. # define __SI_PAD_SIZE ((__SI_MAX_SIZE / sizeof (int)) - 3)
  40. # endif
  41. typedef struct siginfo
  42. {
  43. int si_signo; /* Signal number. */
  44. int si_code; /* Signal code. */
  45. int si_errno; /* If non-zero, an errno value associated with
  46. this signal, as defined in <errno.h>. */
  47. int __pad0[__SI_MAX_SIZE / sizeof (int) - __SI_PAD_SIZE - 3];
  48. /* Explicit padding. */
  49. union
  50. {
  51. int _pad[__SI_PAD_SIZE];
  52. /* kill(). */
  53. struct
  54. {
  55. __pid_t si_pid; /* Sending process ID. */
  56. __uid_t si_uid; /* Real user ID of sending process. */
  57. } _kill;
  58. /* POSIX.1b timers. */
  59. struct
  60. {
  61. int si_tid; /* Timer ID. */
  62. int si_overrun; /* Overrun count. */
  63. sigval_t si_sigval; /* Signal value. */
  64. } _timer;
  65. /* POSIX.1b signals. */
  66. struct
  67. {
  68. __pid_t si_pid; /* Sending process ID. */
  69. __uid_t si_uid; /* Real user ID of sending process. */
  70. sigval_t si_sigval; /* Signal value. */
  71. } _rt;
  72. /* SIGCHLD. */
  73. struct
  74. {
  75. __pid_t si_pid; /* Which child. */
  76. __uid_t si_uid; /* Real user ID of sending process. */
  77. int si_status; /* Exit value or signal. */
  78. __clock_t si_utime;
  79. __clock_t si_stime;
  80. } _sigchld;
  81. /* SIGILL, SIGFPE, SIGSEGV, SIGBUS. */
  82. struct
  83. {
  84. void *si_addr; /* Faulting insn/memory ref. */
  85. short int si_addr_lsb; /* Valid LSB of the reported address. */
  86. } _sigfault;
  87. /* SIGPOLL. */
  88. struct
  89. {
  90. long int si_band; /* Band event for SIGPOLL. */
  91. int si_fd;
  92. } _sigpoll;
  93. } _sifields;
  94. } siginfo_t;
  95. /* X/Open requires some more fields with fixed names. */
  96. # define si_pid _sifields._kill.si_pid
  97. # define si_uid _sifields._kill.si_uid
  98. # define si_timerid _sifields._timer.si_tid
  99. # define si_overrun _sifields._timer.si_overrun
  100. # define si_status _sifields._sigchld.si_status
  101. # define si_utime _sifields._sigchld.si_utime
  102. # define si_stime _sifields._sigchld.si_stime
  103. # define si_value _sifields._rt.si_sigval
  104. # define si_int _sifields._rt.si_sigval.sival_int
  105. # define si_ptr _sifields._rt.si_sigval.sival_ptr
  106. # define si_addr _sifields._sigfault.si_addr
  107. # define si_addr_lsb _sifields._sigfault.si_addr_lsb
  108. # define si_band _sifields._sigpoll.si_band
  109. # define si_fd _sifields._sigpoll.si_fd
  110. /* Values for `si_code'. Positive values are reserved for kernel-generated
  111. signals. */
  112. enum
  113. {
  114. SI_ASYNCNL = -60, /* Sent by asynch name lookup completion. */
  115. # define SI_ASYNCNL SI_ASYNCNL
  116. SI_TKILL = -6, /* Sent by tkill. */
  117. # define SI_TKILL SI_TKILL
  118. SI_SIGIO, /* Sent by queued SIGIO. */
  119. # define SI_SIGIO SI_SIGIO
  120. SI_MESGQ, /* Sent by real time mesq state change. */
  121. # define SI_MESGQ SI_MESGQ
  122. SI_TIMER, /* Sent by real time mesq state change. */
  123. # define SI_TIMER SI_TIMER
  124. SI_ASYNCIO, /* Sent by AIO completion. */
  125. # define SI_ASYNCIO SI_ASYNCIO
  126. SI_QUEUE, /* Sent by sigqueue. */
  127. # define SI_QUEUE SI_QUEUE
  128. SI_USER, /* Sent by kill, sigsend. */
  129. # define SI_USER SI_USER
  130. SI_KERNEL = 0x80 /* Send by kernel. */
  131. #define SI_KERNEL SI_KERNEL
  132. };
  133. # if defined __USE_XOPEN_EXTENDED || defined __USE_XOPEN2K8
  134. /* `si_code' values for SIGILL signal. */
  135. enum
  136. {
  137. ILL_ILLOPC = 1, /* Illegal opcode. */
  138. # define ILL_ILLOPC ILL_ILLOPC
  139. ILL_ILLOPN, /* Illegal operand. */
  140. # define ILL_ILLOPN ILL_ILLOPN
  141. ILL_ILLADR, /* Illegal addressing mode. */
  142. # define ILL_ILLADR ILL_ILLADR
  143. ILL_ILLTRP, /* Illegal trap. */
  144. # define ILL_ILLTRP ILL_ILLTRP
  145. ILL_PRVOPC, /* Privileged opcode. */
  146. # define ILL_PRVOPC ILL_PRVOPC
  147. ILL_PRVREG, /* Privileged register. */
  148. # define ILL_PRVREG ILL_PRVREG
  149. ILL_COPROC, /* Coprocessor error. */
  150. # define ILL_COPROC ILL_COPROC
  151. ILL_BADSTK /* Internal stack error. */
  152. # define ILL_BADSTK ILL_BADSTK
  153. };
  154. /* `si_code' values for SIGFPE signal. */
  155. enum
  156. {
  157. FPE_INTDIV = 1, /* Integer divide by zero. */
  158. # define FPE_INTDIV FPE_INTDIV
  159. FPE_INTOVF, /* Integer overflow. */
  160. # define FPE_INTOVF FPE_INTOVF
  161. FPE_FLTDIV, /* Floating point divide by zero. */
  162. # define FPE_FLTDIV FPE_FLTDIV
  163. FPE_FLTOVF, /* Floating point overflow. */
  164. # define FPE_FLTOVF FPE_FLTOVF
  165. FPE_FLTUND, /* Floating point underflow. */
  166. # define FPE_FLTUND FPE_FLTUND
  167. FPE_FLTRES, /* Floating point inexact result. */
  168. # define FPE_FLTRES FPE_FLTRES
  169. FPE_FLTINV, /* Floating point invalid operation. */
  170. # define FPE_FLTINV FPE_FLTINV
  171. FPE_FLTSUB /* Subscript out of range. */
  172. # define FPE_FLTSUB FPE_FLTSUB
  173. };
  174. /* `si_code' values for SIGSEGV signal. */
  175. enum
  176. {
  177. SEGV_MAPERR = 1, /* Address not mapped to object. */
  178. # define SEGV_MAPERR SEGV_MAPERR
  179. SEGV_ACCERR /* Invalid permissions for mapped object. */
  180. # define SEGV_ACCERR SEGV_ACCERR
  181. };
  182. /* `si_code' values for SIGBUS signal. */
  183. enum
  184. {
  185. BUS_ADRALN = 1, /* Invalid address alignment. */
  186. # define BUS_ADRALN BUS_ADRALN
  187. BUS_ADRERR, /* Non-existant physical address. */
  188. # define BUS_ADRERR BUS_ADRERR
  189. BUS_OBJERR, /* Object specific hardware error. */
  190. # define BUS_OBJERR BUS_OBJERR
  191. BUS_MCEERR_AR, /* Hardware memory error: action required. */
  192. # define BUS_MCEERR_AR BUS_MCEERR_AR
  193. BUS_MCEERR_AO /* Hardware memory error: action optional. */
  194. # define BUS_MCEERR_AO BUS_MCEERR_AO
  195. };
  196. # endif
  197. # ifdef __USE_XOPEN_EXTENDED
  198. /* `si_code' values for SIGTRAP signal. */
  199. enum
  200. {
  201. TRAP_BRKPT = 1, /* Process breakpoint. */
  202. # define TRAP_BRKPT TRAP_BRKPT
  203. TRAP_TRACE /* Process trace trap. */
  204. # define TRAP_TRACE TRAP_TRACE
  205. };
  206. # endif
  207. # if defined __USE_XOPEN_EXTENDED || defined __USE_XOPEN2K8
  208. /* `si_code' values for SIGCHLD signal. */
  209. enum
  210. {
  211. CLD_EXITED = 1, /* Child has exited. */
  212. # define CLD_EXITED CLD_EXITED
  213. CLD_KILLED, /* Child was killed. */
  214. # define CLD_KILLED CLD_KILLED
  215. CLD_DUMPED, /* Child terminated abnormally. */
  216. # define CLD_DUMPED CLD_DUMPED
  217. CLD_TRAPPED, /* Traced child has trapped. */
  218. # define CLD_TRAPPED CLD_TRAPPED
  219. CLD_STOPPED, /* Child has stopped. */
  220. # define CLD_STOPPED CLD_STOPPED
  221. CLD_CONTINUED /* Stopped child has continued. */
  222. # define CLD_CONTINUED CLD_CONTINUED
  223. };
  224. /* `si_code' values for SIGPOLL signal. */
  225. enum
  226. {
  227. POLL_IN = 1, /* Data input available. */
  228. # define POLL_IN POLL_IN
  229. POLL_OUT, /* Output buffers available. */
  230. # define POLL_OUT POLL_OUT
  231. POLL_MSG, /* Input message available. */
  232. # define POLL_MSG POLL_MSG
  233. POLL_ERR, /* I/O error. */
  234. # define POLL_ERR POLL_ERR
  235. POLL_PRI, /* High priority input available. */
  236. # define POLL_PRI POLL_PRI
  237. POLL_HUP /* Device disconnected. */
  238. # define POLL_HUP POLL_HUP
  239. };
  240. # endif
  241. # undef __need_siginfo_t
  242. #endif /* !have siginfo_t && (have _SIGNAL_H || need siginfo_t). */
  243. #if (defined _SIGNAL_H || defined __need_sigevent_t) \
  244. && !defined __have_sigevent_t
  245. # define __have_sigevent_t 1
  246. /* Structure to transport application-defined values with signals. */
  247. # define __SIGEV_MAX_SIZE 64
  248. # if __WORDSIZE == 64
  249. # define __SIGEV_PAD_SIZE ((__SIGEV_MAX_SIZE / sizeof (int)) - 4)
  250. # else
  251. # define __SIGEV_PAD_SIZE ((__SIGEV_MAX_SIZE / sizeof (int)) - 3)
  252. # endif
  253. /* Forward declaration of the `pthread_attr_t' type. */
  254. struct __pthread_attr_s;
  255. /* XXX This one might need to change!!! */
  256. typedef struct sigevent
  257. {
  258. sigval_t sigev_value;
  259. int sigev_signo;
  260. int sigev_notify;
  261. union
  262. {
  263. int _pad[__SIGEV_PAD_SIZE];
  264. /* When SIGEV_SIGNAL and SIGEV_THREAD_ID set, LWP ID of the
  265. thread to receive the signal. */
  266. __pid_t _tid;
  267. struct
  268. {
  269. void (*_function) (sigval_t); /* Function to start. */
  270. void *_attribute; /* Really pthread_attr_t. */
  271. } _sigev_thread;
  272. } _sigev_un;
  273. } sigevent_t;
  274. /* POSIX names to access some of the members. */
  275. # define sigev_notify_function _sigev_un._sigev_thread._function
  276. # define sigev_notify_attributes _sigev_un._sigev_thread._attribute
  277. /* `sigev_notify' values. */
  278. enum
  279. {
  280. SIGEV_SIGNAL = 0, /* Notify via signal. */
  281. # define SIGEV_SIGNAL SIGEV_SIGNAL
  282. SIGEV_NONE, /* Other notification: meaningless. */
  283. # define SIGEV_NONE SIGEV_NONE
  284. SIGEV_THREAD, /* Deliver via thread creation. */
  285. # define SIGEV_THREAD SIGEV_THREAD
  286. SIGEV_THREAD_ID = 4 /* Send signal to specific thread. */
  287. #define SIGEV_THREAD_ID SIGEV_THREAD_ID
  288. };
  289. #endif /* have _SIGNAL_H. */