mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-03-29 17:17:22 +00:00
target/arm: Use tcg_gen_gvec_dup_i64 for LD[1-4]R
Backports commit 10e0b33c676b4e8ac80d5929980f4fa6be617c5a from qemu
This commit is contained in:
parent
74aba4ba51
commit
e6707b900c
|
@ -3293,36 +3293,14 @@ static void disas_ldst_single_struct(DisasContext *s, uint32_t insn)
|
||||||
for (xs = 0; xs < selem; xs++) {
|
for (xs = 0; xs < selem; xs++) {
|
||||||
if (replicate) {
|
if (replicate) {
|
||||||
/* Load and replicate to all elements */
|
/* Load and replicate to all elements */
|
||||||
uint64_t mulconst;
|
|
||||||
TCGv_i64 tcg_tmp = tcg_temp_new_i64(tcg_ctx);
|
TCGv_i64 tcg_tmp = tcg_temp_new_i64(tcg_ctx);
|
||||||
|
|
||||||
tcg_gen_qemu_ld_i64(s->uc, tcg_tmp, tcg_addr,
|
tcg_gen_qemu_ld_i64(s->uc, tcg_tmp, tcg_addr,
|
||||||
get_mem_index(s), s->be_data + scale);
|
get_mem_index(s), s->be_data + scale);
|
||||||
switch (scale) {
|
tcg_gen_gvec_dup_i64(tcg_ctx, scale, vec_full_reg_offset(s, rt),
|
||||||
case 0:
|
(is_q + 1) * 8, vec_full_reg_size(s),
|
||||||
mulconst = 0x0101010101010101ULL;
|
tcg_tmp);
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
mulconst = 0x0001000100010001ULL;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
mulconst = 0x0000000100000001ULL;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
mulconst = 0;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
g_assert_not_reached();
|
|
||||||
}
|
|
||||||
if (mulconst) {
|
|
||||||
tcg_gen_muli_i64(tcg_ctx, tcg_tmp, tcg_tmp, mulconst);
|
|
||||||
}
|
|
||||||
write_vec_element(s, tcg_tmp, rt, 0, MO_64);
|
|
||||||
if (is_q) {
|
|
||||||
write_vec_element(s, tcg_tmp, rt, 1, MO_64);
|
|
||||||
}
|
|
||||||
tcg_temp_free_i64(tcg_ctx, tcg_tmp);
|
tcg_temp_free_i64(tcg_ctx, tcg_tmp);
|
||||||
clear_vec_high(s, is_q, rt);
|
|
||||||
} else {
|
} else {
|
||||||
/* Load/store one element per register */
|
/* Load/store one element per register */
|
||||||
if (is_load) {
|
if (is_load) {
|
||||||
|
|
Loading…
Reference in a new issue