VirtualBox

Changeset 76645 in vbox for trunk


Ignore:
Timestamp:
Jan 5, 2019 3:59:16 AM (6 years ago)
Author:
vboxsync
Message:

VMM/IEM: Nested VMX: bugref:9180 vmread decoding fix.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/VMMAll/IEMAllInstructionsTwoByte0f.cpp.h

    r76553 r76645  
    43434343    {
    43444344        /*
    4345          * Register, memory.
     4345         * Memory, register.
    43464346         */
    43474347        if (enmEffOpSize == IEMMODE_64BIT)
     
    43524352            IEM_MC_ARG(RTGCPTR,       GCPtrVal,                                         2);
    43534353            IEM_MC_ARG(uint64_t,      u64Enc,                                           3);
    4354             IEM_MC_FETCH_GREG_U64(u64Enc, (bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB);
    43554354            IEM_MC_CALC_RM_EFF_ADDR(GCPtrVal, bRm, 0);
    43564355            IEMOP_HLP_DONE_DECODING_NO_SIZE_OP_REPZ_OR_REPNZ_PREFIXES();
     4356            IEM_MC_FETCH_GREG_U64(u64Enc, ((bRm >> X86_MODRM_REG_SHIFT) & X86_MODRM_REG_SMASK) | pVCpu->iem.s.uRexReg);
    43574357            IEM_MC_ASSIGN(iEffSeg, pVCpu->iem.s.iEffSeg);
    43584358            IEM_MC_CALL_CIMPL_4(iemCImpl_vmread_mem, iEffSeg, enmEffAddrMode, GCPtrVal, u64Enc);
     
    43664366            IEM_MC_ARG(RTGCPTR,       GCPtrVal,                                         2);
    43674367            IEM_MC_ARG(uint32_t,      u32Enc,                                           3);
    4368             IEM_MC_FETCH_GREG_U32(u32Enc, (bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB);
    43694368            IEM_MC_CALC_RM_EFF_ADDR(GCPtrVal, bRm, 0);
    43704369            IEMOP_HLP_DONE_DECODING_NO_SIZE_OP_REPZ_OR_REPNZ_PREFIXES();
     4370            IEM_MC_FETCH_GREG_U32(u32Enc, ((bRm >> X86_MODRM_REG_SHIFT) & X86_MODRM_REG_SMASK) | pVCpu->iem.s.uRexReg);
    43714371            IEM_MC_ASSIGN(iEffSeg, pVCpu->iem.s.iEffSeg);
    43724372            IEM_MC_CALL_CIMPL_4(iemCImpl_vmread_mem, iEffSeg, enmEffAddrMode, GCPtrVal, u32Enc);
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