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