signal.h revision 1.12 1 1.12 bjh21 /* $NetBSD: signal.h,v 1.12 2003/04/28 23:16:22 bjh21 Exp $ */
2 1.1 ws
3 1.1 ws /*
4 1.1 ws * Copyright (C) 1995, 1996 Wolfgang Solfrank.
5 1.1 ws * Copyright (C) 1995, 1996 TooLs GmbH.
6 1.1 ws * All rights reserved.
7 1.1 ws *
8 1.1 ws * Redistribution and use in source and binary forms, with or without
9 1.1 ws * modification, are permitted provided that the following conditions
10 1.1 ws * are met:
11 1.1 ws * 1. Redistributions of source code must retain the above copyright
12 1.1 ws * notice, this list of conditions and the following disclaimer.
13 1.1 ws * 2. Redistributions in binary form must reproduce the above copyright
14 1.1 ws * notice, this list of conditions and the following disclaimer in the
15 1.1 ws * documentation and/or other materials provided with the distribution.
16 1.1 ws * 3. All advertising materials mentioning features or use of this software
17 1.1 ws * must display the following acknowledgement:
18 1.1 ws * This product includes software developed by TooLs GmbH.
19 1.1 ws * 4. The name of TooLs GmbH may not be used to endorse or promote products
20 1.1 ws * derived from this software without specific prior written permission.
21 1.1 ws *
22 1.1 ws * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
23 1.1 ws * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
24 1.1 ws * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
25 1.1 ws * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 1.1 ws * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
27 1.1 ws * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
28 1.1 ws * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
29 1.1 ws * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
30 1.1 ws * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
31 1.1 ws * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 1.1 ws */
33 1.6 matt #ifndef _POWERPC_SIGNAL_H_
34 1.6 matt #define _POWERPC_SIGNAL_H_
35 1.1 ws
36 1.12 bjh21 #include <sys/featuretest.h>
37 1.12 bjh21
38 1.2 kleink typedef int sig_atomic_t;
39 1.2 kleink
40 1.12 bjh21 #if defined(_NETBSD_SOURCE)
41 1.1 ws #include <machine/frame.h>
42 1.1 ws
43 1.3 thorpej #if defined(__LIBC12_SOURCE__) || defined(_KERNEL)
44 1.3 thorpej struct sigcontext13 {
45 1.3 thorpej int sc_onstack; /* saved onstack flag */
46 1.4 thorpej int sc_mask; /* saved signal mask (old style) */
47 1.10 matt struct utrapframe sc_frame; /* saved registers */
48 1.3 thorpej };
49 1.3 thorpej #endif /* __LIBC12_SOURCE__ || _KERNEL */
50 1.3 thorpej
51 1.1 ws struct sigcontext {
52 1.1 ws int sc_onstack; /* saved onstack flag */
53 1.4 thorpej int __sc_mask13; /* saved signal mask (old style) */
54 1.10 matt struct utrapframe sc_frame; /* saved registers */
55 1.3 thorpej sigset_t sc_mask; /* saved signal mask (new style) */
56 1.1 ws };
57 1.7 thorpej
58 1.7 thorpej /*
59 1.7 thorpej * The following macros are used to convert from a ucontext to sigcontext,
60 1.7 thorpej * and vice-versa. This is for building a sigcontext to deliver to old-style
61 1.7 thorpej * signal handlers, and converting back (in the event the handler modifies
62 1.7 thorpej * the context).
63 1.7 thorpej */
64 1.7 thorpej #define _MCONTEXT_TO_SIGCONTEXT(uc, sc) \
65 1.7 thorpej do { \
66 1.9 matt memcpy((sc)->sc_frame.fixreg, &(uc)->uc_mcontext.__gregs[_REG_R0], \
67 1.7 thorpej sizeof((sc)->sc_frame.fixreg)); \
68 1.9 matt (sc)->sc_frame.cr = (uc)->uc_mcontext.__gregs[_REG_CR]; \
69 1.9 matt (sc)->sc_frame.lr = (uc)->uc_mcontext.__gregs[_REG_LR]; \
70 1.9 matt (sc)->sc_frame.srr0 = (uc)->uc_mcontext.__gregs[_REG_PC]; \
71 1.9 matt (sc)->sc_frame.srr1 = (uc)->uc_mcontext.__gregs[_REG_MSR]; \
72 1.9 matt (sc)->sc_frame.ctr = (uc)->uc_mcontext.__gregs[_REG_CTR]; \
73 1.9 matt (sc)->sc_frame.xer = (uc)->uc_mcontext.__gregs[_REG_XER]; \
74 1.11 matt (sc)->sc_frame.mq = (uc)->uc_mcontext.__gregs[_REG_MQ]; \
75 1.7 thorpej (sc)->sc_frame.vrsave = (uc)->uc_mcontext.__vrf.__vrsave; \
76 1.10 matt (sc)->sc_frame.spare = 0; \
77 1.7 thorpej } while (/*CONSTCOND*/0)
78 1.7 thorpej
79 1.7 thorpej #define _SIGCONTEXT_TO_MCONTEXT(sc, uc) \
80 1.7 thorpej do { \
81 1.9 matt memcpy(&(uc)->uc_mcontext.__gregs[_REG_R0], (sc)->sc_frame.fixreg, \
82 1.7 thorpej sizeof((sc)->sc_frame.fixreg)); \
83 1.9 matt (uc)->uc_mcontext.__gregs[_REG_CR] = (sc)->sc_frame.cr; \
84 1.9 matt (uc)->uc_mcontext.__gregs[_REG_LR] = (sc)->sc_frame.lr; \
85 1.9 matt (uc)->uc_mcontext.__gregs[_REG_PC] = (sc)->sc_frame.srr0; \
86 1.9 matt (uc)->uc_mcontext.__gregs[_REG_MSR] = (sc)->sc_frame.srr1; \
87 1.9 matt (uc)->uc_mcontext.__gregs[_REG_CTR] = (sc)->sc_frame.ctr; \
88 1.9 matt (uc)->uc_mcontext.__gregs[_REG_XER] = (sc)->sc_frame.xer; \
89 1.10 matt (uc)->uc_mcontext.__gregs[_REG_MQ] = (sc)->sc_frame.mq; \
90 1.7 thorpej (uc)->uc_mcontext.__vrf.__vrsave = (sc)->sc_frame.vrsave; \
91 1.7 thorpej } while (/*CONSTCOND*/0)
92 1.1 ws
93 1.1 ws struct sigframe {
94 1.1 ws struct sigcontext sf_sc;
95 1.1 ws };
96 1.10 matt
97 1.12 bjh21 #endif /* _NETBSD_SOURCE */
98 1.6 matt #endif /* !_POWERPC_SIGNAL_H_ */
99