mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-07-08 13:00:49 +00:00
target/arm: Decode aa64 armv8.1 scalar/vector x indexed element
Backports commit d345df7a3f1336ceb0537c1fa0a7261030426768 from qemu
This commit is contained in:
parent
12fd2cc113
commit
152c9484bd
|
@ -12144,6 +12144,13 @@ static void disas_simd_indexed(DisasContext *s, uint32_t insn)
|
||||||
case 0x19: /* FMULX */
|
case 0x19: /* FMULX */
|
||||||
is_fp = true;
|
is_fp = true;
|
||||||
break;
|
break;
|
||||||
|
case 0x1d: /* SQRDMLAH */
|
||||||
|
case 0x1f: /* SQRDMLSH */
|
||||||
|
if (!arm_dc_feature(s, ARM_FEATURE_V8_RDM)) {
|
||||||
|
unallocated_encoding(s);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
unallocated_encoding(s);
|
unallocated_encoding(s);
|
||||||
return;
|
return;
|
||||||
|
@ -12387,6 +12394,28 @@ static void disas_simd_indexed(DisasContext *s, uint32_t insn)
|
||||||
tcg_op, tcg_idx);
|
tcg_op, tcg_idx);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 0x1d: /* SQRDMLAH */
|
||||||
|
read_vec_element_i32(s, tcg_res, rd, pass,
|
||||||
|
is_scalar ? size : MO_32);
|
||||||
|
if (size == 1) {
|
||||||
|
gen_helper_neon_qrdmlah_s16(tcg_ctx, tcg_res, tcg_ctx->cpu_env,
|
||||||
|
tcg_op, tcg_idx, tcg_res);
|
||||||
|
} else {
|
||||||
|
gen_helper_neon_qrdmlah_s32(tcg_ctx, tcg_res, tcg_ctx->cpu_env,
|
||||||
|
tcg_op, tcg_idx, tcg_res);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 0x1f: /* SQRDMLSH */
|
||||||
|
read_vec_element_i32(s, tcg_res, rd, pass,
|
||||||
|
is_scalar ? size : MO_32);
|
||||||
|
if (size == 1) {
|
||||||
|
gen_helper_neon_qrdmlsh_s16(tcg_ctx, tcg_res, tcg_ctx->cpu_env,
|
||||||
|
tcg_op, tcg_idx, tcg_res);
|
||||||
|
} else {
|
||||||
|
gen_helper_neon_qrdmlsh_s32(tcg_ctx, tcg_res, tcg_ctx->cpu_env,
|
||||||
|
tcg_op, tcg_idx, tcg_res);
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
g_assert_not_reached();
|
g_assert_not_reached();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue