master
1/*-
2 * SPDX-License-Identifier: BSD-3-Clause
3 *
4 * Copyright (c) 2003 Peter Wemm
5 * Copyright (c) 1999 Marcel Moolenaar
6 * All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer
13 * in this position and unchanged.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3. The name of the author may not be used to endorse or promote products
18 * derived from this software without specific prior written permission.
19 *
20 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
21 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
22 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
23 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
24 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
29 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32#ifndef _X86_UCONTEXT_H_
33#define _X86_UCONTEXT_H_
34
35#ifdef __i386__
36/* Keep _MC_* values similar to amd64 */
37#define _MC_HASSEGS 0x1
38#define _MC_HASBASES 0x2
39#define _MC_HASFPXSTATE 0x4
40#define _MC_FLAG_MASK (_MC_HASSEGS | _MC_HASBASES | _MC_HASFPXSTATE)
41
42typedef struct __mcontext {
43 /*
44 * The definition of mcontext_t must match the layout of
45 * struct sigcontext after the sc_mask member. This is so
46 * that we can support sigcontext and ucontext_t at the same
47 * time.
48 */
49 __register_t mc_onstack; /* XXX - sigcontext compat. */
50 __register_t mc_gs; /* machine state (struct trapframe) */
51 __register_t mc_fs;
52 __register_t mc_es;
53 __register_t mc_ds;
54 __register_t mc_edi;
55 __register_t mc_esi;
56 __register_t mc_ebp;
57 __register_t mc_isp;
58 __register_t mc_ebx;
59 __register_t mc_edx;
60 __register_t mc_ecx;
61 __register_t mc_eax;
62 __register_t mc_trapno;
63 __register_t mc_err;
64 __register_t mc_eip;
65 __register_t mc_cs;
66 __register_t mc_eflags;
67 __register_t mc_esp;
68 __register_t mc_ss;
69
70 int mc_len; /* sizeof(mcontext_t) */
71#define _MC_FPFMT_NODEV 0x10000 /* device not present or configured */
72#define _MC_FPFMT_387 0x10001
73#define _MC_FPFMT_XMM 0x10002
74 int mc_fpformat;
75#define _MC_FPOWNED_NONE 0x20000 /* FP state not used */
76#define _MC_FPOWNED_FPU 0x20001 /* FP state came from FPU */
77#define _MC_FPOWNED_PCB 0x20002 /* FP state came from PCB */
78 int mc_ownedfp;
79 __register_t mc_flags;
80 /*
81 * See <machine/npx.h> for the internals of mc_fpstate[].
82 */
83 int mc_fpstate[128] __aligned(16);
84
85 __register_t mc_fsbase;
86 __register_t mc_gsbase;
87
88 __register_t mc_xfpustate;
89 __register_t mc_xfpustate_len;
90
91 int mc_spare2[4];
92} mcontext_t;
93#endif /* __i386__ */
94
95#ifdef __amd64__
96/*
97 * mc_flags bits. Shall be in sync with TF_XXX.
98 */
99#define _MC_HASSEGS 0x1
100#define _MC_HASBASES 0x2
101#define _MC_HASFPXSTATE 0x4
102#define _MC_FLAG_MASK (_MC_HASSEGS | _MC_HASBASES | _MC_HASFPXSTATE)
103
104typedef struct __mcontext {
105 /*
106 * The definition of mcontext_t must match the layout of
107 * struct sigcontext after the sc_mask member. This is so
108 * that we can support sigcontext and ucontext_t at the same
109 * time.
110 */
111 __register_t mc_onstack; /* XXX - sigcontext compat. */
112 __register_t mc_rdi; /* machine state (struct trapframe) */
113 __register_t mc_rsi;
114 __register_t mc_rdx;
115 __register_t mc_rcx;
116 __register_t mc_r8;
117 __register_t mc_r9;
118 __register_t mc_rax;
119 __register_t mc_rbx;
120 __register_t mc_rbp;
121 __register_t mc_r10;
122 __register_t mc_r11;
123 __register_t mc_r12;
124 __register_t mc_r13;
125 __register_t mc_r14;
126 __register_t mc_r15;
127 __uint32_t mc_trapno;
128 __uint16_t mc_fs;
129 __uint16_t mc_gs;
130 __register_t mc_addr;
131 __uint32_t mc_flags;
132 __uint16_t mc_es;
133 __uint16_t mc_ds;
134 __register_t mc_err;
135 __register_t mc_rip;
136 __register_t mc_cs;
137 __register_t mc_rflags;
138 __register_t mc_rsp;
139 __register_t mc_ss;
140
141 long mc_len; /* sizeof(mcontext_t) */
142
143#define _MC_FPFMT_NODEV 0x10000 /* device not present or configured */
144#define _MC_FPFMT_XMM 0x10002
145 long mc_fpformat;
146#define _MC_FPOWNED_NONE 0x20000 /* FP state not used */
147#define _MC_FPOWNED_FPU 0x20001 /* FP state came from FPU */
148#define _MC_FPOWNED_PCB 0x20002 /* FP state came from PCB */
149 long mc_ownedfp;
150 /*
151 * See <machine/fpu.h> for the internals of mc_fpstate[].
152 */
153 long mc_fpstate[64] __aligned(16);
154
155 __register_t mc_fsbase;
156 __register_t mc_gsbase;
157
158 __register_t mc_xfpustate;
159 __register_t mc_xfpustate_len;
160
161 long mc_spare[4];
162} mcontext_t;
163#endif /* __amd64__ */
164
165#endif /* !_X86_UCONTEXT_H_ */