VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-mode-TestDoModesHlp.asm@ 60044

Last change on this file since 60044 was 60019, checked in by vboxsync, 9 years ago

bs3kit: Fixes and updates.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 24.9 KB
Line 
1; $Id: bs3-mode-TestDoModesHlp.asm 60019 2016-03-14 11:33:59Z vboxsync $
2;; @file
3; BS3Kit - Bs3TestDoModes helpers
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;* External Symbols *
32;*********************************************************************************************************************************
33extern TMPL_NM(Bs3SwitchToRM)
34extern TMPL_NM(Bs3SwitchToPE16)
35extern TMPL_NM(Bs3SwitchToPE16_32)
36extern TMPL_NM(Bs3SwitchToPE16_V86)
37extern TMPL_NM(Bs3SwitchToPE32)
38extern TMPL_NM(Bs3SwitchToPE32_16)
39extern TMPL_NM(Bs3SwitchToPEV86)
40extern TMPL_NM(Bs3SwitchToPP16)
41extern TMPL_NM(Bs3SwitchToPP16_32)
42extern TMPL_NM(Bs3SwitchToPP16_V86)
43extern TMPL_NM(Bs3SwitchToPP32)
44extern TMPL_NM(Bs3SwitchToPP32_16)
45extern TMPL_NM(Bs3SwitchToPPV86)
46extern TMPL_NM(Bs3SwitchToPAE16)
47extern TMPL_NM(Bs3SwitchToPAE16_32)
48extern TMPL_NM(Bs3SwitchToPAE16_V86)
49extern TMPL_NM(Bs3SwitchToPAE32)
50extern TMPL_NM(Bs3SwitchToPAE32_16)
51extern TMPL_NM(Bs3SwitchToPAEV86)
52extern TMPL_NM(Bs3SwitchToLM16)
53extern TMPL_NM(Bs3SwitchToLM32)
54extern TMPL_NM(Bs3SwitchToLM64)
55extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_rm)
56extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe16)
57extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe16_32)
58extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe16_v86)
59extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe32)
60extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe32_16)
61extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pev86)
62extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp16)
63extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp16_32)
64extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp16_v86)
65extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp32)
66extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp32_16)
67extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_ppv86)
68extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae16)
69extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae16_32)
70extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae16_v86)
71extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae32)
72extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae32_16)
73extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_paev86)
74extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_lm16)
75extern RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_lm32)
76extern RT_CONCAT3(Bs3SwitchTo,TMPL_MODE_UNAME,_lm64)
77
78
79;;
80; Shared prologue code.
81; @param xAX Where to jump to for the main event.
82;
83BS3_GLOBAL_NAME_EX TMPL_NM(bs3TestCallDoerPrologue), , 0
84 BS3_CALL_CONV_PROLOG 1
85 push xBP
86 mov xBP, xSP
87 xPUSHF
88
89 ; Save non-volatile registers so the DO function doesn't have to.
90 push xBX
91 push xCX
92 push xDX
93 push xSI
94 push xDI
95%if TMPL_BITS != 64
96 push ds
97 push es
98 push ss
99 %if TMPL_BITS != 16
100 push fs
101 push gs
102 %endif
103%endif
104%if TMPL_BITS == 64
105 push r8
106 push r9
107 push r10
108 push r11
109 push r12
110 push r13
111 push r14
112 push r15
113%endif
114
115 ; Jump to the main code.
116 jmp xAX
117
118;;
119; Shared epilogue code.
120; @param xAX Return code.
121;
122BS3_GLOBAL_NAME_EX TMPL_NM(bs3TestCallDoerEpilogue), , 0
123 ; Restore registers.
124%if TMPL_BITS == 16
125 sub bp, (1+5+3)*2
126 mov sp, bp
127%elif TMPL_BITS == 32
128 lea xSP, [xBP - (1+5+5)*4]
129%else
130 lea xSP, [xBP - (1+5+8)*8]
131 pop r15
132 pop r14
133 pop r13
134 pop r12
135 pop r11
136 pop r10
137 pop r9
138 pop r8
139%endif
140%if TMPL_BITS != 64
141 %if TMPL_BITS != 16
142 pop gs
143 pop fs
144 %endif
145 pop ss
146 pop es
147 pop ds
148%endif
149 pop xDI
150 pop xSI
151 pop xDX
152 pop xCX
153 pop xBX
154 xPOPF
155 pop xBP
156 ret
157
158;
159; For checking that the mode switching macros doesn't screw up GPRs.
160; Note! Does not work on pre 286 hardware!
161;
162%ifdef BS3_STRICT
163 %macro STRICT_SAVE_REGS 0
164 movzx esp, sp
165 sub esp, BS3REGCTX_size
166 mov [esp + BS3REGCTX.rax], eax
167 mov dword [esp + BS3REGCTX.rax+4], 0xdead0000
168 mov [esp + BS3REGCTX.rcx], ecx
169 mov dword [esp + BS3REGCTX.rcx+4], 0xdead0001
170 mov [esp + BS3REGCTX.rdx], edx
171 mov dword [esp + BS3REGCTX.rdx+4], 0xdead0002
172 mov [esp + BS3REGCTX.rbx], ebx
173 mov dword [esp + BS3REGCTX.rbx+4], 0xdead0003
174 mov [esp + BS3REGCTX.rbp], ebp
175 mov [esp + BS3REGCTX.rsp], esp
176 mov [esp + BS3REGCTX.rsi], esi
177 mov [esp + BS3REGCTX.rdi], edi
178 %endmacro
179
180 %macro STRICT_CHECK_REGS 0
181%%_esp: cmp [esp + BS3REGCTX.rsp], esp
182 jne %%_esp
183%%_eax: cmp [esp + BS3REGCTX.rax], eax
184 jne %%_eax
185%%_ecx: mov [esp + BS3REGCTX.rcx], ecx
186 jne %%_ecx
187%%_edx: cmp [esp + BS3REGCTX.rdx], edx
188 jne %%_edx
189%%_ebx: cmp [esp + BS3REGCTX.rbx], ebx
190 jne %%_ebx
191%%_ebp: cmp [esp + BS3REGCTX.rbp], ebp
192 jne %%_ebp
193%%_esi: cmp [esp + BS3REGCTX.rsi], esi
194 jne %%_esi
195%%_edi: cmp [esp + BS3REGCTX.rdi], edi
196 jne %%_edi
197 add esp, BS3REGCTX_size
198 %endmacro
199%else
200
201 %macro STRICT_SAVE_REGS 0
202 %endmacro
203 %macro STRICT_CHECK_REGS 0
204 %endmacro
205%endif
206
207
208;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
209;; Real mode
210;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
211
212;;
213; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInRM(uint16_t offBs3Text16);
214; @uses rax
215BS3_PROC_BEGIN_MODE Bs3TestCallDoerInRM
216 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
217 jmp TMPL_NM(bs3TestCallDoerPrologue)
218BS3_BEGIN_TEXT16
219BS3_SET_BITS TMPL_BITS
220.doit:
221 mov ax, [xBP + xCB*2] ; Load function pointer.
222
223 ; Mode switch, make the call, switch back.
224 STRICT_SAVE_REGS
225 call TMPL_NM(Bs3SwitchToRM)
226 BS3_SET_BITS 16
227 STRICT_CHECK_REGS
228
229 mov cx, BS3_MODE_RM
230 push cx
231 call ax
232
233 STRICT_SAVE_REGS
234 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_rm)
235 BS3_SET_BITS TMPL_BITS
236 STRICT_CHECK_REGS
237 jmp TMPL_NM(bs3TestCallDoerEpilogue)
238TMPL_BEGIN_TEXT
239BS3_PROC_END_MODE Bs3TestCallDoerInRM
240
241
242;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
243;; Unpage protection mode.
244;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
245
246;;
247; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPE16(uint16_t offBs3Text16);
248; @uses rax
249BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPE16
250 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
251 jmp TMPL_NM(bs3TestCallDoerPrologue)
252BS3_BEGIN_TEXT16
253BS3_SET_BITS TMPL_BITS
254.doit:
255 mov ax, [xBP + xCB*2] ; Load function pointer.
256
257 ; Mode switch, make the call, switch back.
258 STRICT_SAVE_REGS
259 call TMPL_NM(Bs3SwitchToPE16)
260 BS3_SET_BITS 16
261 STRICT_CHECK_REGS
262
263 push BS3_MODE_PE16
264 call ax
265
266 STRICT_SAVE_REGS
267 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe16)
268 BS3_SET_BITS TMPL_BITS
269 jmp TMPL_NM(bs3TestCallDoerEpilogue)
270TMPL_BEGIN_TEXT
271BS3_PROC_END_MODE Bs3TestCallDoerInPE16
272
273;;
274; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPE16_32(uint16_t offBs3Text16);
275; @uses rax
276BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPE16_32
277 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
278 jmp TMPL_NM(bs3TestCallDoerPrologue)
279.doit:
280 mov eax, [xBP + xCB*2] ; Load function pointer.
281
282 ; Mode switch, make the call, switch back.
283 STRICT_SAVE_REGS
284 call TMPL_NM(Bs3SwitchToPE16_32)
285 BS3_SET_BITS 32
286 STRICT_CHECK_REGS
287
288 push BS3_MODE_RM
289 call eax
290
291 STRICT_SAVE_REGS
292 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe16_32)
293 BS3_SET_BITS TMPL_BITS
294 STRICT_CHECK_REGS
295 jmp TMPL_NM(bs3TestCallDoerEpilogue)
296BS3_PROC_END_MODE Bs3TestCallDoerInPE16_32
297
298;;
299; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPE16_V86(uint16_t offBs3Text16);
300; @uses rax
301BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPE16_V86
302 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
303 jmp TMPL_NM(bs3TestCallDoerPrologue)
304.doit:
305 mov ax, [xBP + xCB*2] ; Load function pointer.
306
307 ; Mode switch, make the call, switch back.
308 STRICT_SAVE_REGS
309 call TMPL_NM(Bs3SwitchToPE16_V86)
310 BS3_SET_BITS 16
311 STRICT_CHECK_REGS
312
313 push BS3_MODE_PE16_V86
314 call ax
315
316 STRICT_SAVE_REGS
317 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe16_v86)
318 BS3_SET_BITS TMPL_BITS
319 STRICT_CHECK_REGS
320 jmp TMPL_NM(bs3TestCallDoerEpilogue)
321BS3_PROC_END_MODE Bs3TestCallDoerInPE16_V86
322
323;;
324; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPE32(uint16_t offBs3Text16);
325; @uses rax
326BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPE32
327 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
328 jmp TMPL_NM(bs3TestCallDoerPrologue)
329.doit:
330 mov eax, [xBP + xCB*2] ; Load function pointer.
331
332 ; Mode switch, make the call, switch back.
333 STRICT_SAVE_REGS
334 call TMPL_NM(Bs3SwitchToPE32)
335 BS3_SET_BITS 32
336 STRICT_CHECK_REGS
337
338 push BS3_MODE_PE32
339 call eax
340
341 STRICT_SAVE_REGS
342 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe32)
343 BS3_SET_BITS TMPL_BITS
344 STRICT_CHECK_REGS
345 jmp TMPL_NM(bs3TestCallDoerEpilogue)
346BS3_PROC_END_MODE Bs3TestCallDoerInPE32
347
348;;
349; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPE32_16(uint16_t offBs3Text16);
350; @uses rax
351BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPE32_16
352 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
353 jmp TMPL_NM(bs3TestCallDoerPrologue)
354BS3_BEGIN_TEXT16
355BS3_SET_BITS TMPL_BITS
356.doit:
357 mov ax, [xBP + xCB*2] ; Load function pointer.
358
359 ; Mode switch, make the call, switch back.
360 STRICT_SAVE_REGS
361 call TMPL_NM(Bs3SwitchToPE32_16)
362 BS3_SET_BITS 16
363 STRICT_CHECK_REGS
364
365 push BS3_MODE_PE32_16
366 call ax
367
368 STRICT_SAVE_REGS
369 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pe32_16)
370 BS3_SET_BITS TMPL_BITS
371 STRICT_CHECK_REGS
372 jmp TMPL_NM(bs3TestCallDoerEpilogue)
373TMPL_BEGIN_TEXT
374BS3_PROC_END_MODE Bs3TestCallDoerInPE32_16
375
376;;
377; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPEV86(uint16_t offBs3Text16);
378; @uses rax
379BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPEV86
380 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
381 jmp TMPL_NM(bs3TestCallDoerPrologue)
382BS3_BEGIN_TEXT16
383BS3_SET_BITS TMPL_BITS
384.doit:
385 mov ax, [xBP + xCB*2] ; Load function pointer.
386
387 ; Mode switch, make the call, switch back.
388 STRICT_SAVE_REGS
389 call TMPL_NM(Bs3SwitchToPEV86)
390 BS3_SET_BITS 16
391 STRICT_CHECK_REGS
392
393 push BS3_MODE_PEV86
394 call ax
395
396 STRICT_SAVE_REGS
397 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pev86)
398 BS3_SET_BITS TMPL_BITS
399 STRICT_CHECK_REGS
400 jmp TMPL_NM(bs3TestCallDoerEpilogue)
401TMPL_BEGIN_TEXT
402BS3_PROC_END_MODE Bs3TestCallDoerInPEV86
403
404
405
406;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
407;; Page protection mode.
408;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
409
410;;
411; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPP16(uint16_t offBs3Text16);
412; @uses rax
413BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPP16
414 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
415 jmp TMPL_NM(bs3TestCallDoerPrologue)
416BS3_BEGIN_TEXT16
417BS3_SET_BITS TMPL_BITS
418.doit:
419 mov ax, [xBP + xCB*2] ; Load function pointer.
420
421 ; Mode switch, make the call, switch back.
422 STRICT_SAVE_REGS
423 call TMPL_NM(Bs3SwitchToPP16)
424 BS3_SET_BITS 16
425 STRICT_CHECK_REGS
426
427 push BS3_MODE_PP16
428 call ax
429
430 STRICT_SAVE_REGS
431 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp16)
432 BS3_SET_BITS TMPL_BITS
433 STRICT_CHECK_REGS
434 jmp TMPL_NM(bs3TestCallDoerEpilogue)
435TMPL_BEGIN_TEXT
436BS3_PROC_END_MODE Bs3TestCallDoerInPP16
437
438;;
439; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPP16_32(uint16_t offBs3Text16);
440; @uses rax
441BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPP16_32
442 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
443 jmp TMPL_NM(bs3TestCallDoerPrologue)
444.doit:
445 mov eax, [xBP + xCB*2] ; Load function pointer.
446
447 ; Mode switch, make the call, switch back.
448 STRICT_SAVE_REGS
449 call TMPL_NM(Bs3SwitchToPP16_32)
450 BS3_SET_BITS 32
451 STRICT_CHECK_REGS
452
453 push BS3_MODE_PP16_32
454 call eax
455
456 STRICT_SAVE_REGS
457 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp16_32)
458 BS3_SET_BITS TMPL_BITS
459 STRICT_CHECK_REGS
460 jmp TMPL_NM(bs3TestCallDoerEpilogue)
461BS3_PROC_END_MODE Bs3TestCallDoerInPP16_32
462
463;;
464; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPP16_V86(uint16_t offBs3Text16);
465; @uses rax
466BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPP16_V86
467 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
468 jmp TMPL_NM(bs3TestCallDoerPrologue)
469.doit:
470 mov ax, [xBP + xCB*2] ; Load function pointer.
471
472 ; Mode switch, make the call, switch back.
473 STRICT_SAVE_REGS
474 call TMPL_NM(Bs3SwitchToPP16_V86)
475 BS3_SET_BITS 16
476 STRICT_CHECK_REGS
477
478 push BS3_MODE_PP16_V86
479 call ax
480
481 STRICT_SAVE_REGS
482 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp16_v86)
483 BS3_SET_BITS TMPL_BITS
484 STRICT_CHECK_REGS
485 jmp TMPL_NM(bs3TestCallDoerEpilogue)
486BS3_PROC_END_MODE Bs3TestCallDoerInPP16_V86
487
488;;
489; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPP32(uint16_t offBs3Text16);
490; @uses rax
491BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPP32
492 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
493 jmp TMPL_NM(bs3TestCallDoerPrologue)
494.doit:
495 mov eax, [xBP + xCB*2] ; Load function pointer.
496
497 ; Mode switch, make the call, switch back.
498 STRICT_SAVE_REGS
499 call TMPL_NM(Bs3SwitchToPP32)
500 BS3_SET_BITS 32
501 STRICT_CHECK_REGS
502
503 push BS3_MODE_PP32
504 call eax
505
506 STRICT_SAVE_REGS
507 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp32)
508 BS3_SET_BITS TMPL_BITS
509 STRICT_CHECK_REGS
510 jmp TMPL_NM(bs3TestCallDoerEpilogue)
511BS3_PROC_END_MODE Bs3TestCallDoerInPP32
512
513;;
514; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPP32_16(uint16_t offBs3Text16);
515; @uses rax
516BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPP32_16
517 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
518 jmp TMPL_NM(bs3TestCallDoerPrologue)
519BS3_BEGIN_TEXT16
520BS3_SET_BITS TMPL_BITS
521.doit:
522 mov ax, [xBP + xCB*2] ; Load function pointer.
523
524 ; Mode switch, make the call, switch back.
525 STRICT_SAVE_REGS
526 call TMPL_NM(Bs3SwitchToPP32_16)
527 BS3_SET_BITS 16
528 STRICT_CHECK_REGS
529
530 push BS3_MODE_PP32_16
531 call ax
532
533 STRICT_SAVE_REGS
534 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pp32_16)
535 BS3_SET_BITS TMPL_BITS
536 STRICT_CHECK_REGS
537 jmp TMPL_NM(bs3TestCallDoerEpilogue)
538TMPL_BEGIN_TEXT
539BS3_PROC_END_MODE Bs3TestCallDoerInPP32_16
540
541;;
542; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPPV86(uint16_t offBs3Text16);
543; @uses rax
544BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPPV86
545 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
546 jmp TMPL_NM(bs3TestCallDoerPrologue)
547BS3_BEGIN_TEXT16
548BS3_SET_BITS TMPL_BITS
549.doit:
550 mov ax, [xBP + xCB*2] ; Load function pointer.
551
552 ; Mode switch, make the call, switch back.
553 STRICT_SAVE_REGS
554 call TMPL_NM(Bs3SwitchToPPV86)
555 BS3_SET_BITS 16
556 STRICT_CHECK_REGS
557
558 push BS3_MODE_PPV86
559 call ax
560
561 STRICT_SAVE_REGS
562 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_ppv86)
563 BS3_SET_BITS TMPL_BITS
564 STRICT_CHECK_REGS
565 jmp TMPL_NM(bs3TestCallDoerEpilogue)
566TMPL_BEGIN_TEXT
567BS3_PROC_END_MODE Bs3TestCallDoerInPPV86
568
569
570
571;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
572;; PAE paged protection mode.
573;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
574
575;;
576; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPAE16(uint16_t offBs3Text16);
577; @uses rax
578BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPAE16
579 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
580 jmp TMPL_NM(bs3TestCallDoerPrologue)
581BS3_BEGIN_TEXT16
582BS3_SET_BITS TMPL_BITS
583.doit:
584 mov ax, [xBP + xCB*2] ; Load function pointer.
585
586 ; Mode switch, make the call, switch back.
587 STRICT_SAVE_REGS
588 call TMPL_NM(Bs3SwitchToPAE16)
589 BS3_SET_BITS 16
590 STRICT_CHECK_REGS
591
592 push BS3_MODE_PAE16
593 call ax
594
595 STRICT_SAVE_REGS
596 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae16)
597 BS3_SET_BITS TMPL_BITS
598 STRICT_CHECK_REGS
599 jmp TMPL_NM(bs3TestCallDoerEpilogue)
600TMPL_BEGIN_TEXT
601BS3_PROC_END_MODE Bs3TestCallDoerInPAE16
602
603;;
604; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPAE16_32(uint16_t offBs3Text16);
605; @uses rax
606BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPAE16_32
607 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
608 jmp TMPL_NM(bs3TestCallDoerPrologue)
609.doit:
610 mov eax, [xBP + xCB*2] ; Load function pointer.
611
612 ; Mode switch, make the call, switch back.
613 STRICT_SAVE_REGS
614 call TMPL_NM(Bs3SwitchToPAE16_32)
615 BS3_SET_BITS 32
616 STRICT_CHECK_REGS
617
618 push BS3_MODE_PAE16_32
619 call eax
620
621 STRICT_SAVE_REGS
622 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae16_32)
623 BS3_SET_BITS TMPL_BITS
624 STRICT_CHECK_REGS
625 jmp TMPL_NM(bs3TestCallDoerEpilogue)
626BS3_PROC_END_MODE Bs3TestCallDoerInPAE16_32
627
628;;
629; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPAE16_V86(uint16_t offBs3Text16);
630; @uses rax
631BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPAE16_V86
632 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
633 jmp TMPL_NM(bs3TestCallDoerPrologue)
634.doit:
635 mov ax, [xBP + xCB*2] ; Load function pointer.
636
637 ; Mode switch, make the call, switch back.
638 STRICT_SAVE_REGS
639 call TMPL_NM(Bs3SwitchToPAE16_V86)
640 BS3_SET_BITS 16
641 STRICT_CHECK_REGS
642
643 push BS3_MODE_PAE16_V86
644 call ax
645
646 STRICT_SAVE_REGS
647 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae16_v86)
648 BS3_SET_BITS TMPL_BITS
649 STRICT_CHECK_REGS
650 jmp TMPL_NM(bs3TestCallDoerEpilogue)
651BS3_PROC_END_MODE Bs3TestCallDoerInPAE16_V86
652
653;;
654; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPAE32(uint16_t offBs3Text16);
655; @uses rax
656BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPAE32
657 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
658 jmp TMPL_NM(bs3TestCallDoerPrologue)
659.doit:
660 mov eax, [xBP + xCB*2] ; Load function pointer.
661
662 ; Mode switch, make the call, switch back.
663 STRICT_SAVE_REGS
664 call TMPL_NM(Bs3SwitchToPAE32)
665 BS3_SET_BITS 32
666 STRICT_CHECK_REGS
667
668 push BS3_MODE_PAE16_32
669 call eax
670
671 STRICT_SAVE_REGS
672 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae32)
673 BS3_SET_BITS TMPL_BITS
674 STRICT_CHECK_REGS
675 jmp TMPL_NM(bs3TestCallDoerEpilogue)
676BS3_PROC_END_MODE Bs3TestCallDoerInPAE32
677
678;;
679; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPAE32_16(uint16_t offBs3Text16);
680; @uses rax
681BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPAE32_16
682 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
683 jmp TMPL_NM(bs3TestCallDoerPrologue)
684BS3_BEGIN_TEXT16
685BS3_SET_BITS TMPL_BITS
686.doit:
687 mov ax, [xBP + xCB*2] ; Load function pointer.
688
689 ; Mode switch, make the call, switch back.
690 STRICT_SAVE_REGS
691 call TMPL_NM(Bs3SwitchToPAE32_16)
692 BS3_SET_BITS 16
693 STRICT_CHECK_REGS
694
695 push BS3_MODE_PAE32_16
696 call ax
697
698 STRICT_SAVE_REGS
699 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_pae32_16)
700 BS3_SET_BITS TMPL_BITS
701 STRICT_CHECK_REGS
702 jmp TMPL_NM(bs3TestCallDoerEpilogue)
703TMPL_BEGIN_TEXT
704BS3_PROC_END_MODE Bs3TestCallDoerInPAE32_16
705
706;;
707; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInPAEV86(uint16_t offBs3Text16);
708; @uses rax
709BS3_PROC_BEGIN_MODE Bs3TestCallDoerInPAEV86
710 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
711 jmp TMPL_NM(bs3TestCallDoerPrologue)
712BS3_BEGIN_TEXT16
713BS3_SET_BITS TMPL_BITS
714.doit:
715 mov ax, [xBP + xCB*2] ; Load function pointer.
716
717 ; Mode switch, make the call, switch back.
718 STRICT_SAVE_REGS
719 call TMPL_NM(Bs3SwitchToPAEV86)
720 BS3_SET_BITS 16
721 STRICT_CHECK_REGS
722
723 push BS3_MODE_PAEV86
724 call ax
725
726 STRICT_SAVE_REGS
727 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_paev86)
728 BS3_SET_BITS TMPL_BITS
729 STRICT_CHECK_REGS
730 jmp TMPL_NM(bs3TestCallDoerEpilogue)
731TMPL_BEGIN_TEXT
732BS3_PROC_END_MODE Bs3TestCallDoerInPAEV86
733
734
735
736;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
737;; Long mode
738;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
739
740;;
741; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInLM16(uint16_t offBs3Text16);
742; @uses rax
743BS3_PROC_BEGIN_MODE Bs3TestCallDoerInLM16
744 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
745 jmp TMPL_NM(bs3TestCallDoerPrologue)
746BS3_BEGIN_TEXT16
747BS3_SET_BITS TMPL_BITS
748.doit:
749 mov ax, [xBP + xCB*2] ; Load function pointer.
750
751 ; Mode switch, make the call, switch back.
752 STRICT_SAVE_REGS
753 call TMPL_NM(Bs3SwitchToLM16)
754 BS3_SET_BITS 16
755 STRICT_CHECK_REGS
756
757 push BS3_MODE_LM16
758 call ax
759
760 STRICT_SAVE_REGS
761 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_lm16)
762 BS3_SET_BITS TMPL_BITS
763 STRICT_CHECK_REGS
764 jmp TMPL_NM(bs3TestCallDoerEpilogue)
765TMPL_BEGIN_TEXT
766BS3_PROC_END_MODE Bs3TestCallDoerInLM16
767
768;;
769; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInLM32(uint16_t offBs3Text16);
770; @uses rax
771BS3_PROC_BEGIN_MODE Bs3TestCallDoerInLM32
772 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
773 jmp TMPL_NM(bs3TestCallDoerPrologue)
774.doit:
775 mov eax, [xBP + xCB*2] ; Load function pointer.
776
777 ; Mode switch, make the call, switch back.
778 STRICT_SAVE_REGS
779 call TMPL_NM(Bs3SwitchToLM32)
780 BS3_SET_BITS 32
781 STRICT_CHECK_REGS
782
783 and esp, ~03h
784 push BS3_MODE_LM32
785 call eax
786
787 STRICT_SAVE_REGS
788 call RT_CONCAT3(_Bs3SwitchTo,TMPL_MODE_UNAME,_lm32)
789 BS3_SET_BITS TMPL_BITS
790 STRICT_CHECK_REGS
791 jmp TMPL_NM(bs3TestCallDoerEpilogue)
792BS3_PROC_END_MODE Bs3TestCallDoerInLM32
793
794;;
795; @cproto BS3_DECL(uint8_t) Bs3TestCallDoerInLM64(uint16_t offBs3Text16);
796; @uses rax
797BS3_PROC_BEGIN_MODE Bs3TestCallDoerInLM64
798 BS3_LEA_MOV_WRT_RIP(xAX, .doit)
799 jmp TMPL_NM(bs3TestCallDoerPrologue)
800.doit:
801 mov eax, [xBP + xCB*2] ; Load function pointer.
802
803 ; Mode switch, make the call, switch back.
804 STRICT_SAVE_REGS
805 call TMPL_NM(Bs3SwitchToLM64)
806 BS3_SET_BITS 64
807 STRICT_CHECK_REGS
808
809 and rsp, ~0fh
810 sub rsp, 18h
811 push BS3_MODE_LM64
812 BS3_CALL rax, 1
813
814 STRICT_SAVE_REGS
815 call RT_CONCAT3(Bs3SwitchTo,TMPL_MODE_UNAME,_lm64)
816 BS3_SET_BITS TMPL_BITS
817 STRICT_CHECK_REGS
818 jmp TMPL_NM(bs3TestCallDoerEpilogue)
819BS3_PROC_END_MODE Bs3TestCallDoerInLM64
820
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