From 647e553f649dd6d1bec0c7b0e8fce639b1ada9ff Mon Sep 17 00:00:00 2001 From: MerryMage Date: Mon, 11 Sep 2017 12:54:14 +0100 Subject: [PATCH] ARM_Interface: Allow for partial invalidation of instruction cache --- src/core/arm/arm_interface.h | 8 ++++++++ src/core/arm/dynarmic/arm_dynarmic.cpp | 4 ++++ src/core/arm/dynarmic/arm_dynarmic.h | 1 + src/core/arm/dyncom/arm_dyncom.cpp | 4 ++++ src/core/arm/dyncom/arm_dyncom.h | 1 + 5 files changed, 18 insertions(+) diff --git a/src/core/arm/arm_interface.h b/src/core/arm/arm_interface.h index 436425c83b..e43ac5429c 100644 --- a/src/core/arm/arm_interface.h +++ b/src/core/arm/arm_interface.h @@ -4,6 +4,7 @@ #pragma once +#include #include "common/common_types.h" #include "core/arm/skyeye_common/arm_regformat.h" #include "core/arm/skyeye_common/vfp/asm_vfp.h" @@ -33,6 +34,13 @@ public: /// Clear all instruction cache virtual void ClearInstructionCache() = 0; + /** + * Invalidate the code cache at a range of addresses. + * @param start_address The starting address of the range to invalidate. + * @param length The length (in bytes) of the range to invalidate. + */ + virtual void InvalidateCacheRange(u32 start_address, size_t length) = 0; + /// Notify CPU emulation that page tables have changed virtual void PageTableChanged() = 0; diff --git a/src/core/arm/dynarmic/arm_dynarmic.cpp b/src/core/arm/dynarmic/arm_dynarmic.cpp index 1c99fc9b87..c318aa0f25 100644 --- a/src/core/arm/dynarmic/arm_dynarmic.cpp +++ b/src/core/arm/dynarmic/arm_dynarmic.cpp @@ -187,6 +187,10 @@ void ARM_Dynarmic::ClearInstructionCache() { } } +void ARM_Dynarmic::InvalidateCacheRange(u32 start_address, size_t length) { + jit->InvalidateCacheRange(start_address, length); +} + void ARM_Dynarmic::PageTableChanged() { current_page_table = Memory::GetCurrentPageTable(); diff --git a/src/core/arm/dynarmic/arm_dynarmic.h b/src/core/arm/dynarmic/arm_dynarmic.h index ffedfbc917..4c5ac7c53a 100644 --- a/src/core/arm/dynarmic/arm_dynarmic.h +++ b/src/core/arm/dynarmic/arm_dynarmic.h @@ -41,6 +41,7 @@ public: void PrepareReschedule() override; void ClearInstructionCache() override; + void InvalidateCacheRange(u32 start_address, size_t length) override; void PageTableChanged() override; private: diff --git a/src/core/arm/dyncom/arm_dyncom.cpp b/src/core/arm/dyncom/arm_dyncom.cpp index 7e0624e164..4f2e1b7a78 100644 --- a/src/core/arm/dyncom/arm_dyncom.cpp +++ b/src/core/arm/dyncom/arm_dyncom.cpp @@ -34,6 +34,10 @@ void ARM_DynCom::ClearInstructionCache() { trans_cache_buf_top = 0; } +void ARM_DynCom::InvalidateCacheRange(u32, size_t) { + ClearInstructionCache(); +} + void ARM_DynCom::PageTableChanged() { ClearInstructionCache(); } diff --git a/src/core/arm/dyncom/arm_dyncom.h b/src/core/arm/dyncom/arm_dyncom.h index 3c6cc3bda5..3c92b25476 100644 --- a/src/core/arm/dyncom/arm_dyncom.h +++ b/src/core/arm/dyncom/arm_dyncom.h @@ -19,6 +19,7 @@ public: void Step() override; void ClearInstructionCache() override; + void InvalidateCacheRange(u32 start_address, size_t length) override; void PageTableChanged() override; void SetPC(u32 pc) override;