mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2024-10-21 03:08:18 +02:00
target/arm: Use vector minmax expanders for aarch32
Backports commit 6f2782218230bbb33fa22f9a2f73f8a570046007 from qemu
This commit is contained in:
parent
96d1df966b
commit
eee33bd692
@ -6530,6 +6530,25 @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
|
|||||||
tcg_gen_gvec_cmp(tcg_ctx, u ? TCG_COND_GEU : TCG_COND_GE, size,
|
tcg_gen_gvec_cmp(tcg_ctx, u ? TCG_COND_GEU : TCG_COND_GE, size,
|
||||||
rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size);
|
rd_ofs, rn_ofs, rm_ofs, vec_size, vec_size);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
case NEON_3R_VMAX:
|
||||||
|
if (u) {
|
||||||
|
tcg_gen_gvec_umax(tcg_ctx, size, rd_ofs, rn_ofs, rm_ofs,
|
||||||
|
vec_size, vec_size);
|
||||||
|
} else {
|
||||||
|
tcg_gen_gvec_smax(tcg_ctx, size, rd_ofs, rn_ofs, rm_ofs,
|
||||||
|
vec_size, vec_size);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
case NEON_3R_VMIN:
|
||||||
|
if (u) {
|
||||||
|
tcg_gen_gvec_umin(tcg_ctx, size, rd_ofs, rn_ofs, rm_ofs,
|
||||||
|
vec_size, vec_size);
|
||||||
|
} else {
|
||||||
|
tcg_gen_gvec_smin(tcg_ctx, size, rd_ofs, rn_ofs, rm_ofs,
|
||||||
|
vec_size, vec_size);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (size == 3) {
|
if (size == 3) {
|
||||||
@ -6695,12 +6714,6 @@ static int disas_neon_data_insn(DisasContext *s, uint32_t insn)
|
|||||||
case NEON_3R_VQRSHL:
|
case NEON_3R_VQRSHL:
|
||||||
GEN_NEON_INTEGER_OP_ENV(qrshl);
|
GEN_NEON_INTEGER_OP_ENV(qrshl);
|
||||||
break;
|
break;
|
||||||
case NEON_3R_VMAX:
|
|
||||||
GEN_NEON_INTEGER_OP(max);
|
|
||||||
break;
|
|
||||||
case NEON_3R_VMIN:
|
|
||||||
GEN_NEON_INTEGER_OP(min);
|
|
||||||
break;
|
|
||||||
case NEON_3R_VABD:
|
case NEON_3R_VABD:
|
||||||
GEN_NEON_INTEGER_OP(abd);
|
GEN_NEON_INTEGER_OP(abd);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user