xref: /freebsd/contrib/tcsh/tc.sig.h (revision d803a9d0e568632fc063675523ff45dcfe173df2)
1c80476e4SDavid E. O'Brien /*
2c80476e4SDavid E. O'Brien  * tc.sig.h: Signal handling
3c80476e4SDavid E. O'Brien  *
4c80476e4SDavid E. O'Brien  */
5c80476e4SDavid E. O'Brien /*-
6c80476e4SDavid E. O'Brien  * Copyright (c) 1980, 1991 The Regents of the University of California.
7c80476e4SDavid E. O'Brien  * All rights reserved.
8c80476e4SDavid E. O'Brien  *
9c80476e4SDavid E. O'Brien  * Redistribution and use in source and binary forms, with or without
10c80476e4SDavid E. O'Brien  * modification, are permitted provided that the following conditions
11c80476e4SDavid E. O'Brien  * are met:
12c80476e4SDavid E. O'Brien  * 1. Redistributions of source code must retain the above copyright
13c80476e4SDavid E. O'Brien  *    notice, this list of conditions and the following disclaimer.
14c80476e4SDavid E. O'Brien  * 2. Redistributions in binary form must reproduce the above copyright
15c80476e4SDavid E. O'Brien  *    notice, this list of conditions and the following disclaimer in the
16c80476e4SDavid E. O'Brien  *    documentation and/or other materials provided with the distribution.
1729301572SMark Peek  * 3. Neither the name of the University nor the names of its contributors
18c80476e4SDavid E. O'Brien  *    may be used to endorse or promote products derived from this software
19c80476e4SDavid E. O'Brien  *    without specific prior written permission.
20c80476e4SDavid E. O'Brien  *
21c80476e4SDavid E. O'Brien  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22c80476e4SDavid E. O'Brien  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23c80476e4SDavid E. O'Brien  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24c80476e4SDavid E. O'Brien  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25c80476e4SDavid E. O'Brien  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26c80476e4SDavid E. O'Brien  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27c80476e4SDavid E. O'Brien  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28c80476e4SDavid E. O'Brien  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29c80476e4SDavid E. O'Brien  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30c80476e4SDavid E. O'Brien  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31c80476e4SDavid E. O'Brien  * SUCH DAMAGE.
32c80476e4SDavid E. O'Brien  */
33c80476e4SDavid E. O'Brien #ifndef _h_tc_sig
34c80476e4SDavid E. O'Brien #define _h_tc_sig
35c80476e4SDavid E. O'Brien 
36a15e6f9aSMark Peek #if (SYSVREL > 0) || defined(BSD4_4) || defined(_MINIX) || defined(DGUX) || defined(WINNT_NATIVE) || defined(__QNXNTO__)
37c80476e4SDavid E. O'Brien # include <signal.h>
38c80476e4SDavid E. O'Brien # ifndef SIGCHLD
39c80476e4SDavid E. O'Brien #  define SIGCHLD SIGCLD
40c80476e4SDavid E. O'Brien # endif /* SIGCHLD */
41c80476e4SDavid E. O'Brien #else /* SYSVREL == 0 */
42c80476e4SDavid E. O'Brien # include <sys/signal.h>
43c80476e4SDavid E. O'Brien #endif /* SYSVREL > 0 */
44c80476e4SDavid E. O'Brien 
45*d803a9d0SBrooks Davis #if defined(SUNOS4) || defined(DGUX) || defined(hp800) || (SYSVREL > 3 && defined(VFORK))
46c80476e4SDavid E. O'Brien # define SAVESIGVEC
4745e5710bSMark Peek #endif /* SUNOS4 || DGUX || hp800 || SVR4 & VFORK */
48c80476e4SDavid E. O'Brien 
49c80476e4SDavid E. O'Brien #if SYSVREL > 0
50c80476e4SDavid E. O'Brien # ifdef BSDJOBS
51c80476e4SDavid E. O'Brien /* here I assume that systems that have bsdjobs implement the
52c80476e4SDavid E. O'Brien  * the setpgrp call correctly. Otherwise defining this would
53c80476e4SDavid E. O'Brien  * work, but it would kill the world, because all the setpgrp
54c80476e4SDavid E. O'Brien  * code is the the part defined when BSDJOBS are defined
55c80476e4SDavid E. O'Brien  * NOTE: we don't want killpg(a, b) == kill(-getpgrp(a), b)
56c80476e4SDavid E. O'Brien  * cause process a might be already dead and getpgrp would fail
57c80476e4SDavid E. O'Brien  */
58c80476e4SDavid E. O'Brien #  define killpg(a, b) kill(-(a), (b))
59c80476e4SDavid E. O'Brien # else
60c80476e4SDavid E. O'Brien /* this is the poor man's version of killpg()! Just kill the
61c80476e4SDavid E. O'Brien  * current process and don't worry about the rest. Someday
62c80476e4SDavid E. O'Brien  * I hope I get to fix that.
63c80476e4SDavid E. O'Brien  */
64c80476e4SDavid E. O'Brien #  define killpg(a, b) kill((a), (b))
65c80476e4SDavid E. O'Brien # endif /* BSDJOBS */
66c80476e4SDavid E. O'Brien #endif /* SYSVREL > 0 */
67c80476e4SDavid E. O'Brien 
68c80476e4SDavid E. O'Brien #ifdef _MINIX
69c80476e4SDavid E. O'Brien # include <signal.h>
70c80476e4SDavid E. O'Brien # define killpg(a, b) kill((a), (b))
713b6eaa7bSAndrey A. Chernov # ifdef _MINIX_VMD
723b6eaa7bSAndrey A. Chernov #  define signal(a, b) signal((a), (a) == SIGCHLD ? SIG_IGN : (b))
733b6eaa7bSAndrey A. Chernov # endif /* _MINIX_VMD */
74c80476e4SDavid E. O'Brien #endif /* _MINIX */
75c80476e4SDavid E. O'Brien 
76c80476e4SDavid E. O'Brien #ifdef _VMS_POSIX
77c80476e4SDavid E. O'Brien # define killpg(a, b) kill(-(a), (b))
78c80476e4SDavid E. O'Brien #endif /* atp _VMS_POSIX */
79c80476e4SDavid E. O'Brien 
8045e5710bSMark Peek #ifdef aiws
8145e5710bSMark Peek # undef	killpg
8245e5710bSMark Peek # define 	killpg(a, b)	kill(-getpgrp(a), b)
8345e5710bSMark Peek #endif /* aiws */
8445e5710bSMark Peek 
85c80476e4SDavid E. O'Brien #if !defined(NSIG) && defined(SIGMAX)
86c80476e4SDavid E. O'Brien # define NSIG (SIGMAX+1)
87c80476e4SDavid E. O'Brien #endif /* !NSIG && SIGMAX */
88c80476e4SDavid E. O'Brien #if !defined(NSIG) && defined(_SIG_MAX)
89c80476e4SDavid E. O'Brien # define NSIG (_SIG_MAX+1)
90c80476e4SDavid E. O'Brien #endif /* !NSIG && _SIG_MAX */
91c80476e4SDavid E. O'Brien #if !defined(NSIG) && defined(_NSIG)
92c80476e4SDavid E. O'Brien # define NSIG _NSIG
93c80476e4SDavid E. O'Brien #endif /* !NSIG && _NSIG */
9423338178SMark Peek #if !defined(NSIG)
9523338178SMark Peek #define NSIG (sizeof(sigset_t) * 8)
9623338178SMark Peek #endif /* !NSIG */
97c80476e4SDavid E. O'Brien #if !defined(MAXSIG) && defined(NSIG)
98c80476e4SDavid E. O'Brien # define MAXSIG NSIG
99c80476e4SDavid E. O'Brien #endif /* !MAXSIG && NSIG */
100c80476e4SDavid E. O'Brien 
101c80476e4SDavid E. O'Brien /*
102c80476e4SDavid E. O'Brien  * We choose a define for the window signal if it exists..
103c80476e4SDavid E. O'Brien  */
104c80476e4SDavid E. O'Brien #ifdef SIGWINCH
105c80476e4SDavid E. O'Brien # define SIG_WINDOW SIGWINCH
106c80476e4SDavid E. O'Brien #else
107c80476e4SDavid E. O'Brien # ifdef SIGWINDOW
108c80476e4SDavid E. O'Brien #  define SIG_WINDOW SIGWINDOW
109c80476e4SDavid E. O'Brien # endif /* SIGWINDOW */
110c80476e4SDavid E. O'Brien #endif /* SIGWINCH */
111c80476e4SDavid E. O'Brien 
112c80476e4SDavid E. O'Brien #ifdef SAVESIGVEC
113c80476e4SDavid E. O'Brien # define NSIGSAVED 7
114c80476e4SDavid E. O'Brien  /*
115c80476e4SDavid E. O'Brien   * These are not inline for speed. gcc -traditional -O on the sparc ignores
116c80476e4SDavid E. O'Brien   * the fact that vfork() corrupts the registers. Calling a routine is not
117c80476e4SDavid E. O'Brien   * nice, since it can make the compiler put some things that we want saved
118c80476e4SDavid E. O'Brien   * into registers 				- christos
119c80476e4SDavid E. O'Brien   */
12045e5710bSMark Peek # define savesigvec(sv, sm)			\
12145e5710bSMark Peek     do {					\
12245e5710bSMark Peek 	sigset_t m__;				\
12345e5710bSMark Peek 						\
12445e5710bSMark Peek 	sigaction(SIGINT,  NULL, &(sv)[0]);	\
12545e5710bSMark Peek 	sigaction(SIGQUIT, NULL, &(sv)[1]);	\
12645e5710bSMark Peek 	sigaction(SIGTSTP, NULL, &(sv)[2]);	\
12745e5710bSMark Peek 	sigaction(SIGTTIN, NULL, &(sv)[3]);	\
12845e5710bSMark Peek 	sigaction(SIGTTOU, NULL, &(sv)[4]);	\
12945e5710bSMark Peek 	sigaction(SIGTERM, NULL, &(sv)[5]);	\
13045e5710bSMark Peek 	sigaction(SIGHUP,  NULL, &(sv)[6]);	\
13145e5710bSMark Peek 	sigemptyset(&m__);			\
13245e5710bSMark Peek 	sigaddset(&m__, SIGINT);		\
13345e5710bSMark Peek 	sigaddset(&m__, SIGQUIT);		\
13445e5710bSMark Peek 	sigaddset(&m__, SIGTSTP);		\
13545e5710bSMark Peek 	sigaddset(&m__, SIGTTIN);		\
13645e5710bSMark Peek 	sigaddset(&m__, SIGTTOU);		\
13745e5710bSMark Peek 	sigaddset(&m__, SIGTERM);		\
13845e5710bSMark Peek 	sigaddset(&m__, SIGHUP);		\
13945e5710bSMark Peek 	sigprocmask(SIG_BLOCK, &m__, &sm);	\
14045e5710bSMark Peek     } while (0)
141c80476e4SDavid E. O'Brien 
142c80476e4SDavid E. O'Brien # define restoresigvec(sv, sm)			\
14345e5710bSMark Peek     do {					\
14445e5710bSMark Peek 	sigaction(SIGINT,  &(sv)[0], NULL);	\
14545e5710bSMark Peek 	sigaction(SIGQUIT, &(sv)[1], NULL);	\
14645e5710bSMark Peek 	sigaction(SIGTSTP, &(sv)[2], NULL);	\
14745e5710bSMark Peek 	sigaction(SIGTTIN, &(sv)[3], NULL);	\
14845e5710bSMark Peek 	sigaction(SIGTTOU, &(sv)[4], NULL);	\
14945e5710bSMark Peek 	sigaction(SIGTERM, &(sv)[5], NULL);	\
15045e5710bSMark Peek 	sigaction(SIGHUP,  &(sv)[6], NULL);	\
15145e5710bSMark Peek 	sigprocmask(SIG_SETMASK, &sm, NULL);	\
15245e5710bSMark Peek     } while (0)
153c80476e4SDavid E. O'Brien # endif /* SAVESIGVEC */
154c80476e4SDavid E. O'Brien 
15545e5710bSMark Peek extern int alrmcatch_disabled;
15645e5710bSMark Peek extern int pchild_disabled;
15745e5710bSMark Peek extern int phup_disabled;
15845e5710bSMark Peek extern int pintr_disabled;
15945e5710bSMark Peek 
16045e5710bSMark Peek extern void sigset_interrupting(int, void (*) (int));
1619ccc37e3SMark Peek extern int handle_pending_signals(void);
16245e5710bSMark Peek 
16345e5710bSMark Peek extern void queue_alrmcatch(int);
16445e5710bSMark Peek extern void queue_pchild(int);
16545e5710bSMark Peek extern void queue_phup(int);
16645e5710bSMark Peek extern void queue_pintr(int);
16745e5710bSMark Peek 
16845e5710bSMark Peek extern void disabled_cleanup(void *);
16945e5710bSMark Peek extern void pintr_disabled_restore(void *);
17045e5710bSMark Peek extern void pintr_push_enable(int *);
17145e5710bSMark Peek 
172c80476e4SDavid E. O'Brien #endif /* _h_tc_sig */
173