From eea3857065ced3ed16d467068ca2a1f859ef6e2e Mon Sep 17 00:00:00 2001 From: ptitSeb Date: Sat, 1 Jan 2022 10:00:22 +0100 Subject: [DYNAREC] Added some more Memory Barrier when trying to emulate StrongMem model (should help RimWorld) --- src/dynarec/dynarec_arm64_00.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/dynarec/dynarec_arm64_00.c b/src/dynarec/dynarec_arm64_00.c index 4cd18a25..77451bb1 100755 --- a/src/dynarec/dynarec_arm64_00.c +++ b/src/dynarec/dynarec_arm64_00.c @@ -926,6 +926,10 @@ uintptr_t dynarec64_00(dynarec_arm_t* dyn, uintptr_t addr, uintptr_t ip, int nin } else { // mem <= reg addr = geted(dyn, addr, ninst, nextop, &ed, x2, &fixedaddress, 0xfff<<(2+rex.w), (1<<(2+rex.w))-1, rex, 0, 0); STRxw_U12(gd, ed, fixedaddress); + if(box64_dynarec_strongmem && + (dyn->insts[ninst].x64.barrier || box64_dynarec_strongmem>1 || (dyn->insts[ninst+1].x64.barrier || dyn->insts[ninst+1].x64.jmp))) { + DMB_ISH(); + } } break; case 0x8A: -- cgit 1.4.1