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