VirtualBox

source: vbox/trunk/include/VBox/vm.h@ 14043

Last change on this file since 14043 was 13960, checked in by vboxsync, 16 years ago

Moved guest and host CPU contexts into per-VCPU array.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 24.4 KB
Line 
1/** @file
2 * VM - The Virtual Machine, data.
3 */
4
5/*
6 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 *
25 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
26 * Clara, CA 95054 USA or visit http://www.sun.com if you need
27 * additional information or have any questions.
28 */
29
30#ifndef ___VBox_vm_h
31#define ___VBox_vm_h
32
33#include <VBox/cdefs.h>
34#include <VBox/types.h>
35#include <VBox/cpum.h>
36#include <VBox/stam.h>
37#include <VBox/vmapi.h>
38#include <VBox/sup.h>
39
40
41/** @defgroup grp_vm The Virtual Machine
42 * @{
43 */
44
45/** Maximum number of virtual CPUs per VM. */
46#define VMCPU_MAX_CPU_COUNT 255
47
48/**
49 * The state of a virtual CPU.
50 *
51 * The VM running states are a sub-states of the VMSTATE_RUNNING state. While
52 * VMCPUSTATE_NOT_RUNNING is a place holder for the other VM states.
53 */
54typedef enum VMCPUSTATE
55{
56 /** The customary invalid zero. */
57 VMCPUSTATE_INVALID = 0,
58
59 /** Running guest code (VM running). */
60 VMCPUSTATE_RUN_EXEC,
61 /** Running guest code in the recompiler (VM running). */
62 VMCPUSTATE_RUN_EXEC_REM,
63 /** Halted (VM running). */
64 VMCPUSTATE_RUN_HALTED,
65 /** All the other bits we do while running a VM (VM running). */
66 VMCPUSTATE_RUN_MISC,
67 /** VM not running, we're servicing requests or whatever. */
68 VMCPUSTATE_NOT_RUNNING,
69 /** The end of valid virtual CPU states. */
70 VMCPUSTATE_END,
71
72 /** Ensure 32-bit type. */
73 VMCPUSTATE_32BIT_HACK = 0x7fffffff
74} VMCPUSTATE;
75
76
77/**
78 * Per virtual CPU data.
79 */
80typedef struct VMCPU
81{
82 /** Per CPU forced action.
83 * See the VMCPU_FF_* \#defines. Updated atomically. */
84 uint32_t volatile fForcedActions;
85 /** The CPU state. */
86 VMCPUSTATE volatile enmState;
87
88 /** Ring-3 Host Context VM Pointer. */
89 PVMR3 pVMR3;
90 /** Ring-0 Host Context VM Pointer. */
91 PVMR0 pVMR0;
92 /** Raw-mode Context VM Pointer. */
93 PVMRC pVMRC;
94 /** The CPU ID.
95 * This is the index into the VM::aCpu array. */
96 VMCPUID idCpu;
97 /** The native thread handle. */
98 RTNATIVETHREAD hNativeThread;
99
100 /** Align the next bit on a 64-byte boundary. */
101 uint32_t au32Alignment[HC_ARCH_BITS == 32 ? 9 : 6];
102
103 /** CPUM part. */
104 union
105 {
106#ifdef ___CPUMInternal_h
107 struct CPUMCPU s;
108#endif
109 char padding[2048]; /* multiple of 32 */
110 } cpum;
111 /** VMM part. */
112 union
113 {
114#ifdef ___VMMInternal_h
115 struct VMMCPU s;
116#endif
117 char padding[32]; /* multiple of 32 */
118 } vmm;
119
120 /** PGM part. */
121 union
122 {
123#ifdef ___PGMInternal_h
124 struct PGMCPU s;
125#endif
126 char padding[32]; /* multiple of 32 */
127 } pgm;
128
129 /** HWACCM part. */
130 union
131 {
132#ifdef ___HWACCMInternal_h
133 struct HWACCMCPU s;
134#endif
135 char padding[1024]; /* multiple of 32 */
136 } hwaccm;
137
138 /** EM part. */
139 union
140 {
141#ifdef ___EMInternal_h
142 struct EMCPU s;
143#endif
144 char padding[32]; /* multiple of 32 */
145 } em;
146
147 /** TM part. */
148 union
149 {
150#ifdef ___TMInternal_h
151 struct TMCPU s;
152#endif
153 char padding[32]; /* multiple of 32 */
154 } tm;
155} VMCPU;
156
157/** Pointer to a VMCPU. */
158#ifndef ___VBox_types_h
159typedef struct VMCPU *PVMCPU;
160#endif
161
162/** The name of the Guest Context VMM Core module. */
163#define VMMGC_MAIN_MODULE_NAME "VMMGC.gc"
164/** The name of the Ring 0 Context VMM Core module. */
165#define VMMR0_MAIN_MODULE_NAME "VMMR0.r0"
166
167/** VM Forced Action Flags.
168 *
169 * Use the VM_FF_SET() and VM_FF_CLEAR() macros to change the force
170 * action mask of a VM.
171 *
172 * @{
173 */
174/** This action forces the VM to service check and pending interrups on the APIC. */
175#define VM_FF_INTERRUPT_APIC RT_BIT_32(0)
176/** This action forces the VM to service check and pending interrups on the PIC. */
177#define VM_FF_INTERRUPT_PIC RT_BIT_32(1)
178/** This action forces the VM to schedule and run pending timer (TM). */
179#define VM_FF_TIMER RT_BIT_32(2)
180/** PDM Queues are pending. */
181#define VM_FF_PDM_QUEUES RT_BIT_32(3)
182/** PDM DMA transfers are pending. */
183#define VM_FF_PDM_DMA RT_BIT_32(4)
184/** PDM critical section unlocking is pending, process promptly upon return to R3. */
185#define VM_FF_PDM_CRITSECT RT_BIT_32(5)
186
187/** This action forces the VM to call DBGF so DBGF can service debugger
188 * requests in the emulation thread.
189 * This action flag stays asserted till DBGF clears it.*/
190#define VM_FF_DBGF RT_BIT_32(8)
191/** This action forces the VM to service pending requests from other
192 * thread or requests which must be executed in another context. */
193#define VM_FF_REQUEST RT_BIT_32(9)
194/** Terminate the VM immediately. */
195#define VM_FF_TERMINATE RT_BIT_32(10)
196/** Reset the VM. (postponed) */
197#define VM_FF_RESET RT_BIT_32(11)
198
199/** This action forces the VM to resync the page tables before going
200 * back to execute guest code. (GLOBAL FLUSH) */
201#define VM_FF_PGM_SYNC_CR3 RT_BIT_32(16)
202/** Same as VM_FF_PGM_SYNC_CR3 except that global pages can be skipped.
203 * (NON-GLOBAL FLUSH) */
204#define VM_FF_PGM_SYNC_CR3_NON_GLOBAL RT_BIT_32(17)
205/** PGM needs to allocate handy pages. */
206#define VM_FF_PGM_NEED_HANDY_PAGES RT_BIT_32(18)
207/** Check the interupt and trap gates */
208#define VM_FF_TRPM_SYNC_IDT RT_BIT_32(19)
209/** Check Guest's TSS ring 0 stack */
210#define VM_FF_SELM_SYNC_TSS RT_BIT_32(20)
211/** Check Guest's GDT table */
212#define VM_FF_SELM_SYNC_GDT RT_BIT_32(21)
213/** Check Guest's LDT table */
214#define VM_FF_SELM_SYNC_LDT RT_BIT_32(22)
215/** Inhibit interrupts pending. See EMGetInhibitInterruptsPC(). */
216#define VM_FF_INHIBIT_INTERRUPTS RT_BIT_32(23)
217
218/** CSAM needs to scan the page that's being executed */
219#define VM_FF_CSAM_SCAN_PAGE RT_BIT_32(24)
220/** CSAM needs to do some homework. */
221#define VM_FF_CSAM_PENDING_ACTION RT_BIT_32(25)
222
223/** Force return to Ring-3. */
224#define VM_FF_TO_R3 RT_BIT_32(28)
225
226/** REM needs to be informed about handler changes. */
227#define VM_FF_REM_HANDLER_NOTIFY RT_BIT_32(29)
228
229/** Suspend the VM - debug only. */
230#define VM_FF_DEBUG_SUSPEND RT_BIT_32(31)
231
232/** Externally forced actions. Used to quit the idle/wait loop. */
233#define VM_FF_EXTERNAL_SUSPENDED_MASK (VM_FF_TERMINATE | VM_FF_DBGF | VM_FF_REQUEST)
234/** Externally forced actions. Used to quit the idle/wait loop. */
235#define VM_FF_EXTERNAL_HALTED_MASK (VM_FF_TERMINATE | VM_FF_DBGF | VM_FF_TIMER | VM_FF_INTERRUPT_APIC | VM_FF_INTERRUPT_PIC | VM_FF_REQUEST | VM_FF_PDM_QUEUES | VM_FF_PDM_DMA)
236/** High priority pre-execution actions. */
237#define VM_FF_HIGH_PRIORITY_PRE_MASK (VM_FF_TERMINATE | VM_FF_DBGF | VM_FF_INTERRUPT_APIC | VM_FF_INTERRUPT_PIC | VM_FF_TIMER | VM_FF_DEBUG_SUSPEND \
238 | VM_FF_PGM_SYNC_CR3 | VM_FF_PGM_SYNC_CR3_NON_GLOBAL | VM_FF_SELM_SYNC_TSS | VM_FF_TRPM_SYNC_IDT | VM_FF_SELM_SYNC_GDT | VM_FF_SELM_SYNC_LDT | VM_FF_PGM_NEED_HANDY_PAGES)
239/** High priority pre raw-mode execution mask. */
240#define VM_FF_HIGH_PRIORITY_PRE_RAW_MASK (VM_FF_PGM_SYNC_CR3 | VM_FF_PGM_SYNC_CR3_NON_GLOBAL | VM_FF_SELM_SYNC_TSS | VM_FF_TRPM_SYNC_IDT | VM_FF_SELM_SYNC_GDT | VM_FF_SELM_SYNC_LDT | VM_FF_PGM_NEED_HANDY_PAGES \
241 | VM_FF_INHIBIT_INTERRUPTS)
242/** High priority post-execution actions. */
243#define VM_FF_HIGH_PRIORITY_POST_MASK (VM_FF_PDM_CRITSECT | VM_FF_CSAM_PENDING_ACTION)
244/** Normal priority post-execution actions. */
245#define VM_FF_NORMAL_PRIORITY_POST_MASK (VM_FF_TERMINATE | VM_FF_DBGF | VM_FF_RESET | VM_FF_CSAM_SCAN_PAGE)
246/** Normal priority actions. */
247#define VM_FF_NORMAL_PRIORITY_MASK (VM_FF_REQUEST | VM_FF_PDM_QUEUES | VM_FF_PDM_DMA | VM_FF_REM_HANDLER_NOTIFY)
248/** Flags to check before resuming guest execution. */
249#define VM_FF_RESUME_GUEST_MASK (VM_FF_TO_R3)
250/** All the forced flags. */
251#define VM_FF_ALL_MASK (~0U)
252/** All the forced flags. */
253#define VM_FF_ALL_BUT_RAW_MASK (~(VM_FF_HIGH_PRIORITY_PRE_RAW_MASK | VM_FF_CSAM_PENDING_ACTION | VM_FF_PDM_CRITSECT))
254
255/** @} */
256
257/** @def VM_FF_SET
258 * Sets a force action flag.
259 *
260 * @param pVM VM Handle.
261 * @param fFlag The flag to set.
262 */
263#if 1
264# define VM_FF_SET(pVM, fFlag) ASMAtomicOrU32(&(pVM)->fForcedActions, (fFlag))
265#else
266# define VM_FF_SET(pVM, fFlag) \
267 do { ASMAtomicOrU32(&(pVM)->fForcedActions, (fFlag)); \
268 RTLogPrintf("VM_FF_SET : %08x %s - %s(%d) %s\n", (pVM)->fForcedActions, #fFlag, __FILE__, __LINE__, __FUNCTION__); \
269 } while (0)
270#endif
271
272/** @def VMCPU_FF_SET
273 * Sets a force action flag for given VCPU.
274 *
275 * @param pVM VM Handle.
276 * @param idCpu Virtual CPU ID.
277 * @param fFlag The flag to set.
278 */
279#ifdef VBOX_WITH_SMP_GUESTS
280# define VMCPU_FF_SET(pVM, idCpu, fFlag) ASMAtomicOrU32(&(pVM)->aCpu[idCpu].fForcedActions, (fFlag))
281#else
282# define VMCPU_FF_SET(pVM, idCpu, fFlag) VM_FF_SET(pVM, fFlag)
283#endif
284
285/** @def VM_FF_CLEAR
286 * Clears a force action flag.
287 *
288 * @param pVM VM Handle.
289 * @param fFlag The flag to clear.
290 */
291#if 1
292# define VM_FF_CLEAR(pVM, fFlag) ASMAtomicAndU32(&(pVM)->fForcedActions, ~(fFlag))
293#else
294# define VM_FF_CLEAR(pVM, fFlag) \
295 do { ASMAtomicAndU32(&(pVM)->fForcedActions, ~(fFlag)); \
296 RTLogPrintf("VM_FF_CLEAR: %08x %s - %s(%d) %s\n", (pVM)->fForcedActions, #fFlag, __FILE__, __LINE__, __FUNCTION__); \
297 } while (0)
298#endif
299
300/** @def VMCPU_FF_CLEAR
301 * Clears a force action flag for given VCPU.
302 *
303 * @param pVM VM Handle.
304 * @param idCpu Virtual CPU ID.
305 * @param fFlag The flag to clear.
306 */
307#ifdef VBOX_WITH_SMP_GUESTS
308# define VMCPU_FF_CLEAR(pVM, idCpu, fFlag) ASMAtomicAndU32(&(pVM)->aCpu[idCpu].fForcedActions, ~(fFlag))
309#else
310# define VMCPU_FF_CLEAR(pVM, idCpu, fFlag) VM_FF_CLEAR(pVM, fFlag)
311#endif
312
313/** @def VM_FF_ISSET
314 * Checks if a force action flag is set.
315 *
316 * @param pVM VM Handle.
317 * @param fFlag The flag to check.
318 */
319#define VM_FF_ISSET(pVM, fFlag) (((pVM)->fForcedActions & (fFlag)) == (fFlag))
320
321/** @def VMCPU_FF_ISSET
322 * Checks if a force action flag is set for given VCPU.
323 *
324 * @param pVM VM Handle.
325 * @param idCpu Virtual CPU ID.
326 * @param fFlag The flag to check.
327 */
328#ifdef VBOX_WITH_SMP_GUESTS
329# define VMCPU_FF_ISSET(pVM, idCpu, fFlag) (((pVM)->aCpu[idCpu].fForcedActions & (fFlag)) == (fFlag))
330#else
331# define VMCPU_FF_ISSET(pVM, idCpu, fFlag) VM_FF_ISSET(pVM, fFlag)
332#endif
333
334/** @def VM_FF_ISPENDING
335 * Checks if one or more force action in the specified set is pending.
336 *
337 * @param pVM VM Handle.
338 * @param fFlags The flags to check for.
339 */
340#define VM_FF_ISPENDING(pVM, fFlags) ((pVM)->fForcedActions & (fFlags))
341
342/** @def VMCPU_FF_ISPENDING
343 * Checks if one or more force action in the specified set is pending for given VCPU.
344 *
345 * @param pVM VM Handle.
346 * @param idCpu Virtual CPU ID.
347 * @param fFlags The flags to check for.
348 */
349#ifdef VBOX_WITH_SMP_GUESTS
350# define VMCPU_FF_ISPENDING(pVM, idCpu, fFlags) ((pVM)->aCpu[idCpu].fForcedActions & (fFlags))
351#else
352# define VMCPU_FF_ISPENDING(pVM, idCpu, fFlags) VM_FF_ISPENDING(pVM, fFlags)
353#endif
354
355/** @def VM_IS_EMT
356 * Checks if the current thread is the emulation thread (EMT).
357 *
358 * @remark The ring-0 variation will need attention if we expand the ring-0
359 * code to let threads other than EMT mess around with the VM.
360 */
361#ifdef IN_RC
362# define VM_IS_EMT(pVM) true
363#elif defined(IN_RING0)
364# define VM_IS_EMT(pVM) true
365#else
366/** @todo need to rework this macro for the case of multiple emulation threads for SMP */
367# define VM_IS_EMT(pVM) (VMR3GetVMCPUNativeThread(pVM) == RTThreadNativeSelf())
368#endif
369
370/** @def VM_ASSERT_EMT
371 * Asserts that the current thread IS the emulation thread (EMT).
372 */
373#ifdef IN_RC
374# define VM_ASSERT_EMT(pVM) Assert(VM_IS_EMT(pVM))
375#elif defined(IN_RING0)
376# define VM_ASSERT_EMT(pVM) Assert(VM_IS_EMT(pVM))
377#else
378# define VM_ASSERT_EMT(pVM) \
379 AssertMsg(VM_IS_EMT(pVM), \
380 ("Not emulation thread! Thread=%RTnthrd ThreadEMT=%RTnthrd\n", RTThreadNativeSelf(), VMR3GetVMCPUNativeThread(pVM)))
381#endif
382
383/** @def VM_ASSERT_EMT_RETURN
384 * Asserts that the current thread IS the emulation thread (EMT) and returns if it isn't.
385 */
386#ifdef IN_RC
387# define VM_ASSERT_EMT_RETURN(pVM, rc) AssertReturn(VM_IS_EMT(pVM), (rc))
388#elif defined(IN_RING0)
389# define VM_ASSERT_EMT_RETURN(pVM, rc) AssertReturn(VM_IS_EMT(pVM), (rc))
390#else
391# define VM_ASSERT_EMT_RETURN(pVM, rc) \
392 AssertMsgReturn(VM_IS_EMT(pVM), \
393 ("Not emulation thread! Thread=%RTnthrd ThreadEMT=%RTnthrd\n", RTThreadNativeSelf(), VMR3GetVMCPUNativeThread(pVM)), \
394 (rc))
395#endif
396
397
398/**
399 * Asserts that the current thread is NOT the emulation thread.
400 */
401#define VM_ASSERT_OTHER_THREAD(pVM) \
402 AssertMsg(!VM_IS_EMT(pVM), ("Not other thread!!\n"))
403
404
405/** @def VM_ASSERT_STATE_RETURN
406 * Asserts a certain VM state.
407 */
408#define VM_ASSERT_STATE(pVM, _enmState) \
409 AssertMsg((pVM)->enmVMState == (_enmState), \
410 ("state %s, expected %s\n", VMGetStateName(pVM->enmVMState), VMGetStateName(_enmState)))
411
412/** @def VM_ASSERT_STATE_RETURN
413 * Asserts a certain VM state and returns if it doesn't match.
414 */
415#define VM_ASSERT_STATE_RETURN(pVM, _enmState, rc) \
416 AssertMsgReturn((pVM)->enmVMState == (_enmState), \
417 ("state %s, expected %s\n", VMGetStateName(pVM->enmVMState), VMGetStateName(_enmState)), \
418 (rc))
419
420
421
422
423/** This is the VM structure.
424 *
425 * It contains (nearly?) all the VM data which have to be available in all
426 * contexts. Even if it contains all the data the idea is to use APIs not
427 * to modify all the members all around the place. Therefore we make use of
428 * unions to hide everything which isn't local to the current source module.
429 * This means we'll have to pay a little bit of attention when adding new
430 * members to structures in the unions and make sure to keep the padding sizes
431 * up to date.
432 *
433 * Run tstVMStructSize after update!
434 */
435typedef struct VM
436{
437 /** The state of the VM.
438 * This field is read only to everyone except the VM and EM. */
439 VMSTATE enmVMState;
440 /** Forced action flags.
441 * See the VM_FF_* \#defines. Updated atomically.
442 */
443 volatile uint32_t fForcedActions;
444 /** Pointer to the array of page descriptors for the VM structure allocation. */
445 R3PTRTYPE(PSUPPAGE) paVMPagesR3;
446 /** Session handle. For use when calling SUPR0 APIs. */
447 PSUPDRVSESSION pSession;
448 /** Pointer to the ring-3 VM structure. */
449 PUVM pUVM;
450 /** Ring-3 Host Context VM Pointer. */
451 R3PTRTYPE(struct VM *) pVMR3;
452 /** Ring-0 Host Context VM Pointer. */
453 R0PTRTYPE(struct VM *) pVMR0;
454 /** Raw-mode Context VM Pointer. */
455 RCPTRTYPE(struct VM *) pVMRC;
456
457 /** The GVM VM handle. Only the GVM should modify this field. */
458 uint32_t hSelf;
459 /** Number of virtual CPUs. */
460 uint32_t cCPUs;
461
462 /** Size of the VM structure including the VMCPU array. */
463 uint32_t cbSelf;
464
465 /** Offset to the VMCPU array starting from beginning of this structure. */
466 uint32_t offVMCPU;
467
468 /** Reserved; alignment. */
469 uint32_t u32Reserved[6];
470
471 /** @name Public VMM Switcher APIs
472 * @{ */
473 /**
474 * Assembly switch entry point for returning to host context.
475 * This function will clean up the stack frame.
476 *
477 * @param eax The return code, register.
478 * @param Ctx The guest core context.
479 * @remark Assume interrupts disabled.
480 */
481 RTRCPTR pfnVMMGCGuestToHostAsmGuestCtx/*(int32_t eax, CPUMCTXCORE Ctx)*/;
482
483 /**
484 * Assembly switch entry point for returning to host context.
485 *
486 * This is an alternative entry point which we'll be using when the we have the
487 * hypervisor context and need to save that before going to the host.
488 *
489 * This is typically useful when abandoning the hypervisor because of a trap
490 * and want the trap state to be saved.
491 *
492 * @param eax The return code, register.
493 * @param ecx Pointer to the hypervisor core context, register.
494 * @remark Assume interrupts disabled.
495 */
496 RTRCPTR pfnVMMGCGuestToHostAsmHyperCtx/*(int32_t eax, PCPUMCTXCORE ecx)*/;
497
498 /**
499 * Assembly switch entry point for returning to host context.
500 *
501 * This is an alternative to the two *Ctx APIs and implies that the context has already
502 * been saved, or that it's just a brief return to HC and that the caller intends to resume
503 * whatever it is doing upon 'return' from this call.
504 *
505 * @param eax The return code, register.
506 * @remark Assume interrupts disabled.
507 */
508 RTRCPTR pfnVMMGCGuestToHostAsm/*(int32_t eax)*/;
509 /** @} */
510
511
512 /** @name Various VM data owned by VM.
513 * @{ */
514 RTTHREAD uPadding1;
515 /** The native handle of ThreadEMT. Getting the native handle
516 * is generally faster than getting the IPRT one (except on OS/2 :-). */
517 RTNATIVETHREAD uPadding2;
518 /** @} */
519
520
521 /** @name Various items that are frequently accessed.
522 * @{ */
523 /** Raw ring-3 indicator. */
524 bool fRawR3Enabled;
525 /** Raw ring-0 indicator. */
526 bool fRawR0Enabled;
527 /** PATM enabled flag.
528 * This is placed here for performance reasons. */
529 bool fPATMEnabled;
530 /** CSAM enabled flag.
531 * This is placed here for performance reasons. */
532 bool fCSAMEnabled;
533
534 /** Hardware VM support is available and enabled.
535 * This is placed here for performance reasons. */
536 bool fHWACCMEnabled;
537
538 /** PARAV enabled flag. */
539 bool fPARAVEnabled;
540 /** @} */
541
542
543 /* padding to make gnuc put the StatQemuToGC where msc does. */
544#if HC_ARCH_BITS == 32
545 uint32_t padding0;
546#endif
547
548 /** Profiling the total time from Qemu to GC. */
549 STAMPROFILEADV StatTotalQemuToGC;
550 /** Profiling the total time from GC to Qemu. */
551 STAMPROFILEADV StatTotalGCToQemu;
552 /** Profiling the total time spent in GC. */
553 STAMPROFILEADV StatTotalInGC;
554 /** Profiling the total time spent not in Qemu. */
555 STAMPROFILEADV StatTotalInQemu;
556 /** Profiling the VMMSwitcher code for going to GC. */
557 STAMPROFILEADV StatSwitcherToGC;
558 /** Profiling the VMMSwitcher code for going to HC. */
559 STAMPROFILEADV StatSwitcherToHC;
560 STAMPROFILEADV StatSwitcherSaveRegs;
561 STAMPROFILEADV StatSwitcherSysEnter;
562 STAMPROFILEADV StatSwitcherDebug;
563 STAMPROFILEADV StatSwitcherCR0;
564 STAMPROFILEADV StatSwitcherCR4;
565 STAMPROFILEADV StatSwitcherJmpCR3;
566 STAMPROFILEADV StatSwitcherRstrRegs;
567 STAMPROFILEADV StatSwitcherLgdt;
568 STAMPROFILEADV StatSwitcherLidt;
569 STAMPROFILEADV StatSwitcherLldt;
570 STAMPROFILEADV StatSwitcherTSS;
571
572/** @todo Realign everything on 64 byte boundaries to better match the
573 * cache-line size. */
574 /* padding - the unions must be aligned on 32 bytes boundraries. */
575 uint32_t padding[HC_ARCH_BITS == 32 ? 4+8 : 6];
576
577 /** CPUM part. */
578 union
579 {
580#ifdef ___CPUMInternal_h
581 struct CPUM s;
582#endif
583 char padding[4096]; /* multiple of 32 */
584 } cpum;
585
586 /** VMM part. */
587 union
588 {
589#ifdef ___VMMInternal_h
590 struct VMM s;
591#endif
592 char padding[1536]; /* multiple of 32 */
593 } vmm;
594
595 /** PGM part. */
596 union
597 {
598#ifdef ___PGMInternal_h
599 struct PGM s;
600#endif
601 char padding[50*1024]; /* multiple of 32 */
602 } pgm;
603
604 /** HWACCM part. */
605 union
606 {
607#ifdef ___HWACCMInternal_h
608 struct HWACCM s;
609#endif
610 char padding[512]; /* multiple of 32 */
611 } hwaccm;
612
613 /** TRPM part. */
614 union
615 {
616#ifdef ___TRPMInternal_h
617 struct TRPM s;
618#endif
619 char padding[5344]; /* multiple of 32 */
620 } trpm;
621
622 /** SELM part. */
623 union
624 {
625#ifdef ___SELMInternal_h
626 struct SELM s;
627#endif
628 char padding[544]; /* multiple of 32 */
629 } selm;
630
631 /** MM part. */
632 union
633 {
634#ifdef ___MMInternal_h
635 struct MM s;
636#endif
637 char padding[192]; /* multiple of 32 */
638 } mm;
639
640 /** CFGM part. */
641 union
642 {
643#ifdef ___CFGMInternal_h
644 struct CFGM s;
645#endif
646 char padding[32]; /* multiple of 32 */
647 } cfgm;
648
649 /** PDM part. */
650 union
651 {
652#ifdef ___PDMInternal_h
653 struct PDM s;
654#endif
655 char padding[1824]; /* multiple of 32 */
656 } pdm;
657
658 /** IOM part. */
659 union
660 {
661#ifdef ___IOMInternal_h
662 struct IOM s;
663#endif
664 char padding[4544]; /* multiple of 32 */
665 } iom;
666
667 /** PATM part. */
668 union
669 {
670#ifdef ___PATMInternal_h
671 struct PATM s;
672#endif
673 char padding[768]; /* multiple of 32 */
674 } patm;
675
676 /** CSAM part. */
677 union
678 {
679#ifdef ___CSAMInternal_h
680 struct CSAM s;
681#endif
682 char padding[3328]; /* multiple of 32 */
683 } csam;
684
685 /** PARAV part. */
686 union
687 {
688#ifdef ___PARAVInternal_h
689 struct PARAV s;
690#endif
691 char padding[128];
692 } parav;
693
694 /** EM part. */
695 union
696 {
697#ifdef ___EMInternal_h
698 struct EM s;
699#endif
700 char padding[1344]; /* multiple of 32 */
701 } em;
702
703 /** TM part. */
704 union
705 {
706#ifdef ___TMInternal_h
707 struct TM s;
708#endif
709 char padding[1536]; /* multiple of 32 */
710 } tm;
711
712 /** DBGF part. */
713 union
714 {
715#ifdef ___DBGFInternal_h
716 struct DBGF s;
717#endif
718 char padding[2368]; /* multiple of 32 */
719 } dbgf;
720
721 /** SSM part. */
722 union
723 {
724#ifdef ___SSMInternal_h
725 struct SSM s;
726#endif
727 char padding[32]; /* multiple of 32 */
728 } ssm;
729
730 /** VM part. */
731 union
732 {
733#ifdef ___VMInternal_h
734 struct VMINT s;
735#endif
736 char padding[768]; /* multiple of 32 */
737 } vm;
738
739 /** REM part. */
740 union
741 {
742#ifdef ___REMInternal_h
743 struct REM s;
744#endif
745
746#ifdef VBOX_WITH_NEW_RECOMPILER
747/** @def VM_REM_SIZE
748 * Must be multiple of 32 and coherent with REM_ENV_SIZE from REMInternal.h. */
749#if GC_ARCH_BITS == 32
750# define VM_REM_SIZE (HC_ARCH_BITS == 32 ? 0x10800 : 0x10800)
751#else
752# define VM_REM_SIZE (HC_ARCH_BITS == 32 ? 0x10900 : 0x10900)
753#endif
754#else /* !VBOX_WITH_NEW_RECOMILER */
755#if GC_ARCH_BITS == 32
756# define VM_REM_SIZE (HC_ARCH_BITS == 32 ? 0x6f00 : 0xbf00)
757#else
758# define VM_REM_SIZE (HC_ARCH_BITS == 32 ? 0x9f00 : 0xdf00)
759#endif
760#endif /* !VBOX_WITH_NEW_RECOMILER */
761 char padding[VM_REM_SIZE]; /* multiple of 32 */
762 } rem;
763
764 /** Padding for aligning the cpu array on a 64 byte boundrary. */
765 uint32_t u32Reserved2[8];
766
767 /** VMCPU array for the configured number of virtual CPUs.
768 * Must be aligned on a 64-byte boundrary. */
769 VMCPU aCpus[1];
770} VM;
771
772/** Pointer to a VM. */
773#ifndef ___VBox_types_h
774typedef struct VM *PVM;
775#endif
776
777
778#ifdef IN_RC
779__BEGIN_DECLS
780
781/** The VM structure.
782 * This is imported from the VMMGCBuiltin module, i.e. it's a one
783 * of those magic globals which we should avoid using.
784 */
785extern DECLIMPORT(VM) g_VM;
786
787__END_DECLS
788#endif
789
790/** @} */
791
792#endif
793
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