summaryrefslogtreecommitdiff
path: root/arm7/lib/src/OS_system.c
diff options
context:
space:
mode:
Diffstat (limited to 'arm7/lib/src/OS_system.c')
-rw-r--r--arm7/lib/src/OS_system.c65
1 files changed, 65 insertions, 0 deletions
diff --git a/arm7/lib/src/OS_system.c b/arm7/lib/src/OS_system.c
new file mode 100644
index 00000000..120eddbf
--- /dev/null
+++ b/arm7/lib/src/OS_system.c
@@ -0,0 +1,65 @@
+#include "function_target.h"
+#include "OS_system.h"
+
+#pragma optimize_for_size on
+
+extern void FUN_037F8CB4(s32 count);
+
+ARM_FUNC asm OSIntrMode OS_EnableInterrupts(void)
+{
+ mrs r0, CPSR
+ bic r1, r0, #HW_PSR_DISABLE_IRQ
+ msr CPSR_c, r1
+ and r0, r0, #HW_PSR_DISABLE_IRQ
+ bx lr
+}
+
+ARM_FUNC asm OSIntrMode OS_DisableInterrupts(void)
+{
+ mrs r0, CPSR
+ orr r1, r0, #HW_PSR_DISABLE_IRQ
+ msr CPSR_c, r1
+ and r0, r0, #HW_PSR_DISABLE_IRQ
+ bx lr
+}
+
+ARM_FUNC asm OSIntrMode OS_RestoreInterrupts(register OSIntrMode state)
+{
+ mrs r1, CPSR
+ bic r2, r1, #HW_PSR_DISABLE_IRQ
+ orr r2, r2, r0
+ msr CPSR_c, r2
+ and r0, r1, #HW_PSR_DISABLE_IRQ
+ bx lr
+}
+
+ARM_FUNC asm OSIntrMode OS_DisableInterrupts_IrqAndFiq(void)
+{
+ mrs r0, CPSR
+ orr r1, r0, #HW_PSR_DISABLE_IRQ_FIQ
+ msr CPSR_c, r1
+ and r0, r0, #HW_PSR_DISABLE_IRQ_FIQ
+ bx lr
+}
+
+ARM_FUNC asm OSIntrMode OS_RestoreInterrupts_IrqAndFiq(register OSIntrMode state)
+{
+ mrs r1, CPSR
+ bic r2, r1, #HW_PSR_DISABLE_IRQ_FIQ
+ orr r2, r2, r0
+ msr CPSR_c, r2
+ and r0, r1, #HW_PSR_DISABLE_IRQ_FIQ
+ bx lr
+}
+
+ARM_FUNC asm OSProcMode OS_GetProcMode(void)
+{
+ mrs r0, CPSR
+ and r0, r0, #HW_PSR_CPU_MODE_MASK
+ bx lr
+}
+
+ARM_FUNC void OS_SpinWait(u32 cycle)
+{
+ FUN_037F8CB4((s32)cycle / 4);
+}