VirtualBox

source: vbox/trunk/src/VBox/HostDrivers/Support/win/SUPDrvA-win.asm@ 14905

Last change on this file since 14905 was 14825, checked in by vboxsync, 16 years ago

SUPDrv: Permit userland to make kernel mappings of SUPR0PageAllocEx allocations. (darwin + VGA + VT-x, #1865/#3202)

File size: 14.7 KB
Line 
1; $Id$
2;; @file
3; VirtualBox Support Driver - Windows NT specific assembly parts.
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;*******************************************************************************
32;* Header Files *
33;*******************************************************************************
34%include "iprt/ntwrap.mac"
35
36BEGINCODE
37%ifdef RT_ARCH_AMD64
38%define _DbgPrint DbgPrint
39%endif
40extern _DbgPrint
41
42%if 1 ; see alternative in SUPDrv-win.cpp
43;;
44; Kind of alias for DbgPrint
45BEGINPROC SUPR0Printf
46 jmp _DbgPrint
47ENDPROC SUPR0Printf
48%endif
49
50
51%ifdef RT_WITH_W64_UNWIND_HACK
52 %ifdef RT_ARCH_AMD64
53
54;
55; This has the same order as the list in SUPDrv.c
56;
57NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0ComponentRegisterFactory
58NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0ComponentDeregisterFactory
59NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0ComponentQueryFactory
60NtWrapDyn2DrvFunctionWith5Params supdrvNtWrap, SUPR0ObjRegister
61NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0ObjAddRef
62NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0ObjRelease
63NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0ObjVerifyAccess
64NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0LockMem
65NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0UnlockMem
66NtWrapDyn2DrvFunctionWith5Params supdrvNtWrap, SUPR0ContAlloc
67NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0ContFree
68NtWrapDyn2DrvFunctionWith5Params supdrvNtWrap, SUPR0LowAlloc
69NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0LowFree
70NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0MemAlloc
71NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0MemGetPhys
72NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0MemFree
73NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0PageAlloc
74NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0PageFree
75;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0Printf - cannot wrap this buster.
76NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, SUPR0GetPagingMode
77NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMemAlloc
78NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMemAllocZ
79NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMemFree
80NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMemDup
81NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMemDupEx
82NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMemRealloc
83NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjAllocLow
84NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjAllocPage
85NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjAllocPhys
86NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjAllocPhysNC
87NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjAllocCont
88NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjEnterPhys
89NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjLockUser
90NtWrapDyn2DrvFunctionWith5Params supdrvNtWrap, RTR0MemObjMapKernel
91NtWrapDyn2DrvFunctionWith7Params supdrvNtWrap, RTR0MemObjMapKernelEx
92NtWrapDyn2DrvFunctionWith6Params supdrvNtWrap, RTR0MemObjMapUser
93;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjAddress - not necessary
94;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjAddressR3 - not necessary
95;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjSize - not necessary
96;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjIsMapping - not necessary
97;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjGetPagePhysAddr - not necessary
98NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0MemObjFree
99;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTProcSelf - not necessary
100;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTR0ProcHandleSelf - not necessary
101NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemFastMutexCreate
102NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemFastMutexDestroy
103NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemFastMutexRequest
104NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemFastMutexRelease
105NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventCreate
106NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventSignal
107NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventWait
108NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventWaitNoResume
109NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventDestroy
110NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventMultiCreate
111NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventMultiSignal
112NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventMultiReset
113NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventMultiWait
114NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventMultiWaitNoResume
115NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSemEventMultiDestroy
116NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSpinlockCreate
117NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSpinlockDestroy
118NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSpinlockAcquire
119NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSpinlockRelease
120NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSpinlockAcquireNoInts
121NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTSpinlockReleaseNoInts
122;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTTimeNanoTS - not necessary
123;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTTimeMilliTS - not necessary
124;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTTimeSystemNanoTS - not necessary
125;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTTimeSystemMilliTS - not necessary
126;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadNativeSelf - not necessary
127NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadSleep
128NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadYield
129%if 0 ; Thread APIs, Part 2
130;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadSelf
131NtWrapDyn2DrvFunctionWith7Params supdrvNtWrap, RTThreadCreate
132NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadGetNative
133NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadWait
134NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadWaitNoResume
135NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadGetName
136NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadSelfName
137NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadGetType
138NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadUserSignal
139NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadUserReset
140NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadUserWait
141NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTThreadUserWaitNoResume
142%endif
143;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTLogDefaultInstance - a bit of a gamble, but we do not want the overhead!
144;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpCpuId - not necessary
145;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpCpuIdFromSetIndex - not necessary
146;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpCpuIdToSetIndex - not necessary
147;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpIsCpuPossible - not necessary
148;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpGetCount - not necessary
149;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpGetMaxCpuId - not necessary
150;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpGetOnlineCount - not necessary
151;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpGetOnlineSet - not necessary
152;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpGetSet - not necessary
153;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpIsCpuOnline - not necessary
154NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpOnAll
155NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpOnOthers
156NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTMpOnSpecific
157;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTLogRelDefaultInstance - not necessary.
158NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTLogSetDefaultInstanceThread
159;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTLogLogger - can't wrap this buster.
160;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTLogLoggerEx - can't wrap this buster.
161NtWrapDyn2DrvFunctionWith5Params supdrvNtWrap, RTLogLoggerExV
162;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTLogPrintf - can't wrap this buster. ;; @todo provide va_list log wrappers in RuntimeR0.
163NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, RTLogPrintfV
164NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, AssertMsg1
165;NtWrapDyn2DrvFunctionWithAllRegParams supdrvNtWrap, AssertMsg2 - can't wrap this buster.
166NtWrapDrv2DynFunctionWithAllRegParams supdrvNtWrap, RTPowerSignalEvent
167
168
169;;
170; @cproto DECLASM(int) supdrvNtWrapVMMR0EntryEx(PFNRT pfnVMMR0EntryEx, PVM pVM, unsigned uOperation, PSUPVMMR0REQHDR pReq, uint64_t u64Arg, PSUPDRVSESSION pSession);
171;
172; @param pfnVMMR0EntryEx rcx
173; @param pVM rdx
174; @param uOperation r8
175; @param pReq r9
176; @param u64Arg [rsp + 28h] / [rbp + 30h]
177; @param pSession [rsp + 30h] / [rbp + 38h]
178;
179BEGINPROC supdrvNtWrapVMMR0EntryEx
180 NtWrapProlog supdrvNtWrapVMMR0EntryEx
181 NtWrapCreateMarker
182
183 mov rax, rcx
184 mov rcx, rdx
185 mov rdx, r8
186 mov r8, r9
187 mov r9, [rbp + 30h]
188 mov r11, [rbp + 38h]
189 mov [rsp + 20h], r11
190 call rax
191
192 NtWrapDestroyMarker
193 NtWrapEpilog supdrvNtWrapVMMR0EntryEx
194ENDPROC supdrvNtWrapVMMR0EntryEx
195
196
197;;
198; @cproto DECLASM(int) supdrvNtWrapVMMR0EntryFast(PFNRT pfnVMMR0EntryFast, PVM pVM, unsigned idCPU, unsigned uOperation);
199;
200; @param pfnVMMR0EntryFast rcx
201; @param pVM rdx
202; @param idCPU r8
203; @param uOperation r9
204;
205BEGINPROC supdrvNtWrapVMMR0EntryFast
206 NtWrapProlog supdrvNtWrapVMMR0EntryFast
207 NtWrapCreateMarker
208
209 mov rax, rcx
210 mov rcx, rdx
211 mov rdx, r8
212 mov r8, r9
213 call rax
214
215 NtWrapDestroyMarker
216 NtWrapEpilog supdrvNtWrapVMMR0EntryFast
217ENDPROC supdrvNtWrapVMMR0EntryFast
218
219
220;;
221; @cproto DECLASM(void) supdrvNtWrapObjDestructor(PFNRT pfnDestruction, void *pvObj, void *pvUser1, void *pvUser2);
222;
223; @param pfnDestruction rcx
224; @param pvObj rdx
225; @param pvUser1 r8
226; @param pvUser2 r9
227;
228BEGINPROC supdrvNtWrapObjDestructor
229 NtWrapProlog supdrvNtWrapObjDestructor
230 NtWrapCreateMarker
231
232 mov rax, rcx
233 mov rcx, rdx
234 mov rdx, r8
235 mov r8, r9
236 call rax
237
238 NtWrapDestroyMarker
239 NtWrapEpilog supdrvNtWrapObjDestructor
240ENDPROC supdrvNtWrapObjDestructor
241
242
243;;
244; @cproto DECLASM(void *) supdrvNtWrapQueryFactoryInterface(PFNRT pfnQueryFactoryInterface, struct SUPDRVFACTORY const *pSupDrvFactory,
245; PSUPDRVSESSION pSession, const char *pszInterfaceUuid);
246;
247; @param pfnQueryFactoryInterface rcx
248; @param pSupDrvFactory rdx
249; @param pSession r8
250; @param pszInterfaceUuid r9
251;
252BEGINPROC supdrvNtWrapQueryFactoryInterface
253 NtWrapProlog supdrvNtWrapQueryFactoryInterface
254 NtWrapCreateMarker
255
256 mov rax, rcx
257 mov rcx, rdx
258 mov rdx, r8
259 mov r8, r9
260 call rax
261
262 NtWrapDestroyMarker
263 NtWrapEpilog supdrvNtWrapQueryFactoryInterface
264ENDPROC supdrvNtWrapQueryFactoryInterface
265
266
267;;
268; @cproto DECLASM(int) supdrvNtWrapModuleInit(PFNRT pfnModuleInit);
269;
270; @param pfnModuleInit rcx
271;
272BEGINPROC supdrvNtWrapModuleInit
273 NtWrapProlog supdrvNtWrapModuleInit
274 NtWrapCreateMarker
275
276 call rcx
277
278 NtWrapDestroyMarker
279 NtWrapEpilog supdrvNtWrapModuleInit
280ENDPROC supdrvNtWrapModuleInit
281
282
283;;
284; @cproto DECLASM(void) supdrvNtWrapModuleTerm(PFNRT pfnModuleTerm);
285;
286; @param pfnModuleInit rcx
287;
288BEGINPROC supdrvNtWrapModuleTerm
289 NtWrapProlog supdrvNtWrapModuleTerm
290 NtWrapCreateMarker
291
292 call rcx
293
294 NtWrapDestroyMarker
295 NtWrapEpilog supdrvNtWrapModuleTerm
296ENDPROC supdrvNtWrapModuleTerm
297
298
299;;
300; @cproto DECLASM(int) supdrvNtWrapServiceReqHandler(PFNRT pfnServiceReqHandler, PSUPDRVSESSION pSession, uint32_t uOperation, uint64_t u64Arg, PSUPR0SERVICEREQHDR pReqHdr);
301;
302; @param pfnSerivceReqHandler rcx
303; @param pSession rdx
304; @param uOperation r8
305; @param u64Arg r9
306; @param pReq [rsp + 28h] / [rbp + 30h]
307;
308BEGINPROC supdrvNtWrapServiceReqHandler
309 NtWrapProlog supdrvNtWrapServiceReqHandler
310 NtWrapCreateMarker
311
312 mov rax, rcx
313 mov rcx, rdx
314 mov rdx, r8
315 mov r8, r9
316 mov r9, [rbp + 30h]
317 call rax
318
319 NtWrapDestroyMarker
320 NtWrapEpilog supdrvNtWrapServiceReqHandler
321ENDPROC supdrvNtWrapServiceReqHandler
322
323
324 %endif ; RT_ARCH_AMD64
325%endif ; RT_WITH_W64_UNWIND_HACK
326
Note: See TracBrowser for help on using the repository browser.

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