1 1.13 perry /* $NetBSD: sigcompat.c,v 1.13 2005/12/24 21:11:16 perry Exp $ */ 2 1.7 christos 3 1.1 cgd /* 4 1.8 perry * Copyright (c) 1989, 1993 5 1.8 perry * The Regents of the University of California. All rights reserved. 6 1.1 cgd * 7 1.1 cgd * Redistribution and use in source and binary forms, with or without 8 1.1 cgd * modification, are permitted provided that the following conditions 9 1.1 cgd * are met: 10 1.1 cgd * 1. Redistributions of source code must retain the above copyright 11 1.1 cgd * notice, this list of conditions and the following disclaimer. 12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 cgd * notice, this list of conditions and the following disclaimer in the 14 1.1 cgd * documentation and/or other materials provided with the distribution. 15 1.11 agc * 3. Neither the name of the University nor the names of its contributors 16 1.1 cgd * may be used to endorse or promote products derived from this software 17 1.1 cgd * without specific prior written permission. 18 1.1 cgd * 19 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 1.1 cgd * SUCH DAMAGE. 30 1.1 cgd */ 31 1.1 cgd 32 1.7 christos #include <sys/cdefs.h> 33 1.1 cgd #if defined(LIBC_SCCS) && !defined(lint) 34 1.7 christos #if 0 35 1.8 perry static char sccsid[] = "@(#)sigcompat.c 8.1 (Berkeley) 6/2/93"; 36 1.7 christos #else 37 1.13 perry __RCSID("$NetBSD: sigcompat.c,v 1.13 2005/12/24 21:11:16 perry Exp $"); 38 1.7 christos #endif 39 1.1 cgd #endif /* LIBC_SCCS and not lint */ 40 1.1 cgd 41 1.1 cgd #include <sys/param.h> 42 1.1 cgd #include <signal.h> 43 1.12 christos #include <compat/sys/signal.h> 44 1.1 cgd 45 1.13 perry static inline void sv2sa(struct sigaction *, const struct sigvec *); 46 1.13 perry static inline void sa2sv(struct sigvec *, const struct sigaction *); 47 1.10 christos 48 1.13 perry static inline void 49 1.12 christos sv2sa(struct sigaction *sa, const struct sigvec *sv) 50 1.10 christos { 51 1.10 christos sigemptyset(&sa->sa_mask); 52 1.10 christos sa->sa_mask.__bits[0] = sv->sv_mask; 53 1.10 christos sa->sa_handler = sv->sv_handler; 54 1.10 christos sa->sa_flags = sv->sv_flags ^ SV_INTERRUPT; /* !SA_INTERRUPT */ 55 1.10 christos } 56 1.10 christos 57 1.13 perry static inline void 58 1.12 christos sa2sv(struct sigvec *sv, const struct sigaction *sa) 59 1.10 christos { 60 1.10 christos sv->sv_mask = sa->sa_mask.__bits[0]; 61 1.10 christos sv->sv_handler = sa->sa_handler; 62 1.10 christos sv->sv_flags = sa->sa_flags ^ SV_INTERRUPT; /* !SA_INTERRUPT */ 63 1.10 christos } 64 1.10 christos 65 1.4 jtc int 66 1.12 christos sigvec(int signo, struct sigvec *nsv, struct sigvec *osv) 67 1.1 cgd { 68 1.1 cgd int ret; 69 1.10 christos struct sigaction osa, nsa; 70 1.10 christos 71 1.10 christos if (nsv) 72 1.10 christos sv2sa(&nsa, nsv); 73 1.10 christos 74 1.10 christos ret = sigaction(signo, nsv ? &nsa : NULL, osv ? &osa : NULL); 75 1.1 cgd 76 1.1 cgd if (ret == 0 && osv) 77 1.10 christos sa2sv(osv, &osa); 78 1.10 christos 79 1.1 cgd return (ret); 80 1.1 cgd } 81 1.1 cgd 82 1.4 jtc int 83 1.12 christos sigsetmask(int mask) 84 1.1 cgd { 85 1.9 christos sigset_t nmask, omask; 86 1.9 christos int n; 87 1.1 cgd 88 1.9 christos sigemptyset(&nmask); 89 1.9 christos nmask.__bits[0] = mask; 90 1.9 christos 91 1.9 christos n = sigprocmask(SIG_SETMASK, &nmask, &omask); 92 1.1 cgd if (n) 93 1.1 cgd return (n); 94 1.9 christos return (omask.__bits[0]); 95 1.1 cgd } 96 1.1 cgd 97 1.4 jtc int 98 1.12 christos sigblock(int mask) 99 1.1 cgd { 100 1.9 christos sigset_t nmask, omask; 101 1.9 christos int n; 102 1.9 christos 103 1.9 christos sigemptyset(&nmask); 104 1.9 christos nmask.__bits[0] = mask; 105 1.1 cgd 106 1.9 christos n = sigprocmask(SIG_BLOCK, &nmask, &omask); 107 1.1 cgd if (n) 108 1.1 cgd return (n); 109 1.9 christos return (omask.__bits[0]); 110 1.1 cgd } 111 1.1 cgd 112 1.4 jtc int 113 1.12 christos sigpause(int mask) 114 1.1 cgd { 115 1.9 christos sigset_t nmask; 116 1.9 christos 117 1.9 christos sigemptyset(&nmask); 118 1.9 christos nmask.__bits[0] = mask; 119 1.9 christos return (sigsuspend(&nmask)); 120 1.1 cgd } 121