summaryrefslogtreecommitdiff
path: root/3ds/3ds_utils.c
diff options
context:
space:
mode:
authorhizzlekizzle2020-02-29 17:23:57 -0600
committerGitHub2020-02-29 17:23:57 -0600
commit3f2f57c982ffead643957db5b26931df4913596f (patch)
treee87ebc1ef6ed9d4b93e399d4d9e2e003a0e3386b /3ds/3ds_utils.c
parentc513ecee59b088014369ab30af634a1cc06fda37 (diff)
parent6a50b8a68d5a0595dc78c90f5d0969021beb7ea1 (diff)
downloadpicogpsp-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.c22
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();
+ }
}