Home | History | Annotate | Line # | Download | only in include
signal.h revision 1.10
      1  1.10      agc /*      $NetBSD: signal.h,v 1.10 2003/08/07 16:30:12 agc Exp $   */
      2   1.2      cgd 
      3   1.1    ragge /*
      4   1.3    ragge  * Copyright (c) 1982, 1986, 1989, 1991 Regents of the University of California.
      5   1.1    ragge  * All rights reserved.
      6   1.1    ragge  *
      7   1.1    ragge  * Redistribution and use in source and binary forms, with or without
      8   1.1    ragge  * modification, are permitted provided that the following conditions
      9   1.1    ragge  * are met:
     10   1.1    ragge  * 1. Redistributions of source code must retain the above copyright
     11   1.1    ragge  *    notice, this list of conditions and the following disclaimer.
     12   1.1    ragge  * 2. Redistributions in binary form must reproduce the above copyright
     13   1.1    ragge  *    notice, this list of conditions and the following disclaimer in the
     14   1.1    ragge  *    documentation and/or other materials provided with the distribution.
     15  1.10      agc  * 3. Neither the name of the University nor the names of its contributors
     16   1.3    ragge  *    may be used to endorse or promote products derived from this software
     17   1.3    ragge  *    without specific prior written permission.
     18   1.1    ragge  *
     19   1.3    ragge  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20   1.3    ragge  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21   1.3    ragge  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22   1.3    ragge  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23   1.3    ragge  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24   1.3    ragge  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25   1.3    ragge  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26   1.3    ragge  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27   1.3    ragge  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28   1.3    ragge  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29   1.3    ragge  * SUCH DAMAGE.
     30   1.3    ragge  *
     31   1.3    ragge  *	@(#)signal.h	7.16 (Berkeley) 3/17/91
     32   1.1    ragge  */
     33   1.1    ragge 
     34   1.1    ragge  /* All bugs are subject to removal without further notice */
     35   1.1    ragge 
     36   1.4      jtc #ifndef _VAX_SIGNAL_H_
     37   1.4      jtc #define _VAX_SIGNAL_H_
     38   1.4      jtc 
     39   1.9    bjh21 #include <sys/featuretest.h>
     40   1.9    bjh21 
     41   1.4      jtc typedef int sig_atomic_t;
     42   1.4      jtc 
     43   1.9    bjh21 #if defined(_NETBSD_SOURCE)
     44   1.3    ragge /*
     45   1.3    ragge  * Information pushed on stack when a signal is delivered.
     46   1.3    ragge  * This is used by the kernel to restore state following
     47   1.3    ragge  * execution of the signal handler.  It is also made available
     48   1.3    ragge  * to the handler to allow it to restore state properly if
     49   1.3    ragge  * a non-standard exit is performed.
     50   1.3    ragge  */
     51   1.7    ragge #if defined(__LIBC12_SOURCE__) || defined(_KERNEL)
     52   1.6  thorpej struct sigcontext13 {
     53   1.3    ragge 	int	sc_onstack;		/* sigstack state to restore */
     54   1.6  thorpej 	int	sc_mask;		/* signal mask to restore (old style) */
     55   1.3    ragge 	int	sc_sp;			/* sp to restore */
     56   1.3    ragge 	int	sc_fp;			/* fp to restore */
     57   1.3    ragge 	int	sc_ap;			/* ap to restore */
     58   1.3    ragge 	int	sc_pc;			/* pc to restore */
     59   1.3    ragge 	int	sc_ps;			/* psl to restore */
     60   1.6  thorpej };
     61   1.6  thorpej #endif /* __LIBC12_SOURCE__ || _KERNEL */
     62   1.6  thorpej 
     63   1.6  thorpej struct sigcontext {
     64   1.6  thorpej 	int	sc_onstack;		/* sigstack state to restore */
     65   1.6  thorpej 	int	__sc_mask13;		/* signal mask to restore (old style) */
     66   1.6  thorpej 	int	sc_sp;			/* sp to restore */
     67   1.6  thorpej 	int	sc_fp;			/* fp to restore */
     68   1.6  thorpej 	int	sc_ap;			/* ap to restore */
     69   1.6  thorpej 	int	sc_pc;			/* pc to restore */
     70   1.6  thorpej 	int	sc_ps;			/* psl to restore */
     71   1.6  thorpej 	sigset_t sc_mask;		/* signal mask to restore (new style) */
     72   1.3    ragge };
     73   1.8  thorpej 
     74   1.8  thorpej /*
     75   1.8  thorpej  * The following macros are used to convert from a ucontext to sigcontext,
     76   1.8  thorpej  * and vice-versa.  This is for building a sigcontext to deliver to old-style
     77   1.8  thorpej  * signal handlers, and converting back (in the event the handler modifies
     78   1.8  thorpej  * the context).
     79   1.8  thorpej  */
     80   1.8  thorpej #define	_MCONTEXT_TO_SIGCONTEXT(uc, sc)					\
     81   1.8  thorpej do {									\
     82   1.8  thorpej 	(sc)->sc_sp = (uc)->uc_mcontext.__gregs[_REG_SP];		\
     83   1.8  thorpej 	(sc)->sc_fp = (uc)->uc_mcontext.__gregs[_REG_FP];		\
     84   1.8  thorpej 	(sc)->sc_ap = (uc)->uc_mcontext.__gregs[_REG_AP];		\
     85   1.8  thorpej 	(sc)->sc_pc = (uc)->uc_mcontext.__gregs[_REG_PC];		\
     86   1.8  thorpej 	(sc)->sc_ps = (uc)->uc_mcontext.__gregs[_REG_PSL];		\
     87   1.8  thorpej } while (/*CONSTCOND*/0)
     88   1.8  thorpej 
     89   1.8  thorpej #define	_SIGCONTEXT_TO_MCONTEXT(sc, uc)					\
     90   1.8  thorpej do {									\
     91   1.8  thorpej 	(uc)->uc_mcontext.__gregs[_REG_SP]  = (sc)->sc_sp;		\
     92   1.8  thorpej 	(uc)->uc_mcontext.__gregs[_REG_FP]  = (sc)->sc_fp;		\
     93   1.8  thorpej 	(uc)->uc_mcontext.__gregs[_REG_AP]  = (sc)->sc_ap;		\
     94   1.8  thorpej 	(uc)->uc_mcontext.__gregs[_REG_PC]  = (sc)->sc_pc;		\
     95   1.8  thorpej 	(uc)->uc_mcontext.__gregs[_REG_PSL] = (sc)->sc_ps;		\
     96   1.8  thorpej } while (/*CONSTCOND*/0)
     97   1.4      jtc 
     98   1.9    bjh21 #endif	/* _NETBSD_SOURCE */
     99   1.4      jtc #endif	/* !_VAX_SIGNAL_H_ */
    100