[BACK]Return to hpux_sig.c CVS log [TXT][DIR] Up to [local] / sys / compat / hpux

Annotation of sys/compat/hpux/hpux_sig.c, Revision 1.1

1.1     ! nbrk        1: /*     $OpenBSD: hpux_sig.c,v 1.9 2004/09/19 21:56:18 mickey Exp $     */
        !             2: /*     $NetBSD: hpux_sig.c,v 1.16 1997/04/01 19:59:02 scottr Exp $     */
        !             3:
        !             4: /*
        !             5:  * Copyright (c) 1988 University of Utah.
        !             6:  * Copyright (c) 1990, 1993
        !             7:  *     The Regents of the University of California.  All rights reserved.
        !             8:  *
        !             9:  * This code is derived from software contributed to Berkeley by
        !            10:  * the Systems Programming Group of the University of Utah Computer
        !            11:  * Science Department.
        !            12:  *
        !            13:  * Redistribution and use in source and binary forms, with or without
        !            14:  * modification, are permitted provided that the following conditions
        !            15:  * are met:
        !            16:  * 1. Redistributions of source code must retain the above copyright
        !            17:  *    notice, this list of conditions and the following disclaimer.
        !            18:  * 2. Redistributions in binary form must reproduce the above copyright
        !            19:  *    notice, this list of conditions and the following disclaimer in the
        !            20:  *    documentation and/or other materials provided with the distribution.
        !            21:  * 3. Neither the name of the University nor the names of its contributors
        !            22:  *    may be used to endorse or promote products derived from this software
        !            23:  *    without specific prior written permission.
        !            24:  *
        !            25:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
        !            26:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
        !            27:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
        !            28:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
        !            29:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
        !            30:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
        !            31:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
        !            32:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
        !            33:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
        !            34:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
        !            35:  * SUCH DAMAGE.
        !            36:  *
        !            37:  * from: Utah $Hdr: hpux_sig.c 1.4 92/01/20$
        !            38:  *
        !            39:  *     @(#)hpux_sig.c  8.2 (Berkeley) 9/23/93
        !            40:  */
        !            41:
        !            42: /*
        !            43:  * Signal related HPUX compatibility routines
        !            44:  */
        !            45:
        !            46: #include <sys/param.h>
        !            47: #include <sys/systm.h>
        !            48: #include <sys/kernel.h>
        !            49: #include <sys/mount.h>
        !            50: #include <sys/proc.h>
        !            51: #include <sys/signalvar.h>
        !            52: #include <sys/syscallargs.h>
        !            53:
        !            54: #include <compat/hpux/hpux.h>
        !            55: #include <compat/hpux/hpux_sig.h>
        !            56: #include <compat/hpux/hpux_syscallargs.h>
        !            57:
        !            58: /* indexed by HPUX signal number - 1 */
        !            59: char hpuxtobsdsigmap[NSIG] = {
        !            60: /*01*/ SIGHUP,  SIGINT, SIGQUIT, SIGILL,   SIGTRAP, SIGIOT,  SIGEMT,   SIGFPE,
        !            61: /*09*/  SIGKILL, SIGBUS, SIGSEGV, SIGSYS,   SIGPIPE, SIGALRM, SIGTERM,  SIGUSR1,
        !            62: /*17*/  SIGUSR2, SIGCHLD, 0,      SIGVTALRM,SIGPROF, SIGIO,   SIGWINCH, SIGSTOP,
        !            63: /*25*/ SIGTSTP, SIGCONT,SIGTTIN, SIGTTOU,  SIGURG,  0,       0,        0
        !            64: };
        !            65:
        !            66: /* indexed by BSD signal number - 1 */
        !            67: char bsdtohpuxsigmap[NSIG] = {
        !            68: /*01*/  1,  2,  3,  4,  5,  6,  7,  8,
        !            69: /*09*/   9, 10, 11, 12, 13, 14, 15, 29,
        !            70: /*17*/  24, 25, 26, 18, 27, 28, 22,  0,
        !            71: /*25*/  0, 20, 21, 23,  0, 16, 17,  0
        !            72: };
        !            73:
        !            74: /*
        !            75:  * XXX: In addition to mapping the signal number we also have
        !            76:  * to see if the "old" style signal mechinism is needed.
        !            77:  * If so, we set the OUSIG flag.  This is not really correct
        !            78:  * as under HP-UX "old" style handling can be set on a per
        !            79:  * signal basis and we are setting it for all signals in one
        !            80:  * swell foop.  I suspect we can get away with this since I
        !            81:  * doubt any program of interest mixes the two semantics.
        !            82:  */
        !            83: int
        !            84: hpux_sys_sigvec(p, v, retval)
        !            85:        struct proc *p;
        !            86:        void *v;
        !            87:        register_t *retval;
        !            88: {
        !            89:        struct hpux_sys_sigvec_args *uap = v;
        !            90:        struct sigvec vec;
        !            91:        struct sigacts *ps = p->p_sigacts;
        !            92:        struct sigvec *sv;
        !            93:        int sig;
        !            94:        int bit, error;
        !            95:
        !            96:        sig = hpuxtobsdsig(SCARG(uap, signo));
        !            97:        if (sig <= 0 || sig >= NSIG || sig == SIGKILL || sig == SIGSTOP)
        !            98:                return (EINVAL);
        !            99:        sv = &vec;
        !           100:        if (SCARG(uap, osv)) {
        !           101:                sv->sv_handler = ps->ps_sigact[sig];
        !           102:                sv->sv_mask = ps->ps_catchmask[sig];
        !           103:                bit = sigmask(sig);
        !           104:                sv->sv_flags = 0;
        !           105:                if ((ps->ps_sigonstack & bit) != 0)
        !           106:                        sv->sv_flags |= SV_ONSTACK;
        !           107:                if ((ps->ps_sigintr & bit) != 0)
        !           108:                        sv->sv_flags |= SV_INTERRUPT;
        !           109:                if ((ps->ps_sigreset & bit) != 0)
        !           110:                        sv->sv_flags |= HPUXSV_RESET;
        !           111:                sv->sv_mask &= ~bit;
        !           112:                error = copyout((caddr_t)sv, (caddr_t)SCARG(uap, osv),
        !           113:                    sizeof (vec));
        !           114:                if (error)
        !           115:                        return (error);
        !           116:        }
        !           117:        if (SCARG(uap, nsv)) {
        !           118:                error = copyin((caddr_t)SCARG(uap, nsv), (caddr_t)sv,
        !           119:                    sizeof (vec));
        !           120:                if (error)
        !           121:                        return (error);
        !           122:                if (sig == SIGCONT && sv->sv_handler == SIG_IGN)
        !           123:                        return (EINVAL);
        !           124:                sv->sv_flags ^= SA_RESTART;
        !           125:                setsigvec(p, sig, (struct sigaction *)sv);
        !           126: #if 0
        !           127: /* XXX -- SOUSIG no longer exists, do something here */
        !           128:                if (sv->sv_flags & HPUXSV_RESET)
        !           129:                        p->p_flag |= SOUSIG;            /* XXX */
        !           130: #endif
        !           131:        }
        !           132:        return (0);
        !           133: }
        !           134:
        !           135: int
        !           136: hpux_sys_sigblock(p, v, retval)
        !           137:        struct proc *p;
        !           138:        void *v;
        !           139:        register_t *retval;
        !           140: {
        !           141:        struct hpux_sys_sigblock_args *uap = v;
        !           142:
        !           143:        (void) splhigh();
        !           144:        *retval = bsdtohpuxmask(p->p_sigmask);
        !           145:        p->p_sigmask |= hpuxtobsdmask(SCARG(uap, mask)) &~ sigcantmask;
        !           146:        (void) spl0();
        !           147:        return (0);
        !           148: }
        !           149:
        !           150: int
        !           151: hpux_sys_sigsetmask(p, v, retval)
        !           152:        struct proc *p;
        !           153:        void *v;
        !           154:        register_t *retval;
        !           155: {
        !           156:        struct hpux_sys_sigsetmask_args *uap = v;
        !           157:
        !           158:        (void) splhigh();
        !           159:        *retval = bsdtohpuxmask(p->p_sigmask);
        !           160:        p->p_sigmask = hpuxtobsdmask(SCARG(uap, mask)) &~ sigcantmask;
        !           161:        (void) spl0();
        !           162:        return (0);
        !           163: }
        !           164:
        !           165: int
        !           166: hpux_sys_sigpause(p, v, retval)
        !           167:        struct proc *p;
        !           168:        void *v;
        !           169:        register_t *retval;
        !           170: {
        !           171:        struct hpux_sys_sigpause_args *uap = v;
        !           172:
        !           173:        SCARG(uap, mask) = hpuxtobsdmask(SCARG(uap, mask));
        !           174:        return (sys_sigsuspend(p, uap, retval));
        !           175: }
        !           176:
        !           177: /* not totally correct, but close enuf' */
        !           178: int
        !           179: hpux_sys_kill(p, v, retval)
        !           180:        struct proc *p;
        !           181:        void *v;
        !           182:        register_t *retval;
        !           183: {
        !           184:        struct hpux_sys_kill_args *uap = v;
        !           185:
        !           186:        if (SCARG(uap, signo)) {
        !           187:                SCARG(uap, signo) = hpuxtobsdsig(SCARG(uap, signo));
        !           188:                if (SCARG(uap, signo) == 0)
        !           189:                        SCARG(uap, signo) = NSIG;
        !           190:        }
        !           191:        return (sys_kill(p, uap, retval));
        !           192: }
        !           193:
        !           194: /*
        !           195:  * The following (sigprocmask, sigpending, sigsuspend, sigaction are
        !           196:  * POSIX calls.  Under BSD, the library routine dereferences the sigset_t
        !           197:  * pointers before traping.  Not so under HP-UX.
        !           198:  */
        !           199:
        !           200: /*
        !           201:  * Manipulate signal mask.
        !           202:  * Note that we receive new mask, not pointer,
        !           203:  * and return old mask as return value;
        !           204:  * the library stub does the rest.
        !           205:  */
        !           206: int
        !           207: hpux_sys_sigprocmask(p, v, retval)
        !           208:        struct proc *p;
        !           209:        void *v;
        !           210:        register_t *retval;
        !           211: {
        !           212:        struct hpux_sys_sigprocmask_args *uap = v;
        !           213:        int mask, error = 0;
        !           214:        hpux_sigset_t sigset;
        !           215:
        !           216:        /*
        !           217:         * Copy out old mask first to ensure no errors.
        !           218:         * (proc sigmask should not be changed if call fails for any reason)
        !           219:         */
        !           220:        if (SCARG(uap, oset)) {
        !           221:                bzero((caddr_t)&sigset, sizeof(sigset));
        !           222:                sigset.sigset[0] = bsdtohpuxmask(p->p_sigmask);
        !           223:                if (copyout((caddr_t)&sigset, (caddr_t)SCARG(uap, oset),
        !           224:                    sizeof(sigset)))
        !           225:                        return (EFAULT);
        !           226:        }
        !           227:        if (SCARG(uap, set)) {
        !           228:                if (copyin((caddr_t)SCARG(uap, set), (caddr_t)&sigset,
        !           229:                    sizeof(sigset)))
        !           230:                        return (EFAULT);
        !           231:                mask = hpuxtobsdmask(sigset.sigset[0]);
        !           232:                (void) splhigh();
        !           233:                switch (SCARG(uap, how)) {
        !           234:                case HPUXSIG_BLOCK:
        !           235:                        p->p_sigmask |= mask &~ sigcantmask;
        !           236:                        break;
        !           237:                case HPUXSIG_UNBLOCK:
        !           238:                        p->p_sigmask &= ~mask;
        !           239:                        break;
        !           240:                case HPUXSIG_SETMASK:
        !           241:                        p->p_sigmask = mask &~ sigcantmask;
        !           242:                        break;
        !           243:                default:
        !           244:                        error = EINVAL;
        !           245:                        break;
        !           246:                }
        !           247:                (void) spl0();
        !           248:        }
        !           249:        return (error);
        !           250: }
        !           251:
        !           252: int
        !           253: hpux_sys_sigpending(p, v, retval)
        !           254:        struct proc *p;
        !           255:        void *v;
        !           256:        register_t *retval;
        !           257: {
        !           258:        struct hpux_sys_sigpending_args *uap = v;
        !           259:        hpux_sigset_t sigset;
        !           260:
        !           261:        sigset.sigset[0] = bsdtohpuxmask(p->p_siglist);
        !           262:        return (copyout((caddr_t)&sigset, (caddr_t)SCARG(uap, set),
        !           263:            sizeof(sigset)));
        !           264: }
        !           265:
        !           266: int
        !           267: hpux_sys_sigsuspend(p, v, retval)
        !           268:        struct proc *p;
        !           269:        void *v;
        !           270:        register_t *retval;
        !           271: {
        !           272:        struct hpux_sys_sigsuspend_args *uap = v;
        !           273:        struct sigacts *ps = p->p_sigacts;
        !           274:        hpux_sigset_t sigset;
        !           275:        int mask;
        !           276:
        !           277:        if (copyin((caddr_t)SCARG(uap, set), (caddr_t)&sigset, sizeof(sigset)))
        !           278:                return (EFAULT);
        !           279:        mask = hpuxtobsdmask(sigset.sigset[0]);
        !           280:        ps->ps_oldmask = p->p_sigmask;
        !           281:        ps->ps_flags |= SAS_OLDMASK;
        !           282:        p->p_sigmask = mask &~ sigcantmask;
        !           283:        (void) tsleep((caddr_t)ps, PPAUSE | PCATCH, "pause", 0);
        !           284:        /* always return EINTR rather than ERESTART... */
        !           285:        return (EINTR);
        !           286: }
        !           287:
        !           288: int
        !           289: hpux_sys_sigaction(p, v, retval)
        !           290:        struct proc *p;
        !           291:        void *v;
        !           292:        register_t *retval;
        !           293: {
        !           294:        struct hpux_sys_sigaction_args *uap = v;
        !           295:        struct hpux_sigaction action;
        !           296:        struct sigacts *ps = p->p_sigacts;
        !           297:        struct hpux_sigaction *sa;
        !           298:        int sig;
        !           299:        int bit;
        !           300:
        !           301:        sig = hpuxtobsdsig(SCARG(uap, signo));
        !           302:        if (sig <= 0 || sig >= NSIG || sig == SIGKILL || sig == SIGSTOP)
        !           303:                return (EINVAL);
        !           304:
        !           305:        sa = &action;
        !           306:        if (SCARG(uap, osa)) {
        !           307:                sa->sa__handler = ps->ps_sigact[sig];
        !           308:                bzero((caddr_t)&sa->sa_mask, sizeof(sa->sa_mask));
        !           309:                sa->sa_mask.sigset[0] = bsdtohpuxmask(ps->ps_catchmask[sig]);
        !           310:                bit = sigmask(sig);
        !           311:                sa->sa_flags = 0;
        !           312:                if ((ps->ps_sigonstack & bit) != 0)
        !           313:                        sa->sa_flags |= HPUXSA_ONSTACK;
        !           314:                if ((ps->ps_sigreset & bit) != 0)
        !           315:                        sa->sa_flags |= HPUXSA_RESETHAND;
        !           316:                if (p->p_flag & P_NOCLDSTOP)
        !           317:                        sa->sa_flags |= HPUXSA_NOCLDSTOP;
        !           318:                if (p->p_flag & P_NOCLDWAIT)
        !           319:                        sa->sa_flags |= HPUXSA_NOCLDWAIT;
        !           320:                if (copyout((caddr_t)sa, (caddr_t)SCARG(uap, osa),
        !           321:                    sizeof (action)))
        !           322:                        return (EFAULT);
        !           323:        }
        !           324:        if (SCARG(uap, nsa)) {
        !           325:                struct sigaction act;
        !           326:
        !           327:                if (copyin((caddr_t)SCARG(uap, nsa), (caddr_t)sa,
        !           328:                    sizeof (action)))
        !           329:                        return (EFAULT);
        !           330:                if (sig == SIGCONT && sa->sa__handler == SIG_IGN)
        !           331:                        return (EINVAL);
        !           332:                /*
        !           333:                 * Create a sigaction struct for setsigvec
        !           334:                 */
        !           335:                act.sa_handler = sa->sa__handler;
        !           336:                act.sa_mask = hpuxtobsdmask(sa->sa_mask.sigset[0]);
        !           337:                act.sa_flags = SA_RESTART;
        !           338:                if (sa->sa_flags & HPUXSA_ONSTACK)
        !           339:                        act.sa_flags |= SA_ONSTACK;
        !           340:                if (sa->sa_flags & HPUXSA_NOCLDSTOP)
        !           341:                        act.sa_flags |= SA_NOCLDSTOP;
        !           342:                if (sa->sa_flags & HPUXSA_NOCLDWAIT)
        !           343:                        act.sa_flags |= SA_NOCLDWAIT;
        !           344:                setsigvec(p, sig, &act);
        !           345: #if 0
        !           346: /* XXX -- SOUSIG no longer exists, do something here */
        !           347:                if (sa->sa_flags & HPUXSA_RESETHAND)
        !           348:                        p->p_flag |= SOUSIG;            /* XXX */
        !           349: #endif
        !           350:        }
        !           351:        return (0);
        !           352: }
        !           353:
        !           354: /* signal numbers: convert from HPUX to BSD */
        !           355: int
        !           356: hpuxtobsdsig(sig)
        !           357:        int sig;
        !           358: {
        !           359:        if (--sig < 0 || sig >= NSIG)
        !           360:                return(0);
        !           361:        return((int)hpuxtobsdsigmap[sig]);
        !           362: }
        !           363:
        !           364: /* signal numbers: convert from BSD to HPUX */
        !           365: int
        !           366: bsdtohpuxsig(sig)
        !           367:        int sig;
        !           368: {
        !           369:        if (--sig < 0 || sig >= NSIG)
        !           370:                return(0);
        !           371:        return((int)bsdtohpuxsigmap[sig]);
        !           372: }
        !           373:
        !           374: /* signal masks: convert from HPUX to BSD (not pretty or fast) */
        !           375: int
        !           376: hpuxtobsdmask(mask)
        !           377:        int mask;
        !           378: {
        !           379:        int nmask, sig, nsig;
        !           380:
        !           381:        if (mask == 0 || mask == -1)
        !           382:                return(mask);
        !           383:        nmask = 0;
        !           384:        for (sig = 1; sig < NSIG; sig++)
        !           385:                if ((mask & sigmask(sig)) && (nsig = hpuxtobsdsig(sig)))
        !           386:                        nmask |= sigmask(nsig);
        !           387:        return(nmask);
        !           388: }
        !           389:
        !           390: int
        !           391: bsdtohpuxmask(mask)
        !           392:        int mask;
        !           393: {
        !           394:        int nmask, sig, nsig;
        !           395:
        !           396:        if (mask == 0 || mask == -1)
        !           397:                return(mask);
        !           398:        nmask = 0;
        !           399:        for (sig = 1; sig < NSIG; sig++)
        !           400:                if ((mask & sigmask(sig)) && (nsig = bsdtohpuxsig(sig)))
        !           401:                        nmask |= sigmask(nsig);
        !           402:        return(nmask);
        !           403: }

CVSweb