sigaction.h 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /* The proper definitions for Linux/MIPS's sigaction.
  2. Copyright (C) 1993, 1994, 1995, 1997, 1998, 1999, 2000, 2003
  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, write to the Free
  15. Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  16. 02111-1307 USA. */
  17. #ifndef _SIGNAL_H
  18. # error "Never include <bits/sigaction.h> directly; use <signal.h> instead."
  19. #endif
  20. /* Structure describing the action to be taken when a signal arrives. */
  21. struct sigaction
  22. {
  23. /* Special flags. */
  24. unsigned int sa_flags;
  25. /* Signal handler. */
  26. #ifdef __USE_POSIX199309
  27. union
  28. {
  29. /* Used if SA_SIGINFO is not set. */
  30. __sighandler_t sa_handler;
  31. /* Used if SA_SIGINFO is set. */
  32. void (*sa_sigaction) (int, siginfo_t *, void *);
  33. }
  34. __sigaction_handler;
  35. # define sa_handler __sigaction_handler.sa_handler
  36. # define sa_sigaction __sigaction_handler.sa_sigaction
  37. #else
  38. __sighandler_t sa_handler;
  39. #endif
  40. /* Additional set of signals to be blocked. */
  41. __sigset_t sa_mask;
  42. /* The ABI says here are two unused ints following. */
  43. /* Restore handler. */
  44. void (*sa_restorer) (void);
  45. #if _MIPS_SZPTR < 64
  46. int sa_resv[1];
  47. #endif
  48. };
  49. /* Bits in `sa_flags'. */
  50. /* Please note that some Linux kernels versions use different values for these
  51. flags which is a bug in those kernel versions. */
  52. #define SA_NOCLDSTOP 0x00000001 /* Don't send SIGCHLD when children stop. */
  53. #define SA_NOCLDWAIT 0x00010000 /* Don't create zombie on child death. */
  54. #define SA_SIGINFO 0x00000008 /* Invoke signal-catching function with
  55. three arguments instead of one. */
  56. #if defined __USE_UNIX98 || defined __USE_MISC
  57. # define SA_ONSTACK 0x08000000 /* Use signal stack by using `sa_restorer'. */
  58. # define SA_RESETHAND 0x80000000 /* Reset to SIG_DFL on entry to handler. */
  59. # define SA_RESTART 0x10000000 /* Restart syscall on signal return. */
  60. # define SA_NODEFER 0x40000000 /* Don't automatically block the signal when
  61. its handler is being executed. */
  62. #endif
  63. #ifdef __USE_MISC
  64. # define SA_INTERRUPT 0x20000000 /* Historical no-op. */
  65. /* Some aliases for the SA_ constants. */
  66. # define SA_NOMASK SA_NODEFER
  67. # define SA_ONESHOT SA_RESETHAND
  68. # define SA_STACK SA_ONSTACK
  69. #endif
  70. /* Values for the HOW argument to `sigprocmask'. */
  71. #define SIG_NOP 0 /* 0 is unused to catch errors */
  72. #define SIG_BLOCK 1 /* Block signals. */
  73. #define SIG_UNBLOCK 2 /* Unblock signals. */
  74. #define SIG_SETMASK 3 /* Set the set of blocked signals. */
  75. #ifdef __USE_MISC
  76. # define SIG_SETMASK32 256 /* Goodie from SGI for BSD compatibility:
  77. set only the low 32 bit of the sigset. */
  78. #endif