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