signal.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. #ifndef _ASMx8664_SIGNAL_H
  2. #define _ASMx8664_SIGNAL_H
  3. #ifndef __ASSEMBLY__
  4. #include <linux/types.h>
  5. #include <linux/time.h>
  6. /* Avoid too many header ordering problems. */
  7. struct siginfo;
  8. #ifdef __KERNEL__
  9. #include <linux/linkage.h>
  10. /* Most things should be clean enough to redefine this at will, if care
  11. is taken to make libc match. */
  12. #define _NSIG 64
  13. #define _NSIG_BPW 64
  14. #define _NSIG_WORDS (_NSIG / _NSIG_BPW)
  15. typedef unsigned long old_sigset_t; /* at least 32 bits */
  16. typedef struct {
  17. unsigned long sig[_NSIG_WORDS];
  18. } sigset_t;
  19. struct pt_regs;
  20. asmlinkage int do_signal(struct pt_regs *regs, sigset_t *oldset);
  21. #else
  22. /* Here we must cater to libcs that poke about in kernel headers. */
  23. #define NSIG 32
  24. typedef unsigned long sigset_t;
  25. #endif /* __KERNEL__ */
  26. #endif
  27. #define SIGHUP 1
  28. #define SIGINT 2
  29. #define SIGQUIT 3
  30. #define SIGILL 4
  31. #define SIGTRAP 5
  32. #define SIGABRT 6
  33. #define SIGIOT 6
  34. #define SIGBUS 7
  35. #define SIGFPE 8
  36. #define SIGKILL 9
  37. #define SIGUSR1 10
  38. #define SIGSEGV 11
  39. #define SIGUSR2 12
  40. #define SIGPIPE 13
  41. #define SIGALRM 14
  42. #define SIGTERM 15
  43. #define SIGSTKFLT 16
  44. #define SIGCHLD 17
  45. #define SIGCONT 18
  46. #define SIGSTOP 19
  47. #define SIGTSTP 20
  48. #define SIGTTIN 21
  49. #define SIGTTOU 22
  50. #define SIGURG 23
  51. #define SIGXCPU 24
  52. #define SIGXFSZ 25
  53. #define SIGVTALRM 26
  54. #define SIGPROF 27
  55. #define SIGWINCH 28
  56. #define SIGIO 29
  57. #define SIGPOLL SIGIO
  58. /*
  59. #define SIGLOST 29
  60. */
  61. #define SIGPWR 30
  62. #define SIGSYS 31
  63. #define SIGUNUSED 31
  64. /* These should not be considered constants from userland. */
  65. #define SIGRTMIN 32
  66. #define SIGRTMAX _NSIG
  67. /*
  68. * SA_FLAGS values:
  69. *
  70. * SA_ONSTACK indicates that a registered stack_t will be used.
  71. * SA_RESTART flag to get restarting signals (which were the default long ago)
  72. * SA_NOCLDSTOP flag to turn off SIGCHLD when children stop.
  73. * SA_RESETHAND clears the handler when the signal is delivered.
  74. * SA_NOCLDWAIT flag on SIGCHLD to inhibit zombies.
  75. * SA_NODEFER prevents the current signal from being masked in the handler.
  76. *
  77. * SA_ONESHOT and SA_NOMASK are the historical Linux names for the Single
  78. * Unix names RESETHAND and NODEFER respectively.
  79. */
  80. #define SA_NOCLDSTOP 0x00000001
  81. #define SA_NOCLDWAIT 0x00000002
  82. #define SA_SIGINFO 0x00000004
  83. #define SA_ONSTACK 0x08000000
  84. #define SA_RESTART 0x10000000
  85. #define SA_NODEFER 0x40000000
  86. #define SA_RESETHAND 0x80000000
  87. #define SA_NOMASK SA_NODEFER
  88. #define SA_ONESHOT SA_RESETHAND
  89. #define SA_RESTORER 0x04000000
  90. /*
  91. * sigaltstack controls
  92. */
  93. #define SS_ONSTACK 1
  94. #define SS_DISABLE 2
  95. #define MINSIGSTKSZ 2048
  96. #define SIGSTKSZ 8192
  97. #include <asm-generic/signal.h>
  98. #ifndef __ASSEMBLY__
  99. struct sigaction {
  100. __sighandler_t sa_handler;
  101. unsigned long sa_flags;
  102. __sigrestore_t sa_restorer;
  103. sigset_t sa_mask; /* mask last for extensibility */
  104. };
  105. struct k_sigaction {
  106. struct sigaction sa;
  107. };
  108. typedef struct sigaltstack {
  109. void __user *ss_sp;
  110. int ss_flags;
  111. size_t ss_size;
  112. } stack_t;
  113. #ifdef __KERNEL__
  114. #include <asm/sigcontext.h>
  115. #undef __HAVE_ARCH_SIG_BITOPS
  116. #if 0
  117. static inline void sigaddset(sigset_t *set, int _sig)
  118. {
  119. __asm__("btsq %1,%0" : "=m"(*set) : "Ir"(_sig - 1) : "cc");
  120. }
  121. static inline void sigdelset(sigset_t *set, int _sig)
  122. {
  123. __asm__("btrq %1,%0" : "=m"(*set) : "Ir"(_sig - 1) : "cc");
  124. }
  125. static inline int __const_sigismember(sigset_t *set, int _sig)
  126. {
  127. unsigned long sig = _sig - 1;
  128. return 1 & (set->sig[sig / _NSIG_BPW] >> (sig & ~(_NSIG_BPW-1)));
  129. }
  130. static inline int __gen_sigismember(sigset_t *set, int _sig)
  131. {
  132. int ret;
  133. __asm__("btq %2,%1\n\tsbbq %0,%0"
  134. : "=r"(ret) : "m"(*set), "Ir"(_sig-1) : "cc");
  135. return ret;
  136. }
  137. #define sigismember(set,sig) \
  138. (__builtin_constant_p(sig) ? \
  139. __const_sigismember((set),(sig)) : \
  140. __gen_sigismember((set),(sig)))
  141. static inline int sigfindinword(unsigned long word)
  142. {
  143. __asm__("bsfq %1,%0" : "=r"(word) : "rm"(word) : "cc");
  144. return word;
  145. }
  146. #endif
  147. #endif
  148. #define ptrace_signal_deliver(regs, cookie) do { } while (0)
  149. #endif /* __KERNEL__ */
  150. #endif