diff options
| author | ptitSeb <sebastien.chev@gmail.com> | 2024-02-01 18:42:37 +0100 |
|---|---|---|
| committer | ptitSeb <sebastien.chev@gmail.com> | 2024-02-01 18:42:37 +0100 |
| commit | a2be60cce825bf83b4754a6fbcbf384273542115 (patch) | |
| tree | b5eda6b301fad836f80b1db4b03e1972698874de /src/dynarec | |
| parent | 1344b1837909da6d91153cf686557a4a10bcb468 (diff) | |
| download | box64-a2be60cce825bf83b4754a6fbcbf384273542115.tar.gz box64-a2be60cce825bf83b4754a6fbcbf384273542115.zip | |
[32BITS] Added 67 64 A1 opcode ([ARM64_DYNAREC] too)
Diffstat (limited to 'src/dynarec')
| -rw-r--r-- | src/dynarec/arm64/dynarec_arm64_6764_32.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/dynarec/arm64/dynarec_arm64_6764_32.c b/src/dynarec/arm64/dynarec_arm64_6764_32.c index f9342181..c62b239a 100644 --- a/src/dynarec/arm64/dynarec_arm64_6764_32.c +++ b/src/dynarec/arm64/dynarec_arm64_6764_32.c @@ -61,6 +61,20 @@ uintptr_t dynarec64_6764_32(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, in switch(opcode) { + case 0xA1: + INST_NAME("MOV EAX, Seg:[Od]"); + i32 = F16; + grab_segdata(dyn, addr, ninst, x4, seg); + if(i32<4096 && !(i32&3)) { + LDRw_U12(xRAX, x4, i32); + } else if(i32<256) { + LDURw_I9(xRAX, x4, i32); + } else { + MOV32w(x1, i32); + LDRw_REG(xRAX, x4, x1); + } + break; + case 0xA3: INST_NAME("MOV Seg:[Od], EAX"); i32 = F16; |