From: OsirizX Date: Thu, 12 Jan 2023 19:39:55 +0000 (-0800) Subject: Apply some cleanups to the abicall macros X-Git-Tag: v2.00~260 X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=1ef527e93b7207df1faab3b4c54e146dd529afa6;p=picodrive.git Apply some cleanups to the abicall macros --- diff --git a/cpu/drc/emit_ppc.c b/cpu/drc/emit_ppc.c index 7d4dfeab..7394485b 100644 --- a/cpu/drc/emit_ppc.c +++ b/cpu/drc/emit_ppc.c @@ -1507,29 +1507,20 @@ static int emith_cond_check(int cond) #define emith_call_cond(cond, target) \ emith_call(target) -#ifdef __PS3__ #define emith_call_reg(r) do { \ - emith_read_r_r_offs_ptr(TOC_REG, r, 8); \ - emith_read_r_r_offs_ptr(r, r, 0); \ EMIT(PPC_MTSP_REG(r, CTR)); \ EMIT(PPC_BLCTRCOND(BXX)); \ } while(0) -#else -#define emith_call_reg(r) do { \ - EMIT(PPC_MTSP_REG(r, CTR)); \ - EMIT(PPC_BLCTRCOND(BXX)); \ -} while(0) -#endif #define emith_abicall_ctx(offs) do { \ emith_ctx_read_ptr(CR, offs); \ - emith_call_reg(CR); \ + emith_abicall_reg(CR); \ } while (0) #ifdef __PS3__ #define emith_abijump_reg(r) \ if ((r) != CR) emith_move_r_r(CR, r); \ - emith_read_r_r_offs_ptr(TOC_REG, CR, 8); \ + emith_read_r_r_offs_ptr(TOC_REG, CR, PTR_SIZE); \ emith_read_r_r_offs_ptr(CR, CR, 0); \ emith_jump_reg(CR) #else @@ -1541,12 +1532,22 @@ static int emith_cond_check(int cond) emith_abijump_reg(r) #define emith_abicall(target) \ emith_move_r_ptr_imm(CR, target); \ - emith_call_reg(CR); + emith_abicall_reg(CR); #define emith_abicall_cond(cond, target) \ emith_abicall(target) -#define emith_abicall_reg(r) \ +#ifdef __PS3__ +#define emith_abicall_reg(r) do { \ if ((r) != CR) emith_move_r_r(CR, r); \ - emith_call_reg(CR) + emith_read_r_r_offs_ptr(TOC_REG, r, PTR_SIZE); \ + emith_read_r_r_offs_ptr(r, r, 0); \ + emith_call_reg(CR); \ +} while(0) +#else +#define emith_abicall_reg(r) do { \ + if ((r) != CR) emith_move_r_r(CR, r); \ + emith_call_reg(CR); \ +} while(0) +#endif #define emith_call_cleanup() /**/ diff --git a/cpu/drc/emit_x86.c b/cpu/drc/emit_x86.c index 6ba7304f..6fbe5abf 100644 --- a/cpu/drc/emit_x86.c +++ b/cpu/drc/emit_x86.c @@ -1043,7 +1043,7 @@ enum { xAX = 0, xCX, xDX, xBX, xSP, xBP, xSI, xDI, // x86-64,i386 common #define emith_rw_offs_max() 0xffffffffU -#define host_call(addr, args) +#define host_call(addr, args) \ addr #ifdef __x86_64__