2 * include/asm-xtensa/signal.h
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file "COPYING" in the main directory of this archive
10 * Copyright (C) 2001 - 2005 Tensilica Inc.
13 #ifndef _XTENSA_SIGNAL_H
14 #define _XTENSA_SIGNAL_H
19 #define _NSIG_WORDS (_NSIG / _NSIG_BPW)
23 #include <linux/types.h>
25 /* Avoid too many header ordering problems. */
27 typedef unsigned long old_sigset_t; /* at least 32 bits */
29 unsigned long sig[_NSIG_WORDS];
65 /* #define SIGLOST 29 */
70 /* These should not be considered constants from userland. */
72 #define SIGRTMAX (_NSIG-1)
77 * SA_ONSTACK indicates that a registered stack_t will be used.
78 * SA_INTERRUPT is a no-op, but left due to historical reasons. Use the
79 * SA_RESTART flag to get restarting signals (which were the default long ago)
80 * SA_NOCLDSTOP flag to turn off SIGCHLD when children stop.
81 * SA_RESETHAND clears the handler when the signal is delivered.
82 * SA_NOCLDWAIT flag on SIGCHLD to inhibit zombies.
83 * SA_NODEFER prevents the current signal from being masked in the handler.
85 * SA_ONESHOT and SA_NOMASK are the historical Linux names for the Single
86 * Unix names RESETHAND and NODEFER respectively.
88 #define SA_NOCLDSTOP 0x00000001
89 #define SA_NOCLDWAIT 0x00000002 /* not supported yet */
90 #define SA_SIGINFO 0x00000004
91 #define SA_ONSTACK 0x08000000
92 #define SA_RESTART 0x10000000
93 #define SA_NODEFER 0x40000000
94 #define SA_RESETHAND 0x80000000
96 #define SA_NOMASK SA_NODEFER
97 #define SA_ONESHOT SA_RESETHAND
98 #define SA_INTERRUPT 0x20000000 /* dummy -- ignored */
100 #define SA_RESTORER 0x04000000
103 * sigaltstack controls
108 #define MINSIGSTKSZ 2048
109 #define SIGSTKSZ 8192
115 * These values of sa_flags are used only by the kernel as part of the
116 * irq handling routines.
118 * SA_INTERRUPT is also used by the irq handling routines.
119 * SA_SHIRQ is for shared interrupt support on PCI and EISA.
121 #define SA_PROBE SA_ONESHOT
122 #define SA_SAMPLE_RANDOM SA_RESTART
123 #define SA_SHIRQ 0x04000000
126 #define SIG_BLOCK 0 /* for blocking signals */
127 #define SIG_UNBLOCK 1 /* for unblocking signals */
128 #define SIG_SETMASK 2 /* for setting the signal mask */
130 /* Type of a signal handler. */
131 typedef void (*__sighandler_t)(int);
133 #define SIG_DFL ((__sighandler_t)0) /* default signal handling */
134 #define SIG_IGN ((__sighandler_t)1) /* ignore signal */
135 #define SIG_ERR ((__sighandler_t)-1) /* error return from signal */
138 struct old_sigaction {
139 __sighandler_t sa_handler;
140 old_sigset_t sa_mask;
141 unsigned long sa_flags;
142 void (*sa_restorer)(void);
146 __sighandler_t sa_handler;
147 unsigned long sa_flags;
148 void (*sa_restorer)(void);
149 sigset_t sa_mask; /* mask last for extensibility */
158 /* Here we must cater to libcs that poke about in kernel headers. */
162 __sighandler_t _sa_handler;
163 void (*_sa_sigaction)(int, struct siginfo *, void *);
166 unsigned long sa_flags;
167 void (*sa_restorer)(void);
170 #define sa_handler _u._sa_handler
171 #define sa_sigaction _u._sa_sigaction
173 #endif /* __KERNEL__ */
175 typedef struct sigaltstack {
182 #include <asm/sigcontext.h>
183 #define ptrace_signal_deliver(regs, cookie) do { } while (0)
185 #endif /* __KERNEL__ */
186 #endif /* __ASSEMBLY__ */
187 #endif /* _XTENSA_SIGNAL_H */