vm.mac revision fa94cbe3cda9a48bb743f0c2b26ec06927878830
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;; @file
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; VM - The Virtual Machine.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; Copyright (C) 2006-2011 Oracle Corporation
c7814cf6e1240a519cbec0441e033d0e2470ed00vboxsync;
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
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync%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
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;;
70aa086e9e9d2f85d2e997d0e69169018a001e54vboxsync; This is part of the VM structure.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsyncstruc VM
70aa086e9e9d2f85d2e997d0e69169018a001e54vboxsync .enmVMState resd 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fGlobalForcedActions resd 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .paVMPagesR3 RTR3PTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pSession RTR0PTR_RES 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .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 .u32Reserved resd 5
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pfnVMMGCGuestToHostAsmGuestCtx RTRCPTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync .pfnVMMGCGuestToHostAsmHyperCtx RTRCPTR_RES 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .pfnVMMGCGuestToHostAsm RTRCPTR_RES 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .uPadding1 RTHCPTR_RES 1
9b19f1c26bfea41cfad5fd97aaf5797a7507fb5cvboxsync .uPadding2 RTHCPTR_RES 1
1eab329ce9690ad59fd3ecbd826c94baf6d7f9fevboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fRecompileUser resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fRecompileSupervisor resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fPATMEnabled resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fCSAMEnabled resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fHWACCMEnabled resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fHwVirtExtForced resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fFaultTolerantMaster resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fUseLargePages resb 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hTraceBufRC RTRCPTR_RES 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .uPadding3 resd 1
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .hTraceBufR3 RTR3PTR_RES 1
683371bbf37760161d1b8454ce978acf89bbb04fvboxsync .hTraceBufR0 RTR0PTR_RES 1
f04eda3b79919a8fdfe041be77aafd118102f0acvboxsync
f04eda3b79919a8fdfe041be77aafd118102f0acvboxsync alignb 8
f04eda3b79919a8fdfe041be77aafd118102f0acvboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatTotalQemuToGC resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatTotalGCToQemu resb STAMPROFILEADV_size
eefd98087b0d2ffd437b0d535a96d8271963e17dvboxsync .StatTotalInGC resb STAMPROFILEADV_size
eefd98087b0d2ffd437b0d535a96d8271963e17dvboxsync .StatTotalInQemu resb STAMPROFILEADV_size
eefd98087b0d2ffd437b0d535a96d8271963e17dvboxsync .StatSwitcherToGC resb STAMPROFILEADV_size
eefd98087b0d2ffd437b0d535a96d8271963e17dvboxsync .StatSwitcherToHC resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherSaveRegs resb STAMPROFILEADV_size
37fd636275891bcf75bd60c624d8fbf3f262c435vboxsync .StatSwitcherSysEnter resb STAMPROFILEADV_size
37fd636275891bcf75bd60c624d8fbf3f262c435vboxsync .StatSwitcherDebug resb STAMPROFILEADV_size
eefd98087b0d2ffd437b0d535a96d8271963e17dvboxsync .StatSwitcherCR0 resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherCR4 resb STAMPROFILEADV_size
37fd636275891bcf75bd60c624d8fbf3f262c435vboxsync .StatSwitcherJmpCR3 resb STAMPROFILEADV_size
eefd98087b0d2ffd437b0d535a96d8271963e17dvboxsync .StatSwitcherRstrRegs resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherLgdt resb STAMPROFILEADV_size
ea4433aedd4105e6599e57e0c5f6cb32a68e963cvboxsync .StatSwitcherLidt resb STAMPROFILEADV_size
acebf0f8a1553ee17c6669acc236dc77e15b57a4vboxsync .StatSwitcherLldt resb STAMPROFILEADV_size
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .StatSwitcherTSS resb STAMPROFILEADV_size
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
63f2e9195f4ae05b9d0571bfdf34d4aa0c719ab1vboxsync%ifndef HC_ARCH_BITS
cc8fc24b48b6dcfb5b11e66d68d08ac3ae46b401vboxsync %error "Missing HC_ARCH_BITS"
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%endif
93f5e318bdffb66ddc6001c0b0e7ea1ca046887dvboxsync%if HC_ARCH_BITS == 32
7dfd3f41f200bede0714c89735d9cc8d310e3f1cvboxsync .abAlignment1 resb 30
7dfd3f41f200bede0714c89735d9cc8d310e3f1cvboxsync%else
8b148a9b18f1df43970276614ab624e85d42f156vboxsync; .abAlignment1 resb 0
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%endif
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync alignb 64
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .cpum resb 1536
f04eda3b79919a8fdfe041be77aafd118102f0acvboxsync .vmm resb 1536
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsyncendstruc
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync;;
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync; This is part of the VMCPU structure.
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsyncstruc VMCPU
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .fLocalForcedActions resd 1
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync .enmState resd 1
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync .pUVCpu RTR3PTR_RES 1
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync .pVMR3 RTR3PTR_RES 1
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync .pVMR0 RTR0PTR_RES 1
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync .pVMRC RTRCPTR_RES 1
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync .idCpu resd 1
cda57af9589fa1c4aedbee904fc3f3139409c97bvboxsync
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
324e9d5fe84f23a35c4feb6853ed3ee9b3b1fad9vboxsync .uAdHoc resd 1
324e9d5fe84f23a35c4feb6853ed3ee9b3b1fad9vboxsync .aStatAdHoc resb STAMPROFILEADV_size * 8
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
1f99e2fdf4c3c62af970234bef6de703148f3bfcvboxsync alignb 64
edf9b1ca7a0ef1def3f24705ccff26eb2ef7f5b0vboxsync
f2c4137b711f0fbacc1ef4f5612c6e2216cbc956vboxsync .cpum resb 3456
f2c4137b711f0fbacc1ef4f5612c6e2216cbc956vboxsync .hwaccm resb 5376
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .em resb 1472
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .iem resb 3072
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .trpm resb 128
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .tm resb 384
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .vmm resb 640
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .pdm resb 128
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .iom resb 512
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .dbgf resb 64
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync alignb 4096
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync .pgm resb 4096
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsyncendstruc
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync%endif
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync
8f28e374e0b8ea801e7b5364bccd8a7e0a6211d3vboxsync