about summary refs log tree commit diff stats
path: root/src/dynarec
diff options
context:
space:
mode:
authorptitSeb <sebastien.chev@gmail.com>2023-06-24 14:49:28 +0200
committerptitSeb <sebastien.chev@gmail.com>2023-06-24 14:49:28 +0200
commit9ea02922eea037e1f16f490141d63bc1b77ce9f4 (patch)
treedea442721db7623e54cbaa68f7bacdeebf105fbf /src/dynarec
parent816cbc74f44fd273d09ab4aff69085115e4c588b (diff)
downloadbox64-9ea02922eea037e1f16f490141d63bc1b77ce9f4.tar.gz
box64-9ea02922eea037e1f16f490141d63bc1b77ce9f4.zip
[32BITS] Added 66/61 opcodes ([ARM64_DYNAREC] too)
Diffstat (limited to 'src/dynarec')
-rwxr-xr-xsrc/dynarec/arm64/dynarec_arm64_00.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/dynarec/arm64/dynarec_arm64_00.c b/src/dynarec/arm64/dynarec_arm64_00.c
index aedbe12f..317d8afd 100755
--- a/src/dynarec/arm64/dynarec_arm64_00.c
+++ b/src/dynarec/arm64/dynarec_arm64_00.c
@@ -602,6 +602,29 @@ uintptr_t dynarec64_00(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin
                 }
             }
             break;
+        case 0x60:
+            if(rex.is32bits) {
+                INST_NAME("PUSHAD");
+                MOVw_REG(x1, xRSP);
+                PUSH2_32(xRAX, xRCX);
+                PUSH2_32(xRDX, xRBX);
+                PUSH2_32(x1, xRBP);
+                PUSH2_32(xRSI, xRDI);
+            } else {
+                DEFAULT;
+            }
+            break;
+        case 0x61:
+            if(rex.is32bits) {
+                INST_NAME("POPAD");
+                POP2_32(xRDI, xRSI);
+                POP2_32(xRBP, x1);
+                POP2_32(xRBX, xRDX);
+                POP2_32(xRCX, xRAX);
+            } else {
+                DEFAULT;
+            }
+            break;
 
         case 0x63:
             if(rex.is32bits) {