VirtualBox

Changeset 67013 in vbox


Ignore:
Timestamp:
May 22, 2017 12:41:30 PM (8 years ago)
Author:
vboxsync
Message:

IEM: Documented and adjusted movd Ed,Pd and mov Eq,Pq (0x0f 0x7e).

Location:
trunk/src/VBox
Files:
3 edited

Legend:

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

    r67012 r67013  
    43894389    uint8_t bRm; IEM_OPCODE_GET_NEXT_U8(&bRm);
    43904390    if (pVCpu->iem.s.fPrefixes & IEM_OP_PRF_SIZE_REX_W)
    4391         IEMOP_MNEMONIC(movq_Eq_Pq, "movq Eq,Pq");
    4392     else
    4393         IEMOP_MNEMONIC(movd_Ed_Pd, "movd Ed,Pd");
    4394     if ((bRm & X86_MODRM_MOD_MASK) == (3 << X86_MODRM_MOD_SHIFT))
    4395     {
    4396         /* greg, MMX */
    4397         IEMOP_HLP_DONE_DECODING_NO_LOCK_PREFIX();
    4398         IEM_MC_BEGIN(0, 1);
    4399         IEM_MC_MAYBE_RAISE_MMX_RELATED_XCPT();
    4400         IEM_MC_ACTUALIZE_FPU_STATE_FOR_READ();
    4401         if (pVCpu->iem.s.fPrefixes & IEM_OP_PRF_SIZE_REX_W)
     4391    {
     4392        /**
     4393         * @opcode      0x7e
     4394         * @opcodesub   rex.w=1
     4395         * @oppfx       none
     4396         * @opcpuid     mmx
     4397         * @opgroup     og_mmx_datamove
     4398         * @opxcpttype  5
     4399         * @optest      64-bit / op1=1 op2=2   -> op1=2   ftw=0xff
     4400         * @optest      64-bit / op1=0 op2=-42 -> op1=-42 ftw=0xff
     4401         * @oponly
     4402         */
     4403        IEMOP_MNEMONIC2(MR, MOVQ, movq, Eq_WO, Pq, DISOPTYPE_HARMLESS, IEMOPHINT_IGNORES_OZ_PFX);
     4404        if ((bRm & X86_MODRM_MOD_MASK) == (3 << X86_MODRM_MOD_SHIFT))
    44024405        {
     4406            /* greg64, MMX */
     4407            IEMOP_HLP_DONE_DECODING_NO_LOCK_PREFIX();
     4408            IEM_MC_BEGIN(0, 1);
    44034409            IEM_MC_LOCAL(uint64_t, u64Tmp);
     4410
     4411            IEM_MC_MAYBE_RAISE_MMX_RELATED_XCPT();
     4412            IEM_MC_ACTUALIZE_FPU_STATE_FOR_CHANGE();
     4413
    44044414            IEM_MC_FETCH_MREG_U64(u64Tmp, (bRm >> X86_MODRM_REG_SHIFT) & X86_MODRM_REG_SMASK);
    44054415            IEM_MC_STORE_GREG_U64((bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB, u64Tmp);
     4416            IEM_MC_FPU_TO_MMX_MODE();
     4417
     4418            IEM_MC_ADVANCE_RIP();
     4419            IEM_MC_END();
    44064420        }
    44074421        else
    44084422        {
     4423            /* [mem64], MMX */
     4424            IEM_MC_BEGIN(0, 2);
     4425            IEM_MC_LOCAL(RTGCPTR, GCPtrEffSrc);
     4426            IEM_MC_LOCAL(uint64_t, u64Tmp);
     4427
     4428            IEM_MC_CALC_RM_EFF_ADDR(GCPtrEffSrc, bRm, 0);
     4429            IEMOP_HLP_DONE_DECODING_NO_LOCK_PREFIX();
     4430            IEM_MC_MAYBE_RAISE_MMX_RELATED_XCPT();
     4431            IEM_MC_ACTUALIZE_FPU_STATE_FOR_CHANGE();
     4432
     4433            IEM_MC_FETCH_MREG_U64(u64Tmp, (bRm >> X86_MODRM_REG_SHIFT) & X86_MODRM_REG_SMASK);
     4434            IEM_MC_STORE_MEM_U64(pVCpu->iem.s.iEffSeg, GCPtrEffSrc, u64Tmp);
     4435            IEM_MC_FPU_TO_MMX_MODE();
     4436
     4437            IEM_MC_ADVANCE_RIP();
     4438            IEM_MC_END();
     4439        }
     4440    }
     4441    else
     4442    {
     4443        /**
     4444         * @opdone
     4445         * @opcode      0x7e
     4446         * @opcodesub   rex.w=0
     4447         * @oppfx       none
     4448         * @opcpuid     mmx
     4449         * @opgroup     og_mmx_datamove
     4450         * @opxcpttype  5
     4451         * @opfunction  iemOp_movd_q_Pd_Ey
     4452         * @optest      op1=1 op2=2   -> op1=2   ftw=0xff
     4453         * @optest      op1=0 op2=-42 -> op1=-42 ftw=0xff
     4454        * @oponly
     4455         */
     4456        IEMOP_MNEMONIC2(MR, MOVD, movd, Ed_WO, Pd, DISOPTYPE_HARMLESS, IEMOPHINT_IGNORES_OZ_PFX);
     4457        if ((bRm & X86_MODRM_MOD_MASK) == (3 << X86_MODRM_MOD_SHIFT))
     4458        {
     4459            /* greg32, MMX */
     4460            IEMOP_HLP_DONE_DECODING_NO_LOCK_PREFIX();
     4461            IEM_MC_BEGIN(0, 1);
    44094462            IEM_MC_LOCAL(uint32_t, u32Tmp);
     4463
     4464            IEM_MC_MAYBE_RAISE_MMX_RELATED_XCPT();
     4465            IEM_MC_ACTUALIZE_FPU_STATE_FOR_CHANGE();
     4466
    44104467            IEM_MC_FETCH_MREG_U32(u32Tmp, (bRm >> X86_MODRM_REG_SHIFT) & X86_MODRM_REG_SMASK);
    44114468            IEM_MC_STORE_GREG_U32((bRm & X86_MODRM_RM_MASK) | pVCpu->iem.s.uRexB, u32Tmp);
    4412         }
    4413         IEM_MC_ADVANCE_RIP();
    4414         IEM_MC_END();
    4415     }
    4416     else
    4417     {
    4418         /* [mem], MMX */
    4419         IEM_MC_BEGIN(0, 2);
    4420         IEM_MC_LOCAL(RTGCPTR, GCPtrEffSrc);
    4421         IEM_MC_MAYBE_RAISE_MMX_RELATED_XCPT();
    4422         IEM_MC_CALC_RM_EFF_ADDR(GCPtrEffSrc, bRm, 1);
    4423         IEMOP_HLP_DONE_DECODING_NO_LOCK_PREFIX();
    4424         IEM_MC_ACTUALIZE_FPU_STATE_FOR_READ();
    4425         if (pVCpu->iem.s.fPrefixes & IEM_OP_PRF_SIZE_REX_W)
    4426         {
    4427             IEM_MC_LOCAL(uint64_t, u64Tmp);
    4428             IEM_MC_FETCH_MREG_U64(u64Tmp, (bRm >> X86_MODRM_REG_SHIFT) & X86_MODRM_REG_SMASK);
    4429             IEM_MC_STORE_MEM_U64(pVCpu->iem.s.iEffSeg, GCPtrEffSrc, u64Tmp);
     4469            IEM_MC_FPU_TO_MMX_MODE();
     4470
     4471            IEM_MC_ADVANCE_RIP();
     4472            IEM_MC_END();
    44304473        }
    44314474        else
    44324475        {
     4476            /* [mem32], MMX */
     4477            IEM_MC_BEGIN(0, 2);
     4478            IEM_MC_LOCAL(RTGCPTR, GCPtrEffSrc);
    44334479            IEM_MC_LOCAL(uint32_t, u32Tmp);
     4480
     4481            IEM_MC_CALC_RM_EFF_ADDR(GCPtrEffSrc, bRm, 0);
     4482            IEMOP_HLP_DONE_DECODING_NO_LOCK_PREFIX();
     4483            IEM_MC_MAYBE_RAISE_MMX_RELATED_XCPT();
     4484            IEM_MC_ACTUALIZE_FPU_STATE_FOR_CHANGE();
     4485
    44344486            IEM_MC_FETCH_MREG_U32(u32Tmp, (bRm >> X86_MODRM_REG_SHIFT) & X86_MODRM_REG_SMASK);
    44354487            IEM_MC_STORE_MEM_U32(pVCpu->iem.s.iEffSeg, GCPtrEffSrc, u32Tmp);
     4488            IEM_MC_FPU_TO_MMX_MODE();
     4489
     4490            IEM_MC_ADVANCE_RIP();
     4491            IEM_MC_END();
    44364492        }
    4437         IEM_MC_ADVANCE_RIP();
    4438         IEM_MC_END();
    4439     }
    4440     return VINF_SUCCESS;
    4441 }
     4493    }
     4494    return VINF_SUCCESS;
     4495
     4496}
     4497
    44424498
    44434499/** Opcode 0x66 0x0f 0x7e - movd_q Ey, Vy */
  • trunk/src/VBox/ValidationKit/bootsectors/bs3-cpu-generated-1-template.c

    r67012 r67013  
    41664166            break;
    41674167
     4168        case BS3CG1ENC_MODRM_Ed_WO_Pd_WZ:
     4169            pThis->pfnEncoder        = Bs3Cg1EncodeNext_MODRM_PdZx_WO_Ed_WZ;
     4170            pThis->iRmOp             = 0;
     4171            pThis->iRegOp            = 1;
     4172            pThis->aOperands[0].cbOp = 4;
     4173            pThis->aOperands[1].cbOp = 4;
     4174            pThis->aOperands[0].idxFieldBase   = BS3CG1DST_EAX;
     4175            pThis->aOperands[1].idxFieldBase   = BS3CG1DST_MM0;
     4176            pThis->aOperands[0].enmLocation    = BS3CG1OPLOC_CTX;
     4177            pThis->aOperands[0].enmLocationReg = BS3CG1OPLOC_CTX;
     4178            pThis->aOperands[0].enmLocationMem = BS3CG1OPLOC_MEM_WO;
     4179            pThis->aOperands[1].enmLocation    = BS3CG1OPLOC_CTX;
     4180            break;
     4181
     4182        case BS3CG1ENC_MODRM_Eq_WO_Pq_WNZ:
     4183            pThis->pfnEncoder        = Bs3Cg1EncodeNext_MODRM_Pq_WO_Eq_WNZ;
     4184            pThis->iRmOp             = 0;
     4185            pThis->iRegOp            = 1;
     4186            pThis->aOperands[0].cbOp = 8;
     4187            pThis->aOperands[1].cbOp = 8;
     4188            pThis->aOperands[0].idxFieldBase   = BS3CG1DST_RAX;
     4189            pThis->aOperands[1].idxFieldBase   = BS3CG1DST_MM0;
     4190            pThis->aOperands[0].enmLocation    = BS3CG1OPLOC_CTX;
     4191            pThis->aOperands[0].enmLocationReg = BS3CG1OPLOC_CTX;
     4192            pThis->aOperands[0].enmLocationMem = BS3CG1OPLOC_MEM_WO;
     4193            pThis->aOperands[1].enmLocation    = BS3CG1OPLOC_CTX;
     4194            break;
     4195
    41684196        case BS3CG1ENC_MODRM_Gb_Eb:
    41694197            pThis->iRmOp             = 1;
  • trunk/src/VBox/ValidationKit/bootsectors/bs3-cpu-generated-1.h

    r67012 r67013  
    138138    BS3CG1ENC_MODRM_Eb_Gb,
    139139    BS3CG1ENC_MODRM_Ev_Gv,
     140    BS3CG1ENC_MODRM_Ed_WO_Pd_WZ,
     141    BS3CG1ENC_MODRM_Eq_WO_Pq_WNZ,
    140142    BS3CG1ENC_MODRM_Pq_WO_Qq,
    141143    BS3CG1ENC_MODRM_Wss_WO_Vss,
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