[PATCH] x86emul: always set operand size for AVX-VNNI-INT8 insns

Jan Beulich posted 1 patch 3 months ago
Failed in applying to current master (apply log)
[PATCH] x86emul: always set operand size for AVX-VNNI-INT8 insns
Posted by Jan Beulich 3 months ago
Unlike for AVX-VNNI-INT16 I missed to notice that op_bytes may still be
zero when reaching the respective case block: With the ext0f38_table[]
entries having simd_packed_int, the defaulting at the bottom of
x86emul_decode() won't set the field to non-zero for F3- or F2-prefixed
insns.

Fixes: 842acaa743a5 ("x86emul: support AVX-VNNI-INT8")
Signed-off-by: Jan Beulich <jbeulich@suse.com>

--- a/xen/arch/x86/x86_emulate/x86_emulate.c
+++ b/xen/arch/x86/x86_emulate/x86_emulate.c
@@ -6075,6 +6075,7 @@ x86_emulate(
     case X86EMUL_OPC_VEX_F2(0x0f38, 0x51): /* vpdpbssds [xy]mm/mem,[xy]mm,[xy]mm */
         host_and_vcpu_must_have(avx_vnni_int8);
         generate_exception_if(vex.w, X86_EXC_UD);
+        op_bytes = 16 << vex.l;
         goto simd_0f_ymm;
 
     case X86EMUL_OPC_VEX_66(0x0f38, 0x50): /* vpdpbusd [xy]mm/mem,[xy]mm,[xy]mm */
Re: [PATCH] x86emul: always set operand size for AVX-VNNI-INT8 insns
Posted by Andrew Cooper 3 months ago
On 21/08/2024 10:26 am, Jan Beulich wrote:
> Unlike for AVX-VNNI-INT16 I missed to notice that op_bytes may still be

Minor grammar note.  It's either "I missed that", or "I failed to notice
that".

> zero when reaching the respective case block: With the ext0f38_table[]
> entries having simd_packed_int, the defaulting at the bottom of
> x86emul_decode() won't set the field to non-zero for F3- or F2-prefixed
> insns.
>
> Fixes: 842acaa743a5 ("x86emul: support AVX-VNNI-INT8")
> Signed-off-by: Jan Beulich <jbeulich@suse.com>

Acked-by: Andrew Cooper <andrew.cooper3@citrix.com>