Subversion Repositories freemyipod

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
10 theseven 1
//
2
//
3
//    Copyright 2010 TheSeven
4
//
5
//
6
//    This file is part of emBIOS.
7
//
8
//    emBIOS is free software: you can redistribute it and/or
9
//    modify it under the terms of the GNU General Public License as
10
//    published by the Free Software Foundation, either version 2 of the
11
//    License, or (at your option) any later version.
12
//
13
//    emBIOS is distributed in the hope that it will be useful,
14
//    but WITHOUT ANY WARRANTY; without even the implied warranty of
15
//    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16
//    See the GNU General Public License for more details.
17
//
18
//    You should have received a copy of the GNU General Public License along
19
//    with emBIOS.  If not, see <http://www.gnu.org/licenses/>.
20
//
21
//
22
 
23
 
24
#include "global.h"
25
#include "mmu.h"
26
 
27
 
28
void clean_dcache()
29
{
85 theseven 30
    asm volatile(
265 theseven 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"
85 theseven 36
        "MOV PC, LR                \n\t"
37
    );
10 theseven 38
}
39
 
40
void invalidate_dcache()
41
{
85 theseven 42
    asm volatile(
265 theseven 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"
85 theseven 48
        "MOV PC, LR                \n\t"
49
    );
10 theseven 50
}
265 theseven 51
 
85 theseven 52
void invalidate_icache()
53
{
54
    asm volatile(
265 theseven 55
        "MOV R0, #0                \n\t"
56
        "MCR p15, 0, R0,c7,c5,0    \n\t"
85 theseven 57
        "MOV PC, LR                \n\t"
58
    );
59
}