[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen staging] x86emul: support AVX512F legacy-equivalent logic insns
commit a1c7f59ce351b6bf908203d36c7a55058115d15a Author: Jan Beulich <jbeulich@xxxxxxxx> AuthorDate: Tue Nov 20 15:11:09 2018 +0100 Commit: Jan Beulich <jbeulich@xxxxxxxx> CommitDate: Tue Nov 20 15:11:09 2018 +0100 x86emul: support AVX512F legacy-equivalent logic insns Plus vpternlog{d,q} as being extensively used by the compiler, in order to facilitate test enabling in the harness as soon as possible. Also the twobyte_table[] entries for a few more insns get their .d8s field set right away, in order to not split and later re-combine the groups. Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> Acked-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> --- tools/tests/x86_emulator/evex-disp8.c | 5 +++++ xen/arch/x86/x86_emulate/x86_emulate.c | 31 ++++++++++++++++++++++++++----- 2 files changed, 31 insertions(+), 5 deletions(-) diff --git a/tools/tests/x86_emulator/evex-disp8.c b/tools/tests/x86_emulator/evex-disp8.c index b92851b8c4..41f0faac81 100644 --- a/tools/tests/x86_emulator/evex-disp8.c +++ b/tools/tests/x86_emulator/evex-disp8.c @@ -157,6 +157,11 @@ static const struct test avx512f_all[] = { INSN_PFP_NB(movu, 0f, 10), INSN_PFP_NB(movu, 0f, 11), INSN_FP(mul, 0f, 59), + INSN(pand, 66, 0f, db, vl, dq, vl), + INSN(pandn, 66, 0f, df, vl, dq, vl), + INSN(por, 66, 0f, eb, vl, dq, vl), + INSN(pternlog, 66, 0f3a, 25, vl, dq, vl), + INSN(pxor, 66, 0f, ef, vl, dq, vl), INSN_PFP(shuf, 0f, c6), INSN_FP(sqrt, 0f, 51), INSN_FP(sub, 0f, 5c), diff --git a/xen/arch/x86/x86_emulate/x86_emulate.c b/xen/arch/x86/x86_emulate/x86_emulate.c index 773b971369..9bd5d35a44 100644 --- a/xen/arch/x86/x86_emulate/x86_emulate.c +++ b/xen/arch/x86/x86_emulate/x86_emulate.c @@ -364,13 +364,13 @@ static const struct twobyte_table { [0xd4 ... 0xd5] = { DstImplicit|SrcMem|ModRM, simd_packed_int }, [0xd6] = { DstMem|SrcImplicit|ModRM|Mov, simd_other, 3 }, [0xd7] = { DstReg|SrcImplicit|ModRM|Mov }, - [0xd8 ... 0xdf] = { DstImplicit|SrcMem|ModRM, simd_packed_int }, + [0xd8 ... 0xdf] = { DstImplicit|SrcMem|ModRM, simd_packed_int, d8s_vl }, [0xe0] = { DstImplicit|SrcMem|ModRM, simd_packed_int }, [0xe1 ... 0xe2] = { DstImplicit|SrcMem|ModRM, simd_other }, [0xe3 ... 0xe5] = { DstImplicit|SrcMem|ModRM, simd_packed_int }, [0xe6] = { DstImplicit|SrcMem|ModRM|Mov, simd_other }, [0xe7] = { DstMem|SrcImplicit|ModRM|Mov, simd_packed_int, d8s_vl }, - [0xe8 ... 0xef] = { DstImplicit|SrcMem|ModRM, simd_packed_int }, + [0xe8 ... 0xef] = { DstImplicit|SrcMem|ModRM, simd_packed_int, d8s_vl }, [0xf0] = { DstImplicit|SrcMem|ModRM|Mov, simd_other }, [0xf1 ... 0xf3] = { DstImplicit|SrcMem|ModRM, simd_other }, [0xf4 ... 0xf6] = { DstImplicit|SrcMem|ModRM, simd_packed_int }, @@ -493,6 +493,7 @@ static const struct ext0f3a_table { uint8_t to_mem:1; uint8_t two_op:1; uint8_t four_op:1; + disp8scale_t d8s:4; } ext0f3a_table[256] = { [0x00] = { .simd_size = simd_packed_int, .two_op = 1 }, [0x01] = { .simd_size = simd_packed_fp, .two_op = 1 }, @@ -510,6 +511,7 @@ static const struct ext0f3a_table { [0x20] = { .simd_size = simd_none }, [0x21] = { .simd_size = simd_other }, [0x22] = { .simd_size = simd_none }, + [0x25] = { .simd_size = simd_packed_int, .d8s = d8s_vl }, [0x30 ... 0x33] = { .simd_size = simd_other, .two_op = 1 }, [0x38] = { .simd_size = simd_128 }, [0x39] = { .simd_size = simd_128, .to_mem = 1, .two_op = 1 }, @@ -3025,20 +3027,33 @@ x86_decode( disp8scale = decode_disp8scale(ext0f38_table[b].d8s, state); break; + case ext_0f3a: + /* + * Cannot update d here yet, as the immediate operand still + * needs fetching. + */ + state->simd_size = ext0f3a_table[b].simd_size; + if ( evex_encoded() ) + disp8scale = decode_disp8scale(ext0f3a_table[b].d8s, state); + break; + case ext_8f09: if ( ext8f09_table[b].two_op ) d |= TwoOp; state->simd_size = ext8f09_table[b].simd_size; break; - case ext_0f3a: case ext_8f08: + case ext_8f0a: /* * Cannot update d here yet, as the immediate operand still * needs fetching. */ - default: break; + + default: + ASSERT_UNREACHABLE(); + return X86EMUL_UNIMPLEMENTED; } if ( modrm_mod == 3 ) @@ -3217,7 +3232,6 @@ x86_decode( else if ( ext0f3a_table[b].four_op && !mode_64bit() && vex.opcx ) imm1 &= 0x7f; state->desc = d; - state->simd_size = ext0f3a_table[b].simd_size; rc = x86_decode_0f3a(state, ctxt, ops); break; @@ -5951,6 +5965,11 @@ x86_emulate( generate_exception_if(evex.w != (evex.pfx & VEX_PREFIX_DOUBLE_MASK), EXC_UD); fault_suppression = false; + /* fall through */ + case X86EMUL_OPC_EVEX_66(0x0f, 0xdb): /* vpand{d,q} [xyz]mm/mem,[xyz]mm,[xyz]mm{k} */ + case X86EMUL_OPC_EVEX_66(0x0f, 0xdf): /* vpandn{d,q} [xyz]mm/mem,[xyz]mm,[xyz]mm{k} */ + case X86EMUL_OPC_EVEX_66(0x0f, 0xeb): /* vpor{d,q} [xyz]mm/mem,[xyz]mm,[xyz]mm{k} */ + case X86EMUL_OPC_EVEX_66(0x0f, 0xef): /* vpxor{d,q} [xyz]mm/mem,[xyz]mm,[xyz]mm{k} */ avx512f_no_sae: host_and_vcpu_must_have(avx512f); generate_exception_if(ea.type != OP_MEM && evex.br, EXC_UD); @@ -7534,6 +7553,8 @@ x86_emulate( fault_suppression = false; generate_exception_if(evex.w != (evex.pfx & VEX_PREFIX_DOUBLE_MASK), EXC_UD); + /* fall through */ + case X86EMUL_OPC_EVEX_66(0x0f3a, 0x25): /* vpternlog{d,q} $imm8,[xyz]mm/mem,[xyz]mm,[xyz]mm{k} */ host_and_vcpu_must_have(avx512f); generate_exception_if(ea.type != OP_MEM && evex.br, EXC_UD); avx512_vlen_check(false); -- generated by git-patchbot for /home/xen/git/xen.git#staging _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |