1 /*	$NetBSD: signal.h,v 1.13 2014/01/29 00:42:15 matt Exp $	*/
2 
3 /*
4  * Copyright (c) 1994-1996 Mark Brinicombe.
5  * Copyright (c) 1994 Brini.
6  * All rights reserved.
7  *
8  * This code is derived from software written for Brini by Mark Brinicombe
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
13  * 1. Redistributions of source code must retain the above copyright
14  *    notice, this list of conditions and the following disclaimer.
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in the
17  *    documentation and/or other materials provided with the distribution.
18  * 3. All advertising materials mentioning features or use of this software
19  *    must display the following acknowledgement:
20  *	This product includes software developed by Brini.
21  * 4. The name of the company nor the name of the author may be used to
22  *    endorse or promote products derived from this software without specific
23  *    prior written permission.
24  *
25  * THIS SOFTWARE IS PROVIDED BY BRINI ``AS IS'' AND ANY EXPRESS OR IMPLIED
26  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
27  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
28  * IN NO EVENT SHALL BRINI OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
29  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
30  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
31  * 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  * RiscBSD kernel project
38  *
39  * signal.h
40  *
41  * Architecture dependent signal types and structures
42  *
43  * Created      : 30/09/94
44  */
45 
46 #ifndef _ARM_SIGNAL_H_
47 #define _ARM_SIGNAL_H_
48 
49 #include <sys/featuretest.h>
50 
51 #ifndef _LOCORE
52 typedef int sig_atomic_t;
53 #endif
54 
55 #if defined(_NETBSD_SOURCE)
56 
57 #ifndef _LOCORE
58 /*
59  * Information pushed on stack when a signal is delivered.
60  * This is used by the kernel to restore state following
61  * execution of the signal handler.  It is also made available
62  * to the handler to allow it to restore state properly if
63  * a non-standard exit is performed.
64  */
65 
66 #if defined(__LIBC12_SOURCE__) || defined(_KERNEL)
67 struct sigcontext13 {
68 	int	sc_onstack;		/* sigstack state to restore */
69 	int	sc_mask;		/* signal mask to restore (old style) */
70 
71 	unsigned int sc_spsr;
72 	unsigned int sc_r0;
73 	unsigned int sc_r1;
74 	unsigned int sc_r2;
75 	unsigned int sc_r3;
76 	unsigned int sc_r4;
77 	unsigned int sc_r5;
78 	unsigned int sc_r6;
79 	unsigned int sc_r7;
80 	unsigned int sc_r8;
81 	unsigned int sc_r9;
82 	unsigned int sc_r10;
83 	unsigned int sc_r11;
84 	unsigned int sc_r12;
85 	unsigned int sc_usr_sp;
86 	unsigned int sc_usr_lr;
87 	unsigned int sc_svc_lr;
88 	unsigned int sc_pc;
89 };
90 #endif /* __LIBC12_SOURCE__ || _KERNEL */
91 
92 struct sigcontext {
93 	int	sc_onstack;		/* sigstack state to restore */
94 	int	__sc_mask13;		/* signal mask to restore (old style) */
95 
96 	unsigned int sc_spsr;
97 	unsigned int sc_r0;
98 	unsigned int sc_r1;
99 	unsigned int sc_r2;
100 	unsigned int sc_r3;
101 	unsigned int sc_r4;
102 	unsigned int sc_r5;
103 	unsigned int sc_r6;
104 	unsigned int sc_r7;
105 	unsigned int sc_r8;
106 	unsigned int sc_r9;
107 	unsigned int sc_r10;
108 	unsigned int sc_r11;
109 	unsigned int sc_r12;
110 	unsigned int sc_usr_sp;
111 	unsigned int sc_usr_lr;
112 	unsigned int sc_svc_lr;
113 	unsigned int sc_pc;
114 
115 	sigset_t sc_mask;		/* signal mask to restore (new style) */
116 };
117 
118 #endif /* !_LOCORE */
119 
120 /* Signals codes */
121 
122 /*
123  * SIGFPE codes
124  *
125  * see ieeefp.h for definition of FP exception codes
126  */
127 
128 #define SIG_CODE_FPE_CODE_MASK	0x00000f00	/* Mask for exception code */
129 #define SIG_CODE_FPE_CODE_SHIFT	8		/* Shift for exception code */
130 #define SIG_CODE_FPE_TYPE_MASK	0x000000ff	/* Mask for specific code */
131 
132 /*
133  * SIGILL codes
134  *
135  * the signal code is the instruction that raised the signal
136  */
137 
138 /*
139  * SIGBUS and SIGSEGV codes
140  *
141  * The signal code is combination of the fault address and the fault code.
142  *
143  * The fault code is the coproc #15 fault status code
144  *
145  * The exception to this is a SIGBUS or SIGSEGV from a prefetch abort.
146  * In this case the fault status code is not valid so the TYPE_MASK
147  * should be treated as undefined (in practice it is the bottom 4 bits
148  * of the fault address).
149  */
150 
151 #define SIG_CODE_BUS_ADDR_MASK	0xfffffff0
152 #define SIG_CODE_BUS_TYPE_MASK	0x0000000f
153 #define SIG_CODE_SEGV_ADDR_MASK	SIG_CODE_BUS_ADDR_MASK
154 #define SIG_CODE_SEGV_TYPE_MASK	SIG_CODE_BUS_TYPE_MASK
155 
156 #endif	/* _NETBSD_SOURCE */
157 #endif	/* !_ARM_SIGNAL_H_ */
158 
159 /* End of signal.h */
160