mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-22 16:50:58 +00:00
target/arm: Avoid an extra temporary for store_exclusive
Instead of copying addr to a local temp, reuse the value (which we have just compared as equal) already saved in cpu_exclusive_addr. Backports commit 37e29a64254bf82a1901784fcca17c25f8164c2f from qemu
This commit is contained in:
parent
7fded6c15c
commit
c5e952978c
|
@ -1951,7 +1951,7 @@ static void gen_load_exclusive(DisasContext *s, int rt, int rt2,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gen_store_exclusive(DisasContext *s, int rd, int rt, int rt2,
|
static void gen_store_exclusive(DisasContext *s, int rd, int rt, int rt2,
|
||||||
TCGv_i64 inaddr, int size, int is_pair)
|
TCGv_i64 addr, int size, int is_pair)
|
||||||
{
|
{
|
||||||
TCGContext *tcg_ctx = s->uc->tcg_ctx;
|
TCGContext *tcg_ctx = s->uc->tcg_ctx;
|
||||||
/* if (env->exclusive_addr == addr && env->exclusive_val == [addr]
|
/* if (env->exclusive_addr == addr && env->exclusive_val == [addr]
|
||||||
|
@ -1968,13 +1968,8 @@ static void gen_store_exclusive(DisasContext *s, int rd, int rt, int rt2,
|
||||||
*/
|
*/
|
||||||
TCGLabel *fail_label = gen_new_label(tcg_ctx);
|
TCGLabel *fail_label = gen_new_label(tcg_ctx);
|
||||||
TCGLabel *done_label = gen_new_label(tcg_ctx);
|
TCGLabel *done_label = gen_new_label(tcg_ctx);
|
||||||
TCGv_i64 addr = tcg_temp_local_new_i64(tcg_ctx);
|
|
||||||
TCGv_i64 tmp;
|
TCGv_i64 tmp;
|
||||||
|
|
||||||
/* Copy input into a local temp so it is not trashed when the
|
|
||||||
* basic block ends at the branch insn.
|
|
||||||
*/
|
|
||||||
tcg_gen_mov_i64(tcg_ctx, addr, inaddr);
|
|
||||||
tcg_gen_brcond_i64(tcg_ctx, TCG_COND_NE, addr, tcg_ctx->cpu_exclusive_addr, fail_label);
|
tcg_gen_brcond_i64(tcg_ctx, TCG_COND_NE, addr, tcg_ctx->cpu_exclusive_addr, fail_label);
|
||||||
|
|
||||||
tmp = tcg_temp_new_i64(tcg_ctx);
|
tmp = tcg_temp_new_i64(tcg_ctx);
|
||||||
|
@ -1986,27 +1981,25 @@ static void gen_store_exclusive(DisasContext *s, int rd, int rt, int rt2,
|
||||||
} else {
|
} else {
|
||||||
tcg_gen_concat32_i64(tcg_ctx, tmp, cpu_reg(s, rt2), cpu_reg(s, rt));
|
tcg_gen_concat32_i64(tcg_ctx, tmp, cpu_reg(s, rt2), cpu_reg(s, rt));
|
||||||
}
|
}
|
||||||
tcg_gen_atomic_cmpxchg_i64(tcg_ctx, tmp, addr, tcg_ctx->cpu_exclusive_val, tmp,
|
tcg_gen_atomic_cmpxchg_i64(tcg_ctx, tmp, tcg_ctx->cpu_exclusive_addr,
|
||||||
|
tcg_ctx->cpu_exclusive_val, tmp,
|
||||||
get_mem_index(s),
|
get_mem_index(s),
|
||||||
MO_64 | MO_ALIGN | s->be_data);
|
MO_64 | MO_ALIGN | s->be_data);
|
||||||
tcg_gen_setcond_i64(tcg_ctx, TCG_COND_NE, tmp, tmp, tcg_ctx->cpu_exclusive_val);
|
tcg_gen_setcond_i64(tcg_ctx, TCG_COND_NE, tmp, tmp, tcg_ctx->cpu_exclusive_val);
|
||||||
} else if (s->be_data == MO_LE) {
|
} else if (s->be_data == MO_LE) {
|
||||||
gen_helper_paired_cmpxchg64_le(tcg_ctx, tmp, tcg_ctx->cpu_env, addr, cpu_reg(s, rt),
|
gen_helper_paired_cmpxchg64_le(tcg_ctx, tmp, tcg_ctx->cpu_env, tcg_ctx->cpu_exclusive_addr,
|
||||||
cpu_reg(s, rt2));
|
cpu_reg(s, rt), cpu_reg(s, rt2));
|
||||||
} else {
|
} else {
|
||||||
gen_helper_paired_cmpxchg64_be(tcg_ctx, tmp, tcg_ctx->cpu_env, addr, cpu_reg(s, rt),
|
gen_helper_paired_cmpxchg64_be(tcg_ctx, tmp, tcg_ctx->cpu_env, tcg_ctx->cpu_exclusive_addr,
|
||||||
cpu_reg(s, rt2));
|
cpu_reg(s, rt), cpu_reg(s, rt2));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
TCGv_i64 val = cpu_reg(s, rt);
|
tcg_gen_atomic_cmpxchg_i64(tcg_ctx, tmp, tcg_ctx->cpu_exclusive_addr, tcg_ctx->cpu_exclusive_val,
|
||||||
tcg_gen_atomic_cmpxchg_i64(tcg_ctx, tmp, addr, tcg_ctx->cpu_exclusive_val, val,
|
cpu_reg(s, rt), get_mem_index(s),
|
||||||
get_mem_index(s),
|
|
||||||
size | MO_ALIGN | s->be_data);
|
size | MO_ALIGN | s->be_data);
|
||||||
tcg_gen_setcond_i64(tcg_ctx, TCG_COND_NE, tmp, tmp, tcg_ctx->cpu_exclusive_val);
|
tcg_gen_setcond_i64(tcg_ctx, TCG_COND_NE, tmp, tmp, tcg_ctx->cpu_exclusive_val);
|
||||||
}
|
}
|
||||||
|
|
||||||
tcg_temp_free_i64(tcg_ctx, addr);
|
|
||||||
|
|
||||||
tcg_gen_mov_i64(tcg_ctx, cpu_reg(s, rd), tmp);
|
tcg_gen_mov_i64(tcg_ctx, cpu_reg(s, rd), tmp);
|
||||||
tcg_temp_free_i64(tcg_ctx, tmp);
|
tcg_temp_free_i64(tcg_ctx, tmp);
|
||||||
tcg_gen_br(tcg_ctx, done_label);
|
tcg_gen_br(tcg_ctx, done_label);
|
||||||
|
|
Loading…
Reference in a new issue