summaryrefslogtreecommitdiff
path: root/arm9/lib/src
diff options
context:
space:
mode:
authorred031000 <rubenru09@aol.com>2020-05-21 23:30:24 +0100
committerred031000 <rubenru09@aol.com>2020-05-21 23:30:24 +0100
commit3c62c1ee513696153e6c554c0d97557b56a4c997 (patch)
treedf84b50deef93a23939e9410afdc3d7998de97fd /arm9/lib/src
parentb4d6f1314b3b322afabe85d848e09a36d4e7a47a (diff)
OSi_DoLockByWord
Diffstat (limited to 'arm9/lib/src')
-rw-r--r--arm9/lib/src/OS_spinLock.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/arm9/lib/src/OS_spinLock.c b/arm9/lib/src/OS_spinLock.c
index 46309c42..45e29ab8 100644
--- a/arm9/lib/src/OS_spinLock.c
+++ b/arm9/lib/src/OS_spinLock.c
@@ -10,6 +10,8 @@
extern void OS_TryLockByWord(u16 param1, OSLockWord* lockp, void* func);
extern void OS_UnlockByWord(u16 param1, OSLockWord* lockp, void* func);
extern void MIi_CpuClear32(u32 param1, void * addr, u32 length); //not too sure about names
+extern s32 OSi_DoTryLockByWord(u16 lockId, OSLockWord *lockp, void (*ctrlFuncp) (void),
+ BOOL disableFiq);
ARM_FUNC void OS_InitLock()
{
@@ -44,3 +46,14 @@ ARM_FUNC void OS_InitLock()
OS_UnlockByWord(0x7e, lockp, NULL);
OS_TryLockByWord(0x7f, lockp, NULL);
}
+
+ARM_FUNC s32 OSi_DoLockByWord(u16 lockId, OSLockWord *lockp, void (*ctrlFuncp) (void), //should be static
+ BOOL disableFiq)
+{
+ s32 lastLockFlag;
+ while ((lastLockFlag = OSi_DoTryLockByWord(lockId, lockp, ctrlFuncp, disableFiq)) > 0) {
+ OSi_WaitByLoop();
+ }
+
+ return lastLockFlag;
+}