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 | |
| parent | 816cbc74f44fd273d09ab4aff69085115e4c588b (diff) | |
| download | box64-9ea02922eea037e1f16f490141d63bc1b77ce9f4.tar.gz box64-9ea02922eea037e1f16f490141d63bc1b77ce9f4.zip | |
[32BITS] Added 66/61 opcodes ([ARM64_DYNAREC] too)
Diffstat (limited to 'src')
| -rwxr-xr-x | src/dynarec/arm64/dynarec_arm64_00.c | 23 | ||||
| -rwxr-xr-x | src/emu/x64run.c | 31 |
2 files changed, 54 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) { diff --git a/src/emu/x64run.c b/src/emu/x64run.c index 8e611920..3c6808de 100755 --- a/src/emu/x64run.c +++ b/src/emu/x64run.c @@ -299,6 +299,37 @@ x64emurun: tmp8u = (opcode&7)+(rex.b<<3); emu->regs[tmp8u].q[0] = is32bits?Pop32(emu):Pop(emu); break; + case 0x60: /* PUSHAD */ + if(rex.is32bits) { + tmp32u = R_ESP; + Push(emu, R_EAX); + Push(emu, R_ECX); + Push(emu, R_EDX); + Push(emu, R_EBX); + Push(emu, tmp32u); + Push(emu, R_EBP); + Push(emu, R_ESI); + Push(emu, R_EDI); + } else { + unimp = 1; + goto fini; + } + break; + case 0x61: /* POPAD */ + if(rex.is32bits) { + R_EDI = Pop(emu); + R_ESI = Pop(emu); + R_EBP = Pop(emu); + R_ESP+=4; // POP ESP + R_EBX = Pop(emu); + R_EDX = Pop(emu); + R_ECX = Pop(emu); + R_EAX = Pop(emu); + } else { + unimp = 1; + goto fini; + } + break; case 0x63: /* MOVSXD Gd,Ed */ nextop = F8; |