1 | ; $Id: X86Stub.asm 69221 2017-10-24 15:07:46Z vboxsync $
|
---|
2 | ;; @file
|
---|
3 | ; VMM - World Switchers, X86 Stub.
|
---|
4 | ;
|
---|
5 |
|
---|
6 | ;
|
---|
7 | ; Copyright (C) 2006-2017 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 |
|
---|
18 | ;*******************************************************************************
|
---|
19 | ;* Defined Constants And Macros *
|
---|
20 | ;*******************************************************************************
|
---|
21 | %define NAME_OVERLOAD(name) vmmR3SwitcherX86Stub_ %+ name
|
---|
22 |
|
---|
23 |
|
---|
24 | ;*******************************************************************************
|
---|
25 | ;* Header Files *
|
---|
26 | ;*******************************************************************************
|
---|
27 | %include "VBox/asmdefs.mac"
|
---|
28 | %include "VBox/err.mac"
|
---|
29 | %include "VMMSwitcher.mac"
|
---|
30 |
|
---|
31 |
|
---|
32 | BEGINCODE
|
---|
33 | GLOBALNAME Start
|
---|
34 | BITS 32
|
---|
35 |
|
---|
36 | BEGINPROC vmmR0ToRawMode
|
---|
37 | mov eax, VERR_VMM_SWITCHER_STUB
|
---|
38 | ret
|
---|
39 | ENDPROC vmmR0ToRawMode
|
---|
40 |
|
---|
41 | BEGINPROC vmmRCCallTrampoline
|
---|
42 | .tight_loop:
|
---|
43 | int3
|
---|
44 | jmp .tight_loop
|
---|
45 | ENDPROC vmmRCCallTrampoline
|
---|
46 |
|
---|
47 | BEGINPROC vmmRCToHost
|
---|
48 | mov eax, VERR_VMM_SWITCHER_STUB
|
---|
49 | ret
|
---|
50 | ENDPROC vmmRCToHost
|
---|
51 |
|
---|
52 | BEGINPROC vmmRCToHostAsmNoReturn
|
---|
53 | mov eax, VERR_VMM_SWITCHER_STUB
|
---|
54 | ret
|
---|
55 | ENDPROC vmmRCToHostAsmNoReturn
|
---|
56 |
|
---|
57 | BEGINPROC vmmRCToHostAsm
|
---|
58 | mov eax, VERR_VMM_SWITCHER_STUB
|
---|
59 | ret
|
---|
60 | ENDPROC vmmRCToHostAsm
|
---|
61 |
|
---|
62 | GLOBALNAME End
|
---|
63 |
|
---|
64 | ;
|
---|
65 | ; The description string (in the text section).
|
---|
66 | ;
|
---|
67 | NAME(Description):
|
---|
68 | db "X86 Stub."
|
---|
69 | db 0
|
---|
70 |
|
---|
71 |
|
---|
72 | ;
|
---|
73 | ; Dummy fixups.
|
---|
74 | ;
|
---|
75 | BEGINDATA
|
---|
76 | GLOBALNAME Fixups
|
---|
77 | db FIX_THE_END ; final entry.
|
---|
78 | GLOBALNAME FixupsEnd
|
---|
79 |
|
---|
80 |
|
---|
81 | ;;
|
---|
82 | ; The switcher definition structure.
|
---|
83 | ALIGNDATA(16)
|
---|
84 | GLOBALNAME Def
|
---|
85 | istruc VMMSWITCHERDEF
|
---|
86 | at VMMSWITCHERDEF.pvCode, RTCCPTR_DEF NAME(Start)
|
---|
87 | at VMMSWITCHERDEF.pvFixups, RTCCPTR_DEF NAME(Fixups)
|
---|
88 | at VMMSWITCHERDEF.pszDesc, RTCCPTR_DEF NAME(Description)
|
---|
89 | at VMMSWITCHERDEF.pfnRelocate, RTCCPTR_DEF 0
|
---|
90 | at VMMSWITCHERDEF.enmType, dd VMMSWITCHER_X86_STUB
|
---|
91 | at VMMSWITCHERDEF.cbCode, dd NAME(End) - NAME(Start)
|
---|
92 | at VMMSWITCHERDEF.offR0ToRawMode, dd NAME(vmmR0ToRawMode) - NAME(Start)
|
---|
93 | at VMMSWITCHERDEF.offRCToHost, dd NAME(vmmRCToHost) - NAME(Start)
|
---|
94 | at VMMSWITCHERDEF.offRCCallTrampoline, dd NAME(vmmRCCallTrampoline) - NAME(Start)
|
---|
95 | at VMMSWITCHERDEF.offRCToHostAsm, dd NAME(vmmRCToHostAsm) - NAME(Start)
|
---|
96 | at VMMSWITCHERDEF.offRCToHostAsmNoReturn, dd NAME(vmmRCToHostAsmNoReturn) - NAME(Start)
|
---|
97 | ; disasm help
|
---|
98 | at VMMSWITCHERDEF.offHCCode0, dd 0
|
---|
99 | at VMMSWITCHERDEF.cbHCCode0, dd NAME(vmmRCCallTrampoline) - NAME(Start)
|
---|
100 | at VMMSWITCHERDEF.offHCCode1, dd 0
|
---|
101 | at VMMSWITCHERDEF.cbHCCode1, dd 0
|
---|
102 | at VMMSWITCHERDEF.offIDCode0, dd 0
|
---|
103 | at VMMSWITCHERDEF.cbIDCode0, dd 0
|
---|
104 | at VMMSWITCHERDEF.offIDCode1, dd 0
|
---|
105 | at VMMSWITCHERDEF.cbIDCode1, dd 0
|
---|
106 | at VMMSWITCHERDEF.offGCCode, dd NAME(vmmRCCallTrampoline) - NAME(Start)
|
---|
107 | at VMMSWITCHERDEF.cbGCCode, dd NAME(End) - NAME(vmmRCCallTrampoline)
|
---|
108 |
|
---|
109 | iend
|
---|
110 |
|
---|