From 9f70767acf00dd93eec4db70cdc520e442e48636 Mon Sep 17 00:00:00 2001 From: ptitSeb Date: Mon, 27 May 2024 13:45:35 +0200 Subject: [ARM64_DYNAREC] Fixed some SHA1 opcode when source is same as dest --- src/dynarec/arm64/dynarec_arm64_0f.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/dynarec/arm64/dynarec_arm64_0f.c b/src/dynarec/arm64/dynarec_arm64_0f.c index b7da8adb..e4b75556 100644 --- a/src/dynarec/arm64/dynarec_arm64_0f.c +++ b/src/dynarec/arm64/dynarec_arm64_0f.c @@ -740,7 +740,11 @@ uintptr_t dynarec64_0F(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin } else v1 = q1; VREV64Q_32(q0, q0); - VREV64Q_32(v1, q1); + if(q0==q1) { + VMOVQ(v1, q0); + } else { + VREV64Q_32(v1, q1); + } VZIP1Q_64(v0, v1, q0); VZIP2Q_64(v1, v1, q0); SHA256H(v1, v0, d0); @@ -894,10 +898,7 @@ uintptr_t dynarec64_0F(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin VREV64Q_32(v0, v0); VEORQ(d1, d1, d1); if(MODREG) { - if(q0==q1) - v1 = v0; - else - v1 = fpu_get_scratch(dyn); + v1 = fpu_get_scratch(dyn); } else v1 = q1; if(v1!=v0) { -- cgit 1.4.1