summaryrefslogtreecommitdiff
path: root/3ds/3ds_cache_utils.S
diff options
context:
space:
mode:
authorJustin Weiss2020-02-29 10:50:30 -0800
committerJustin Weiss2020-02-29 10:55:58 -0800
commit6a50b8a68d5a0595dc78c90f5d0969021beb7ea1 (patch)
tree79becdf758bdca2d5f34cc4b6de3f33400bf66c9 /3ds/3ds_cache_utils.S
parent4d6846b4b72f0f5bbfeb684106cbf5fca8d4743a (diff)
downloadpicogpsp-6a50b8a68d5a0595dc78c90f5d0969021beb7ea1.tar.gz
picogpsp-6a50b8a68d5a0595dc78c90f5d0969021beb7ea1.tar.bz2
picogpsp-6a50b8a68d5a0595dc78c90f5d0969021beb7ea1.zip
[3DS] Fix dynarec prefetch aborts
Similar fix to https://github.com/libretro/pcsx_rearmed/pull/390. The Nintendo svcBackdoor can cause stack corruption if an interrupt happens during it, this uses Luma3DS/Rosalina's svcCustomBackdoor instead.
Diffstat (limited to '3ds/3ds_cache_utils.S')
-rw-r--r--3ds/3ds_cache_utils.S25
1 files changed, 25 insertions, 0 deletions
diff --git a/3ds/3ds_cache_utils.S b/3ds/3ds_cache_utils.S
new file mode 100644
index 0000000..c8df651
--- /dev/null
+++ b/3ds/3ds_cache_utils.S
@@ -0,0 +1,25 @@
+ .text
+ .arm
+ .balign 4
+
+ .func ctr_clear_cache_kernel
+ctr_clear_cache_kernel:
+ cpsid aif
+ mov r0, #0
+ mcr p15, 0, r0, c7, c10, 0 @ Clean entire data cache
+ mcr p15, 0, r0, c7, c10, 5 @ Data Memory Barrier
+ mcr p15, 0, r0, c7, c5, 0 @ Invalidate entire instruction cache / Flush BTB
+ mcr p15, 0, r0, c7, c10, 4 @ Data Sync Barrier
+ bx lr
+ .endfunc
+
+ @@ Clear the entire data cache / invalidate the instruction cache. Uses
+ @@ Rosalina svcCustomBackdoor to avoid svcBackdoor stack corruption
+ @@ during interrupts.
+ .global ctr_clear_cache
+ .func ctr_clear_cache
+ctr_clear_cache:
+ ldr r0, =ctr_clear_cache_kernel
+ svc 0x80 @ svcCustomBackdoor
+ bx lr
+ .endfunc