mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-06 17:23:56 -06:00
target/i386: move BSWAP to new decoder
Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
2b8046f361
commit
37861fa519
3 changed files with 23 additions and 1 deletions
|
@ -1124,6 +1124,15 @@ static const X86OpEntry opcodes_0F[256] = {
|
||||||
[0xc5] = X86_OP_ENTRY3(PEXTRW, G,d, U,dq,I,b, vex5 mmx p_00_66),
|
[0xc5] = X86_OP_ENTRY3(PEXTRW, G,d, U,dq,I,b, vex5 mmx p_00_66),
|
||||||
[0xc6] = X86_OP_ENTRY4(VSHUF, V,x, H,x, W,x, vex4 p_00_66),
|
[0xc6] = X86_OP_ENTRY4(VSHUF, V,x, H,x, W,x, vex4 p_00_66),
|
||||||
|
|
||||||
|
[0xc8] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
[0xc9] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
[0xca] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
[0xcb] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
[0xcc] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
[0xcd] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
[0xce] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
[0xcf] = X86_OP_ENTRY1(BSWAP, LoBits,y),
|
||||||
|
|
||||||
[0xd0] = X86_OP_ENTRY3(VADDSUB, V,x, H,x, W,x, vex2 cpuid(SSE3) p_66_f2),
|
[0xd0] = X86_OP_ENTRY3(VADDSUB, V,x, H,x, W,x, vex2 cpuid(SSE3) p_66_f2),
|
||||||
[0xd1] = X86_OP_ENTRY3(PSRLW_r, V,x, H,x, W,x, vex4 mmx avx2_256 p_00_66),
|
[0xd1] = X86_OP_ENTRY3(PSRLW_r, V,x, H,x, W,x, vex4 mmx avx2_256 p_00_66),
|
||||||
[0xd2] = X86_OP_ENTRY3(PSRLD_r, V,x, H,x, W,x, vex4 mmx avx2_256 p_00_66),
|
[0xd2] = X86_OP_ENTRY3(PSRLD_r, V,x, H,x, W,x, vex4 mmx avx2_256 p_00_66),
|
||||||
|
|
|
@ -1310,6 +1310,17 @@ static void gen_BOUND(DisasContext *s, CPUX86State *env, X86DecodedInsn *decode)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void gen_BSWAP(DisasContext *s, CPUX86State *env, X86DecodedInsn *decode)
|
||||||
|
{
|
||||||
|
#ifdef TARGET_X86_64
|
||||||
|
if (s->dflag == MO_64) {
|
||||||
|
tcg_gen_bswap64_i64(s->T0, s->T0);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
tcg_gen_bswap32_tl(s->T0, s->T0, TCG_BSWAP_OZ);
|
||||||
|
}
|
||||||
|
|
||||||
static void gen_BZHI(DisasContext *s, CPUX86State *env, X86DecodedInsn *decode)
|
static void gen_BZHI(DisasContext *s, CPUX86State *env, X86DecodedInsn *decode)
|
||||||
{
|
{
|
||||||
MemOp ot = decode->op[0].ot;
|
MemOp ot = decode->op[0].ot;
|
||||||
|
|
|
@ -3207,7 +3207,9 @@ static bool disas_insn(DisasContext *s, CPUState *cpu)
|
||||||
#ifndef CONFIG_USER_ONLY
|
#ifndef CONFIG_USER_ONLY
|
||||||
use_new &= b <= limit;
|
use_new &= b <= limit;
|
||||||
#endif
|
#endif
|
||||||
if (use_new && (b >= 0x138 && b <= 0x19f)) {
|
if (use_new &&
|
||||||
|
((b >= 0x138 && b <= 0x19f) ||
|
||||||
|
(b >= 0x1c8 && b <= 0x1cf))) {
|
||||||
disas_insn_new(s, cpu, b);
|
disas_insn_new(s, cpu, b);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue