signal.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /*
  2. * This file is subject to the terms and conditions of the GNU General Public
  3. * License. See the file "COPYING" in the main directory of this archive
  4. * for more details.
  5. *
  6. * Copyright (C) 1995, 96, 97, 98, 99, 2003 by Ralf Baechle
  7. * Copyright (C) 1999 Silicon Graphics, Inc.
  8. */
  9. #ifndef _ASM_SIGNAL_H
  10. #define _ASM_SIGNAL_H
  11. #include <linux/config.h>
  12. #include <linux/types.h>
  13. #define _NSIG 128
  14. #define _NSIG_BPW (sizeof(unsigned long) * 8)
  15. #define _NSIG_WORDS (_NSIG / _NSIG_BPW)
  16. typedef struct {
  17. unsigned long sig[_NSIG_WORDS];
  18. } sigset_t;
  19. typedef unsigned long old_sigset_t; /* at least 32 bits */
  20. #define SIGHUP 1 /* Hangup (POSIX). */
  21. #define SIGINT 2 /* Interrupt (ANSI). */
  22. #define SIGQUIT 3 /* Quit (POSIX). */
  23. #define SIGILL 4 /* Illegal instruction (ANSI). */
  24. #define SIGTRAP 5 /* Trace trap (POSIX). */
  25. #define SIGIOT 6 /* IOT trap (4.2 BSD). */
  26. #define SIGABRT SIGIOT /* Abort (ANSI). */
  27. #define SIGEMT 7
  28. #define SIGFPE 8 /* Floating-point exception (ANSI). */
  29. #define SIGKILL 9 /* Kill, unblockable (POSIX). */
  30. #define SIGBUS 10 /* BUS error (4.2 BSD). */
  31. #define SIGSEGV 11 /* Segmentation violation (ANSI). */
  32. #define SIGSYS 12
  33. #define SIGPIPE 13 /* Broken pipe (POSIX). */
  34. #define SIGALRM 14 /* Alarm clock (POSIX). */
  35. #define SIGTERM 15 /* Termination (ANSI). */
  36. #define SIGUSR1 16 /* User-defined signal 1 (POSIX). */
  37. #define SIGUSR2 17 /* User-defined signal 2 (POSIX). */
  38. #define SIGCHLD 18 /* Child status has changed (POSIX). */
  39. #define SIGCLD SIGCHLD /* Same as SIGCHLD (System V). */
  40. #define SIGPWR 19 /* Power failure restart (System V). */
  41. #define SIGWINCH 20 /* Window size change (4.3 BSD, Sun). */
  42. #define SIGURG 21 /* Urgent condition on socket (4.2 BSD). */
  43. #define SIGIO 22 /* I/O now possible (4.2 BSD). */
  44. #define SIGPOLL SIGIO /* Pollable event occurred (System V). */
  45. #define SIGSTOP 23 /* Stop, unblockable (POSIX). */
  46. #define SIGTSTP 24 /* Keyboard stop (POSIX). */
  47. #define SIGCONT 25 /* Continue (POSIX). */
  48. #define SIGTTIN 26 /* Background read from tty (POSIX). */
  49. #define SIGTTOU 27 /* Background write to tty (POSIX). */
  50. #define SIGVTALRM 28 /* Virtual alarm clock (4.2 BSD). */
  51. #define SIGPROF 29 /* Profiling alarm clock (4.2 BSD). */
  52. #define SIGXCPU 30 /* CPU limit exceeded (4.2 BSD). */
  53. #define SIGXFSZ 31 /* File size limit exceeded (4.2 BSD). */
  54. /* These should not be considered constants from userland. */
  55. #define SIGRTMIN 32
  56. #define SIGRTMAX _NSIG
  57. /*
  58. * SA_FLAGS values:
  59. *
  60. * SA_ONSTACK indicates that a registered stack_t will be used.
  61. * SA_INTERRUPT is a no-op, but left due to historical reasons. Use the
  62. * SA_RESTART flag to get restarting signals (which were the default long ago)
  63. * SA_NOCLDSTOP flag to turn off SIGCHLD when children stop.
  64. * SA_RESETHAND clears the handler when the signal is delivered.
  65. * SA_NOCLDWAIT flag on SIGCHLD to inhibit zombies.
  66. * SA_NODEFER prevents the current signal from being masked in the handler.
  67. *
  68. * SA_ONESHOT and SA_NOMASK are the historical Linux names for the Single
  69. * Unix names RESETHAND and NODEFER respectively.
  70. */
  71. #define SA_ONSTACK 0x08000000
  72. #define SA_RESETHAND 0x80000000
  73. #define SA_RESTART 0x10000000
  74. #define SA_SIGINFO 0x00000008
  75. #define SA_NODEFER 0x40000000
  76. #define SA_NOCLDWAIT 0x00010000
  77. #define SA_NOCLDSTOP 0x00000001
  78. #define SA_NOMASK SA_NODEFER
  79. #define SA_ONESHOT SA_RESETHAND
  80. #define SA_INTERRUPT 0x20000000 /* dummy -- ignored */
  81. #define SA_RESTORER 0x04000000 /* Only for o32 */
  82. /*
  83. * sigaltstack controls
  84. */
  85. #define SS_ONSTACK 1
  86. #define SS_DISABLE 2
  87. #define MINSIGSTKSZ 2048
  88. #define SIGSTKSZ 8192
  89. #ifdef __KERNEL__
  90. /*
  91. * These values of sa_flags are used only by the kernel as part of the
  92. * irq handling routines.
  93. *
  94. * SA_INTERRUPT is also used by the irq handling routines.
  95. * SA_SHIRQ flag is for shared interrupt support on PCI and EISA.
  96. */
  97. #define SA_SAMPLE_RANDOM SA_RESTART
  98. #ifdef CONFIG_TRAD_SIGNALS
  99. #define sig_uses_siginfo(ka) ((ka)->sa.sa_flags & SA_SIGINFO)
  100. #else
  101. #define sig_uses_siginfo(ka) (1)
  102. #endif
  103. #endif /* __KERNEL__ */
  104. #define SIG_BLOCK 1 /* for blocking signals */
  105. #define SIG_UNBLOCK 2 /* for unblocking signals */
  106. #define SIG_SETMASK 3 /* for setting the signal mask */
  107. #define SIG_SETMASK32 256 /* Goodie from SGI for BSD compatibility:
  108. set only the low 32 bit of the sigset. */
  109. /* Type of a signal handler. */
  110. typedef void __signalfn_t(int);
  111. typedef __signalfn_t __user *__sighandler_t;
  112. /* Fake signal functions */
  113. #define SIG_DFL ((__sighandler_t)0) /* default signal handling */
  114. #define SIG_IGN ((__sighandler_t)1) /* ignore signal */
  115. #define SIG_ERR ((__sighandler_t)-1) /* error return from signal */
  116. struct sigaction {
  117. unsigned int sa_flags;
  118. __sighandler_t sa_handler;
  119. sigset_t sa_mask;
  120. };
  121. struct k_sigaction {
  122. struct sigaction sa;
  123. #ifdef CONFIG_BINFMT_IRIX
  124. void (*sa_restorer)(void);
  125. #endif
  126. };
  127. /* IRIX compatible stack_t */
  128. typedef struct sigaltstack {
  129. void *ss_sp;
  130. size_t ss_size;
  131. int ss_flags;
  132. } stack_t;
  133. #ifdef __KERNEL__
  134. #include <asm/sigcontext.h>
  135. #define ptrace_signal_deliver(regs, cookie) do { } while (0)
  136. #endif /* __KERNEL__ */
  137. #endif /* _ASM_SIGNAL_H */