2009-04-10 18:15:10 +02:00
|
|
|
/*
|
|
|
|
mini - a Free Software replacement for the Nintendo/BroadOn IOS.
|
|
|
|
memory management, MMU, caches, and flushing
|
|
|
|
|
|
|
|
Copyright (C) 2008, 2009 Hector Martin "marcan" <marcan@marcansoft.com>
|
|
|
|
|
2009-05-11 07:53:16 +02:00
|
|
|
# This code is licensed to you under the terms of the GNU GPL, version 2;
|
|
|
|
# see file COPYING or http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt
|
2009-04-10 18:15:10 +02:00
|
|
|
*/
|
2009-05-11 07:53:16 +02:00
|
|
|
|
2008-12-28 14:35:37 +01:00
|
|
|
.arm
|
|
|
|
|
|
|
|
.globl _dc_inval_entries
|
|
|
|
.globl _dc_flush_entries
|
|
|
|
.globl _dc_flush
|
2009-01-16 08:53:03 +01:00
|
|
|
.globl _dc_inval
|
2008-12-28 14:35:37 +01:00
|
|
|
.globl _ic_inval
|
|
|
|
.globl _drain_write_buffer
|
2009-01-16 08:53:03 +01:00
|
|
|
.globl _tlb_inval
|
2008-12-28 14:35:37 +01:00
|
|
|
|
|
|
|
.text
|
|
|
|
|
|
|
|
_dc_inval_entries:
|
|
|
|
mcr p15, 0, r0, c7, c6, 1
|
|
|
|
add r0, #0x20
|
|
|
|
subs r1, #1
|
2009-03-07 20:13:49 +01:00
|
|
|
bne _dc_inval_entries
|
2008-12-28 14:35:37 +01:00
|
|
|
bx lr
|
|
|
|
|
|
|
|
_dc_flush_entries:
|
|
|
|
mcr p15, 0, r0, c7, c10, 1
|
|
|
|
add r0, #0x20
|
|
|
|
subs r1, #1
|
2009-03-07 20:13:49 +01:00
|
|
|
bne _dc_flush_entries
|
2008-12-28 14:35:37 +01:00
|
|
|
bx lr
|
|
|
|
|
|
|
|
_dc_flush:
|
|
|
|
mrc p15, 0, pc, c7, c10, 3
|
|
|
|
bne _dc_flush
|
|
|
|
bx lr
|
|
|
|
|
2009-01-16 08:53:03 +01:00
|
|
|
_dc_inval:
|
|
|
|
mov r0, #0
|
|
|
|
mcr p15, 0, r0, c7, c6, 0
|
|
|
|
bx lr
|
|
|
|
|
2008-12-28 14:35:37 +01:00
|
|
|
_ic_inval:
|
|
|
|
mov r0, #0
|
|
|
|
mcr p15, 0, r0, c7, c5, 0
|
|
|
|
bx lr
|
|
|
|
|
|
|
|
_drain_write_buffer:
|
|
|
|
mov r0, #0
|
|
|
|
mcr p15, 0, r0, c7, c10, 4
|
|
|
|
bx lr
|
|
|
|
|
2009-01-16 08:53:03 +01:00
|
|
|
_tlb_inval:
|
|
|
|
mov r0, #0
|
|
|
|
mcr p15, 0, r0, c8, c7
|
|
|
|
bx lr
|
2009-04-13 22:13:45 +02:00
|
|
|
|