vm.mac revision 03e8e21575a0d6ace51c528e7a6fcc35ce69cae7
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;; @file
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; VM - The Virtual Machine.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; Copyright (C) 2006-2014 Oracle Corporation
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; This file is part of VirtualBox Open Source Edition (OSE), as
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; available from http://www.virtualbox.org. This file is free software;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; you can redistribute it and/or modify it under the terms of the GNU
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; General Public License (GPL) as published by the Free Software
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; Foundation, in version 2 as it comes in the "COPYING" file of the
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; The contents of this file may alternatively be used under the terms
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; of the Common Development and Distribution License Version 1.0
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; VirtualBox OSE distribution, in which case the provisions of the
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; CDDL are applicable instead of those of the GPL.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; You may elect to license modified versions of this file under the
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; terms and conditions of either the GPL or the CDDL or both.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%ifndef ___VBox_vmm_vm_mac
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%define ___VBox_vmm_vm_mac
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%include "VBox/vmm/stam.mac"
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;/** This action forces the VM to service check and pending interrups on the APIC. */
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%define VMCPU_FF_INTERRUPT_APIC (1 << 0)
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;/** This action forces the VM to service check and pending interrups on the PIC. */
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%define VMCPU_FF_INTERRUPT_PIC (1 << 1)
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;/** This action forces the VM to schedule and run pending timer (TM). */
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%define VMCPU_FF_TIMER (1 << 2)
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;/** This action forces the VM to service pending requests from other
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; * thread or requests which must be executed in another context. */
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%define VMCPU_FF_REQUEST (1 << 9)
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
70aa086e9e9d2f85d2e997d0e69169018a001e54vboxsync;;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; This is part of the VM structure.
70aa086e9e9d2f85d2e997d0e69169018a001e54vboxsyncstruc VM
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .enmVMState resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .fGlobalForcedActions resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .paVMPagesR3 RTR3PTR_RES 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .pSession RTR0PTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pUVM RTR3PTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pVMR3 RTR3PTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pVMR0 RTR0PTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pVMRC RTRCPTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .hSelf resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .cCpus resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .uCpuExecutionCap resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .cbSelf resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .offVMCPU resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pfnVMMRCToHostAsm resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pfnVMMRCToHostAsmNoReturn resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .fRecompileUser resb 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .fRecompileSupervisor resb 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .fRawRing1Enabled resb 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .fPATMEnabled resb 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .fCSAMEnabled resb 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .fHMEnabled resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fHMEnabledFixed resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fHMNeedRawModeCtx resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fFaultTolerantMaster resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fUseLargePages resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .uPadding1 resb 2
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hTraceBufRC RTRCPTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hTraceBufR3 RTR3PTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hTraceBufR0 RTR0PTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync alignb 8
683371bbf37760161d1b8454ce978acf89bbb04fvboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatTotalQemuToGC resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatTotalGCToQemu resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatTotalInGC resb STAMPROFILEADV_size
37fd636275891bcf75bd60c624d8fbf3f262c435vboxsync .StatTotalInQemu resb STAMPROFILEADV_size
37fd636275891bcf75bd60c624d8fbf3f262c435vboxsync .StatSwitcherToGC resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherToHC resb STAMPROFILEADV_size
37fd636275891bcf75bd60c624d8fbf3f262c435vboxsync .StatSwitcherSaveRegs resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherSysEnter resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherDebug resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherCR0 resb STAMPROFILEADV_size
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatSwitcherCR4 resb STAMPROFILEADV_size
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatSwitcherJmpCR3 resb STAMPROFILEADV_size
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatSwitcherRstrRegs resb STAMPROFILEADV_size
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatSwitcherLgdt resb STAMPROFILEADV_size
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatSwitcherLidt resb STAMPROFILEADV_size
7dfd3f41f200bede0714c89735d9cc8d310e3f1cvboxsync .StatSwitcherLldt resb STAMPROFILEADV_size
7dfd3f41f200bede0714c89735d9cc8d310e3f1cvboxsync .StatSwitcherTSS resb STAMPROFILEADV_size
8b148a9b18f1df43970276614ab624e85d42f156vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%ifndef HC_ARCH_BITS
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync %error "Missing HC_ARCH_BITS"
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%endif
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%if HC_ARCH_BITS == 32
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .abAlignment3 resb 16
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%else
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; .abAlignment3 resb 16
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%endif
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync alignb 64
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .cpum resb 1536
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .vmm resb 1536
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsyncendstruc
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; This is part of the VMCPU structure.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsyncstruc VMCPU
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fLocalForcedActions resd 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .enmState resd 1
324e9d5fe84f23a35c4feb6853ed3ee9b3b1fad9vboxsync .pUVCpu RTR3PTR_RES 1
324e9d5fe84f23a35c4feb6853ed3ee9b3b1fad9vboxsync .pVMR3 RTR3PTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .pVMR0 RTR0PTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .pVMRC RTRCPTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .idCpu resd 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hNativeThread RTR0PTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hNativeThreadR0 RTR0PTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .idHostCpu resd 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fTraceGroups resd 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%if HC_ARCH_BITS == 32
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .abAlignment1 resb 16+64
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%else
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .abAlignment1 resb 60
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%endif
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .uAdHoc resd 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .aStatAdHoc resb STAMPROFILEADV_size * 8
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync alignb 64
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .cpum resb 3584
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hm resb 5760
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .em resb 1408
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .iem resb 3072
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .trpm resb 128
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .tm resb 384
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .vmm resb 704
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .pdm resb 256
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .iom resb 512
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .dbgf resb 64
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .gim resb 64
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync alignb 4096
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .pgm resb 4096
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsyncendstruc
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%endif
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync