VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-cmn-RegCtxSaveEx.asm@ 65370

Last change on this file since 65370 was 60749, checked in by vboxsync, 9 years ago

bs3kit: updates

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 9.2 KB
Line 
1; $Id: bs3-cmn-RegCtxSaveEx.asm 60749 2016-04-28 19:41:14Z vboxsync $
2;; @file
3; BS3Kit - Bs3RegCtxSaveEx.
4;
5
6;
7; Copyright (C) 2007-2016 Oracle Corporation
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
27%include "bs3kit-template-header.mac"
28
29
30
31;*********************************************************************************************************************************
32;* External Symbols *
33;*********************************************************************************************************************************
34BS3_EXTERN_DATA16 g_bBs3CurrentMode
35
36TMPL_BEGIN_TEXT
37BS3_EXTERN_CMN Bs3Panic
38BS3_EXTERN_CMN Bs3RegCtxSave
39BS3_EXTERN_CMN Bs3SwitchTo16Bit
40%if TMPL_BITS != 64
41BS3_EXTERN_CMN Bs3SwitchTo16BitV86
42%endif
43%if TMPL_BITS != 32
44BS3_EXTERN_CMN Bs3SwitchTo32Bit
45%endif
46%if TMPL_BITS != 64
47BS3_EXTERN_CMN Bs3SwitchTo64Bit
48%endif
49%if TMPL_BITS == 16
50BS3_EXTERN_CMN Bs3SelRealModeDataToProtFar16
51BS3_EXTERN_CMN Bs3SelProtFar16DataToRealMode
52BS3_EXTERN_CMN Bs3SelRealModeDataToFlat
53BS3_EXTERN_CMN Bs3SelProtFar16DataToFlat
54%else
55BS3_EXTERN_CMN Bs3SelFlatDataToProtFar16
56%endif
57%if TMPL_BITS == 32
58BS3_EXTERN_CMN Bs3SelFlatDataToRealMode
59%endif
60
61BS3_BEGIN_TEXT16
62%if TMPL_BITS != 16
63extern _Bs3RegCtxSave_c16
64extern _Bs3SwitchTo%[TMPL_BITS]Bit_c16
65%endif
66
67BS3_BEGIN_TEXT32
68%if TMPL_BITS != 32
69extern _Bs3RegCtxSave_c32
70extern _Bs3SwitchTo%[TMPL_BITS]Bit_c32
71%endif
72%if TMPL_BITS == 16
73extern _Bs3SwitchTo16BitV86_c32
74%endif
75
76BS3_BEGIN_TEXT64
77%if TMPL_BITS != 64
78extern _Bs3RegCtxSave_c64
79extern _Bs3SwitchTo%[TMPL_BITS]Bit_c64
80%endif
81
82TMPL_BEGIN_TEXT
83
84
85
86;;
87; Saves the current register context.
88;
89; @param pRegCtx
90; @param bBitMode (8)
91; @param cbExtraStack (16)
92; @uses xAX, xDX, xCX
93;
94BS3_PROC_BEGIN_CMN Bs3RegCtxSaveEx, BS3_PBC_NEAR ; Far stub generated by the makefile/bs3kit.h.
95TONLY16 CPU 8086
96 BS3_CALL_CONV_PROLOG 3
97 push xBP
98 mov xBP, xSP
99
100 ;
101 ; Get the CPU bitcount part of the current mode.
102 ;
103 mov dl, [BS3_DATA16_WRT(g_bBs3CurrentMode)]
104 and dl, BS3_MODE_CODE_MASK
105%if TMPL_BITS == 16
106 push dx ; bp - 2: previous CPU mode (16-bit)
107%endif
108
109 ;
110 ; Reserve extra stack space. Make sure we've got 20h here in case we
111 ; are saving a 64-bit context.
112 ;
113 mov ax, [xBP + xCB + cbCurRetAddr + sCB + xCB]
114%ifdef BS3_STRICT
115 cmp ax, 4096
116 jb .extra_stack_ok
117 call Bs3Panic
118.extra_stack_ok:
119%endif
120 cmp ax, 20h
121 jae .at_least_20h_extra_stack
122 add ax, 20h
123.at_least_20h_extra_stack:
124 sub sp, ax
125
126 ;
127 ; Are we just saving the mode we're already in?
128 ;
129 mov al, [xBP + xCB + cbCurRetAddr + sCB]
130 and al, BS3_MODE_CODE_MASK
131 cmp dl, al
132 jne .not_the_same_mode
133
134%if TMPL_BITS == 16
135 push word [xBP + xCB + cbCurRetAddr + 2]
136 push word [xBP + xCB + cbCurRetAddr]
137%elif TMPL_BITS == 32
138 push dword [xBP + xCB + cbCurRetAddr]
139%endif
140 call Bs3RegCtxSave ; 64-bit: rcx is untouched thus far.
141
142
143 ;
144 ; Return - no need to pop xAX and xDX as the last two
145 ; operations preserves all registers.
146 ;
147.return:
148 mov xSP, xBP
149 pop xBP
150 BS3_CALL_CONV_EPILOG 3
151 BS3_HYBRID_RET
152
153
154 ;
155 ; Turns out we have to do switch to a different bitcount before saving.
156 ;
157.not_the_same_mode:
158 cmp al, BS3_MODE_CODE_16
159 je .code_16
160
161TONLY16 CPU 386
162%if TMPL_BITS != 32
163 cmp al, BS3_MODE_CODE_32
164 je .code_32
165%endif
166%if TMPL_BITS != 64
167 cmp al, BS3_MODE_CODE_V86
168 je .code_v86
169 cmp al, BS3_MODE_CODE_64
170 jne .bad_input_mode
171 jmp .code_64
172%endif
173
174 ; Bad input (al=input, dl=current).
175.bad_input_mode:
176 call Bs3Panic
177
178
179 ;
180 ; Save a 16-bit context.
181 ;
182 ; Convert pRegCtx to 16:16 protected mode and make sure we're in the
183 ; 16-bit code segment.
184 ;
185.code_16:
186%if TMPL_BITS == 16
187 %ifdef BS3_STRICT
188 cmp dl, BS3_MODE_CODE_V86
189 jne .bad_input_mode
190 %endif
191 push word [xBP + xCB + cbCurRetAddr + 2]
192 push word [xBP + xCB + cbCurRetAddr]
193 call Bs3SelRealModeDataToProtFar16
194 add sp, 4h
195 push dx ; Parameter #0 for _Bs3RegCtxSave_c16
196 push ax
197%else
198 %if TMPL_BITS == 32
199 push dword [xBP + xCB + cbCurRetAddr]
200 %endif
201 call Bs3SelFlatDataToProtFar16 ; 64-bit: BS3_CALL not needed, ecx not touched thus far.
202 mov [xSP], eax ; Parameter #0 for _Bs3RegCtxSave_c16
203 jmp .code_16_safe_segment
204 BS3_BEGIN_TEXT16
205 BS3_SET_BITS TMPL_BITS
206.code_16_safe_segment:
207%endif
208 call Bs3SwitchTo16Bit
209 BS3_SET_BITS 16
210
211 call _Bs3RegCtxSave_c16
212
213%if TMPL_BITS == 16
214 call _Bs3SwitchTo16BitV86_c16
215%else
216 call _Bs3SwitchTo%[TMPL_BITS]Bit_c16
217%endif
218 BS3_SET_BITS TMPL_BITS
219 jmp .return
220 TMPL_BEGIN_TEXT
221
222TONLY16 CPU 386
223
224
225%if TMPL_BITS != 64
226 ;
227 ; Save a v8086 context.
228 ;
229.code_v86:
230 %if TMPL_BITS == 16
231 %ifdef BS3_STRICT
232 cmp dl, BS3_MODE_CODE_16
233 jne .bad_input_mode
234 %endif
235 push word [xBP + xCB + cbCurRetAddr + 2]
236 push word [xBP + xCB + cbCurRetAddr]
237 call Bs3SelProtFar16DataToRealMode
238 add sp, 4h
239 push dx ; Parameter #0 for _Bs3RegCtxSave_c16
240 push ax
241 %else
242 push dword [xBP + xCB + cbCurRetAddr]
243 call Bs3SelFlatDataToRealMode
244 mov [xSP], eax ; Parameter #0 for _Bs3RegCtxSave_c16
245 jmp .code_v86_safe_segment
246 BS3_BEGIN_TEXT16
247 BS3_SET_BITS TMPL_BITS
248.code_v86_safe_segment:
249 %endif
250 call Bs3SwitchTo16BitV86
251 BS3_SET_BITS 16
252
253 call _Bs3RegCtxSave_c16
254
255 call _Bs3SwitchTo%[TMPL_BITS]Bit_c16
256 BS3_SET_BITS TMPL_BITS
257 jmp .return
258TMPL_BEGIN_TEXT
259%endif
260
261
262%if TMPL_BITS != 32
263 ;
264 ; Save a 32-bit context.
265 ;
266.code_32:
267 %if TMPL_BITS == 16
268 push word [xBP + xCB + cbCurRetAddr + 2]
269 push word [xBP + xCB + cbCurRetAddr]
270 test dl, BS3_MODE_CODE_V86
271 jnz .code_32_from_v86
272 call Bs3SelProtFar16DataToFlat
273 jmp .code_32_flat_ptr
274.code_32_from_v86:
275 call Bs3SelRealModeDataToFlat
276.code_32_flat_ptr:
277 add sp, 4h
278 push dx ; Parameter #0 for _Bs3RegCtxSave_c32
279 push ax
280 %else
281 mov [rsp], ecx ; Parameter #0 for _Bs3RegCtxSave_c16
282 %endif
283 call Bs3SwitchTo32Bit
284 BS3_SET_BITS 32
285
286 call _Bs3RegCtxSave_c32
287
288 %if TMPL_BITS == 16
289 cmp byte [bp - 2], BS3_MODE_CODE_V86
290 je .code_32_back_to_v86
291 call _Bs3SwitchTo16Bit_c32
292 BS3_SET_BITS TMPL_BITS
293 jmp .return
294.code_32_back_to_v86:
295 BS3_SET_BITS 32
296 call _Bs3SwitchTo16BitV86_c32
297 %else
298 call _Bs3SwitchTo64Bit_c32
299 %endif
300 BS3_SET_BITS TMPL_BITS
301 jmp .return
302%endif
303
304
305%if TMPL_BITS != 64
306 ;
307 ; Save a 64-bit context.
308 ;
309 CPU x86-64
310.code_64:
311 %if TMPL_BITS == 16
312 %ifdef BS3_STRICT
313 cmp dl, BS3_MODE_CODE_16
314 jne .bad_input_mode
315 %endif
316 push word [xBP + xCB + cbCurRetAddr + 2]
317 push word [xBP + xCB + cbCurRetAddr]
318 call Bs3SelProtFar16DataToFlat
319 add sp, 4h
320 mov cx, dx ; Parameter #0 for _Bs3RegCtxSave_c64
321 shl ecx, 16
322 mov cx, ax
323 %else
324 mov ecx, [xBP + xCB + cbCurRetAddr] ; Parameter #0 for _Bs3RegCtxSave_c64
325 %endif
326 call Bs3SwitchTo64Bit ; (preserves all 32-bit GPRs)
327 BS3_SET_BITS 64
328
329 call _Bs3RegCtxSave_c64 ; No BS3_CALL as rcx is already ready.
330
331 call _Bs3SwitchTo%[TMPL_BITS]Bit_c64
332 BS3_SET_BITS TMPL_BITS
333 jmp .return
334%endif
335BS3_PROC_END_CMN Bs3RegCtxSaveEx
336
337
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