diff options
author | Twinaphex | 2020-02-25 05:32:11 +0100 |
---|---|---|
committer | GitHub | 2020-02-25 05:32:11 +0100 |
commit | 58e485d6efcecfe0fb7d072d705cf658e6162b4e (patch) | |
tree | 5033883571d4d43164cca5419b74649cfc0abeda /frontend/3ds/3ds_utils.h | |
parent | 37c2f059e48351904a4ff63675e3971e222ab074 (diff) | |
parent | b37c639ee018ef6403859952fd459fe8073313d3 (diff) | |
download | pcsx_rearmed-58e485d6efcecfe0fb7d072d705cf658e6162b4e.tar.gz pcsx_rearmed-58e485d6efcecfe0fb7d072d705cf658e6162b4e.tar.bz2 pcsx_rearmed-58e485d6efcecfe0fb7d072d705cf658e6162b4e.zip |
Merge pull request #390 from justinweiss/ctr-fix-dynarec-crashes
Fix dynarec crashes on 3DS
Diffstat (limited to 'frontend/3ds/3ds_utils.h')
-rw-r--r-- | frontend/3ds/3ds_utils.h | 31 |
1 files changed, 27 insertions, 4 deletions
diff --git a/frontend/3ds/3ds_utils.h b/frontend/3ds/3ds_utils.h index 1f12b84..cad4cbe 100644 --- a/frontend/3ds/3ds_utils.h +++ b/frontend/3ds/3ds_utils.h @@ -8,6 +8,8 @@ #define MEMOP_MAP 4 #define MEMOP_UNMAP 5 +#define GET_VERSION_MAJOR(version) ((version) >>24) + void* linearMemAlign(size_t size, size_t alignment); void linearFree(void* mem); @@ -21,6 +23,7 @@ int32_t threadJoin(int32_t thread, int64_t timeout_ns); void threadFree(int32_t thread); void threadExit(int32_t rc) __attribute__((noreturn)); +int32_t svcGetSystemInfo(int64_t* out, uint32_t type, int32_t param); int32_t svcBackdoor(int32_t (*callback)(void)); #define DEBUG_HOLD() do{printf("%s@%s:%d.\n",__FUNCTION__, __FILE__, __LINE__);fflush(stdout);wait_for_input();}while(0) @@ -29,6 +32,24 @@ void wait_for_input(void); extern __attribute__((weak)) int __ctr_svchax; +bool has_rosalina; + +static void check_rosalina() { + int64_t version; + uint32_t major; + + has_rosalina = false; + + if (!svcGetSystemInfo(&version, 0x10000, 0)) { + major = GET_VERSION_MAJOR(version); + + if (major >= 8) + has_rosalina = true; + } +} + +void ctr_clear_cache(void); + typedef int32_t (*ctr_callback_type)(void); static inline void ctr_invalidate_ICache_kernel(void) @@ -57,12 +78,14 @@ static inline void ctr_flush_DCache(void) svcBackdoor((ctr_callback_type)ctr_flush_DCache_kernel); } - static inline void ctr_flush_invalidate_cache(void) { - ctr_flush_DCache(); - ctr_invalidate_ICache(); + if (has_rosalina) { + ctr_clear_cache(); + } else { + ctr_flush_DCache(); + ctr_invalidate_ICache(); + } } - #endif // _3DS_UTILS_H |