Deleted Added
full compact
frame.h (92761) frame.h (114349)
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

--- 20 unchanged lines hidden (view full) ---

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
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

--- 20 unchanged lines hidden (view full) ---

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 * $FreeBSD: head/sys/amd64/include/frame.h 92761 2002-03-20 05:48:58Z alfred $
37 * $FreeBSD: head/sys/amd64/include/frame.h 114349 2003-05-01 01:05:25Z peter $
38 */
39
40#ifndef _MACHINE_FRAME_H_
41#define _MACHINE_FRAME_H_ 1
42
43/*
44 * System stack frames.
45 */
46
47/*
48 * Exception/Trap Stack Frame
38 */
39
40#ifndef _MACHINE_FRAME_H_
41#define _MACHINE_FRAME_H_ 1
42
43/*
44 * System stack frames.
45 */
46
47/*
48 * Exception/Trap Stack Frame
49 *
50 * The ordering of this is specifically so that we can take first 6
51 * the syscall arguments directly from the beginning of the frame.
49 */
50
51struct trapframe {
52 */
53
54struct trapframe {
52 int tf_fs;
53 int tf_es;
54 int tf_ds;
55 int tf_edi;
56 int tf_esi;
57 int tf_ebp;
58 int tf_isp;
59 int tf_ebx;
60 int tf_edx;
61 int tf_ecx;
62 int tf_eax;
63 int tf_trapno;
64 /* below portion defined in 386 hardware */
65 int tf_err;
66 int tf_eip;
67 int tf_cs;
68 int tf_eflags;
69 /* below only when crossing rings (e.g. user to kernel) */
70 int tf_esp;
71 int tf_ss;
55 register_t tf_rdi;
56 register_t tf_rsi;
57 register_t tf_rdx;
58 register_t tf_rcx;
59 register_t tf_r8;
60 register_t tf_r9;
61 register_t tf_rax;
62 register_t tf_rbx;
63 register_t tf_rbp;
64 register_t tf_r10;
65 register_t tf_r11;
66 register_t tf_r12;
67 register_t tf_r13;
68 register_t tf_r14;
69 register_t tf_r15;
70 register_t tf_trapno;
71 /* below portion defined in hardware */
72 register_t tf_err;
73 register_t tf_rip;
74 register_t tf_cs;
75 register_t tf_rflags;
76 register_t tf_rsp;
77 register_t tf_ss;
72};
73
78};
79
74/* Superset of trap frame, for traps from virtual-8086 mode */
75
76struct trapframe_vm86 {
77 int tf_fs;
78 int tf_es;
79 int tf_ds;
80 int tf_edi;
81 int tf_esi;
82 int tf_ebp;
83 int tf_isp;
84 int tf_ebx;
85 int tf_edx;
86 int tf_ecx;
87 int tf_eax;
88 int tf_trapno;
89 /* below portion defined in 386 hardware */
90 int tf_err;
91 int tf_eip;
92 int tf_cs;
93 int tf_eflags;
94 /* below only when crossing rings (e.g. user to kernel) */
95 int tf_esp;
96 int tf_ss;
97 /* below only when switching out of VM86 mode */
98 int tf_vm86_es;
99 int tf_vm86_ds;
100 int tf_vm86_fs;
101 int tf_vm86_gs;
102};
103
104/* Interrupt stack frame */
105
106struct intrframe {
80/* Interrupt stack frame */
81
82struct intrframe {
107 int if_vec;
108 int if_fs;
109 int if_es;
110 int if_ds;
111 int if_edi;
112 int if_esi;
113 int if_ebp;
114 int :32;
115 int if_ebx;
116 int if_edx;
117 int if_ecx;
118 int if_eax;
119 int :32; /* for compat with trap frame - trapno */
120 int :32; /* for compat with trap frame - err */
121 /* below portion defined in 386 hardware */
122 int if_eip;
123 int if_cs;
124 int if_eflags;
125 /* below only when crossing rings (e.g. user to kernel) */
126 int if_esp;
127 int if_ss;
83 register_t if_rdi;
84 register_t if_rsi;
85 register_t if_rdx;
86 register_t if_rcx;
87 register_t if_r8;
88 register_t if_r9;
89 register_t if_rax;
90 register_t if_rbx;
91 register_t if_rbp;
92 register_t if_r10;
93 register_t if_r11;
94 register_t if_r12;
95 register_t if_r13;
96 register_t if_r14;
97 register_t if_r15;
98 register_t :64; /* compat with trap frame - trapno */
99 register_t :64; /* compat with trap frame - err */
100 /* below portion defined in hardware */
101 register_t if_rip;
102 register_t if_cs;
103 register_t if_rflags;
104 register_t if_rsp;
105 register_t if_ss;
128};
129
130/* frame of clock (same as interrupt frame) */
131
132struct clockframe {
106};
107
108/* frame of clock (same as interrupt frame) */
109
110struct clockframe {
133 int cf_vec;
134 int cf_fs;
135 int cf_es;
136 int cf_ds;
137 int cf_edi;
138 int cf_esi;
139 int cf_ebp;
140 int :32;
141 int cf_ebx;
142 int cf_edx;
143 int cf_ecx;
144 int cf_eax;
145 int :32; /* for compat with trap frame - trapno */
146 int :32; /* for compat with trap frame - err */
147 /* below portion defined in 386 hardware */
148 int cf_eip;
149 int cf_cs;
150 int cf_eflags;
151 /* below only when crossing rings (e.g. user to kernel) */
152 int cf_esp;
153 int cf_ss;
111 register_t cf_rdi;
112 register_t cf_rsi;
113 register_t cf_rdx;
114 register_t cf_rcx;
115 register_t cf_r8;
116 register_t cf_r9;
117 register_t cf_rax;
118 register_t cf_rbx;
119 register_t cf_rbp;
120 register_t cf_r10;
121 register_t cf_r11;
122 register_t cf_r12;
123 register_t cf_r13;
124 register_t cf_r14;
125 register_t cf_r15;
126 register_t :64; /* compat with trap frame - trapno */
127 register_t :64; /* compat with trap frame - err */
128 /* below portion defined in hardware */
129 register_t cf_rip;
130 register_t cf_cs;
131 register_t cf_rflags;
132 register_t cf_rsp;
133 register_t cf_ss;
154};
155
156int kdb_trap(int, int, struct trapframe *);
134};
135
136int kdb_trap(int, int, struct trapframe *);
157extern int (*pmath_emulate)(struct trapframe *);
158
137
159#define INTR_TO_TRAPFRAME(frame) ((struct trapframe *)&(frame)->if_fs)
160
161#endif /* _MACHINE_FRAME_H_ */
138#endif /* _MACHINE_FRAME_H_ */