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