sigaction.h 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /* The proper definitions for Linux/SPARC sigaction.
  2. Copyright (C) 1996, 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
  3. This file is part of the GNU C Library.
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. The GNU C Library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with the GNU C Library; if not, see
  14. <http://www.gnu.org/licenses/>. */
  15. #ifndef _SIGNAL_H
  16. # error "Never include <bits/sigaction.h> directly; use <signal.h> instead."
  17. #endif
  18. /* Structure describing the action to be taken when a signal arrives. */
  19. struct sigaction {
  20. #ifdef __USE_POSIX199309
  21. union {
  22. __sighandler_t sa_handler;
  23. void (*sa_sigaction)(int, siginfo_t *, void *);
  24. } __sigaction_handler;
  25. # define sa_handler __sigaction_handler.sa_handler
  26. # define sa_sigaction __sigaction_handler.sa_sigaction
  27. #else
  28. __sighandler_t sa_handler;
  29. #endif
  30. unsigned long sa_flags;
  31. void (*sa_restorer)(void);
  32. sigset_t sa_mask;
  33. };
  34. /* Bits in `sa_flags'. */
  35. #define SA_NOCLDSTOP 0x00000008 /* Don't send SIGCHLD when children stop. */
  36. #define SA_NOCLDWAIT 0x00000100 /* Don't create zombie on child death. */
  37. #define SA_SIGINFO 0x00000200 /* Invoke signal-catching function with
  38. three arguments instead of one. */
  39. #if defined __USE_UNIX98 || defined __USE_MISC
  40. # define SA_ONSTACK 0x00000001 /* Use signal stack by using `sa_restorer'. */
  41. # define SA_RESTART 0x00000002 /* Restart syscall on signal return. */
  42. # define SA_INTERRUPT 0x00000010 /* Historical no-op. */
  43. # define SA_NOMASK 0x00000020 /* Don't automatically block the signal when
  44. its handler is being executed. */
  45. # define SA_ONESHOT 0x00000004 /* Reset to SIG_DFL on entry to handler. */
  46. /* Some aliases for the SA_ constants. */
  47. # define SA_NODEFER SA_NOMASK
  48. # define SA_RESETHAND SA_ONESHOT
  49. # define SA_STACK SA_ONSTACK
  50. #endif
  51. /* Values for the HOW argument to `sigprocmask'. */
  52. #define SIG_BLOCK 1 /* Block signals. */
  53. #define SIG_UNBLOCK 2 /* Unblock signals. */
  54. #define SIG_SETMASK 4 /* Set the set of blocked signals. */