[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v5 08/47] x86emul: support basic AVX512F FP compare insns
V{,U}COMIS{S,D} to follow later. Also correct the AVX counterpart's comment. Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> Acked-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> --- v5: Adjust title. v3: New. --- a/tools/tests/x86_emulator/evex-disp8.c +++ b/tools/tests/x86_emulator/evex-disp8.c @@ -105,6 +105,7 @@ enum esz { static const struct test avx512f_all[] = { INSN_FP(add, 0f, 58), + INSN_FP(cmp, 0f, c2), INSN_FP(div, 0f, 5e), INSN_FP(max, 0f, 5f), INSN_FP(min, 0f, 5d), --- a/xen/arch/x86/x86_emulate/x86_emulate.c +++ b/xen/arch/x86/x86_emulate/x86_emulate.c @@ -352,7 +352,7 @@ static const struct twobyte_table { [0xbf] = { DstReg|SrcMem16|ModRM|Mov }, [0xc0] = { ByteOp|DstMem|SrcReg|ModRM }, [0xc1] = { DstMem|SrcReg|ModRM }, - [0xc2] = { DstImplicit|SrcImmByte|ModRM, simd_any_fp }, + [0xc2] = { DstImplicit|SrcImmByte|ModRM, simd_any_fp, d8s_vl }, [0xc3] = { DstMem|SrcReg|ModRM|Mov }, [0xc4] = { DstReg|SrcImmByte|ModRM, simd_packed_int }, [0xc5] = { DstReg|SrcImmByte|ModRM|Mov }, @@ -7443,7 +7443,7 @@ x86_emulate( goto add; CASE_SIMD_ALL_FP(, 0x0f, 0xc2): /* cmp{p,s}{s,d} $imm8,xmm/mem,xmm */ - CASE_SIMD_ALL_FP(_VEX, 0x0f, 0xc2): /* vcmp{p,s}{s,d} $imm8,{x,y}mm/mem,{x,y}mm */ + CASE_SIMD_ALL_FP(_VEX, 0x0f, 0xc2): /* vcmp{p,s}{s,d} $imm8,{x,y}mm/mem,{x,y}mm,{x,y}mm */ CASE_SIMD_PACKED_FP(, 0x0f, 0xc6): /* shufp{s,d} $imm8,xmm/mem,xmm */ CASE_SIMD_PACKED_FP(_VEX, 0x0f, 0xc6): /* vshufp{s,d} $imm8,{x,y}mm/mem,{x,y}mm */ d = (d & ~SrcMask) | SrcMem; @@ -7457,6 +7457,30 @@ x86_emulate( } goto simd_0f_imm8_avx; + CASE_SIMD_ALL_FP(_EVEX, 0x0f, 0xc2): /* vcmp{p,s}{s,d} $imm8,[xyz]mm/mem,[xyz]mm,k{k} */ + generate_exception_if((evex.w != (evex.pfx & VEX_PREFIX_DOUBLE_MASK) || + (ea.type == OP_MEM && evex.br && + (evex.pfx & VEX_PREFIX_SCALAR_MASK)) || + !evex.r || !evex.R || evex.z), + EXC_UD); + host_and_vcpu_must_have(avx512f); + if ( ea.type == OP_MEM || !evex.br ) + avx512_vlen_check(evex.pfx & VEX_PREFIX_SCALAR_MASK); + d = (d & ~SrcMask) | SrcMem; + get_fpu(X86EMUL_FPU_zmm); + opc = init_evex(stub); + opc[0] = b; + opc[1] = modrm; + if ( ea.type == OP_MEM ) + { + /* convert memory operand to (%rAX) */ + evex.b = 1; + opc[1] &= 0x38; + } + opc[2] = imm1; + insn_bytes = EVEX_PFX_BYTES + 3; + break; + case X86EMUL_OPC(0x0f, 0xc3): /* movnti */ /* Ignore the non-temporal hint for now. */ vcpu_must_have(sse2); _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |