target/i386: Fix BEXTR instruction
authorRichard Henderson <richard.henderson@linaro.org>
Sat, 14 Jan 2023 23:05:42 +0000 (13:05 -1000)
committerPaolo Bonzini <pbonzini@redhat.com>
Sat, 11 Feb 2023 08:07:25 +0000 (09:07 +0100)
commitb14c0098975264ed03144f145bca0179a6763a07
tree8296781e30c6d0ff58b729095b93d03c7a3e9b32
parent5d62d6649cd367b5b4a3676e7514d2f9ca86cb03
target/i386: Fix BEXTR instruction

There were two problems here: not limiting the input to operand bits,
and not correctly handling large extraction length.

Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1372
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20230114230542.3116013-3-richard.henderson@linaro.org>
Cc: qemu-stable@nongnu.org
Fixes: 1d0b926150e5 ("target/i386: move scalar 0F 38 and 0F 3A instruction to new decoder", 2022-10-18)
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
target/i386/tcg/emit.c.inc
tests/tcg/i386/test-i386-bmi2.c