From 6b390caef546f65ac1f4b95983227186cd93d601 Mon Sep 17 00:00:00 2001 From: Yang Liu Date: Mon, 27 Nov 2023 04:51:27 +0800 Subject: [DYNAREC_RV64] Fixed emit_ror32 (#1087) --- src/dynarec/rv64/dynarec_rv64_emit_shift.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/dynarec/rv64/dynarec_rv64_emit_shift.c b/src/dynarec/rv64/dynarec_rv64_emit_shift.c index 80dea7a9..2460bd72 100644 --- a/src/dynarec/rv64/dynarec_rv64_emit_shift.c +++ b/src/dynarec/rv64/dynarec_rv64_emit_shift.c @@ -385,8 +385,8 @@ void emit_ror32(dynarec_rv64_t* dyn, int ninst, rex_t rex, int s1, int s2, int s SDxw(s1, xEmu, offsetof(x64emu_t, res)); } IFX(X_CF) { - SRLI(s3, s1, rex.w?63:31); - AND(xFlags, xFlags, s3); + SRLIxw(s3, s1, rex.w?63:31); + OR(xFlags, xFlags, s3); } IFX(X_OF) { ADDI(s3, xZR, 1); @@ -479,8 +479,8 @@ void emit_ror32c(dynarec_rv64_t* dyn, int ninst, rex_t rex, int s1, uint32_t c, SDxw(s1, xEmu, offsetof(x64emu_t, res)); } IFX(X_CF) { - SRLI(s3, s1, rex.w?63:31); - AND(xFlags, xFlags, s3); + SRLIxw(s3, s1, rex.w?63:31); + OR(xFlags, xFlags, s3); } IFX(X_OF) { if(c==1) { -- cgit 1.4.1