mirror of
				https://github.com/yuzu-emu/unicorn.git
				synced 2025-11-04 11:14:50 +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