VirtualBox

Changeset 48208 in vbox for trunk/src/VBox/VMM/VMMR0


Ignore:
Timestamp:
Aug 30, 2013 10:05:31 PM (11 years ago)
Author:
vboxsync
Message:

VMM: Cleanup, hungarian and comments.

Location:
trunk/src/VBox/VMM/VMMR0
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/VMMR0/GVMMR0.cpp

    r47456 r48208  
    10741074    GVMM_GET_VALID_INSTANCE(pGVMM, VERR_GVMM_INSTANCE);
    10751075
    1076 
    10771076    /*
    10781077     * Validate the VM structure, state and caller.
     
    10801079    AssertPtrReturn(pVM, VERR_INVALID_POINTER);
    10811080    AssertReturn(!((uintptr_t)pVM & PAGE_OFFSET_MASK), VERR_INVALID_POINTER);
    1082     AssertMsgReturn(pVM->enmVMState >= VMSTATE_CREATING && pVM->enmVMState <= VMSTATE_TERMINATED, ("%d\n", pVM->enmVMState), VERR_WRONG_ORDER);
     1081    AssertMsgReturn(pVM->enmVMState >= VMSTATE_CREATING && pVM->enmVMState <= VMSTATE_TERMINATED, ("%d\n", pVM->enmVMState),
     1082                    VERR_WRONG_ORDER);
    10831083
    10841084    uint32_t hGVM = pVM->hSelf;
     
    10901090
    10911091    RTPROCESS      ProcId = RTProcSelf();
    1092     RTNATIVETHREAD hSelf = RTThreadNativeSelf();
     1092    RTNATIVETHREAD hSelf  = RTThreadNativeSelf();
    10931093    AssertReturn(   (   pHandle->hEMT0  == hSelf
    10941094                     && pHandle->ProcId == ProcId)
  • trunk/src/VBox/VMM/VMMR0/HMR0.cpp

    r48153 r48208  
    114114
    115115        /** Host CR4 value (set by ring-0 VMX init) */
    116         uint64_t                    hostCR4;
     116        uint64_t                    u64HostCr4;
    117117
    118118        /** Host EFER value (set by ring-0 VMX init) */
    119         uint64_t                    hostEFER;
     119        uint64_t                    u64HostEfer;
    120120
    121121        /** VMX MSR values */
    122122        struct
    123123        {
    124             uint64_t                feature_ctrl;
    125             uint64_t                vmx_basic_info;
    126             VMX_CAPABILITY          vmx_pin_ctls;
    127             VMX_CAPABILITY          vmx_proc_ctls;
    128             VMX_CAPABILITY          vmx_proc_ctls2;
    129             VMX_CAPABILITY          vmx_exit;
    130             VMX_CAPABILITY          vmx_entry;
    131             uint64_t                vmx_misc;
    132             uint64_t                vmx_cr0_fixed0;
    133             uint64_t                vmx_cr0_fixed1;
    134             uint64_t                vmx_cr4_fixed0;
    135             uint64_t                vmx_cr4_fixed1;
    136             uint64_t                vmx_vmcs_enum;
    137             uint64_t                vmx_vmfunc;
    138             uint64_t                vmx_ept_vpid_caps;
     124            uint64_t                u64FeatureCtrl;
     125            uint64_t                u64BasicInfo;
     126            VMXCAPABILITY           vmxPinCtls;
     127            VMXCAPABILITY           vmxProcCtls;
     128            VMXCAPABILITY           vmxProcCtls2;
     129            VMXCAPABILITY           vmxExit;
     130            VMXCAPABILITY           vmxEntry;
     131            uint64_t                u64Misc;
     132            uint64_t                u64Cr0Fixed0;
     133            uint64_t                u64Cr0Fixed1;
     134            uint64_t                u64Cr4Fixed0;
     135            uint64_t                u64Cr4Fixed1;
     136            uint64_t                u64VmcsEnum;
     137            uint64_t                u64Vmfunc;
     138            uint64_t                u64EptVpidCaps;
    139139        } msr;
    140140        /* Last instruction error */
     
    158158    } svm;
    159159    /** Saved error from detection */
    160     int32_t         lLastError;
     160    int32_t                         lLastError;
    161161
    162162    struct
     
    172172     *  actions when the host is being suspended to speed up the suspending and
    173173     *  avoid trouble. */
    174     volatile        bool            fSuspended;
     174    volatile bool                   fSuspended;
    175175
    176176    /** Whether we've already initialized all CPUs.
     
    371371    {
    372372        /** @todo move this into a separate function. */
    373         g_HvmR0.vmx.msr.feature_ctrl = ASMRdMsr(MSR_IA32_FEATURE_CONTROL);
     373        g_HvmR0.vmx.msr.u64FeatureCtrl = ASMRdMsr(MSR_IA32_FEATURE_CONTROL);
    374374
    375375        /*
     
    402402        {
    403403            /* Reread in case we've changed it. */
    404             g_HvmR0.vmx.msr.feature_ctrl = ASMRdMsr(MSR_IA32_FEATURE_CONTROL);
    405 
    406             if (   (g_HvmR0.vmx.msr.feature_ctrl & (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
    407                 ==                                 (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
     404            g_HvmR0.vmx.msr.u64FeatureCtrl = ASMRdMsr(MSR_IA32_FEATURE_CONTROL);
     405
     406            if (   (g_HvmR0.vmx.msr.u64FeatureCtrl & (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
     407                ==                                   (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
    408408            {
    409409                /*
    410                  * Read all relevant MSR.
     410                 * Read all relevant MSRs.
    411411                 */
    412                 g_HvmR0.vmx.msr.vmx_basic_info  = ASMRdMsr(MSR_IA32_VMX_BASIC_INFO);
    413                 g_HvmR0.vmx.msr.vmx_pin_ctls.u  = ASMRdMsr(MSR_IA32_VMX_PINBASED_CTLS);
    414                 g_HvmR0.vmx.msr.vmx_proc_ctls.u = ASMRdMsr(MSR_IA32_VMX_PROCBASED_CTLS);
    415                 g_HvmR0.vmx.msr.vmx_exit.u      = ASMRdMsr(MSR_IA32_VMX_EXIT_CTLS);
    416                 g_HvmR0.vmx.msr.vmx_entry.u     = ASMRdMsr(MSR_IA32_VMX_ENTRY_CTLS);
    417                 g_HvmR0.vmx.msr.vmx_misc        = ASMRdMsr(MSR_IA32_VMX_MISC);
    418                 g_HvmR0.vmx.msr.vmx_cr0_fixed0  = ASMRdMsr(MSR_IA32_VMX_CR0_FIXED0);
    419                 g_HvmR0.vmx.msr.vmx_cr0_fixed1  = ASMRdMsr(MSR_IA32_VMX_CR0_FIXED1);
    420                 g_HvmR0.vmx.msr.vmx_cr4_fixed0  = ASMRdMsr(MSR_IA32_VMX_CR4_FIXED0);
    421                 g_HvmR0.vmx.msr.vmx_cr4_fixed1  = ASMRdMsr(MSR_IA32_VMX_CR4_FIXED1);
    422                 g_HvmR0.vmx.msr.vmx_vmcs_enum   = ASMRdMsr(MSR_IA32_VMX_VMCS_ENUM);
    423                 g_HvmR0.vmx.hostCR4             = ASMGetCR4();
    424                 g_HvmR0.vmx.hostEFER            = ASMRdMsr(MSR_K6_EFER);
     412                g_HvmR0.vmx.msr.u64BasicInfo    = ASMRdMsr(MSR_IA32_VMX_BASIC_INFO);
     413                g_HvmR0.vmx.msr.vmxPinCtls.u    = ASMRdMsr(MSR_IA32_VMX_PINBASED_CTLS);
     414                g_HvmR0.vmx.msr.vmxProcCtls.u  = ASMRdMsr(MSR_IA32_VMX_PROCBASED_CTLS);
     415                g_HvmR0.vmx.msr.vmxExit.u       = ASMRdMsr(MSR_IA32_VMX_EXIT_CTLS);
     416                g_HvmR0.vmx.msr.vmxEntry.u      = ASMRdMsr(MSR_IA32_VMX_ENTRY_CTLS);
     417                g_HvmR0.vmx.msr.u64Misc         = ASMRdMsr(MSR_IA32_VMX_MISC);
     418                g_HvmR0.vmx.msr.u64Cr0Fixed0    = ASMRdMsr(MSR_IA32_VMX_CR0_FIXED0);
     419                g_HvmR0.vmx.msr.u64Cr0Fixed1    = ASMRdMsr(MSR_IA32_VMX_CR0_FIXED1);
     420                g_HvmR0.vmx.msr.u64Cr4Fixed0    = ASMRdMsr(MSR_IA32_VMX_CR4_FIXED0);
     421                g_HvmR0.vmx.msr.u64Cr4Fixed1    = ASMRdMsr(MSR_IA32_VMX_CR4_FIXED1);
     422                g_HvmR0.vmx.msr.u64VmcsEnum     = ASMRdMsr(MSR_IA32_VMX_VMCS_ENUM);
     423                g_HvmR0.vmx.u64HostCr4          = ASMGetCR4();
     424                g_HvmR0.vmx.u64HostEfer         = ASMRdMsr(MSR_K6_EFER);
    425425                /* VPID 16 bits ASID. */
    426426                g_HvmR0.uMaxAsid                = 0x10000; /* exclusive */
    427427
    428                 if (g_HvmR0.vmx.msr.vmx_proc_ctls.n.allowed1 & VMX_VMCS_CTRL_PROC_EXEC_USE_SECONDARY_EXEC_CTRL)
     428                if (g_HvmR0.vmx.msr.vmxProcCtls.n.allowed1 & VMX_VMCS_CTRL_PROC_EXEC_USE_SECONDARY_EXEC_CTRL)
    429429                {
    430                     g_HvmR0.vmx.msr.vmx_proc_ctls2.u = ASMRdMsr(MSR_IA32_VMX_PROCBASED_CTLS2);
    431                     if (  g_HvmR0.vmx.msr.vmx_proc_ctls2.n.allowed1
    432                         & (VMX_VMCS_CTRL_PROC_EXEC2_EPT | VMX_VMCS_CTRL_PROC_EXEC2_VPID))
    433                     {
    434                         g_HvmR0.vmx.msr.vmx_ept_vpid_caps = ASMRdMsr(MSR_IA32_VMX_EPT_VPID_CAP);
    435                     }
    436 
    437                     if (g_HvmR0.vmx.msr.vmx_proc_ctls2.n.allowed1 & VMX_VMCS_CTRL_PROC_EXEC2_VMFUNC)
    438                         g_HvmR0.vmx.msr.vmx_vmfunc        = ASMRdMsr(MSR_IA32_VMX_VMFUNC);
     430                    g_HvmR0.vmx.msr.vmxProcCtls2.u = ASMRdMsr(MSR_IA32_VMX_PROCBASED_CTLS2);
     431                    if (g_HvmR0.vmx.msr.vmxProcCtls2.n.allowed1 & (VMX_VMCS_CTRL_PROC_EXEC2_EPT | VMX_VMCS_CTRL_PROC_EXEC2_VPID))
     432                        g_HvmR0.vmx.msr.u64EptVpidCaps = ASMRdMsr(MSR_IA32_VMX_EPT_VPID_CAP);
     433
     434                    if (g_HvmR0.vmx.msr.vmxProcCtls2.n.allowed1 & VMX_VMCS_CTRL_PROC_EXEC2_VMFUNC)
     435                        g_HvmR0.vmx.msr.u64Vmfunc = ASMRdMsr(MSR_IA32_VMX_VMFUNC);
    439436                }
    440437
     
    457454
    458455                    /* Set revision dword at the beginning of the structure. */
    459                     *(uint32_t *)pvScatchPage = MSR_IA32_VMX_BASIC_INFO_VMCS_ID(g_HvmR0.vmx.msr.vmx_basic_info);
     456                    *(uint32_t *)pvScatchPage = MSR_IA32_VMX_BASIC_INFO_VMCS_ID(g_HvmR0.vmx.msr.u64BasicInfo);
    460457
    461458                    /* Make sure we don't get rescheduled to another cpu during this probe. */
     
    465462                     * Check CR4.VMXE
    466463                     */
    467                     g_HvmR0.vmx.hostCR4 = ASMGetCR4();
    468                     if (!(g_HvmR0.vmx.hostCR4 & X86_CR4_VMXE))
     464                    g_HvmR0.vmx.u64HostCr4 = ASMGetCR4();
     465                    if (!(g_HvmR0.vmx.u64HostCr4 & X86_CR4_VMXE))
    469466                    {
    470467                        /* In theory this bit could be cleared behind our back.  Which would cause
    471468                           #UD faults when we try to execute the VMX instructions... */
    472                         ASMSetCR4(g_HvmR0.vmx.hostCR4 | X86_CR4_VMXE);
     469                        ASMSetCR4(g_HvmR0.vmx.u64HostCr4 | X86_CR4_VMXE);
    473470                    }
    474471
     
    503500                       if it wasn't so before (some software could incorrectly
    504501                       think it's in VMX mode). */
    505                     ASMSetCR4(g_HvmR0.vmx.hostCR4);
     502                    ASMSetCR4(g_HvmR0.vmx.u64HostCr4);
    506503                    ASMSetFlags(fFlags);
    507504
     
    539536                 * Timer Does Not Count Down at the Rate Specified" erratum.
    540537                 */
    541                 if (g_HvmR0.vmx.msr.vmx_pin_ctls.n.allowed1 & VMX_VMCS_CTRL_PIN_EXEC_PREEMPT_TIMER)
     538                if (g_HvmR0.vmx.msr.vmxPinCtls.n.allowed1 & VMX_VMCS_CTRL_PIN_EXEC_PREEMPT_TIMER)
    542539                {
    543540                    g_HvmR0.vmx.fUsePreemptTimer   = true;
    544                     g_HvmR0.vmx.cPreemptTimerShift = MSR_IA32_VMX_MISC_PREEMPT_TSC_BIT(g_HvmR0.vmx.msr.vmx_misc);
     541                    g_HvmR0.vmx.cPreemptTimerShift = MSR_IA32_VMX_MISC_PREEMPT_TSC_BIT(g_HvmR0.vmx.msr.u64Misc);
    545542                    if (hmR0InitIntelIsSubjectToVmxPreemptionTimerErratum())
    546543                        g_HvmR0.vmx.cPreemptTimerShift = 0; /* This is about right most of the time here. */
     
    781778            HMR0FIRSTRC FirstRc;
    782779            hmR0FirstRcInit(&FirstRc);
    783             rc = RTMpOnAll(hmR0DisableCpuCallback, NULL, &FirstRc);
     780            rc = RTMpOnAll(hmR0DisableCpuCallback, NULL /* pvUser 1 */, &FirstRc);
    784781            Assert(RT_SUCCESS(rc) || rc == VERR_NOT_SUPPORTED);
    785782            if (RT_SUCCESS(rc))
     
    842839        /* MSR is not yet locked; we can change it ourselves here. */
    843840        ASMWrMsr(MSR_IA32_FEATURE_CONTROL,
    844                  g_HvmR0.vmx.msr.feature_ctrl | MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK);
     841                 g_HvmR0.vmx.msr.u64FeatureCtrl | MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK);
    845842        fFC = ASMRdMsr(MSR_IA32_FEATURE_CONTROL);
    846843    }
    847844
    848845    int rc;
    849     if (   (fFC & (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
    850         == (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
     846    if ((fFC & (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
     847        ==     (MSR_IA32_FEATURE_CONTROL_VMXON | MSR_IA32_FEATURE_CONTROL_LOCK))
     848    {
    851849        rc = VINF_SUCCESS;
     850    }
    852851    else
    853852        rc = VERR_VMX_MSR_LOCKED_OR_DISABLED;
     
    907906 *
    908907 * @returns VBox status code.
    909  * @param   pVM         Pointer to the VM (can be 0).
     908 * @param   pVM         Pointer to the VM (can be NULL).
    910909 * @param   idCpu       The identifier for the CPU the function is called on.
    911910 */
     
    914913    PHMGLOBALCPUINFO pCpu = &g_HvmR0.aCpuInfo[idCpu];
    915914
    916     Assert(idCpu == (RTCPUID)RTMpCpuIdToSetIndex(idCpu)); /// @todo fix idCpu == index assumption (rainy day)
     915    Assert(idCpu == (RTCPUID)RTMpCpuIdToSetIndex(idCpu));  /** @todo fix idCpu == index assumption (rainy day) */
    917916    Assert(idCpu < RT_ELEMENTS(g_HvmR0.aCpuInfo));
    918917    Assert(!pCpu->fConfigured);
     
    924923    int rc;
    925924    if (g_HvmR0.vmx.fSupported && g_HvmR0.vmx.fUsingSUPR0EnableVTx)
    926         rc = g_HvmR0.pfnEnableCpu(pCpu, pVM, NULL, NIL_RTHCPHYS, true);
     925        rc = g_HvmR0.pfnEnableCpu(pCpu, pVM, NULL /* pvCpuPage */, NIL_RTHCPHYS, true);
    927926    else
    928927    {
     
    945944 *
    946945 * @param   idCpu       The identifier for the CPU the function is called on.
    947  * @param   pvUser1     The 1st user argument.
     946 * @param   pvUser1     Opaque pointer to the VM (can be NULL!).
    948947 * @param   pvUser2     The 2nd user argument.
    949948 */
     
    11061105/**
    11071106 * Worker function passed to RTMpOnAll, RTMpOnOthers and RTMpOnSpecific that
    1108  * is to be called on the target cpus.
     1107 * is to be called on the target CPUs.
    11091108 *
    11101109 * @param   idCpu       The identifier for the CPU the function is called on.
    11111110 * @param   pvUser1     The 1st user argument.
    1112  * @param   pvUser2     The 2nd user argument.
     1111 * @param   pvUser2     Opaque pointer to the FirstRc.
    11131112 */
    11141113static DECLCALLBACK(void) hmR0DisableCpuCallback(RTCPUID idCpu, void *pvUser1, void *pvUser2)
     
    11831182            {
    11841183                /* Turn off VT-x or AMD-V on all CPUs. */
    1185                 rc = RTMpOnAll(hmR0DisableCpuCallback, NULL, &FirstRc);
     1184                rc = RTMpOnAll(hmR0DisableCpuCallback, NULL /* pvUser 1 */, &FirstRc);
    11861185                Assert(RT_SUCCESS(rc) || rc == VERR_NOT_SUPPORTED);
    11871186            }
     
    12061205            {
    12071206                /* Turn VT-x or AMD-V back on on all CPUs. */
    1208                 rc = RTMpOnAll(hmR0EnableCpuCallback, NULL, &FirstRc /* output ignored */);
     1207                rc = RTMpOnAll(hmR0EnableCpuCallback, NULL /* pVM */, &FirstRc /* output ignored */);
    12091208                Assert(RT_SUCCESS(rc) || rc == VERR_NOT_SUPPORTED);
    12101209            }
     
    12421241     * Copy globals to the VM structure.
    12431242     */
     1243    /** @todo r=ramshankar: Why do we do this for MSRs? We never change them in the
     1244     *        per-VM structures anyway... */
    12441245    pVM->hm.s.vmx.fSupported            = g_HvmR0.vmx.fSupported;
    12451246    pVM->hm.s.svm.fSupported            = g_HvmR0.svm.fSupported;
     
    12471248    pVM->hm.s.vmx.fUsePreemptTimer      = g_HvmR0.vmx.fUsePreemptTimer;
    12481249    pVM->hm.s.vmx.cPreemptTimerShift    = g_HvmR0.vmx.cPreemptTimerShift;
    1249     pVM->hm.s.vmx.msr.feature_ctrl      = g_HvmR0.vmx.msr.feature_ctrl;
    1250     pVM->hm.s.vmx.hostCR4               = g_HvmR0.vmx.hostCR4;
    1251     pVM->hm.s.vmx.hostEFER              = g_HvmR0.vmx.hostEFER;
    1252     pVM->hm.s.vmx.msr.vmx_basic_info    = g_HvmR0.vmx.msr.vmx_basic_info;
    1253     pVM->hm.s.vmx.msr.vmx_pin_ctls      = g_HvmR0.vmx.msr.vmx_pin_ctls;
    1254     pVM->hm.s.vmx.msr.vmx_proc_ctls     = g_HvmR0.vmx.msr.vmx_proc_ctls;
    1255     pVM->hm.s.vmx.msr.vmx_proc_ctls2    = g_HvmR0.vmx.msr.vmx_proc_ctls2;
    1256     pVM->hm.s.vmx.msr.vmx_exit          = g_HvmR0.vmx.msr.vmx_exit;
    1257     pVM->hm.s.vmx.msr.vmx_entry         = g_HvmR0.vmx.msr.vmx_entry;
    1258     pVM->hm.s.vmx.msr.vmx_misc          = g_HvmR0.vmx.msr.vmx_misc;
    1259     pVM->hm.s.vmx.msr.vmx_cr0_fixed0    = g_HvmR0.vmx.msr.vmx_cr0_fixed0;
    1260     pVM->hm.s.vmx.msr.vmx_cr0_fixed1    = g_HvmR0.vmx.msr.vmx_cr0_fixed1;
    1261     pVM->hm.s.vmx.msr.vmx_cr4_fixed0    = g_HvmR0.vmx.msr.vmx_cr4_fixed0;
    1262     pVM->hm.s.vmx.msr.vmx_cr4_fixed1    = g_HvmR0.vmx.msr.vmx_cr4_fixed1;
    1263     pVM->hm.s.vmx.msr.vmx_vmcs_enum     = g_HvmR0.vmx.msr.vmx_vmcs_enum;
    1264     pVM->hm.s.vmx.msr.vmx_vmfunc        = g_HvmR0.vmx.msr.vmx_vmfunc;
    1265     pVM->hm.s.vmx.msr.vmx_ept_vpid_caps = g_HvmR0.vmx.msr.vmx_ept_vpid_caps;
     1250    pVM->hm.s.vmx.msr.feature_ctrl      = g_HvmR0.vmx.msr.u64FeatureCtrl;
     1251    pVM->hm.s.vmx.hostCR4               = g_HvmR0.vmx.u64HostCr4;
     1252    pVM->hm.s.vmx.hostEFER              = g_HvmR0.vmx.u64HostEfer;
     1253    pVM->hm.s.vmx.msr.vmx_basic_info    = g_HvmR0.vmx.msr.u64BasicInfo;
     1254    pVM->hm.s.vmx.msr.vmx_pin_ctls      = g_HvmR0.vmx.msr.vmxPinCtls;
     1255    pVM->hm.s.vmx.msr.vmx_proc_ctls     = g_HvmR0.vmx.msr.vmxProcCtls;
     1256    pVM->hm.s.vmx.msr.vmx_proc_ctls2    = g_HvmR0.vmx.msr.vmxProcCtls2;
     1257    pVM->hm.s.vmx.msr.vmx_exit          = g_HvmR0.vmx.msr.vmxExit;
     1258    pVM->hm.s.vmx.msr.vmx_entry         = g_HvmR0.vmx.msr.vmxEntry;
     1259    pVM->hm.s.vmx.msr.vmx_misc          = g_HvmR0.vmx.msr.u64Misc;
     1260    pVM->hm.s.vmx.msr.vmx_cr0_fixed0    = g_HvmR0.vmx.msr.u64Cr0Fixed0;
     1261    pVM->hm.s.vmx.msr.vmx_cr0_fixed1    = g_HvmR0.vmx.msr.u64Cr0Fixed1;
     1262    pVM->hm.s.vmx.msr.vmx_cr4_fixed0    = g_HvmR0.vmx.msr.u64Cr4Fixed0;
     1263    pVM->hm.s.vmx.msr.vmx_cr4_fixed1    = g_HvmR0.vmx.msr.u64Cr4Fixed1;
     1264    pVM->hm.s.vmx.msr.vmx_vmcs_enum     = g_HvmR0.vmx.msr.u64VmcsEnum;
     1265    pVM->hm.s.vmx.msr.vmx_vmfunc        = g_HvmR0.vmx.msr.u64Vmfunc;
     1266    pVM->hm.s.vmx.msr.vmx_ept_vpid_caps = g_HvmR0.vmx.msr.u64EptVpidCaps;
    12661267    pVM->hm.s.svm.msrHwcr               = g_HvmR0.svm.msrHwcr;
    12671268    pVM->hm.s.svm.u32Rev                = g_HvmR0.svm.u32Rev;
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