summaryrefslogtreecommitdiff
path: root/arm9/lib/src/OS_system.c
blob: e5dfcb475764abc329fa70afe5f27c8c0517b217 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
//
// Created by mart on 4/23/20.
//

#include "OS_system.h"

ARM_FUNC asm OSIntrMode OS_EnableInterrupts() {
    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() {
    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(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() {
    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(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 OSIntrMode OS_GetCpsrIrq() {
    mrs r0, cpsr
    and r0, r0, #HW_PSR_DISABLE_IRQ
    bx lr
}

ARM_FUNC asm OSProcMode OS_GetProcMode() {
    mrs r0, cpsr
    and r0, r0, #HW_PSR_CPU_MODE_MASK
    bx lr
}

ARM_FUNC asm void OS_SpinWait() {
    subs r0, r0, #0x4
    bhs OS_SpinWait
    bx lr
}

ARM_FUNC void OS_WaitVBlankIntr() {
    SVC_WaitByLoop(0x1);
    OS_WaitIrq(TRUE, OS_IE_V_BLANK);
}