kernel tree reorganization stage 1: Major cvs repository work (not logged as
[dragonfly.git] / sys / i386 / include / signal.h
1 /*
2  * Copyright (c) 1986, 1989, 1991, 1993
3  *      The Regents of the University of California.  All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  * 3. All advertising materials mentioning features or use of this software
14  *    must display the following acknowledgement:
15  *      This product includes software developed by the University of
16  *      California, Berkeley and its contributors.
17  * 4. Neither the name of the University nor the names of its contributors
18  *    may be used to endorse or promote products derived from this software
19  *    without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31  * SUCH DAMAGE.
32  *
33  *      @(#)signal.h    8.1 (Berkeley) 6/11/93
34  * $FreeBSD: src/sys/i386/include/signal.h,v 1.12 1999/11/12 13:52:11 marcel Exp $
35  * $DragonFly: src/sys/i386/include/Attic/signal.h,v 1.3 2003/08/07 21:17:22 dillon Exp $
36  */
37
38 #ifndef _MACHINE_SIGNAL_H_
39 #define _MACHINE_SIGNAL_H_
40
41 /*
42  * Machine-dependent signal definitions
43  */
44
45 typedef int sig_atomic_t;
46
47 #if !defined(_ANSI_SOURCE) && !defined(_POSIX_SOURCE)
48
49 #include "trap.h"       /* codes for SIGILL, SIGFPE */
50
51 /*
52  * Information pushed on stack when a signal is delivered.
53  * This is used by the kernel to restore state following
54  * execution of the signal handler.  It is also made available
55  * to the handler to allow it to restore state properly if
56  * a non-standard exit is performed.
57  */
58 typedef unsigned int osigset_t;
59
60 struct  osigcontext {
61         int     sc_onstack;             /* sigstack state to restore */
62         osigset_t sc_mask;              /* signal mask to restore */
63         int     sc_esp;                 /* machine state follows: */
64         int     sc_ebp;
65         int     sc_isp;
66         int     sc_eip;
67         int     sc_efl;
68         int     sc_es;
69         int     sc_ds;
70         int     sc_cs;
71         int     sc_ss;
72         int     sc_edi;
73         int     sc_esi;
74         int     sc_ebx;
75         int     sc_edx;
76         int     sc_ecx;
77         int     sc_eax;
78         int     sc_gs;
79         int     sc_fs;
80         int     sc_trapno;
81         int     sc_err;
82 };
83
84 /*
85  * The sequence of the fields/registers in struct sigcontext should match
86  * those in mcontext_t.
87  */
88 struct  sigcontext {
89         sigset_t sc_mask;               /* signal mask to restore */
90         int     sc_onstack;             /* sigstack state to restore */
91         int     sc_gs;                  /* machine state (struct trapframe): */
92         int     sc_fs;
93         int     sc_es;
94         int     sc_ds;
95         int     sc_edi;
96         int     sc_esi;
97         int     sc_ebp;
98         int     sc_isp;
99         int     sc_ebx;
100         int     sc_edx;
101         int     sc_ecx;
102         int     sc_eax;
103         int     sc_trapno;
104         int     sc_err;
105         int     sc_eip;
106         int     sc_cs;
107         int     sc_efl;
108         int     sc_esp;
109         int     sc_ss;
110         /*
111          * XXX FPU state is 27 * 4 bytes h/w, 1 * 4 bytes s/w (probably not
112          * needed here), or that + 16 * 4 bytes for emulators (probably all
113          * needed here).  The "spare" bytes are mostly not spare.
114          */
115         int     sc_fpregs[28];          /* machine state (FPU): */
116         int     sc_spare[17];
117 };
118
119 #define sc_sp           sc_esp
120 #define sc_fp           sc_ebp
121 #define sc_pc           sc_eip
122 #define sc_ps           sc_efl
123 #define sc_eflags       sc_efl
124
125 #endif /* !_ANSI_SOURCE && !_POSIX_SOURCE */
126
127 #endif /* !_MACHINE_SIGNAL_H_ */