191078fcaSMarcel Moolenaar /*- 291078fcaSMarcel Moolenaar * Copyright (c) 1999 Marcel Moolenaar 391078fcaSMarcel Moolenaar * All rights reserved. 491078fcaSMarcel Moolenaar * 591078fcaSMarcel Moolenaar * Redistribution and use in source and binary forms, with or without 691078fcaSMarcel Moolenaar * modification, are permitted provided that the following conditions 791078fcaSMarcel Moolenaar * are met: 891078fcaSMarcel Moolenaar * 1. Redistributions of source code must retain the above copyright 991078fcaSMarcel Moolenaar * notice, this list of conditions and the following disclaimer 1091078fcaSMarcel Moolenaar * in this position and unchanged. 1191078fcaSMarcel Moolenaar * 2. Redistributions in binary form must reproduce the above copyright 1291078fcaSMarcel Moolenaar * notice, this list of conditions and the following disclaimer in the 1391078fcaSMarcel Moolenaar * documentation and/or other materials provided with the distribution. 1491078fcaSMarcel Moolenaar * 3. The name of the author may not be used to endorse or promote products 1591078fcaSMarcel Moolenaar * derived from this software without specific prior written permission. 1691078fcaSMarcel Moolenaar * 1791078fcaSMarcel Moolenaar * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 1891078fcaSMarcel Moolenaar * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 1991078fcaSMarcel Moolenaar * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 2091078fcaSMarcel Moolenaar * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 2191078fcaSMarcel Moolenaar * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 2291078fcaSMarcel Moolenaar * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 2391078fcaSMarcel Moolenaar * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 2491078fcaSMarcel Moolenaar * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 2591078fcaSMarcel Moolenaar * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 2691078fcaSMarcel Moolenaar * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 2791078fcaSMarcel Moolenaar * 2891078fcaSMarcel Moolenaar * $FreeBSD$ 2991078fcaSMarcel Moolenaar */ 3091078fcaSMarcel Moolenaar 3191078fcaSMarcel Moolenaar #ifndef _MACHINE_UCONTEXT_H_ 32c5c6b7b3SMarcel Moolenaar #define _MACHINE_UCONTEXT_H_ 3391078fcaSMarcel Moolenaar 34c5c6b7b3SMarcel Moolenaar typedef struct __mcontext { 35c5c6b7b3SMarcel Moolenaar /* 36210430fdSMarcel Moolenaar * The first 20 fields must match the definition of 37c5c6b7b3SMarcel Moolenaar * sigcontext. So that we can support sigcontext 38c5c6b7b3SMarcel Moolenaar * and ucontext_t at the same time. 39c5c6b7b3SMarcel Moolenaar */ 40c5c6b7b3SMarcel Moolenaar int mc_onstack; /* XXX - sigcontext compat. */ 41c5c6b7b3SMarcel Moolenaar int mc_gs; 42210430fdSMarcel Moolenaar int mc_fs; 43210430fdSMarcel Moolenaar int mc_es; 44210430fdSMarcel Moolenaar int mc_ds; 45210430fdSMarcel Moolenaar int mc_edi; 46210430fdSMarcel Moolenaar int mc_esi; 47210430fdSMarcel Moolenaar int mc_ebp; 48210430fdSMarcel Moolenaar int mc_isp; 49210430fdSMarcel Moolenaar int mc_ebx; 50210430fdSMarcel Moolenaar int mc_edx; 51210430fdSMarcel Moolenaar int mc_ecx; 52210430fdSMarcel Moolenaar int mc_eax; 53210430fdSMarcel Moolenaar int mc_trapno; 54210430fdSMarcel Moolenaar int mc_err; 55210430fdSMarcel Moolenaar int mc_eip; 56210430fdSMarcel Moolenaar int mc_cs; 57210430fdSMarcel Moolenaar int mc_eflags; 58210430fdSMarcel Moolenaar int mc_esp; /* machine state */ 59210430fdSMarcel Moolenaar int mc_ss; 60c5c6b7b3SMarcel Moolenaar 619ba15479SJonathan Mini int mc_len; /* sizeof(mcontext_t) */ 6280047e95SDaniel Eischen #define _MC_FPFMT_NODEV 0x10000 /* device not present or configured */ 6380047e95SDaniel Eischen #define _MC_FPFMT_387 0x10001 6480047e95SDaniel Eischen #define _MC_FPFMT_XMM 0x10002 659ba15479SJonathan Mini int mc_fpformat; 6680047e95SDaniel Eischen #define _MC_FPOWNED_NONE 0x20000 /* FP state not used */ 6780047e95SDaniel Eischen #define _MC_FPOWNED_FPU 0x20001 /* FP state came from FPU */ 6880047e95SDaniel Eischen #define _MC_FPOWNED_PCB 0x20002 /* FP state came from PCB */ 699ba15479SJonathan Mini int mc_ownedfp; 709ba15479SJonathan Mini int mc_spare1[1]; /* align next field to 16 bytes */ 719ba15479SJonathan Mini int mc_fpstate[128]; /* must be multiple of 16 bytes */ 729ba15479SJonathan Mini int mc_spare2[8]; 7391078fcaSMarcel Moolenaar } mcontext_t; 7491078fcaSMarcel Moolenaar 759ba15479SJonathan Mini #ifdef _KERNEL 7623eeeff7SPeter Wemm #ifdef COMPAT_FREEBSD4 7723eeeff7SPeter Wemm /* For 4.x binaries */ 7823eeeff7SPeter Wemm struct mcontext4 { 7923eeeff7SPeter Wemm int mc_onstack; /* XXX - sigcontext compat. */ 8023eeeff7SPeter Wemm int mc_gs; 8123eeeff7SPeter Wemm int mc_fs; 8223eeeff7SPeter Wemm int mc_es; 8323eeeff7SPeter Wemm int mc_ds; 8423eeeff7SPeter Wemm int mc_edi; 8523eeeff7SPeter Wemm int mc_esi; 8623eeeff7SPeter Wemm int mc_ebp; 8723eeeff7SPeter Wemm int mc_isp; 8823eeeff7SPeter Wemm int mc_ebx; 8923eeeff7SPeter Wemm int mc_edx; 9023eeeff7SPeter Wemm int mc_ecx; 9123eeeff7SPeter Wemm int mc_eax; 9223eeeff7SPeter Wemm int mc_trapno; 9323eeeff7SPeter Wemm int mc_err; 9423eeeff7SPeter Wemm int mc_eip; 9523eeeff7SPeter Wemm int mc_cs; 9623eeeff7SPeter Wemm int mc_eflags; 9723eeeff7SPeter Wemm int mc_esp; /* machine state */ 9823eeeff7SPeter Wemm int mc_ss; 9923eeeff7SPeter Wemm int mc_fpregs[28]; /* env87 + fpacc87 + u_long */ 10023eeeff7SPeter Wemm int __spare__[17]; 10123eeeff7SPeter Wemm }; 10223eeeff7SPeter Wemm #endif 10323eeeff7SPeter Wemm 1049ba15479SJonathan Mini struct thread; 1059ba15479SJonathan Mini 1069ba15479SJonathan Mini void get_mcontext(struct thread *td, mcontext_t *mcp); 1079ba15479SJonathan Mini int set_mcontext(struct thread *td, const mcontext_t *mcp); 1089ba15479SJonathan Mini #endif 1099ba15479SJonathan Mini 110c5c6b7b3SMarcel Moolenaar #endif /* !_MACHINE_UCONTEXT_H_ */ 111