diff options
| author | ptitSeb <sebastien.chev@gmail.com> | 2022-07-03 15:49:23 +0200 |
|---|---|---|
| committer | ptitSeb <sebastien.chev@gmail.com> | 2022-07-03 15:49:23 +0200 |
| commit | ebce5998de914d13fc840fc1fe1594f4054aaec8 (patch) | |
| tree | 0ee04d42258ecf07d576afe7af3f8f95fe98d129 /src | |
| parent | 672a41a79cbcfa095d6951112d592354e0efbd5a (diff) | |
| download | box64-ebce5998de914d13fc840fc1fe1594f4054aaec8.tar.gz box64-ebce5998de914d13fc840fc1fe1594f4054aaec8.zip | |
Added 66 F0 0F C1 opcode ([DYNAREC] too) (for FRAMED Collection on Steam)
Diffstat (limited to 'src')
| -rw-r--r-- | src/dynarec/arm64/dynarec_arm64_66f0.c | 37 | ||||
| -rw-r--r-- | src/emu/x64run66f0.c | 42 |
2 files changed, 79 insertions, 0 deletions
diff --git a/src/dynarec/arm64/dynarec_arm64_66f0.c b/src/dynarec/arm64/dynarec_arm64_66f0.c index 786bab29..c65bbf93 100644 --- a/src/dynarec/arm64/dynarec_arm64_66f0.c +++ b/src/dynarec/arm64/dynarec_arm64_66f0.c @@ -74,6 +74,43 @@ uintptr_t dynarec64_66F0(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int n DMB_ISH(); break; + case 0x0F: + opcode = F8; + switch(opcode) { + + case 0xC1: + INST_NAME("LOCK XADD Gw, Ew"); + SETFLAGS(X_ALL, SF_SET_PENDING); + nextop = F8; + gd = xRAX+((nextop&0x38)>>3)+(rex.r<<3); + UXTHx(x5, gd); + DMB_ISH(); + if(MODREG) { + ed = xRAX+(nextop&7)+(rex.b<<3); + BFIx(gd, ed, 0, 16); + emit_add16(dyn, ninst, x5, gd, x3, x4); + BFIx(ed, x5, 0, 16); + } else { + addr = geted(dyn, addr, ninst, nextop, &wback, x2, &fixedaddress, 0, 0, rex, LOCK_LOCK, 0, 0); + MARKLOCK; + LDAXRH(x1, wback); + ADDxw_REG(x4, x1, x5); + STLXRH(x3, x4, wback); + CBNZx_MARKLOCK(x3); + IFX(X_ALL|X_PEND) { + MOVxw_REG(x2, x1); + emit_add16(dyn, ninst, x2, x5, x3, x4); + } + BFIx(gd, x1, 0, 16); + } + DMB_ISH(); + break; + + default: + DEFAULT; + } + break; + case 0x81: case 0x83: nextop = F8; diff --git a/src/emu/x64run66f0.c b/src/emu/x64run66f0.c index 3837eba1..cbf08825 100644 --- a/src/emu/x64run66f0.c +++ b/src/emu/x64run66f0.c @@ -78,6 +78,48 @@ int Run66F0(x64emu_t *emu, rex_t rex) #endif break; + case 0xC1: /* XADD Gw,Ew */ + nextop = F8; + GETEW(0); + GETGW; +#ifdef DYNAREC + if(rex.w) { + do { + tmp64u = native_lock_read_dd(ED); + tmp64u2 = add64(emu, tmp64u, GD->q[0]); + } while(native_lock_write_dd(ED, tmp64u2)); + GD->q[0] = tmp64u; + } else { + if(((uintptr_t)ED)&1) { + do { + tmp16u = ED->word[0] & ~0xff; + tmp16u |= native_lock_read_h(ED); + tmp16u2 = add16(emu, tmp16u, GD->word[0]); + } while(native_lock_write_h(ED, tmp16u2&0xff)); + ED->word[0] = tmp16u2; + } else { + do { + tmp16u = native_lock_read_h(ED); + tmp16u2 = add16(emu, tmp16u, GD->word[0]); + } while(native_lock_write_h(ED, tmp16u2)); + } + GD->word[0] = tmp16u; + } +#else + pthread_mutex_lock(&emu->context->mutex_lock); + if(rex.w) { + tmp64u = add64(emu, ED->q[0], GD->q[0]); + GD->q[0] = ED->q[0]; + ED->q[0] = tmp64u; + } else { + tmp16u = add16(emu, ED->word[0], GD->word[0]); + GD->word[0] = ED->word[0]; + ED->word[0] = tmp16u; + } + pthread_mutex_unlock(&emu->context->mutex_lock); +#endif + break; + default: return 1; } |