diff options
author | hizzlekizzle | 2020-02-29 17:23:57 -0600 |
---|---|---|
committer | GitHub | 2020-02-29 17:23:57 -0600 |
commit | 3f2f57c982ffead643957db5b26931df4913596f (patch) | |
tree | e87ebc1ef6ed9d4b93e399d4d9e2e003a0e3386b /3ds/3ds_utils.c | |
parent | c513ecee59b088014369ab30af634a1cc06fda37 (diff) | |
parent | 6a50b8a68d5a0595dc78c90f5d0969021beb7ea1 (diff) | |
download | picogpsp-3f2f57c982ffead643957db5b26931df4913596f.tar.gz picogpsp-3f2f57c982ffead643957db5b26931df4913596f.tar.bz2 picogpsp-3f2f57c982ffead643957db5b26931df4913596f.zip |
Merge pull request #64 from justinweiss/3ds-fix-prefetch-abort
[3DS] Fix dynarec prefetch aborts
Diffstat (limited to '3ds/3ds_utils.c')
-rw-r--r-- | 3ds/3ds_utils.c | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/3ds/3ds_utils.c b/3ds/3ds_utils.c index 4f8f9be..266eca0 100644 --- a/3ds/3ds_utils.c +++ b/3ds/3ds_utils.c @@ -7,6 +7,20 @@ typedef s32 (*ctr_callback_type)(void); +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; + } +} + static void ctr_invalidate_ICache_kernel(void) { __asm__ volatile( @@ -38,6 +52,10 @@ void ctr_flush_DCache(void) 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(); + } } |