131a53cd0SKonstantin Belousov /*- 2ebf5747bSPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause 3ebf5747bSPedro F. Giffuni * 431a53cd0SKonstantin Belousov * Copyright (c) 2003 Peter Wemm 531a53cd0SKonstantin Belousov * Copyright (c) 1999 Marcel Moolenaar 631a53cd0SKonstantin Belousov * All rights reserved. 731a53cd0SKonstantin Belousov * 831a53cd0SKonstantin Belousov * Redistribution and use in source and binary forms, with or without 931a53cd0SKonstantin Belousov * modification, are permitted provided that the following conditions 1031a53cd0SKonstantin Belousov * are met: 1131a53cd0SKonstantin Belousov * 1. Redistributions of source code must retain the above copyright 1231a53cd0SKonstantin Belousov * notice, this list of conditions and the following disclaimer 1331a53cd0SKonstantin Belousov * in this position and unchanged. 1431a53cd0SKonstantin Belousov * 2. Redistributions in binary form must reproduce the above copyright 1531a53cd0SKonstantin Belousov * notice, this list of conditions and the following disclaimer in the 1631a53cd0SKonstantin Belousov * documentation and/or other materials provided with the distribution. 1731a53cd0SKonstantin Belousov * 3. The name of the author may not be used to endorse or promote products 1831a53cd0SKonstantin Belousov * derived from this software without specific prior written permission. 1931a53cd0SKonstantin Belousov * 2031a53cd0SKonstantin Belousov * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 2131a53cd0SKonstantin Belousov * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 2231a53cd0SKonstantin Belousov * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 2331a53cd0SKonstantin Belousov * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 2431a53cd0SKonstantin Belousov * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 2531a53cd0SKonstantin Belousov * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 2631a53cd0SKonstantin Belousov * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 2731a53cd0SKonstantin Belousov * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 2831a53cd0SKonstantin Belousov * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 2931a53cd0SKonstantin Belousov * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 3031a53cd0SKonstantin Belousov * 3131a53cd0SKonstantin Belousov * $FreeBSD$ 3231a53cd0SKonstantin Belousov */ 3331a53cd0SKonstantin Belousov 3431a53cd0SKonstantin Belousov #ifndef _X86_UCONTEXT_H_ 3531a53cd0SKonstantin Belousov #define _X86_UCONTEXT_H_ 3631a53cd0SKonstantin Belousov 3731a53cd0SKonstantin Belousov #ifdef __i386__ 3831a53cd0SKonstantin Belousov /* Keep _MC_* values similar to amd64 */ 3931a53cd0SKonstantin Belousov #define _MC_HASSEGS 0x1 4031a53cd0SKonstantin Belousov #define _MC_HASBASES 0x2 4131a53cd0SKonstantin Belousov #define _MC_HASFPXSTATE 0x4 4231a53cd0SKonstantin Belousov #define _MC_FLAG_MASK (_MC_HASSEGS | _MC_HASBASES | _MC_HASFPXSTATE) 4331a53cd0SKonstantin Belousov 4431a53cd0SKonstantin Belousov typedef struct __mcontext { 4531a53cd0SKonstantin Belousov /* 4631a53cd0SKonstantin Belousov * The definition of mcontext_t must match the layout of 4731a53cd0SKonstantin Belousov * struct sigcontext after the sc_mask member. This is so 4831a53cd0SKonstantin Belousov * that we can support sigcontext and ucontext_t at the same 4931a53cd0SKonstantin Belousov * time. 5031a53cd0SKonstantin Belousov */ 5131a53cd0SKonstantin Belousov __register_t mc_onstack; /* XXX - sigcontext compat. */ 5231a53cd0SKonstantin Belousov __register_t mc_gs; /* machine state (struct trapframe) */ 5331a53cd0SKonstantin Belousov __register_t mc_fs; 5431a53cd0SKonstantin Belousov __register_t mc_es; 5531a53cd0SKonstantin Belousov __register_t mc_ds; 5631a53cd0SKonstantin Belousov __register_t mc_edi; 5731a53cd0SKonstantin Belousov __register_t mc_esi; 5831a53cd0SKonstantin Belousov __register_t mc_ebp; 5931a53cd0SKonstantin Belousov __register_t mc_isp; 6031a53cd0SKonstantin Belousov __register_t mc_ebx; 6131a53cd0SKonstantin Belousov __register_t mc_edx; 6231a53cd0SKonstantin Belousov __register_t mc_ecx; 6331a53cd0SKonstantin Belousov __register_t mc_eax; 6431a53cd0SKonstantin Belousov __register_t mc_trapno; 6531a53cd0SKonstantin Belousov __register_t mc_err; 6631a53cd0SKonstantin Belousov __register_t mc_eip; 6731a53cd0SKonstantin Belousov __register_t mc_cs; 6831a53cd0SKonstantin Belousov __register_t mc_eflags; 6931a53cd0SKonstantin Belousov __register_t mc_esp; 7031a53cd0SKonstantin Belousov __register_t mc_ss; 7131a53cd0SKonstantin Belousov 7231a53cd0SKonstantin Belousov int mc_len; /* sizeof(mcontext_t) */ 7331a53cd0SKonstantin Belousov #define _MC_FPFMT_NODEV 0x10000 /* device not present or configured */ 7431a53cd0SKonstantin Belousov #define _MC_FPFMT_387 0x10001 7531a53cd0SKonstantin Belousov #define _MC_FPFMT_XMM 0x10002 7631a53cd0SKonstantin Belousov int mc_fpformat; 7731a53cd0SKonstantin Belousov #define _MC_FPOWNED_NONE 0x20000 /* FP state not used */ 7831a53cd0SKonstantin Belousov #define _MC_FPOWNED_FPU 0x20001 /* FP state came from FPU */ 7931a53cd0SKonstantin Belousov #define _MC_FPOWNED_PCB 0x20002 /* FP state came from PCB */ 8031a53cd0SKonstantin Belousov int mc_ownedfp; 8131a53cd0SKonstantin Belousov __register_t mc_flags; 8231a53cd0SKonstantin Belousov /* 8331a53cd0SKonstantin Belousov * See <machine/npx.h> for the internals of mc_fpstate[]. 8431a53cd0SKonstantin Belousov */ 8531a53cd0SKonstantin Belousov int mc_fpstate[128] __aligned(16); 8631a53cd0SKonstantin Belousov 8731a53cd0SKonstantin Belousov __register_t mc_fsbase; 8831a53cd0SKonstantin Belousov __register_t mc_gsbase; 8931a53cd0SKonstantin Belousov 9031a53cd0SKonstantin Belousov __register_t mc_xfpustate; 9131a53cd0SKonstantin Belousov __register_t mc_xfpustate_len; 9231a53cd0SKonstantin Belousov 9331a53cd0SKonstantin Belousov int mc_spare2[4]; 9431a53cd0SKonstantin Belousov } mcontext_t; 9531a53cd0SKonstantin Belousov #endif /* __i386__ */ 9631a53cd0SKonstantin Belousov 9731a53cd0SKonstantin Belousov #ifdef __amd64__ 9831a53cd0SKonstantin Belousov /* 99*7af5f2acSJohn Baldwin * mc_flags bits. Shall be in sync with TF_XXX. 10031a53cd0SKonstantin Belousov */ 10131a53cd0SKonstantin Belousov #define _MC_HASSEGS 0x1 10231a53cd0SKonstantin Belousov #define _MC_HASBASES 0x2 10331a53cd0SKonstantin Belousov #define _MC_HASFPXSTATE 0x4 10431a53cd0SKonstantin Belousov #define _MC_FLAG_MASK (_MC_HASSEGS | _MC_HASBASES | _MC_HASFPXSTATE) 10531a53cd0SKonstantin Belousov 10631a53cd0SKonstantin Belousov typedef struct __mcontext { 10731a53cd0SKonstantin Belousov /* 10831a53cd0SKonstantin Belousov * The definition of mcontext_t must match the layout of 10931a53cd0SKonstantin Belousov * struct sigcontext after the sc_mask member. This is so 11031a53cd0SKonstantin Belousov * that we can support sigcontext and ucontext_t at the same 11131a53cd0SKonstantin Belousov * time. 11231a53cd0SKonstantin Belousov */ 11331a53cd0SKonstantin Belousov __register_t mc_onstack; /* XXX - sigcontext compat. */ 11431a53cd0SKonstantin Belousov __register_t mc_rdi; /* machine state (struct trapframe) */ 11531a53cd0SKonstantin Belousov __register_t mc_rsi; 11631a53cd0SKonstantin Belousov __register_t mc_rdx; 11731a53cd0SKonstantin Belousov __register_t mc_rcx; 11831a53cd0SKonstantin Belousov __register_t mc_r8; 11931a53cd0SKonstantin Belousov __register_t mc_r9; 12031a53cd0SKonstantin Belousov __register_t mc_rax; 12131a53cd0SKonstantin Belousov __register_t mc_rbx; 12231a53cd0SKonstantin Belousov __register_t mc_rbp; 12331a53cd0SKonstantin Belousov __register_t mc_r10; 12431a53cd0SKonstantin Belousov __register_t mc_r11; 12531a53cd0SKonstantin Belousov __register_t mc_r12; 12631a53cd0SKonstantin Belousov __register_t mc_r13; 12731a53cd0SKonstantin Belousov __register_t mc_r14; 12831a53cd0SKonstantin Belousov __register_t mc_r15; 12931a53cd0SKonstantin Belousov __uint32_t mc_trapno; 13031a53cd0SKonstantin Belousov __uint16_t mc_fs; 13131a53cd0SKonstantin Belousov __uint16_t mc_gs; 13231a53cd0SKonstantin Belousov __register_t mc_addr; 13331a53cd0SKonstantin Belousov __uint32_t mc_flags; 13431a53cd0SKonstantin Belousov __uint16_t mc_es; 13531a53cd0SKonstantin Belousov __uint16_t mc_ds; 13631a53cd0SKonstantin Belousov __register_t mc_err; 13731a53cd0SKonstantin Belousov __register_t mc_rip; 13831a53cd0SKonstantin Belousov __register_t mc_cs; 13931a53cd0SKonstantin Belousov __register_t mc_rflags; 14031a53cd0SKonstantin Belousov __register_t mc_rsp; 14131a53cd0SKonstantin Belousov __register_t mc_ss; 14231a53cd0SKonstantin Belousov 14331a53cd0SKonstantin Belousov long mc_len; /* sizeof(mcontext_t) */ 14431a53cd0SKonstantin Belousov 14531a53cd0SKonstantin Belousov #define _MC_FPFMT_NODEV 0x10000 /* device not present or configured */ 14631a53cd0SKonstantin Belousov #define _MC_FPFMT_XMM 0x10002 14731a53cd0SKonstantin Belousov long mc_fpformat; 14831a53cd0SKonstantin Belousov #define _MC_FPOWNED_NONE 0x20000 /* FP state not used */ 14931a53cd0SKonstantin Belousov #define _MC_FPOWNED_FPU 0x20001 /* FP state came from FPU */ 15031a53cd0SKonstantin Belousov #define _MC_FPOWNED_PCB 0x20002 /* FP state came from PCB */ 15131a53cd0SKonstantin Belousov long mc_ownedfp; 15231a53cd0SKonstantin Belousov /* 15331a53cd0SKonstantin Belousov * See <machine/fpu.h> for the internals of mc_fpstate[]. 15431a53cd0SKonstantin Belousov */ 15531a53cd0SKonstantin Belousov long mc_fpstate[64] __aligned(16); 15631a53cd0SKonstantin Belousov 15731a53cd0SKonstantin Belousov __register_t mc_fsbase; 15831a53cd0SKonstantin Belousov __register_t mc_gsbase; 15931a53cd0SKonstantin Belousov 16031a53cd0SKonstantin Belousov __register_t mc_xfpustate; 16131a53cd0SKonstantin Belousov __register_t mc_xfpustate_len; 16231a53cd0SKonstantin Belousov 16331a53cd0SKonstantin Belousov long mc_spare[4]; 16431a53cd0SKonstantin Belousov } mcontext_t; 16531a53cd0SKonstantin Belousov #endif /* __amd64__ */ 16631a53cd0SKonstantin Belousov 16731a53cd0SKonstantin Belousov #endif /* !_X86_UCONTEXT_H_ */ 168