Subversion Repositories freemyipod

Rev

Rev 265 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 265 Rev 267
Line 26... Line 26...
26
 
26
 
27
 
27
 
28
void clean_dcache()
28
void clean_dcache()
29
{
29
{
30
    asm volatile(
30
    asm volatile(
31
        "clean_dcache_loop:        \n\t"
-
 
32
        "MRC p15, 0, R15,c7,c10,3  \n\t"
-
 
33
        "BNE clean_dcache_loop     \n\t"
-
 
34
        "MOV R0, #0                \n\t"
-
 
35
        "MCR p15, 0, R0,c7,c10,4   \n\t"
-
 
36
        "MOV PC, LR                \n\t"
31
        "MOV PC, LR                \n\t"
37
    );
32
    );
38
}
33
}
39
 
34
 
40
void invalidate_dcache()
35
void invalidate_dcache()
41
{
36
{
42
    asm volatile(
37
    asm volatile(
43
        "invalidate_dcache_loop:   \n\t"
-
 
44
        "MRC p15, 0, R15,c7,c14,3  \n\t"
-
 
45
        "BNE invalidate_dcache_loop\n\t"
-
 
46
        "MOV R0, #0                \n\t"
-
 
47
        "MCR p15, 0, R0,c7,c10,4   \n\t"
-
 
48
        "MOV PC, LR                \n\t"
38
        "MOV PC, LR                \n\t"
49
    );
39
    );
50
}
40
}
51
 
41
 
52
void invalidate_icache()
42
void invalidate_icache()
53
{
43
{
54
    asm volatile(
44
    asm volatile(
55
        "MOV R0, #0                \n\t"
-
 
56
        "MCR p15, 0, R0,c7,c5,0    \n\t"
-
 
57
        "MOV PC, LR                \n\t"
45
        "MOV PC, LR                \n\t"
58
    );
46
    );
59
}
47
}