diff options
| author | ptitSeb <sebastien.chev@gmail.com> | 2023-06-24 13:30:19 +0200 |
|---|---|---|
| committer | ptitSeb <sebastien.chev@gmail.com> | 2023-06-24 13:30:19 +0200 |
| commit | 974df6190ecc0d3d3faafe45d77ae13e1abaad11 (patch) | |
| tree | 487ee334d1b25ca2c5b927ccafb06cd538bc886f /src | |
| parent | 294a18e68036d5368f952028c4542939bd7c878e (diff) | |
| download | box64-974df6190ecc0d3d3faafe45d77ae13e1abaad11.tar.gz box64-974df6190ecc0d3d3faafe45d77ae13e1abaad11.zip | |
[32BITS][ARM64_DYNAREC] Added 66 40..4F opcodes
Diffstat (limited to 'src')
| -rwxr-xr-x | src/dynarec/arm64/dynarec_arm64_66.c | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/dynarec/arm64/dynarec_arm64_66.c b/src/dynarec/arm64/dynarec_arm64_66.c index 65f123fb..9b8e440c 100755 --- a/src/dynarec/arm64/dynarec_arm64_66.c +++ b/src/dynarec/arm64/dynarec_arm64_66.c @@ -296,6 +296,37 @@ uintptr_t dynarec64_66(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin } break; + case 0x40: + case 0x41: + case 0x42: + case 0x43: + case 0x44: + case 0x45: + case 0x46: + case 0x47: + INST_NAME("INC Reg16 (32bits)"); + SETFLAGS(X_ALL&~X_CF, SF_SUBSET_PENDING); + gd = xRAX + (opcode&7); + UXTHw(x1, gd); + emit_inc16(dyn, ninst, x1, x2, x3); + BFIw(gd, x1, 0, 16); + break; + case 0x48: + case 0x49: + case 0x4A: + case 0x4B: + case 0x4C: + case 0x4D: + case 0x4E: + case 0x4F: + INST_NAME("DEC Reg16 (32bits)"); + SETFLAGS(X_ALL&~X_CF, SF_SUBSET_PENDING); + gd = xRAX + (opcode&7); + UXTHw(x1, gd); + emit_dec16(dyn, ninst, x1, x2, x3); + BFIw(gd, x1, 0, 16); + break; + case 0x64: addr = dynarec64_6664(dyn, addr, ip, ninst, rex, _FS, ok, need_epilog); break; |