VirtualBox

Changeset 72512 in vbox for trunk


Ignore:
Timestamp:
Jun 11, 2018 2:12:21 PM (7 years ago)
Author:
vboxsync
Message:

IEM: Made sldt use CImpl so to better facilitate SVM intercepts.

Location:
trunk/src/VBox/VMM
Files:
4 edited

Legend:

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

    r72505 r72512  
    1108211082        (a_u32Dst) = iemSRegBaseFetchU64(pVCpu, (a_iSReg)); \
    1108311083    } while (0)
    11084 /** @todo IEM_MC_FETCH_LDTR_U16, IEM_MC_FETCH_LDTR_U32, IEM_MC_FETCH_LDTR_U64, IEM_MC_FETCH_TR_U16, IEM_MC_FETCH_TR_U32, and IEM_MC_FETCH_TR_U64 aren't worth it... */
    11085 #define IEM_MC_FETCH_LDTR_U16(a_u16Dst) do { \
    11086         IEM_CTX_IMPORT_NORET(pVCpu, CPUMCTX_EXTRN_LDTR); \
    11087         (a_u16Dst) = pVCpu->cpum.GstCtx.ldtr.Sel; \
    11088    } while (0)
    11089 #define IEM_MC_FETCH_LDTR_U32(a_u32Dst) do { \
    11090         IEM_CTX_IMPORT_NORET(pVCpu, CPUMCTX_EXTRN_LDTR); \
    11091         (a_u32Dst) = pVCpu->cpum.GstCtx.ldtr.Sel; \
    11092     } while (0)
    11093 #define IEM_MC_FETCH_LDTR_U64(a_u64Dst) do { \
    11094         IEM_CTX_IMPORT_NORET(pVCpu, CPUMCTX_EXTRN_LDTR); \
    11095         (a_u64Dst) = pVCpu->cpum.GstCtx.ldtr.Sel; \
    11096    } while (0)
    1109711084#define IEM_MC_FETCH_TR_U16(a_u16Dst) do { \
    1109811085        IEM_CTX_IMPORT_NORET(pVCpu, CPUMCTX_EXTRN_TR); \
  • trunk/src/VBox/VMM/VMMAll/IEMAllCImpl.cpp.h

    r72506 r72512  
    48964896
    48974897/**
     4898 * Implements sldt GReg
     4899 *
     4900 * @param   iGReg           The general register to store the CRx value in.
     4901 * @param   enmEffOpSize    The operand size.
     4902 */
     4903IEM_CIMPL_DEF_2(iemCImpl_sldt_reg, uint8_t, iGReg, uint8_t, enmEffOpSize)
     4904{
     4905    IEMOP_HLP_SVM_INSTR_INTERCEPT_AND_NRIP(pVCpu, SVM_CTRL_INTERCEPT_LDTR_READS, SVM_EXIT_LDTR_READ, 0, 0);
     4906
     4907    IEM_CTX_IMPORT_RET(pVCpu, CPUMCTX_EXTRN_LDTR);
     4908    switch (enmEffOpSize)
     4909    {
     4910        case IEMMODE_16BIT: *(uint16_t *)iemGRegRef(pVCpu, iGReg) = pVCpu->cpum.GstCtx.ldtr.Sel; break;
     4911        case IEMMODE_32BIT: *(uint64_t *)iemGRegRef(pVCpu, iGReg) = pVCpu->cpum.GstCtx.ldtr.Sel; break;
     4912        case IEMMODE_64BIT: *(uint64_t *)iemGRegRef(pVCpu, iGReg) = pVCpu->cpum.GstCtx.ldtr.Sel; break;
     4913        IEM_NOT_REACHED_DEFAULT_CASE_RET();
     4914    }
     4915    iemRegAddToRipAndClearRF(pVCpu, cbInstr);
     4916    return VINF_SUCCESS;
     4917}
     4918
     4919
     4920/**
     4921 * Implements sldt mem.
     4922 *
     4923 * @param   iGReg           The general register to store the CRx value in.
     4924 * @param   iEffSeg         The effective segment register to use with @a GCPtrMem.
     4925 * @param   GCPtrEffDst     Where to store the 16-bit CR0 value.
     4926 */
     4927IEM_CIMPL_DEF_2(iemCImpl_sldt_mem, uint8_t, iEffSeg, RTGCPTR, GCPtrEffDst)
     4928{
     4929    IEMOP_HLP_SVM_INSTR_INTERCEPT_AND_NRIP(pVCpu, SVM_CTRL_INTERCEPT_LDTR_READS, SVM_EXIT_LDTR_READ, 0, 0);
     4930
     4931    IEM_CTX_IMPORT_RET(pVCpu, CPUMCTX_EXTRN_LDTR);
     4932    VBOXSTRICTRC rcStrict = iemMemStoreDataU16(pVCpu, iEffSeg, GCPtrEffDst, pVCpu->cpum.GstCtx.ldtr.Sel);
     4933    if (rcStrict == VINF_SUCCESS)
     4934        iemRegAddToRipAndClearRF(pVCpu, cbInstr);
     4935    return rcStrict;
     4936}
     4937
     4938
     4939/**
    48984940 * Implements lldt.
    48994941 *
     
    51355177 * Implements smsw mem.
    51365178 *
    5137  * @param   iGReg           The general register to store the CRx value in.
     5179 * @param   iGReg           The general register to store the CR0 value in.
    51385180 * @param   iEffSeg         The effective segment register to use with @a GCPtrMem.
    51395181 * @param   GCPtrEffDst     Where to store the 16-bit CR0 value.
  • trunk/src/VBox/VMM/VMMAll/IEMAllInstructionsTwoByte0f.cpp.h

    r72505 r72512  
    3535    {
    3636        IEMOP_HLP_DECODED_NL_1(OP_SLDT, IEMOPFORM_M_REG, OP_PARM_Ew, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP);
    37         IEMOP_HLP_SVM_INSTR_INTERCEPT_AND_NRIP(pVCpu, SVM_CTRL_INTERCEPT_LDTR_READS, SVM_EXIT_LDTR_READ, 0, 0);
    38         switch (pVCpu->iem.s.enmEffOpSize)
    39         {
    40             case IEMMODE_16BIT:
    41                 IEM_MC_BEGIN(0, 1);
    42                 IEM_MC_LOCAL(uint16_t, u16Ldtr);
    43                 IEM_MC_FETCH_LDTR_U16(u16Ldtr);
    44                 IEM_MC_STORE_GREG_U16((bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB, u16Ldtr);
    45                 IEM_MC_ADVANCE_RIP();
    46                 IEM_MC_END();
    47                 break;
    48 
    49             case IEMMODE_32BIT:
    50                 IEM_MC_BEGIN(0, 1);
    51                 IEM_MC_LOCAL(uint32_t, u32Ldtr);
    52                 IEM_MC_FETCH_LDTR_U32(u32Ldtr);
    53                 IEM_MC_STORE_GREG_U32((bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB, u32Ldtr);
    54                 IEM_MC_ADVANCE_RIP();
    55                 IEM_MC_END();
    56                 break;
    57 
    58             case IEMMODE_64BIT:
    59                 IEM_MC_BEGIN(0, 1);
    60                 IEM_MC_LOCAL(uint64_t, u64Ldtr);
    61                 IEM_MC_FETCH_LDTR_U64(u64Ldtr);
    62                 IEM_MC_STORE_GREG_U64((bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB, u64Ldtr);
    63                 IEM_MC_ADVANCE_RIP();
    64                 IEM_MC_END();
    65                 break;
    66 
    67             IEM_NOT_REACHED_DEFAULT_CASE_RET();
    68         }
    69     }
    70     else
    71     {
    72         IEM_MC_BEGIN(0, 2);
    73         IEM_MC_LOCAL(uint16_t, u16Ldtr);
    74         IEM_MC_LOCAL(RTGCPTR, GCPtrEffDst);
    75         IEM_MC_CALC_RM_EFF_ADDR(GCPtrEffDst, bRm, 0);
    76         IEMOP_HLP_DECODED_NL_1(OP_SLDT, IEMOPFORM_M_MEM, OP_PARM_Ew, DISOPTYPE_DANGEROUS | DISOPTYPE_PRIVILEGED_NOTRAP);
    77         IEMOP_HLP_SVM_INSTR_INTERCEPT_AND_NRIP(pVCpu, SVM_CTRL_INTERCEPT_LDTR_READS, SVM_EXIT_LDTR_READ, 0, 0);
    78         IEM_MC_FETCH_LDTR_U16(u16Ldtr);
    79         IEM_MC_STORE_MEM_U16(pVCpu->iem.s.iEffSeg, GCPtrEffDst, u16Ldtr);
    80         IEM_MC_ADVANCE_RIP();
    81         IEM_MC_END();
    82     }
     37        return IEM_MC_DEFER_TO_CIMPL_2(iemCImpl_sldt_reg, (bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB, pVCpu->iem.s.enmEffOpSize);
     38    }
     39
     40    /* Ignore operand size here, memory refs are always 16-bit. */
     41    IEM_MC_BEGIN(2, 0);
     42    IEM_MC_ARG(uint16_t, iEffSeg,               0);
     43    IEM_MC_ARG(RTGCPTR,  GCPtrEffDst,           1);
     44    IEM_MC_CALC_RM_EFF_ADDR(GCPtrEffDst, bRm, 0);
     45    IEMOP_HLP_DONE_DECODING_NO_LOCK_PREFIX();
     46    IEM_MC_ASSIGN(iEffSeg, pVCpu->iem.s.iEffSeg);
     47    IEM_MC_CALL_CIMPL_2(iemCImpl_sldt_mem, iEffSeg, GCPtrEffDst);
     48    IEM_MC_END();
    8349    return VINF_SUCCESS;
    8450}
  • trunk/src/VBox/VMM/testcase/tstIEMCheckMc.cpp

    r72505 r72512  
    429429#define IEM_MC_FETCH_SREG_BASE_U64(a_u64Dst, a_iSReg)   do { (a_u64Dst) = 0; CHK_TYPE(uint64_t, a_u64Dst); } while (0)
    430430#define IEM_MC_FETCH_SREG_BASE_U32(a_u32Dst, a_iSReg)   do { (a_u32Dst) = 0; CHK_TYPE(uint32_t, a_u32Dst); } while (0)
    431 #define IEM_MC_FETCH_LDTR_U16(a_u16Dst)                 do { (a_u16Dst) = 0; CHK_TYPE(uint16_t, a_u16Dst); } while (0)
    432 #define IEM_MC_FETCH_LDTR_U32(a_u32Dst)                 do { (a_u32Dst) = 0; CHK_TYPE(uint32_t, a_u32Dst); } while (0)
    433 #define IEM_MC_FETCH_LDTR_U64(a_u64Dst)                 do { (a_u64Dst) = 0; CHK_TYPE(uint64_t, a_u64Dst); } while (0)
    434431#define IEM_MC_FETCH_TR_U16(a_u16Dst)                   do { (a_u16Dst) = 0; CHK_TYPE(uint16_t, a_u16Dst); } while (0)
    435432#define IEM_MC_FETCH_TR_U32(a_u32Dst)                   do { (a_u32Dst) = 0; CHK_TYPE(uint32_t, a_u32Dst); } while (0)
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