Commit | Line | Data |
---|---|---|
9ab9afa9 | 1 | /* syssignal.h - System-dependent definitions for signals. |
429ab54e | 2 | Copyright (C) 1993, 1999, 2001, 2002, 2003, 2004, |
114f9c96 | 3 | 2005, 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. |
9ab9afa9 JB |
4 | |
5 | This file is part of GNU Emacs. | |
6 | ||
b9b1cc14 | 7 | GNU Emacs is free software: you can redistribute it and/or modify |
9ab9afa9 | 8 | it under the terms of the GNU General Public License as published by |
b9b1cc14 GM |
9 | the Free Software Foundation, either version 3 of the License, or |
10 | (at your option) any later version. | |
9ab9afa9 JB |
11 | |
12 | GNU Emacs is distributed in the hope that it will be useful, | |
13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 | GNU General Public License for more details. | |
16 | ||
17 | You should have received a copy of the GNU General Public License | |
b9b1cc14 | 18 | along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
9ab9afa9 | 19 | |
383e0970 | 20 | extern void init_signals (void); |
2b98b088 | 21 | |
07b87a10 | 22 | #if defined (HAVE_GTK_AND_PTHREAD) || defined (HAVE_NS) |
333f1b6f | 23 | #include <pthread.h> |
f8240abd YM |
24 | /* If defined, asynchronous signals delivered to a non-main thread are |
25 | forwarded to the main thread. */ | |
26 | #define FORWARD_SIGNAL_TO_MAIN_THREAD | |
27 | #endif | |
28 | ||
c3aa5fec | 29 | /* Don't #include <signal.h>. That header should always be #included |
cf026b25 JB |
30 | before "config.h", because some configuration files (like s/hpux.h) |
31 | indicate that SIGIO doesn't work by #undef-ing SIGIO. If this file | |
32 | #includes <signal.h>, then that will re-#define SIGIO and confuse | |
33 | things. */ | |
4d553a13 | 34 | /* XXX This is not correct anymore, there is a BROKEN_SIGIO macro. */ |
00eaaa32 | 35 | |
9ab9afa9 JB |
36 | #define SIGMASKTYPE sigset_t |
37 | ||
38 | #define SIGEMPTYMASK (empty_mask) | |
39 | #define SIGFULLMASK (full_mask) | |
47b682b7 | 40 | extern sigset_t empty_mask, full_mask; |
9ab9afa9 | 41 | |
1b1f8f85 | 42 | /* POSIX pretty much destroys any possibility of writing sigmask as a |
47b682b7 AS |
43 | macro in standard C. We always define our own version because the |
44 | predefined macro in Glibc 2.1 is only provided for compatility for old | |
45 | programs that use int as signal mask type. */ | |
46 | #undef sigmask | |
1b1f8f85 JB |
47 | #ifdef __GNUC__ |
48 | #define sigmask(SIG) \ | |
49 | ({ \ | |
50 | sigset_t _mask; \ | |
51 | sigemptyset (&_mask); \ | |
52 | sigaddset (&_mask, SIG); \ | |
53 | _mask; \ | |
54 | }) | |
985a35a3 | 55 | #else /* ! defined (__GNUC__) */ |
9bd67a37 | 56 | extern sigset_t sys_sigmask (); |
1b1f8f85 | 57 | #define sigmask(SIG) (sys_sigmask (SIG)) |
985a35a3 | 58 | #endif /* ! defined (__GNUC__) */ |
1b1f8f85 | 59 | |
47b682b7 AS |
60 | #undef sigpause |
61 | #define sigpause(MASK) sigsuspend (&(MASK)) | |
9f910b50 | 62 | |
69037d5a RS |
63 | #define sigblock(SIG) sys_sigblock (SIG) |
64 | #define sigunblock(SIG) sys_sigunblock (SIG) | |
cc210d67 | 65 | #ifndef sigsetmask |
69037d5a | 66 | #define sigsetmask(SIG) sys_sigsetmask (SIG) |
cc210d67 | 67 | #endif |
6c8a1e24 | 68 | #undef signal |
9c063f29 | 69 | #define signal(SIG,ACT) sys_signal(SIG,ACT) |
9ab9afa9 | 70 | |
ae877222 DN |
71 | /* Whether this is what all systems want or not, this is what |
72 | appears to be assumed in the source, for example data.c:arith_error. */ | |
73 | typedef RETSIGTYPE (*signal_handler_t) (int); | |
74 | ||
383e0970 J |
75 | signal_handler_t sys_signal (int signal_number, signal_handler_t action); |
76 | sigset_t sys_sigblock (sigset_t new_mask); | |
77 | sigset_t sys_sigunblock (sigset_t new_mask); | |
78 | sigset_t sys_sigsetmask (sigset_t new_mask); | |
9ab9afa9 | 79 | |
69037d5a | 80 | #define sys_sigdel(MASK,SIG) sigdelset (&MASK,SIG) |
9ab9afa9 | 81 | |
1b1f8f85 | 82 | #define sigfree() sigsetmask (SIGEMPTYMASK) |
1b1f8f85 | 83 | |
68c45bf0 PE |
84 | #if defined (SIGINFO) && defined (BROKEN_SIGINFO) |
85 | #undef SIGINFO | |
86 | #endif | |
87 | #if defined (SIGIO) && defined (BROKEN_SIGIO) | |
098767d9 | 88 | # undef SIGIO |
68c45bf0 PE |
89 | #endif |
90 | #if defined (SIGPOLL) && defined (BROKEN_SIGPOLL) | |
91 | #undef SIGPOLL | |
92 | #endif | |
93 | #if defined (SIGTSTP) && defined (BROKEN_SIGTSTP) | |
94 | #undef SIGTSTP | |
95 | #endif | |
96 | #if defined (SIGURG) && defined (BROKEN_SIGURG) | |
97 | #undef SIGURG | |
98 | #endif | |
4e677396 KH |
99 | #if defined (SIGAIO) && defined (BROKEN_SIGAIO) |
100 | #undef SIGAIO | |
101 | #endif | |
102 | #if defined (SIGPTY) && defined (BROKEN_SIGPTY) | |
103 | #undef SIGPTY | |
104 | #endif | |
105 | ||
68c45bf0 PE |
106 | |
107 | #if NSIG < NSIG_MINIMUM | |
108 | # ifdef NSIG | |
109 | # undef NSIG | |
110 | # endif | |
111 | # define NSIG NSIG_MINIMUM | |
112 | #endif | |
113 | ||
9ab9afa9 JB |
114 | /* On bsd, [man says] kill does not accept a negative number to kill a pgrp. |
115 | Must do that using the killpg call. */ | |
6df54671 | 116 | #ifdef BSD_SYSTEM |
9ab9afa9 JB |
117 | #define EMACS_KILLPG(gid, signo) (killpg ( (gid), (signo))) |
118 | #else | |
57d65592 | 119 | #ifdef WINDOWSNT |
f405affb | 120 | #define EMACS_KILLPG(gid, signo) (kill (gid, signo)) |
57d65592 | 121 | #else |
9ab9afa9 JB |
122 | #define EMACS_KILLPG(gid, signo) (kill (-(gid), (signo))) |
123 | #endif | |
57d65592 | 124 | #endif |
9ab9afa9 JB |
125 | |
126 | /* Define SIGCHLD as an alias for SIGCLD. There are many conditionals | |
127 | testing SIGCHLD. */ | |
9ab9afa9 JB |
128 | #ifdef SIGCLD |
129 | #ifndef SIGCHLD | |
130 | #define SIGCHLD SIGCLD | |
985a35a3 JB |
131 | #endif /* SIGCHLD */ |
132 | #endif /* ! defined (SIGCLD) */ | |
68c45bf0 PE |
133 | |
134 | #ifndef HAVE_STRSIGNAL | |
135 | /* strsignal is in sysdep.c */ | |
361358ea | 136 | char *strsignal (int); |
68c45bf0 | 137 | #endif |
ab5796a9 | 138 | |
f8240abd | 139 | #ifdef FORWARD_SIGNAL_TO_MAIN_THREAD |
dff94ed5 | 140 | extern pthread_t main_thread; |
333f1b6f JD |
141 | #define SIGNAL_THREAD_CHECK(signo) \ |
142 | do { \ | |
3fb8b536 | 143 | if (!pthread_equal (pthread_self (), main_thread)) \ |
333f1b6f JD |
144 | { \ |
145 | /* POSIX says any thread can receive the signal. On GNU/Linux \ | |
146 | that is not true, but for other systems (FreeBSD at least) \ | |
147 | it is. So direct the signal to the correct thread and block \ | |
148 | it from this thread. */ \ | |
149 | sigset_t new_mask; \ | |
150 | \ | |
151 | sigemptyset (&new_mask); \ | |
152 | sigaddset (&new_mask, signo); \ | |
153 | pthread_sigmask (SIG_BLOCK, &new_mask, 0); \ | |
154 | pthread_kill (main_thread, signo); \ | |
155 | return; \ | |
156 | } \ | |
157 | } while (0) | |
158 | ||
f8240abd | 159 | #else /* not FORWARD_SIGNAL_TO_MAIN_THREAD */ |
333f1b6f | 160 | #define SIGNAL_THREAD_CHECK(signo) |
f8240abd | 161 | #endif /* not FORWARD_SIGNAL_TO_MAIN_THREAD */ |
ab5796a9 MB |
162 | /* arch-tag: 4580e86a-340d-4574-9e11-a742b6e1a152 |
163 | (do not change this comment) */ |