1 /*- 2 * Copyright (c) 1990 The Regents of the University of California. 3 * All rights reserved. 4 * 5 * This code is derived from software contributed to Berkeley by 6 * William Jolitz. 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 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. All advertising materials mentioning features or use of this software 17 * must display the following acknowledgement: 18 * This product includes software developed by the University of 19 * California, Berkeley and its contributors. 20 * 4. Neither the name of the University nor the names of its contributors 21 * may be used to endorse or promote products derived from this software 22 * without specific prior written permission. 23 * 24 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 25 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 27 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34 * SUCH DAMAGE. 35 * 36 * from: @(#)frame.h 5.2 (Berkeley) 1/18/91 37 * $Id: frame.h,v 1.16 1999/04/28 01:03:59 luoqi Exp $ 38 */ 39 40 #ifndef _MACHINE_FRAME_H_ 41 #define _MACHINE_FRAME_H_ 1 42 43 #include <sys/signal.h> 44 45 /* 46 * System stack frames. 47 */ 48 49 /* 50 * Exception/Trap Stack Frame 51 */ 52 53 struct trapframe { 54 int tf_fs; 55 int tf_es; 56 int tf_ds; 57 int tf_edi; 58 int tf_esi; 59 int tf_ebp; 60 int tf_isp; 61 int tf_ebx; 62 int tf_edx; 63 int tf_ecx; 64 int tf_eax; 65 int tf_trapno; 66 /* below portion defined in 386 hardware */ 67 int tf_err; 68 int tf_eip; 69 int tf_cs; 70 int tf_eflags; 71 /* below only when crossing rings (e.g. user to kernel) */ 72 int tf_esp; 73 int tf_ss; 74 }; 75 76 /* Superset of trap frame, for traps from virtual-8086 mode */ 77 78 struct trapframe_vm86 { 79 int tf_fs; 80 int tf_es; 81 int tf_ds; 82 int tf_edi; 83 int tf_esi; 84 int tf_ebp; 85 int tf_isp; 86 int tf_ebx; 87 int tf_edx; 88 int tf_ecx; 89 int tf_eax; 90 int tf_trapno; 91 /* below portion defined in 386 hardware */ 92 int tf_err; 93 int tf_eip; 94 int tf_cs; 95 int tf_eflags; 96 /* below only when crossing rings (e.g. user to kernel) */ 97 int tf_esp; 98 int tf_ss; 99 /* below only when switching out of VM86 mode */ 100 int tf_vm86_es; 101 int tf_vm86_ds; 102 int tf_vm86_fs; 103 int tf_vm86_gs; 104 }; 105 106 /* Interrupt stack frame */ 107 108 struct intrframe { 109 int if_vec; 110 int if_ppl; 111 int if_fs; 112 int if_es; 113 int if_ds; 114 int if_edi; 115 int if_esi; 116 int if_ebp; 117 int :32; 118 int if_ebx; 119 int if_edx; 120 int if_ecx; 121 int if_eax; 122 int :32; /* for compat with trap frame - trapno */ 123 int :32; /* for compat with trap frame - err */ 124 /* below portion defined in 386 hardware */ 125 int if_eip; 126 int if_cs; 127 int if_eflags; 128 /* below only when crossing rings (e.g. user to kernel) */ 129 int if_esp; 130 int if_ss; 131 }; 132 133 /* frame of clock (same as interrupt frame) */ 134 135 struct clockframe { 136 int cf_vec; 137 int cf_ppl; 138 int cf_fs; 139 int cf_es; 140 int cf_ds; 141 int cf_edi; 142 int cf_esi; 143 int cf_ebp; 144 int :32; 145 int cf_ebx; 146 int cf_edx; 147 int cf_ecx; 148 int cf_eax; 149 int :32; /* for compat with trap frame - trapno */ 150 int :32; /* for compat with trap frame - err */ 151 /* below portion defined in 386 hardware */ 152 int cf_eip; 153 int cf_cs; 154 int cf_eflags; 155 /* below only when crossing rings (e.g. user to kernel) */ 156 int cf_esp; 157 int cf_ss; 158 }; 159 160 /* 161 * Signal frame 162 */ 163 struct sigframe { 164 int sf_signum; 165 int sf_code; 166 struct sigcontext *sf_scp; 167 char *sf_addr; 168 sig_t sf_handler; 169 struct sigcontext sf_sc; 170 }; 171 172 int kdb_trap __P((int, int, struct trapframe *)); 173 extern int (*pmath_emulate) __P((struct trapframe *)); 174 175 #define INTR_TO_TRAPFRAME(frame) ((struct trapframe *)&(frame)->if_fs) 176 177 #endif /* _MACHINE_FRAME_H_ */ 178