VirtualBox

source: vbox/trunk/include/VBox/cpum.mac@ 12986

Last change on this file since 12986 was 12600, checked in by vboxsync, 16 years ago

Turned dr0..dr7 into an array.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.4 KB
Line 
1;; @file
2;
3; CPUM - CPU Monitor.
4;
5
6;
7; Copyright (C) 2006-2007 Sun Microsystems, Inc.
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17; The contents of this file may alternatively be used under the terms
18; of the Common Development and Distribution License Version 1.0
19; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20; VirtualBox OSE distribution, in which case the provisions of the
21; CDDL are applicable instead of those of the GPL.
22;
23; You may elect to license modified versions of this file under the
24; terms and conditions of either the GPL or the CDDL or both.
25;
26; Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
27; Clara, CA 95054 USA or visit http://www.sun.com if you need
28; additional information or have any questions.
29;
30
31%ifndef __VBox_cpum_mac__
32%define __VBox_cpum_mac__
33
34
35;;
36; Registers frame.
37; This is used internally in TRPM, VMMSwitcher_GuestToHost_GuestCtx
38; and other places.
39struc CPUMCTXCORE
40 .edi resq 1
41 .esi resq 1
42 .ebp resq 1
43 .eax resq 1
44 .ebx resq 1
45 .edx resq 1
46 .ecx resq 1
47 .esp resq 1
48 .lss_esp resd 1
49 .ss resw 1
50 .ssPadding resw 1
51 .gs resw 1
52 .gsPadding resw 1
53 .fs resw 1
54 .fsPadding resw 1
55 .es resw 1
56 .esPadding resw 1
57 .ds resw 1
58 .dsPadding resw 1
59 .cs resw 1
60 .csPadding resw 3
61 .eflags resq 1
62 .eip resq 1
63
64 .r8 resq 1
65 .r9 resq 1
66 .r10 resq 1
67 .r11 resq 1
68 .r12 resq 1
69 .r13 resq 1
70 .r14 resq 1
71 .r15 resq 1
72
73 .esHid.u64Base resq 1
74 .esHid.u32Limit resd 1
75 .esHid.Attr resd 1
76
77 .csHid.u64Base resq 1
78 .csHid.u32Limit resd 1
79 .csHid.Attr resd 1
80
81 .ssHid.u64Base resq 1
82 .ssHid.u32Limit resd 1
83 .ssHid.Attr resd 1
84
85 .dsHid.u64Base resq 1
86 .dsHid.u32Limit resd 1
87 .dsHid.Attr resd 1
88
89 .fsHid.u64Base resq 1
90 .fsHid.u32Limit resd 1
91 .fsHid.Attr resd 1
92
93 .gsHid.u64Base resq 1
94 .gsHid.u32Limit resd 1
95 .gsHid.Attr resd 1
96
97endstruc
98
99
100struc CPUMCTX
101 .fpu resb 512
102
103 .edi resq 1
104 .esi resq 1
105 .ebp resq 1
106 .eax resq 1
107 .ebx resq 1
108 .edx resq 1
109 .ecx resq 1
110 .esp resq 1
111 .lss_esp resd 1
112 .ss resw 1
113 .ssPadding resw 1
114 .gs resw 1
115 .gsPadding resw 1
116 .fs resw 1
117 .fsPadding resw 1
118 .es resw 1
119 .esPadding resw 1
120 .ds resw 1
121 .dsPadding resw 1
122 .cs resw 1
123 .csPadding resw 3
124 .eflags resq 1
125 .eip resq 1
126
127 .r8 resq 1
128 .r9 resq 1
129 .r10 resq 1
130 .r11 resq 1
131 .r12 resq 1
132 .r13 resq 1
133 .r14 resq 1
134 .r15 resq 1
135
136 .esHid.u64Base resq 1
137 .esHid.u32Limit resd 1
138 .esHid.Attr resd 1
139
140 .csHid.u64Base resq 1
141 .csHid.u32Limit resd 1
142 .csHid.Attr resd 1
143
144 .ssHid.u64Base resq 1
145 .ssHid.u32Limit resd 1
146 .ssHid.Attr resd 1
147
148 .dsHid.u64Base resq 1
149 .dsHid.u32Limit resd 1
150 .dsHid.Attr resd 1
151
152 .fsHid.u64Base resq 1
153 .fsHid.u32Limit resd 1
154 .fsHid.Attr resd 1
155
156 .gsHid.u64Base resq 1
157 .gsHid.u32Limit resd 1
158 .gsHid.Attr resd 1
159
160
161 .cr0 resq 1
162 .cr2 resq 1
163 .cr3 resq 1
164 .cr4 resq 1
165
166 .dr resq 8
167
168 .gdtr resb 10 ; GDT limit + linear address
169 .gdtrPadding resw 1
170 .idtr resb 10 ; IDT limit + linear address
171 .idtrPadding resw 1
172 .ldtr resw 1
173 .ldtrPadding resw 1
174 .tr resw 1
175 .trPadding resw 1
176
177 .SysEnter.cs resb 8
178 .SysEnter.eip resb 8
179 .SysEnter.esp resb 8
180
181 .msrEFER resb 8
182 .msrSTAR resb 8
183 .msrPAT resb 8
184 .msrLSTAR resb 8
185 .msrCSTAR resb 8
186 .msrSFMASK resb 8
187 .msrKERNELGSBASE resb 8
188
189 .ldtrHid.u64Base resq 1
190 .ldtrHid.u32Limit resd 1
191 .ldtrHid.Attr resd 1
192
193 .trHid.u64Base resq 1
194 .trHid.u32Limit resd 1
195 .trHid.Attr resd 1
196
197 ; padding
198;;; .padding resd 6
199endstruc
200
201;;
202; FPU/XMM state
203;;
204struc X86FXSTATE
205 ;/** Control word. */
206 .FCW resw 1
207 ;/** Status word. */
208 .FSW resw 1
209 ;/** Tag word (it's a byte actually). */
210 .FTW resb 1
211 .huh1 resb 1
212 ;/** Opcode. */
213 .FOP resw 1
214 ;/** Instruction pointer. */
215 .FPUIP resd 1
216 ;/** Code selector. */
217 .CS resw 1
218 .Rsvrd1 resw 1
219 ;/* - offset 16 - */
220 ;/** Data pointer. */
221 .FPUDP resd 1
222 ;/** Data segment */
223 .DS resw 1
224 .Rsrvd2 resw 1
225 .MXCSR resd 1
226 .MXCSR_MASK resd 1
227 ;/* - offset 32 - */
228 ; FPU & MMX registers
229 .aRegs resq 8*2
230 ;/* - offset 160 - */
231 ;/* 8 XMM registers in 32 bits mode; 16 in long mode */
232 .aXMM resq 16*2
233 ;/* - offset 416 - */
234 .au32RsrvdRest resd (512 - 416) / 4
235endstruc
236
237%endif
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette