implement few AVX-512 unsigned convert instructions
This commit is contained in:
parent
d3107f9f25
commit
51d0161148
@ -367,6 +367,66 @@ BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCMPSS_MASK_KGbHssWssIbR(bxInstruc
|
|||||||
|
|
||||||
// convert
|
// convert
|
||||||
|
|
||||||
|
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTUSI2SS_VssEdR(bxInstruction_c *i)
|
||||||
|
{
|
||||||
|
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
||||||
|
|
||||||
|
float_status_t status;
|
||||||
|
mxcsr_to_softfloat_status_word(status, MXCSR);
|
||||||
|
softfloat_status_word_rc_override(status, i);
|
||||||
|
|
||||||
|
op1.xmm32u(0) = uint32_to_float32(BX_READ_32BIT_REG(i->src2()), status);
|
||||||
|
|
||||||
|
check_exceptionsSSE(get_exception_flags(status));
|
||||||
|
|
||||||
|
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
||||||
|
|
||||||
|
BX_NEXT_INSTR(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTUSI2SS_VssEqR(bxInstruction_c *i)
|
||||||
|
{
|
||||||
|
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
||||||
|
|
||||||
|
float_status_t status;
|
||||||
|
mxcsr_to_softfloat_status_word(status, MXCSR);
|
||||||
|
softfloat_status_word_rc_override(status, i);
|
||||||
|
|
||||||
|
op1.xmm32u(0) = uint64_to_float32(BX_READ_64BIT_REG(i->src2()), status);
|
||||||
|
|
||||||
|
check_exceptionsSSE(get_exception_flags(status));
|
||||||
|
|
||||||
|
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
||||||
|
|
||||||
|
BX_NEXT_INSTR(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTUSI2SD_VsdEdR(bxInstruction_c *i)
|
||||||
|
{
|
||||||
|
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
||||||
|
op1.xmm64u(0) = uint32_to_float64(BX_READ_32BIT_REG(i->src2()));
|
||||||
|
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
||||||
|
|
||||||
|
BX_NEXT_INSTR(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTUSI2SD_VsdEqR(bxInstruction_c *i)
|
||||||
|
{
|
||||||
|
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
||||||
|
|
||||||
|
float_status_t status;
|
||||||
|
mxcsr_to_softfloat_status_word(status, MXCSR);
|
||||||
|
softfloat_status_word_rc_override(status, i);
|
||||||
|
|
||||||
|
op1.xmm64u(0) = uint64_to_float64(BX_READ_64BIT_REG(i->src2()), status);
|
||||||
|
|
||||||
|
check_exceptionsSSE(get_exception_flags(status));
|
||||||
|
|
||||||
|
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
||||||
|
|
||||||
|
BX_NEXT_INSTR(i);
|
||||||
|
}
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
|
||||||
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTPS2PD_MASK_VpdWpsR(bxInstruction_c *i)
|
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTPS2PD_MASK_VpdWpsR(bxInstruction_c *i)
|
||||||
|
@ -149,7 +149,6 @@ BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SS_VssEdR(bxInstruction_c *
|
|||||||
/* Opcode: VEX.F3.0F 2A (VEX.W=1) */
|
/* Opcode: VEX.F3.0F 2A (VEX.W=1) */
|
||||||
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SS_VssEqR(bxInstruction_c *i)
|
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SS_VssEqR(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
#if BX_SUPPORT_X86_64
|
|
||||||
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
||||||
|
|
||||||
float_status_t status;
|
float_status_t status;
|
||||||
@ -161,7 +160,6 @@ BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SS_VssEqR(bxInstruction_c *
|
|||||||
check_exceptionsSSE(get_exception_flags(status));
|
check_exceptionsSSE(get_exception_flags(status));
|
||||||
|
|
||||||
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
||||||
#endif
|
|
||||||
|
|
||||||
BX_NEXT_INSTR(i);
|
BX_NEXT_INSTR(i);
|
||||||
}
|
}
|
||||||
@ -179,7 +177,6 @@ BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SD_VsdEdR(bxInstruction_c *
|
|||||||
/* Opcode: VEX.F2.0F 2A (VEX.W=1) */
|
/* Opcode: VEX.F2.0F 2A (VEX.W=1) */
|
||||||
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SD_VsdEqR(bxInstruction_c *i)
|
BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SD_VsdEqR(bxInstruction_c *i)
|
||||||
{
|
{
|
||||||
#if BX_SUPPORT_X86_64
|
|
||||||
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
BxPackedXmmRegister op1 = BX_READ_XMM_REG(i->src1());
|
||||||
|
|
||||||
float_status_t status;
|
float_status_t status;
|
||||||
@ -191,7 +188,6 @@ BX_INSF_TYPE BX_CPP_AttrRegparmN(1) BX_CPU_C::VCVTSI2SD_VsdEqR(bxInstruction_c *
|
|||||||
check_exceptionsSSE(get_exception_flags(status));
|
check_exceptionsSSE(get_exception_flags(status));
|
||||||
|
|
||||||
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
BX_WRITE_XMM_REG_CLEAR_HIGH(i->dst(), op1);
|
||||||
#endif
|
|
||||||
|
|
||||||
BX_NEXT_INSTR(i);
|
BX_NEXT_INSTR(i);
|
||||||
}
|
}
|
||||||
|
@ -3230,6 +3230,11 @@ public: // for now...
|
|||||||
BX_SMF BX_INSF_TYPE VSQRTSS_MASK_VssHpsWssR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
BX_SMF BX_INSF_TYPE VSQRTSS_MASK_VssHpsWssR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
BX_SMF BX_INSF_TYPE VSQRTSD_MASK_VsdHpdWsdR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
BX_SMF BX_INSF_TYPE VSQRTSD_MASK_VsdHpdWsdR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
|
|
||||||
|
BX_SMF BX_INSF_TYPE VCVTUSI2SD_VsdEdR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
|
BX_SMF BX_INSF_TYPE VCVTUSI2SS_VssEdR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
|
BX_SMF BX_INSF_TYPE VCVTUSI2SD_VsdEqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
|
BX_SMF BX_INSF_TYPE VCVTUSI2SS_VssEqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
|
|
||||||
BX_SMF BX_INSF_TYPE VPADDD_MASK_VdqHdqWdqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
BX_SMF BX_INSF_TYPE VPADDD_MASK_VdqHdqWdqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
BX_SMF BX_INSF_TYPE VPSUBD_MASK_VdqHdqWdqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
BX_SMF BX_INSF_TYPE VPSUBD_MASK_VdqHdqWdqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
BX_SMF BX_INSF_TYPE VPANDD_MASK_VdqHdqWdqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
BX_SMF BX_INSF_TYPE VPANDD_MASK_VdqHdqWdqR(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
||||||
|
@ -285,6 +285,12 @@ static const BxOpcodeInfo_t BxOpcodeGroupEVEX_0f6f_Mask[3] = {
|
|||||||
/* F2 */ { 0, BX_IA_ERROR }
|
/* F2 */ { 0, BX_IA_ERROR }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const BxOpcodeInfo_t BxOpcodeGroupEVEX_0f7b[3] = {
|
||||||
|
/* 66 */ { 0, BX_IA_ERROR },
|
||||||
|
/* F3 */ { BxAliasVexW64, BX_IA_V512_VCVTUSI2SS_VssEd },
|
||||||
|
/* F2 */ { BxAliasVexW64, BX_IA_V512_VCVTUSI2SD_VsdEd }
|
||||||
|
};
|
||||||
|
|
||||||
static const BxOpcodeInfo_t BxOpcodeGroupEVEX_0f7e[3] = {
|
static const BxOpcodeInfo_t BxOpcodeGroupEVEX_0f7e[3] = {
|
||||||
/* 66 */ { BxAliasVexW64, BX_IA_V512_VMOVD_EdVd },
|
/* 66 */ { BxAliasVexW64, BX_IA_V512_VMOVD_EdVd },
|
||||||
/* F3 */ { BxVexW1, BX_IA_V512_VMOVQ_VqWq },
|
/* F3 */ { BxVexW1, BX_IA_V512_VMOVQ_VqWq },
|
||||||
@ -630,8 +636,8 @@ static const BxOpcodeInfo_t BxOpcodeTableEVEX[256*3*2] = {
|
|||||||
/* 79 */ { 0, BX_IA_ERROR },
|
/* 79 */ { 0, BX_IA_ERROR },
|
||||||
/* 7A k0 */ { 0, BX_IA_ERROR },
|
/* 7A k0 */ { 0, BX_IA_ERROR },
|
||||||
/* 7A */ { 0, BX_IA_ERROR },
|
/* 7A */ { 0, BX_IA_ERROR },
|
||||||
/* 7B k0 */ { 0, BX_IA_ERROR },
|
/* 7B k0 */ { BxPrefixSSE4, BX_IA_ERROR, BxOpcodeGroupEVEX_0f7b },
|
||||||
/* 7B */ { 0, BX_IA_ERROR },
|
/* 7B */ { 0, BX_IA_ERROR }, // #UD
|
||||||
/* 7C k0 */ { 0, BX_IA_ERROR },
|
/* 7C k0 */ { 0, BX_IA_ERROR },
|
||||||
/* 7C */ { 0, BX_IA_ERROR },
|
/* 7C */ { 0, BX_IA_ERROR },
|
||||||
/* 7D k0 */ { 0, BX_IA_ERROR },
|
/* 7D k0 */ { 0, BX_IA_ERROR },
|
||||||
|
@ -3025,6 +3025,11 @@ bx_define_opcode(BX_IA_V512_VCVTSI2SS_VssEd, &BX_CPU_C::LOAD_Ed, &BX_CPU_C::VCVT
|
|||||||
bx_define_opcode(BX_IA_V512_VCVTSI2SS_VssEq, &BX_CPU_C::LOAD_Eq, &BX_CPU_C::VCVTSI2SS_VssEqR, BX_ISA_AVX512, OP_Vss, OP_Hps, OP_Eq, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST)
|
bx_define_opcode(BX_IA_V512_VCVTSI2SS_VssEq, &BX_CPU_C::LOAD_Eq, &BX_CPU_C::VCVTSI2SS_VssEqR, BX_ISA_AVX512, OP_Vss, OP_Hps, OP_Eq, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST)
|
||||||
bx_define_opcode(BX_IA_V512_VCVTSI2SD_VsdEd, &BX_CPU_C::LOAD_Ed, &BX_CPU_C::VCVTSI2SD_VsdEdR, BX_ISA_AVX512, OP_Vsd, OP_Hpd, OP_Ed, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST | BX_PREPARE_EVEX_NO_SAE)
|
bx_define_opcode(BX_IA_V512_VCVTSI2SD_VsdEd, &BX_CPU_C::LOAD_Ed, &BX_CPU_C::VCVTSI2SD_VsdEdR, BX_ISA_AVX512, OP_Vsd, OP_Hpd, OP_Ed, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST | BX_PREPARE_EVEX_NO_SAE)
|
||||||
bx_define_opcode(BX_IA_V512_VCVTSI2SD_VsdEq, &BX_CPU_C::LOAD_Eq, &BX_CPU_C::VCVTSI2SD_VsdEqR, BX_ISA_AVX512, OP_Vsd, OP_Hpd, OP_Eq, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST)
|
bx_define_opcode(BX_IA_V512_VCVTSI2SD_VsdEq, &BX_CPU_C::LOAD_Eq, &BX_CPU_C::VCVTSI2SD_VsdEqR, BX_ISA_AVX512, OP_Vsd, OP_Hpd, OP_Eq, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST)
|
||||||
|
|
||||||
|
bx_define_opcode(BX_IA_V512_VCVTUSI2SS_VssEd, &BX_CPU_C::LOAD_Ed, &BX_CPU_C::VCVTUSI2SS_VssEdR, BX_ISA_AVX512, OP_Vss, OP_Hps, OP_Ed, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST)
|
||||||
|
bx_define_opcode(BX_IA_V512_VCVTUSI2SS_VssEq, &BX_CPU_C::LOAD_Eq, &BX_CPU_C::VCVTUSI2SS_VssEqR, BX_ISA_AVX512, OP_Vss, OP_Hps, OP_Eq, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST)
|
||||||
|
bx_define_opcode(BX_IA_V512_VCVTUSI2SD_VsdEd, &BX_CPU_C::LOAD_Ed, &BX_CPU_C::VCVTUSI2SD_VsdEdR, BX_ISA_AVX512, OP_Vsd, OP_Hpd, OP_Ed, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST | BX_PREPARE_EVEX_NO_SAE)
|
||||||
|
bx_define_opcode(BX_IA_V512_VCVTUSI2SD_VsdEq, &BX_CPU_C::LOAD_Eq, &BX_CPU_C::VCVTUSI2SD_VsdEqR, BX_ISA_AVX512, OP_Vsd, OP_Hpd, OP_Eq, OP_NONE, BX_PREPARE_EVEX_NO_BROADCAST)
|
||||||
// VexW64 aliased
|
// VexW64 aliased
|
||||||
|
|
||||||
#endif // BX_SUPPORT_EVEX
|
#endif // BX_SUPPORT_EVEX
|
||||||
|
Loading…
Reference in New Issue
Block a user