VirtualBox

Changeset 73274 in vbox for trunk/include/VBox


Ignore:
Timestamp:
Jul 20, 2018 3:40:10 PM (7 years ago)
Author:
vboxsync
Message:

VMM: Nested VMX: bugref:9180 Reports bits of IA32_FEATURE_CONTROL, start implementing IA32_VMX_BASIC MSRs, cleanups.

Location:
trunk/include/VBox/vmm
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/include/VBox/vmm/cpum.h

    r73257 r73274  
    11181118
    11191119    /** @todo VMX features. */
    1120     uint32_t        auPadding[1];
     1120    /** VMX: INS/OUTS VM-exit instruction info. */
     1121    uint32_t        fVmxInsOutInfo : 1;
     1122    uint32_t        fVmxPadding0 : 31;
    11211123} CPUMFEATURES;
    11221124#ifndef VBOX_FOR_DTRACE_LIB
  • trunk/include/VBox/vmm/hm_vmx.h

    r73256 r73274  
    10911091 */
    10921092/** VMCS revision identifier used by the processor. */
    1093 #define MSR_IA32_VMX_BASIC_INFO_VMCS_ID(a)                      ((a) & 0x7FFFFFFF)
    1094 /** Size of the VMCS. */
    1095 #define MSR_IA32_VMX_BASIC_INFO_VMCS_SIZE(a)                    (((a) >> 32) & 0x1FFF)
    1096 /** Width of physical address used for the VMCS.
    1097  *  0 -> limited to the available amount of physical ram
    1098  *  1 -> within the first 4 GB
    1099  */
    1100 #define MSR_IA32_VMX_BASIC_INFO_VMCS_PHYS_WIDTH(a)              (((a) >> 48) & 1)
    1101 /** Whether the processor supports the dual-monitor treatment of
    1102  *  system-management interrupts and system-management code. (always 1) */
    1103 #define MSR_IA32_VMX_BASIC_INFO_VMCS_DUAL_MON(a)                (((a) >> 49) & 1)
    1104 /** Memory type that must be used for the VMCS. */
    1105 #define MSR_IA32_VMX_BASIC_INFO_VMCS_MEM_TYPE(a)                (((a) >> 50) & 0xF)
    1106 /** Whether the processor provides additional information for exits due to
    1107  *  INS/OUTS. */
    1108 #define MSR_IA32_VMX_BASIC_INFO_VMCS_INS_OUTS(a)                (((a) >> 54) & 1)
     1093#define MSR_IA32_VMX_BASIC_VMCS_ID(a)                      ((a) & 0x7FFFFFFF)
     1094/** Shift to get the VMCS size. */
     1095#define MSR_IA32_VMX_BASIC_VMCS_SIZE_SHIFT                 32
     1096/** VMCS size in bytes. */
     1097#define MSR_IA32_VMX_BASIC_VMCS_SIZE(a)                    (((a) >> 32) & 0x1FFF)
     1098/** Shift to get the width of physical addresses and associated memory regions. */
     1099#define MSR_IA32_VMX_BASIC_VMCS_PHYS_WIDTH_SHIFT           48
     1100/** Width of physical addresses used for the VMCS and associated memory regions. */
     1101#define MSR_IA32_VMX_BASIC_VMCS_PHYS_WIDTH(a)              (((a) >> 48) & 1)
     1102/** Shift to get the dual-monitor treatment of SMI and SMM. */
     1103#define MSR_IA32_VMX_BASIC_DUAL_MON_SHIFT                  49
     1104/** Dual-monitor treatment of SMI and SMM supported. */
     1105#define MSR_IA32_VMX_BASIC_DUAL_MON(a)                     (((a) >> 49) & 1)
     1106/** Shift to get the memory type that must be used for the VMCS and associated
     1107 *  memory regions. */
     1108#define MSR_IA32_VMX_BASIC_VMCS_MEM_TYPE_SHIFT             50
     1109/** Memory type that must be used for the VMCS and associated memory regions. */
     1110#define MSR_IA32_VMX_BASIC_VMCS_MEM_TYPE(a)                (((a) >> 50) & 0xF)
     1111/** Shift to get the additional VM-exit information for INS/OUTS. */
     1112#define MSR_IA32_VMX_BASIC_VMCS_INS_OUTS_SHIFT             54
     1113/** Additional VM-exit information for INS/OUTS. */
     1114#define MSR_IA32_VMX_BASIC_VMCS_INS_OUTS(a)                (((a) >> 54) & 1)
     1115/** Shift to get the VMCS true controls. */
     1116#define MSR_IA32_VMX_BASIC_TRUE_CONTROLS_SHIFT             55
    11091117/** Whether default 1 bits in control MSRs (pin/proc/exit/entry) may be
    11101118 *  cleared to 0 and that 'true' control MSRs are supported. */
    1111 #define MSR_IA32_VMX_BASIC_INFO_TRUE_CONTROLS(a)                (((a) >> 55) & 1)
     1119#define MSR_IA32_VMX_BASIC_TRUE_CONTROLS(a)                (((a) >> 55) & 1)
    11121120/** @} */
    11131121
     
    11181126/** Relationship between the preemption timer and tsc; count down every time bit
    11191127 *  x of the tsc changes. */
    1120 #define MSR_IA32_VMX_MISC_PREEMPT_TSC_BIT(a)                    ((a) & 0x1f)
     1128#define MSR_IA32_VMX_MISC_PREEMPT_TSC_BIT(a)                    ((a) & 0x1F)
    11211129/** Whether VM-exit stores EFER.LMA into the "IA32e mode guest" field. */
    11221130#define MSR_IA32_VMX_MISC_STORE_EFERLMA_VMEXIT(a)               (((a) >> 5) & 1)
     
    15161524 * @{
    15171525 */
    1518 #define VMX_EXIT_REASON_BASIC(a)                                ((a) & 0xffff)
     1526#define VMX_EXIT_REASON_BASIC(a)                                ((a) & 0xFFFF)
    15191527/** @} */
    15201528
     
    15321540 * @{
    15331541 */
    1534 #define VMX_EXIT_INTERRUPTION_INFO_VECTOR(a)                    ((a) & 0xff)
     1542#define VMX_EXIT_INTERRUPTION_INFO_VECTOR(a)                    ((a) & 0xFF)
    15351543#define VMX_EXIT_INTERRUPTION_INFO_TYPE_SHIFT                   8
    15361544#define VMX_EXIT_INTERRUPTION_INFO_TYPE(a)                      (((a) >> VMX_EXIT_INTERRUPTION_INFO_TYPE_SHIFT) & 7)
     
    15611569 * @{
    15621570 */
    1563 #define VMX_IDT_VECTORING_INFO_VECTOR(a)                        ((a) & 0xff)
     1571#define VMX_IDT_VECTORING_INFO_VECTOR(a)                        ((a) & 0xFF)
    15641572#define VMX_IDT_VECTORING_INFO_TYPE_SHIFT                       8
    15651573#define VMX_IDT_VECTORING_INFO_TYPE(a)                          (((a) >> VMX_IDT_VECTORING_INFO_TYPE_SHIFT) & 7)
     
    17271735 * @{
    17281736 */
    1729 #define VMX_EXIT_QUAL_TASK_SWITCH_SELECTOR(a)          ((a) & 0xffff)
     1737#define VMX_EXIT_QUAL_TASK_SWITCH_SELECTOR(a)          ((a) & 0xFFFF)
    17301738#define VMX_EXIT_QUAL_TASK_SWITCH_TYPE(a)              (((a) >> 30) & 0x3)
    17311739/** Task switch caused by a call instruction. */
     
    17791787#define VMX_EXIT_QUAL_IO_ENCODING(a)                   (((a) >> 6) & 1)
    17801788/** 16-31: IO Port (0-0xffff). */
    1781 #define VMX_EXIT_QUAL_IO_PORT(a)                       (((a) >> 16) & 0xffff)
     1789#define VMX_EXIT_QUAL_IO_PORT(a)                       (((a) >> 16) & 0xFFFF)
    17821790/* Rest reserved. */
    17831791/** @} */
     
    20032011
    20042012
     2013/** VMCS revision identifier used for emulating VMX (bit 31 MBZ). Bump this
     2014 *  arbitarily chosen identifier if incompatible changes to the layout of our VMCS
     2015 *  structure is done. */
     2016#define VMX_VMCS_REVISION_ID                                    UINT32_C(0x1d000001)
     2017AssertCompile(!(VMX_VMCS_REVISION_ID & RT_BIT(31)));
     2018/** VMCS (and related regions) memory type - Uncacheable. */
     2019#define VMX_VMCS_MEM_TYPE_UC                                    0
     2020/** VMCS (and related regions) memory type - Write back. */
     2021#define VMX_VMCS_MEM_TYPE_WB                                    6
     2022
     2023
    20052024/** @defgroup grp_hm_vmx_asm    VMX Assembly Helpers
    20062025 * @{
Note: See TracChangeset for help on using the changeset viewer.

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