diff options
| author | ptitSeb <sebastien.chev@gmail.com> | 2021-03-19 21:47:48 +0100 |
|---|---|---|
| committer | ptitSeb <sebastien.chev@gmail.com> | 2021-03-19 21:47:48 +0100 |
| commit | 44eb9cf6788aff06b2e4fc536b86ef0458e7decf (patch) | |
| tree | 0bf2274e9dc877cb7b05e63acb7f71d42dd26a23 /src | |
| parent | 597a56d0ffe894e0e74ce18a10556c7d91b3a925 (diff) | |
| download | box64-44eb9cf6788aff06b2e4fc536b86ef0458e7decf.tar.gz box64-44eb9cf6788aff06b2e4fc536b86ef0458e7decf.zip | |
[DYNAREC] Added C7 MOV opcode
Diffstat (limited to 'src')
| -rwxr-xr-x | src/dynarec/dynarec_arm64_00.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/dynarec/dynarec_arm64_00.c b/src/dynarec/dynarec_arm64_00.c index e4987c6e..0e6613a9 100755 --- a/src/dynarec/dynarec_arm64_00.c +++ b/src/dynarec/dynarec_arm64_00.c @@ -640,6 +640,21 @@ uintptr_t dynarec64_00(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin *ok = 0; break; + case 0xC7: + INST_NAME("MOV Ed, Id"); + nextop=F8; + if(MODREG) { // reg <= i32 + i64 = F32S; + ed = xRAX+(nextop&7)+(rex.b<<3); + MOV64xw(ed, i64); + } else { // mem <= i32 + addr = geted(dyn, addr, ninst, nextop, &ed, x2, &fixedaddress, 0xfff<<(2+rex.w), (1<<(2+rex.w))-1, rex, 0, 4); + i64 = F32S; + MOV64xw(x3, i64); + STRxw_U12(x3, ed, fixedaddress); + } + break; + case 0xCC: SETFLAGS(X_ALL, SF_SET); // Hack, set all flags (to an unknown state...) if(PK(0)=='S' && PK(1)=='C') { |