summaryrefslogtreecommitdiffstats
path: root/src/core/arm/dynarmic/arm_dynarmic_32.cpp
diff options
context:
space:
mode:
authorMerry <git@mary.rs>2022-08-09 21:48:19 +0200
committerMerry <git@mary.rs>2022-08-09 21:48:19 +0200
commit9bdef7428a0aeabba99ebd824368e92caf46fc10 (patch)
treebdfae2adf1f073203e794ea882a0cbd4e1623388 /src/core/arm/dynarmic/arm_dynarmic_32.cpp
parentMerge pull request #8734 from liamwhite/bors-is-my-best-friend (diff)
downloadyuzu-9bdef7428a0aeabba99ebd824368e92caf46fc10.tar
yuzu-9bdef7428a0aeabba99ebd824368e92caf46fc10.tar.gz
yuzu-9bdef7428a0aeabba99ebd824368e92caf46fc10.tar.bz2
yuzu-9bdef7428a0aeabba99ebd824368e92caf46fc10.tar.lz
yuzu-9bdef7428a0aeabba99ebd824368e92caf46fc10.tar.xz
yuzu-9bdef7428a0aeabba99ebd824368e92caf46fc10.tar.zst
yuzu-9bdef7428a0aeabba99ebd824368e92caf46fc10.zip
Diffstat (limited to 'src/core/arm/dynarmic/arm_dynarmic_32.cpp')
-rw-r--r--src/core/arm/dynarmic/arm_dynarmic_32.cpp15
1 files changed, 9 insertions, 6 deletions
diff --git a/src/core/arm/dynarmic/arm_dynarmic_32.cpp b/src/core/arm/dynarmic/arm_dynarmic_32.cpp
index 1638bc41d..3b8b43994 100644
--- a/src/core/arm/dynarmic/arm_dynarmic_32.cpp
+++ b/src/core/arm/dynarmic/arm_dynarmic_32.cpp
@@ -195,14 +195,16 @@ std::shared_ptr<Dynarmic::A32::Jit> ARM_Dynarmic_32::MakeJit(Common::PageTable*
if (page_table) {
config.page_table = reinterpret_cast<std::array<std::uint8_t*, NUM_PAGE_TABLE_ENTRIES>*>(
page_table->pointers.data());
+ config.absolute_offset_page_table = true;
+ config.page_table_pointer_mask_bits = Common::PageTable::ATTRIBUTE_BITS;
+ config.detect_misaligned_access_via_page_table = 16 | 32 | 64 | 128;
+ config.only_detect_misalignment_via_page_table_on_page_boundary = true;
+
config.fastmem_pointer = page_table->fastmem_arena;
+
+ config.fastmem_exclusive_access = config.fastmem_pointer != nullptr;
+ config.recompile_on_exclusive_fastmem_failure = true;
}
- config.absolute_offset_page_table = true;
- config.page_table_pointer_mask_bits = Common::PageTable::ATTRIBUTE_BITS;
- config.detect_misaligned_access_via_page_table = 16 | 32 | 64 | 128;
- config.only_detect_misalignment_via_page_table_on_page_boundary = true;
- config.fastmem_exclusive_access = true;
- config.recompile_on_exclusive_fastmem_failure = true;
// Multi-process state
config.processor_id = core_index;
@@ -254,6 +256,7 @@ std::shared_ptr<Dynarmic::A32::Jit> ARM_Dynarmic_32::MakeJit(Common::PageTable*
}
if (!Settings::values.cpuopt_fastmem) {
config.fastmem_pointer = nullptr;
+ config.fastmem_exclusive_access = false;
}
if (!Settings::values.cpuopt_fastmem_exclusives) {
config.fastmem_exclusive_access = false;