summaryrefslogtreecommitdiff
path: root/arm9/lib/NitroSDK/src/OS_cache.c
blob: 8b202fda8e6f92a9f69f2e7beb546795145c08d7 (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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#include "OS_cache.h"
#include "nitro/types.h"
#include "function_target.h"

ARM_FUNC asm void DC_InvalidateAll(void)
{
    mov r0, #0
    mcr p15, 0, r0, c7, c6, 0 //Invalidate Entire Data Cache
    bx lr
}

ARM_FUNC asm void DC_StoreAll(void)
{
    mov r1, #0

_020CC0C8:
    mov r0, #0

_020CC0CC:
    orr r2, r1, r0
    mcr p15, 0, r2, c7, c10, 2 //Clean Data Cache Line Set/Index
    add r0, r0, #32
    cmp r0, #0x400
    blt _020CC0CC

    add r1, r1, #0x40000000
    cmp r1, #0
    bne _020CC0C8

    bx lr
}

ARM_FUNC asm void DC_FlushAll(void)
{
    mov r12, #0
    mov r1, #0

_020CC0F8:
    mov r0, #0

_020CC0FC:
    orr r2, r1, r0
    mcr p15, 0, r12, c7, c10, 4 //Drain Write Buffer
    mcr p15, 0, r2, c7, c14, 2 //Clean and Invalidate Data Cache Line Set/Index
    add r0, r0, #32
    cmp r0, #0x400
    blt _020CC0FC

    add r1, r1, #0x40000000
    cmp r1, #0
    bne _020CC0F8

    bx lr
}

ARM_FUNC asm void DC_InvalidateRange(register void *startAddr, register u32 nBytes)
{
    add r1, r1, r0
    bic r0, r0, #31

_020CC12C:
    mcr p15, 0, r0, c7, c6, 1 //Invalidated Data Cache Line Virtual Address
    add r0, r0, #32
    cmp r0, r1
    blt _020CC12C

    bx lr
}

ARM_FUNC asm void DC_StoreRange(register void *startAddr, register u32 nBytes)
{
    add r1, r1, r0
    bic r0, r0, #31

_020CC148:
    mcr p15, 0, r0, c7, c10, 1 //Clean Data Cache Line Virtual Address
    add r0, r0, #32
    cmp r0, r1
    blt _020CC148

    bx lr
}

ARM_FUNC asm void DC_FlushRange(register const void *startAddr, register u32 nBytes)
{
    mov r12, #0
    add r1, r1, r0
    bic r0, r0, #31

_020CC168:
    mcr p15, 0, r12, c7, c10, 4 //Drain Write Buffer
    mcr p15, 0, r0, c7, c14, 1 //Clean and Invalidate Data Cache Line Virtual Address
    add r0, r0, #32
    cmp r0, r1
    blt _020CC168

    bx lr
}

ARM_FUNC asm void DC_WaitWriteBufferEmpty(void)
{
    mov r0, #0
    mcr p15, 0, r0, c7, c10, 4 //Drain Write Buffer
    bx lr
}

ARM_FUNC asm void IC_InvalidateAll(void)
{
    mov r0, #0
    mcr p15, 0, r0, c7, c5, 0 //Invalidate Entire Instruction Cache
    bx lr
}

ARM_FUNC asm void IC_InvalidateRange(register void *startAddr, register u32 nBytes)
{
    add r1, r1, r0
    bic r0, r0, #31

_020CC1A0:
    mcr p15, 0, r0, c7, c5, 1 //Invalidate Instruction Cache Line Virtual Address
    add r0, r0, #32
    cmp r0, r1
    blt _020CC1A0

    bx lr
}