about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--src/dynarec/arm64/dynarec_arm64_66.c12
-rw-r--r--src/emu/x64run66.c8
2 files changed, 20 insertions, 0 deletions
diff --git a/src/dynarec/arm64/dynarec_arm64_66.c b/src/dynarec/arm64/dynarec_arm64_66.c
index a4d19285..ce0e14d3 100644
--- a/src/dynarec/arm64/dynarec_arm64_66.c
+++ b/src/dynarec/arm64/dynarec_arm64_66.c
@@ -1343,6 +1343,18 @@ uintptr_t dynarec64_66(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin
                     break;

             }

             break;

+        case 0xF8:

+            INST_NAME("CLC");

+            SETFLAGS(X_CF, SF_SUBSET);

+            SET_DFNONE(x1);

+            BFCx(xFlags, F_CF, 1);

+            break;

+        case 0xF9:

+            INST_NAME("STC");

+            SETFLAGS(X_CF, SF_SUBSET);

+            SET_DFNONE(x1);

+            ORRx_mask(xFlags, xFlags, 1, 0, 0); // xFlags | 1

+            break;

 

         case 0xFF:

             nextop = F8;

diff --git a/src/emu/x64run66.c b/src/emu/x64run66.c
index e26eb379..1b826126 100644
--- a/src/emu/x64run66.c
+++ b/src/emu/x64run66.c
@@ -869,6 +869,14 @@ uintptr_t Run66(x64emu_t *emu, rex_t rex, int rep, uintptr_t addr)
             }

         }

         break;

+    case 0xF8:                      /* CLC */

+        CHECK_FLAGS(emu);

+        CLEAR_FLAG(F_CF);

+        break;

+    case 0xF9:                      /* STC */

+        CHECK_FLAGS(emu);

+        SET_FLAG(F_CF);

+        break;

 

     case 0xFF:                      /* GRP 5 Ew */

         nextop = F8;