VirtualBox

source: vbox/trunk/src/VBox/VMM/include/VMMInternal.h@ 90192

Last change on this file since 90192 was 90189, checked in by vboxsync, 4 years ago

VMM: Make the setjmp code a bit stricter with when to resume a call. bugref:10064 ticketref:20090 ticketref:20456

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 22.9 KB
Line 
1/* $Id: VMMInternal.h 90189 2021-07-14 16:39:09Z vboxsync $ */
2/** @file
3 * VMM - Internal header file.
4 */
5
6/*
7 * Copyright (C) 2006-2020 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#ifndef VMM_INCLUDED_SRC_include_VMMInternal_h
19#define VMM_INCLUDED_SRC_include_VMMInternal_h
20#ifndef RT_WITHOUT_PRAGMA_ONCE
21# pragma once
22#endif
23
24#include <VBox/cdefs.h>
25#include <VBox/sup.h>
26#include <VBox/vmm/stam.h>
27#include <VBox/vmm/vmm.h>
28#include <VBox/log.h>
29#include <iprt/critsect.h>
30
31#if !defined(IN_VMM_R3) && !defined(IN_VMM_R0) && !defined(IN_VMM_RC)
32# error "Not in VMM! This is an internal header!"
33#endif
34#if HC_ARCH_BITS == 32
35# error "32-bit hosts are no longer supported. Go back to 6.0 or earlier!"
36#endif
37
38
39
40/** @defgroup grp_vmm_int Internals
41 * @ingroup grp_vmm
42 * @internal
43 * @{
44 */
45
46/** @def VBOX_WITH_RC_RELEASE_LOGGING
47 * Enables RC release logging. */
48#define VBOX_WITH_RC_RELEASE_LOGGING
49
50/** @def VBOX_WITH_R0_LOGGING
51 * Enables Ring-0 logging (non-release).
52 *
53 * Ring-0 logging isn't 100% safe yet (thread id reuse / process exit cleanup),
54 * so you have to sign up here by adding your defined(DEBUG_<userid>) to the
55 * \#if, or by adding VBOX_WITH_R0_LOGGING to your LocalConfig.kmk.
56 */
57#if defined(DEBUG_sandervl) || defined(DEBUG_frank) || defined(DEBUG_ramshankar) || defined(DOXYGEN_RUNNING)
58# define VBOX_WITH_R0_LOGGING
59#endif
60
61/** @def VBOX_STRICT_VMM_STACK
62 * Enables VMM stack guard pages to catch stack over- and underruns. */
63#if defined(VBOX_STRICT) || defined(DOXYGEN_RUNNING)
64# define VBOX_STRICT_VMM_STACK
65#endif
66
67
68/**
69 * The ring-0 logger instance wrapper.
70 *
71 * We need to be able to find the VM handle from the logger instance, so we wrap
72 * it in this structure.
73 */
74typedef struct VMMR0LOGGER
75{
76 /** Pointer to Pointer to the VM. */
77 R0PTRTYPE(PVMCC) pVM;
78 /** Size of the allocated logger instance (Logger). */
79 uint32_t cbLogger;
80 /** Flag indicating whether we've create the logger Ring-0 instance yet. */
81 bool fCreated;
82 /** Flag indicating whether we've disabled flushing (world switch) or not. */
83 bool fFlushingDisabled;
84 /** Flag indicating whether we've registered the instance already. */
85 bool fRegistered;
86 bool a8Alignment;
87 /** The CPU ID. */
88 VMCPUID idCpu;
89#if HC_ARCH_BITS == 64
90 uint32_t u32Alignment;
91#endif
92 /** The ring-0 logger instance. This extends beyond the size. */
93 RTLOGGER Logger;
94} VMMR0LOGGER;
95/** Pointer to a ring-0 logger instance wrapper. */
96typedef VMMR0LOGGER *PVMMR0LOGGER;
97
98
99/**
100 * Jump buffer for the setjmp/longjmp like constructs used to
101 * quickly 'call' back into Ring-3.
102 */
103typedef struct VMMR0JMPBUF
104{
105 /** Traditional jmp_buf stuff
106 * @{ */
107#if HC_ARCH_BITS == 32
108 uint32_t ebx;
109 uint32_t esi;
110 uint32_t edi;
111 uint32_t ebp;
112 uint32_t esp;
113 uint32_t eip;
114 uint32_t eflags;
115#endif
116#if HC_ARCH_BITS == 64
117 uint64_t rbx;
118# ifdef RT_OS_WINDOWS
119 uint64_t rsi;
120 uint64_t rdi;
121# endif
122 uint64_t rbp;
123 uint64_t r12;
124 uint64_t r13;
125 uint64_t r14;
126 uint64_t r15;
127 uint64_t rsp;
128 uint64_t rip;
129# ifdef RT_OS_WINDOWS
130 uint128_t xmm6;
131 uint128_t xmm7;
132 uint128_t xmm8;
133 uint128_t xmm9;
134 uint128_t xmm10;
135 uint128_t xmm11;
136 uint128_t xmm12;
137 uint128_t xmm13;
138 uint128_t xmm14;
139 uint128_t xmm15;
140# endif
141 uint64_t rflags;
142#endif
143 /** @} */
144
145 /** Flag that indicates that we've done a ring-3 call. */
146 bool fInRing3Call;
147 /** The number of bytes we've saved. */
148 uint32_t cbSavedStack;
149 /** Pointer to the buffer used to save the stack.
150 * This is assumed to be 8KB. */
151 RTR0PTR pvSavedStack;
152 /** Esp we we match against esp on resume to make sure the stack wasn't relocated. */
153 RTHCUINTREG SpCheck;
154 /** The esp we should resume execution with after the restore. */
155 RTHCUINTREG SpResume;
156 /** ESP/RSP at the time of the jump to ring 3. */
157 RTHCUINTREG SavedEsp;
158 /** EBP/RBP at the time of the jump to ring 3. */
159 RTHCUINTREG SavedEbp;
160 /** EIP/RIP within vmmR0CallRing3LongJmp for assisting unwinding. */
161 RTHCUINTREG SavedEipForUnwind;
162 /** Unwind: The vmmR0CallRing3SetJmp return address value. */
163 RTHCUINTREG UnwindRetPcValue;
164 /** Unwind: The vmmR0CallRing3SetJmp return address stack location. */
165 RTHCUINTREG UnwindRetPcLocation;
166
167 /** The function last being executed here. */
168 RTHCUINTREG pfn;
169 /** The first argument to the function. */
170 RTHCUINTREG pvUser1;
171 /** The second argument to the function. */
172 RTHCUINTREG pvUser2;
173
174#if HC_ARCH_BITS == 32
175 /** Alignment padding. */
176 uint32_t uPadding;
177#endif
178
179 /** Stats: Max amount of stack used. */
180 uint32_t cbUsedMax;
181 /** Stats: Average stack usage. (Avg = cbUsedTotal / cUsedTotal) */
182 uint32_t cbUsedAvg;
183 /** Stats: Total amount of stack used. */
184 uint64_t cbUsedTotal;
185 /** Stats: Number of stack usages. */
186 uint64_t cUsedTotal;
187} VMMR0JMPBUF;
188/** Pointer to a ring-0 jump buffer. */
189typedef VMMR0JMPBUF *PVMMR0JMPBUF;
190
191
192/**
193 * VMM Data (part of VM)
194 */
195typedef struct VMM
196{
197 /** Whether we should use the periodic preemption timers. */
198 bool fUsePeriodicPreemptionTimers;
199 /** Alignment padding. */
200 bool afPadding0[7];
201
202#if 0 /* pointless when timers doesn't run on EMT */
203 /** The EMT yield timer. */
204 TMTIMERHANDLE hYieldTimer;
205 /** The period to the next timeout when suspended or stopped.
206 * This is 0 when running. */
207 uint32_t cYieldResumeMillies;
208 /** The EMT yield timer interval (milliseconds). */
209 uint32_t cYieldEveryMillies;
210 /** The timestamp of the previous yield. (nano) */
211 uint64_t u64LastYield;
212#endif
213
214 /** @name EMT Rendezvous
215 * @{ */
216 /** Semaphore to wait on upon entering ordered execution. */
217 R3PTRTYPE(PRTSEMEVENT) pahEvtRendezvousEnterOrdered;
218 /** Semaphore to wait on upon entering for one-by-one execution. */
219 RTSEMEVENT hEvtRendezvousEnterOneByOne;
220 /** Semaphore to wait on upon entering for all-at-once execution. */
221 RTSEMEVENTMULTI hEvtMulRendezvousEnterAllAtOnce;
222 /** Semaphore to wait on when done. */
223 RTSEMEVENTMULTI hEvtMulRendezvousDone;
224 /** Semaphore the VMMR3EmtRendezvous caller waits on at the end. */
225 RTSEMEVENT hEvtRendezvousDoneCaller;
226 /** Semaphore to wait on upon recursing. */
227 RTSEMEVENTMULTI hEvtMulRendezvousRecursionPush;
228 /** Semaphore to wait on after done with recursion (caller restoring state). */
229 RTSEMEVENTMULTI hEvtMulRendezvousRecursionPop;
230 /** Semaphore the initiator waits on while the EMTs are getting into position
231 * on hEvtMulRendezvousRecursionPush. */
232 RTSEMEVENT hEvtRendezvousRecursionPushCaller;
233 /** Semaphore the initiator waits on while the EMTs sitting on
234 * hEvtMulRendezvousRecursionPop wakes up and leave. */
235 RTSEMEVENT hEvtRendezvousRecursionPopCaller;
236 /** Callback. */
237 R3PTRTYPE(PFNVMMEMTRENDEZVOUS) volatile pfnRendezvous;
238 /** The user argument for the callback. */
239 RTR3PTR volatile pvRendezvousUser;
240 /** Flags. */
241 volatile uint32_t fRendezvousFlags;
242 /** The number of EMTs that has entered. */
243 volatile uint32_t cRendezvousEmtsEntered;
244 /** The number of EMTs that has done their job. */
245 volatile uint32_t cRendezvousEmtsDone;
246 /** The number of EMTs that has returned. */
247 volatile uint32_t cRendezvousEmtsReturned;
248 /** The status code. */
249 volatile int32_t i32RendezvousStatus;
250 /** Spin lock. */
251 volatile uint32_t u32RendezvousLock;
252 /** The recursion depth. */
253 volatile uint32_t cRendezvousRecursions;
254 /** The number of EMTs that have entered the recursion routine. */
255 volatile uint32_t cRendezvousEmtsRecursingPush;
256 /** The number of EMTs that have leaft the recursion routine. */
257 volatile uint32_t cRendezvousEmtsRecursingPop;
258 /** Triggers rendezvous recursion in the other threads. */
259 volatile bool fRendezvousRecursion;
260
261 /** @} */
262
263 /** RTThreadPreemptIsPendingTrusty() result, set by vmmR0InitVM() for
264 * release logging purposes. */
265 bool fIsPreemptPendingApiTrusty : 1;
266 /** The RTThreadPreemptIsPossible() result, set by vmmR0InitVM() for
267 * release logging purposes. */
268 bool fIsPreemptPossible : 1;
269
270 bool afAlignment2[2]; /**< Alignment padding. */
271
272 /** Buffer for storing the standard assertion message for a ring-0 assertion.
273 * Used for saving the assertion message text for the release log and guru
274 * meditation dump. */
275 char szRing0AssertMsg1[512];
276 /** Buffer for storing the custom message for a ring-0 assertion. */
277 char szRing0AssertMsg2[256];
278
279 /** Number of VMMR0_DO_HM_RUN or VMMR0_DO_NEM_RUN calls. */
280 STAMCOUNTER StatRunGC;
281
282 /** Statistics for each of the RC/R0 return codes.
283 * @{ */
284 STAMCOUNTER StatRZRetNormal;
285 STAMCOUNTER StatRZRetInterrupt;
286 STAMCOUNTER StatRZRetInterruptHyper;
287 STAMCOUNTER StatRZRetGuestTrap;
288 STAMCOUNTER StatRZRetRingSwitch;
289 STAMCOUNTER StatRZRetRingSwitchInt;
290 STAMCOUNTER StatRZRetStaleSelector;
291 STAMCOUNTER StatRZRetIRETTrap;
292 STAMCOUNTER StatRZRetEmulate;
293 STAMCOUNTER StatRZRetPatchEmulate;
294 STAMCOUNTER StatRZRetIORead;
295 STAMCOUNTER StatRZRetIOWrite;
296 STAMCOUNTER StatRZRetIOCommitWrite;
297 STAMCOUNTER StatRZRetMMIORead;
298 STAMCOUNTER StatRZRetMMIOWrite;
299 STAMCOUNTER StatRZRetMMIOCommitWrite;
300 STAMCOUNTER StatRZRetMMIOPatchRead;
301 STAMCOUNTER StatRZRetMMIOPatchWrite;
302 STAMCOUNTER StatRZRetMMIOReadWrite;
303 STAMCOUNTER StatRZRetMSRRead;
304 STAMCOUNTER StatRZRetMSRWrite;
305 STAMCOUNTER StatRZRetLDTFault;
306 STAMCOUNTER StatRZRetGDTFault;
307 STAMCOUNTER StatRZRetIDTFault;
308 STAMCOUNTER StatRZRetTSSFault;
309 STAMCOUNTER StatRZRetCSAMTask;
310 STAMCOUNTER StatRZRetSyncCR3;
311 STAMCOUNTER StatRZRetMisc;
312 STAMCOUNTER StatRZRetPatchInt3;
313 STAMCOUNTER StatRZRetPatchPF;
314 STAMCOUNTER StatRZRetPatchGP;
315 STAMCOUNTER StatRZRetPatchIretIRQ;
316 STAMCOUNTER StatRZRetRescheduleREM;
317 STAMCOUNTER StatRZRetToR3Total;
318 STAMCOUNTER StatRZRetToR3FF;
319 STAMCOUNTER StatRZRetToR3Unknown;
320 STAMCOUNTER StatRZRetToR3TMVirt;
321 STAMCOUNTER StatRZRetToR3HandyPages;
322 STAMCOUNTER StatRZRetToR3PDMQueues;
323 STAMCOUNTER StatRZRetToR3Rendezvous;
324 STAMCOUNTER StatRZRetToR3Timer;
325 STAMCOUNTER StatRZRetToR3DMA;
326 STAMCOUNTER StatRZRetToR3CritSect;
327 STAMCOUNTER StatRZRetToR3Iem;
328 STAMCOUNTER StatRZRetToR3Iom;
329 STAMCOUNTER StatRZRetTimerPending;
330 STAMCOUNTER StatRZRetInterruptPending;
331 STAMCOUNTER StatRZRetCallRing3;
332 STAMCOUNTER StatRZRetPATMDuplicateFn;
333 STAMCOUNTER StatRZRetPGMChangeMode;
334 STAMCOUNTER StatRZRetPendingRequest;
335 STAMCOUNTER StatRZRetPGMFlushPending;
336 STAMCOUNTER StatRZRetPatchTPR;
337 STAMCOUNTER StatRZCallPDMCritSectEnter;
338 STAMCOUNTER StatRZCallPDMLock;
339 STAMCOUNTER StatRZCallLogFlush;
340 STAMCOUNTER StatRZCallPGMPoolGrow;
341 STAMCOUNTER StatRZCallPGMMapChunk;
342 STAMCOUNTER StatRZCallPGMAllocHandy;
343 STAMCOUNTER StatRZCallVMSetError;
344 STAMCOUNTER StatRZCallVMSetRuntimeError;
345 STAMCOUNTER StatRZCallPGMLock;
346 /** @} */
347} VMM;
348/** Pointer to VMM. */
349typedef VMM *PVMM;
350
351
352/**
353 * VMMCPU Data (part of VMCPU)
354 */
355typedef struct VMMCPU
356{
357 /** The last RC/R0 return code. */
358 int32_t iLastGZRc;
359 /** Alignment padding. */
360 uint32_t u32Padding0;
361
362 /** VMM stack, pointer to the top of the stack in R3.
363 * Stack is allocated from the hypervisor heap and is page aligned
364 * and always writable in RC. */
365 R3PTRTYPE(uint8_t *) pbEMTStackR3;
366
367 /** Pointer to the R0 logger instance - R3 Ptr.
368 * This is NULL if logging is disabled. */
369 R3PTRTYPE(PVMMR0LOGGER) pR0LoggerR3;
370 /** Pointer to the R0 logger instance - R0 Ptr.
371 * This is NULL if logging is disabled. */
372 R0PTRTYPE(PVMMR0LOGGER) pR0LoggerR0;
373
374 /** Pointer to the R0 release logger instance - R3 Ptr.
375 * This is NULL if logging is disabled. */
376 R3PTRTYPE(PVMMR0LOGGER) pR0RelLoggerR3;
377 /** Pointer to the R0 release instance - R0 Ptr.
378 * This is NULL if logging is disabled. */
379 R0PTRTYPE(PVMMR0LOGGER) pR0RelLoggerR0;
380
381 /** Thread context switching hook (ring-0). */
382 RTTHREADCTXHOOK hCtxHook;
383
384 /** @name Rendezvous
385 * @{ */
386 /** Whether the EMT is executing a rendezvous right now. For detecting
387 * attempts at recursive rendezvous. */
388 bool volatile fInRendezvous;
389 bool afPadding1[10];
390 /** @} */
391
392 /** Whether we can HLT in VMMR0 rather than having to return to EM.
393 * Updated by vmR3SetHaltMethodU(). */
394 bool fMayHaltInRing0;
395 /** The minimum delta for which we can HLT in ring-0 for.
396 * The deadlines we can calculate are from TM, so, if it's too close
397 * we should just return to ring-3 and run the timer wheel, no point
398 * in spinning in ring-0.
399 * Updated by vmR3SetHaltMethodU(). */
400 uint32_t cNsSpinBlockThreshold;
401 /** Number of ring-0 halts (used for depreciating following values). */
402 uint32_t cR0Halts;
403 /** Number of ring-0 halts succeeding (VINF_SUCCESS) recently. */
404 uint32_t cR0HaltsSucceeded;
405 /** Number of ring-0 halts failing (VINF_EM_HALT) recently. */
406 uint32_t cR0HaltsToRing3;
407 /** Padding */
408 uint32_t u32Padding2;
409
410 /** @name Raw-mode context tracing data.
411 * @{ */
412 SUPDRVTRACERUSRCTX TracerCtx;
413 /** @} */
414
415 /** Alignment padding, making sure u64CallRing3Arg and CallRing3JmpBufR0 are nicely aligned. */
416 uint32_t au32Padding3[1];
417
418 /** @name Call Ring-3
419 * Formerly known as host calls.
420 * @{ */
421 /** The disable counter. */
422 uint32_t cCallRing3Disabled;
423 /** The pending operation. */
424 VMMCALLRING3 enmCallRing3Operation;
425 /** The result of the last operation. */
426 int32_t rcCallRing3;
427 /** The argument to the operation. */
428 uint64_t u64CallRing3Arg;
429 /** The Ring-0 notification callback. */
430 R0PTRTYPE(PFNVMMR0CALLRING3NOTIFICATION) pfnCallRing3CallbackR0;
431 /** The Ring-0 notification callback user argument. */
432 R0PTRTYPE(void *) pvCallRing3CallbackUserR0;
433 /** The Ring-0 jmp buffer.
434 * @remarks The size of this type isn't stable in assembly, so don't put
435 * anything that needs to be accessed from assembly after it. */
436 VMMR0JMPBUF CallRing3JmpBufR0;
437 /** @} */
438
439 STAMPROFILE StatR0HaltBlock;
440 STAMPROFILE StatR0HaltBlockOnTime;
441 STAMPROFILE StatR0HaltBlockOverslept;
442 STAMPROFILE StatR0HaltBlockInsomnia;
443 STAMCOUNTER StatR0HaltExec;
444 STAMCOUNTER StatR0HaltExecFromBlock;
445 STAMCOUNTER StatR0HaltExecFromSpin;
446 STAMCOUNTER StatR0HaltToR3;
447 STAMCOUNTER StatR0HaltToR3FromSpin;
448 STAMCOUNTER StatR0HaltToR3Other;
449 STAMCOUNTER StatR0HaltToR3PendingFF;
450 STAMCOUNTER StatR0HaltToR3SmallDelta;
451 STAMCOUNTER StatR0HaltToR3PostNoInt;
452 STAMCOUNTER StatR0HaltToR3PostPendingFF;
453} VMMCPU;
454AssertCompileMemberAlignment(VMMCPU, TracerCtx, 8);
455/** Pointer to VMMCPU. */
456typedef VMMCPU *PVMMCPU;
457
458/**
459 * VMM per-VCpu ring-0 only instance data.
460 */
461typedef struct VMMR0PERVCPU
462{
463 /** @name Arguments passed by VMMR0EntryEx via vmmR0CallRing3SetJmpEx.
464 * @note Cannot be put on the stack as the location may change and upset the
465 * validation of resume-after-ring-3-call logic.
466 * @{ */
467 PGVM pGVM;
468 VMCPUID idCpu;
469 VMMR0OPERATION enmOperation;
470 PSUPVMMR0REQHDR pReq;
471 uint64_t u64Arg;
472 PSUPDRVSESSION pSession;
473 /** @} */
474} VMMR0PERVCPU;
475/** Pointer to VMM ring-0 VMCPU instance data. */
476typedef VMMR0PERVCPU *PVMMR0PERVCPU;
477
478
479RT_C_DECLS_BEGIN
480
481int vmmInitFormatTypes(void);
482void vmmTermFormatTypes(void);
483uint32_t vmmGetBuildType(void);
484
485#ifdef IN_RING3
486int vmmR3SwitcherInit(PVM pVM);
487void vmmR3SwitcherRelocate(PVM pVM, RTGCINTPTR offDelta);
488#endif /* IN_RING3 */
489
490#ifdef IN_RING0
491
492/**
493 * World switcher assembly routine.
494 * It will call VMMRCEntry().
495 *
496 * @returns return code from VMMRCEntry().
497 * @param pVM The cross context VM structure.
498 * @param uArg See VMMRCEntry().
499 * @internal
500 */
501DECLASM(int) vmmR0WorldSwitch(PVM pVM, unsigned uArg);
502
503/**
504 * Callback function for vmmR0CallRing3SetJmp.
505 *
506 * @returns VBox status code.
507 * @param pVM The cross context VM structure.
508 */
509typedef DECLCALLBACKTYPE(int, FNVMMR0SETJMP,(PVMCC pVM, PVMCPUCC pVCpu));
510/** Pointer to FNVMMR0SETJMP(). */
511typedef FNVMMR0SETJMP *PFNVMMR0SETJMP;
512
513/**
514 * The setjmp variant used for calling Ring-3.
515 *
516 * This differs from the normal setjmp in that it will resume VMMRZCallRing3 if we're
517 * in the middle of a ring-3 call. Another differences is the function pointer and
518 * argument. This has to do with resuming code and the stack frame of the caller.
519 *
520 * @returns VINF_SUCCESS on success or whatever is passed to vmmR0CallRing3LongJmp.
521 * @param pJmpBuf The jmp_buf to set.
522 * @param pfn The function to be called when not resuming.
523 * @param pVM The cross context VM structure.
524 * @param pVCpu The cross context virtual CPU structure of the calling EMT.
525 */
526DECLASM(int) vmmR0CallRing3SetJmp(PVMMR0JMPBUF pJmpBuf, PFNVMMR0SETJMP pfn, PVM pVM, PVMCPU pVCpu);
527
528
529/**
530 * Callback function for vmmR0CallRing3SetJmp2.
531 *
532 * @returns VBox status code.
533 * @param pvUser The user argument.
534 */
535typedef DECLCALLBACKTYPE(int, FNVMMR0SETJMP2,(PGVM pGVM, VMCPUID idCpu));
536/** Pointer to FNVMMR0SETJMP2(). */
537typedef FNVMMR0SETJMP2 *PFNVMMR0SETJMP2;
538
539/**
540 * Same as vmmR0CallRing3SetJmp except for the function signature.
541 *
542 * @returns VINF_SUCCESS on success or whatever is passed to vmmR0CallRing3LongJmp.
543 * @param pJmpBuf The jmp_buf to set.
544 * @param pfn The function to be called when not resuming.
545 * @param pGVM The ring-0 VM structure.
546 * @param idCpu The ID of the calling EMT.
547 */
548DECLASM(int) vmmR0CallRing3SetJmp2(PVMMR0JMPBUF pJmpBuf, PFNVMMR0SETJMP2 pfn, PGVM pGVM, VMCPUID idCpu);
549
550
551/**
552 * Callback function for vmmR0CallRing3SetJmpEx.
553 *
554 * @returns VBox status code.
555 * @param pvUser The user argument.
556 */
557typedef DECLCALLBACKTYPE(int, FNVMMR0SETJMPEX,(void *pvUser));
558/** Pointer to FNVMMR0SETJMPEX(). */
559typedef FNVMMR0SETJMPEX *PFNVMMR0SETJMPEX;
560
561/**
562 * Same as vmmR0CallRing3SetJmp except for the function signature.
563 *
564 * @returns VINF_SUCCESS on success or whatever is passed to vmmR0CallRing3LongJmp.
565 * @param pJmpBuf The jmp_buf to set.
566 * @param pfn The function to be called when not resuming.
567 * @param pvUser The argument of that function.
568 * @param uCallKey Unused call parameter that should be used to help
569 * uniquely identify the call.
570 */
571DECLASM(int) vmmR0CallRing3SetJmpEx(PVMMR0JMPBUF pJmpBuf, PFNVMMR0SETJMPEX pfn, void *pvUser, uintptr_t uCallKey);
572
573
574/**
575 * Worker for VMMRZCallRing3.
576 * This will save the stack and registers.
577 *
578 * @returns rc.
579 * @param pJmpBuf Pointer to the jump buffer.
580 * @param rc The return code.
581 */
582DECLASM(int) vmmR0CallRing3LongJmp(PVMMR0JMPBUF pJmpBuf, int rc);
583
584/**
585 * Internal R0 logger worker: Logger wrapper.
586 */
587VMMR0DECL(void) vmmR0LoggerWrapper(const char *pszFormat, ...);
588
589/**
590 * Internal R0 logger worker: Flush logger.
591 *
592 * @param pLogger The logger instance to flush.
593 * @remark This function must be exported!
594 */
595VMMR0DECL(void) vmmR0LoggerFlush(PRTLOGGER pLogger);
596
597/**
598 * Internal R0 logger worker: Custom prefix.
599 *
600 * @returns Number of chars written.
601 *
602 * @param pLogger The logger instance.
603 * @param pchBuf The output buffer.
604 * @param cchBuf The size of the buffer.
605 * @param pvUser User argument (ignored).
606 */
607VMMR0DECL(size_t) vmmR0LoggerPrefix(PRTLOGGER pLogger, char *pchBuf, size_t cchBuf, void *pvUser);
608
609# ifdef VBOX_WITH_TRIPLE_FAULT_HACK
610int vmmR0TripleFaultHackInit(void);
611void vmmR0TripleFaultHackTerm(void);
612# endif
613
614#endif /* IN_RING0 */
615
616RT_C_DECLS_END
617
618/** @} */
619
620#endif /* !VMM_INCLUDED_SRC_include_VMMInternal_h */
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