From 126119b1fbfd77d5c872130b76bb093d1bf1dbee Mon Sep 17 00:00:00 2001 From: ptitSeb Date: Mon, 14 Jun 2021 17:31:01 +0200 Subject: [DYNAREC] Added shrd32c emiter and 0F AC opcode --- src/dynarec/dynarec_arm64_0f.c | 11 +++- src/dynarec/dynarec_arm64_emit_shift.c | 103 +++++++++++++++------------------ src/dynarec/dynarec_arm64_helper.h | 2 +- 3 files changed, 59 insertions(+), 57 deletions(-) (limited to 'src') diff --git a/src/dynarec/dynarec_arm64_0f.c b/src/dynarec/dynarec_arm64_0f.c index 56d61471..56e3529b 100755 --- a/src/dynarec/dynarec_arm64_0f.c +++ b/src/dynarec/dynarec_arm64_0f.c @@ -1086,7 +1086,16 @@ uintptr_t dynarec64_0F(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin STRxw_U12(ed, wback, fixedaddress); } break; - + case 0xAC: + nextop = F8; + INST_NAME("SHRD Ed, Gd, Ib"); + SETFLAGS(X_ALL, SF_SET_PENDING); + GETED(1); + GETGD; + u8 = F8; + emit_shrd32c(dyn, ninst, rex, ed, gd, u8, x3, x4); + WBACK; + break; case 0xAD: nextop = F8; INST_NAME("SHRD Ed, Gd, CL"); diff --git a/src/dynarec/dynarec_arm64_emit_shift.c b/src/dynarec/dynarec_arm64_emit_shift.c index 1e0c89a3..db76657d 100755 --- a/src/dynarec/dynarec_arm64_emit_shift.c +++ b/src/dynarec/dynarec_arm64_emit_shift.c @@ -345,61 +345,54 @@ void emit_ror32c(dynarec_arm_t* dyn, int ninst, rex_t rex, int s1, int32_t c, in } // emit SHRD32 instruction, from s1, fill s2 , constant c, store result in s1 using s3 and s4 as scratch -//void emit_shrd32c(dynarec_arm_t* dyn, int ninst, int s1, int s2, int32_t c, int s3, int s4) -//{ -// c&=0x1f; -// IFX(X_PEND) { -// MOVW(s3, c); -// STR_IMM9(s1, xEmu, offsetof(x64emu_t, op1)); -// STR_IMM9(s3, xEmu, offsetof(x64emu_t, op2)); -// // same flags calc as shr32 -// SET_DF(s4, d_shr32); -// } else IFX(X_ALL) { -// SET_DFNONE(s4); -// } -// if(!c) { -// IFX(X_PEND) { -// STR_IMM9(s1, xEmu, offsetof(x64emu_t, res)); -// } -// return; -// } -// IFX(X_CF) { -// MOVS_REG_LSR_IMM5(s1, s1, c); -// } else { -// MOV_REG_LSR_IMM5(s1, s1, c); -// } -// IFX(X_ZF|X_CF) { -// BIC_IMM8(xFlags, xFlags, (1<