diff options
| author | ptitSeb <sebastien.chev@gmail.com> | 2023-06-24 14:49:28 +0200 |
|---|---|---|
| committer | ptitSeb <sebastien.chev@gmail.com> | 2023-06-24 14:49:28 +0200 |
| commit | 9ea02922eea037e1f16f490141d63bc1b77ce9f4 (patch) | |
| tree | dea442721db7623e54cbaa68f7bacdeebf105fbf /src/dynarec | |
| parent | 816cbc74f44fd273d09ab4aff69085115e4c588b (diff) | |
| download | box64-9ea02922eea037e1f16f490141d63bc1b77ce9f4.tar.gz box64-9ea02922eea037e1f16f490141d63bc1b77ce9f4.zip | |
[32BITS] Added 66/61 opcodes ([ARM64_DYNAREC] too)
Diffstat (limited to 'src/dynarec')
| -rwxr-xr-x | src/dynarec/arm64/dynarec_arm64_00.c | 23 |
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) { |