mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-02-02 03:31:15 +00:00
target-sparc: Use tcg_gen_atomic_cmpxchg_tl
Backports commit 5a7267b6a9e94c264ca77a7ca5a239e70dac81da from qemu
This commit is contained in:
parent
47313adedd
commit
f9d91a81b5
|
@ -2548,32 +2548,22 @@ static void gen_swap_asi(DisasContext *dc, TCGv dst, TCGv src,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gen_cas_asi(DisasContext *dc, TCGv addr, TCGv cmpr,
|
static void gen_cas_asi(DisasContext *dc, TCGv addr, TCGv cmpv,
|
||||||
int insn, int rd)
|
int insn, int rd)
|
||||||
{
|
{
|
||||||
TCGContext *tcg_ctx = dc->uc->tcg_ctx;
|
TCGContext *tcg_ctx = dc->uc->tcg_ctx;
|
||||||
DisasASI da = get_asi(dc, insn, MO_TEUL);
|
DisasASI da = get_asi(dc, insn, MO_TEUL);
|
||||||
TCGv cmpv, oldv, tmpv;
|
TCGv oldv;
|
||||||
|
|
||||||
switch (da.type) {
|
switch (da.type) {
|
||||||
case GET_ASI_EXCP:
|
case GET_ASI_EXCP:
|
||||||
return;
|
return;
|
||||||
case GET_ASI_DIRECT:
|
case GET_ASI_DIRECT:
|
||||||
cmpv = tcg_temp_new(tcg_ctx);
|
|
||||||
oldv = tcg_temp_new(tcg_ctx);
|
oldv = tcg_temp_new(tcg_ctx);
|
||||||
tmpv = tcg_temp_new(tcg_ctx);
|
tcg_gen_atomic_cmpxchg_tl(tcg_ctx, oldv, addr, cmpv, gen_load_gpr(dc, rd),
|
||||||
tcg_gen_ext32u_tl(tcg_ctx, cmpv, cmpr);
|
da.mem_idx, da.memop);
|
||||||
|
|
||||||
/* ??? Should be atomic. */
|
|
||||||
tcg_gen_qemu_ld_tl(dc->uc, oldv, addr, da.mem_idx, da.memop);
|
|
||||||
tcg_gen_movcond_tl(tcg_ctx, TCG_COND_EQ, tmpv, oldv, cmpv,
|
|
||||||
gen_load_gpr(dc, rd), oldv);
|
|
||||||
tcg_gen_qemu_st_tl(dc->uc, tmpv, addr, da.mem_idx, da.memop);
|
|
||||||
|
|
||||||
gen_store_gpr(dc, rd, oldv);
|
gen_store_gpr(dc, rd, oldv);
|
||||||
tcg_temp_free(tcg_ctx, cmpv);
|
|
||||||
tcg_temp_free(tcg_ctx, oldv);
|
tcg_temp_free(tcg_ctx, oldv);
|
||||||
tcg_temp_free(tcg_ctx, tmpv);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* ??? Should be DAE_invalid_asi. */
|
/* ??? Should be DAE_invalid_asi. */
|
||||||
|
@ -2933,24 +2923,17 @@ static void gen_casx_asi(DisasContext *dc, TCGv addr, TCGv cmpv,
|
||||||
{
|
{
|
||||||
TCGContext *tcg_ctx = dc->uc->tcg_ctx;
|
TCGContext *tcg_ctx = dc->uc->tcg_ctx;
|
||||||
DisasASI da = get_asi(dc, insn, MO_TEQ);
|
DisasASI da = get_asi(dc, insn, MO_TEQ);
|
||||||
TCGv oldv, tmpv;
|
TCGv oldv;
|
||||||
|
|
||||||
switch (da.type) {
|
switch (da.type) {
|
||||||
case GET_ASI_EXCP:
|
case GET_ASI_EXCP:
|
||||||
return;
|
return;
|
||||||
case GET_ASI_DIRECT:
|
case GET_ASI_DIRECT:
|
||||||
oldv = tcg_temp_new(tcg_ctx);
|
oldv = tcg_temp_new(tcg_ctx);
|
||||||
tmpv = tcg_temp_new(tcg_ctx);
|
tcg_gen_atomic_cmpxchg_tl(tcg_ctx, oldv, addr, cmpv, gen_load_gpr(dc, rd),
|
||||||
|
da.mem_idx, da.memop);
|
||||||
/* ??? Should be atomic. */
|
|
||||||
tcg_gen_qemu_ld_tl(dc->uc, oldv, addr, da.mem_idx, da.memop);
|
|
||||||
tcg_gen_movcond_tl(tcg_ctx, TCG_COND_EQ, tmpv, oldv, cmpv,
|
|
||||||
gen_load_gpr(dc, rd), oldv);
|
|
||||||
tcg_gen_qemu_st_tl(dc->uc, tmpv, addr, da.mem_idx, da.memop);
|
|
||||||
|
|
||||||
gen_store_gpr(dc, rd, oldv);
|
gen_store_gpr(dc, rd, oldv);
|
||||||
tcg_temp_free(tcg_ctx, oldv);
|
tcg_temp_free(tcg_ctx, oldv);
|
||||||
tcg_temp_free(tcg_ctx, tmpv);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* ??? Should be DAE_invalid_asi. */
|
/* ??? Should be DAE_invalid_asi. */
|
||||||
|
|
Loading…
Reference in a new issue