码迷,mamicode.com
首页 > 系统相关 > 详细

关闭mmu和cache

时间:2018-01-24 00:44:28      阅读:223      评论:0      收藏:0      [点我收藏+]

标签:bsp   efi   进程   保存   instr   svc   地址   mvn   software   

处理器内部寄存器,访问速度最快,但是数量少

TCM:紧耦合存储器(Cache、主存储器)

辅助存储器(Flash、SD等)

 

Cache是一种容量小但是存取速度非常快的存储器

它保存最近用到的存储器中的数据的拷贝,对于程

序员来说,Cache是透明的,他自动决定保存哪些

数据、覆盖哪些数据。按照功能划分:

I-cache:指令Cache

D-cache:数据Cache

虚拟地址:程序中使用的地址

物理地址:物理存储单元的实际的地址

虚拟地址可以解决地址冲突,可以是进程使用更大的空间

1、使Icache+Dcache无效

2、关闭I/D-Cache

.text
.global _start
_start:
    b reset
    ldr pc, _undefined_instruction
    ldr pc, _software_interrupt
    ldr pc, _prefetch_abort
    ldr pc, _data_abort
    ldr pc, _not_used
    ldr pc, _irq
    ldr pc, _fiq

_undefined_instruction: .word undefined_instruction
_software_interrupt:.word software_interrupt
_prefetch_abort:.word prefetch_abort
_data_abort:.word data_abort
_not_used:.word not_used
_irq:.word irq
_fiq:.word fiq

undefined_instruction:
    nop
    
software_interrupt:
    nop

prefetch_abort:
    nop
    
data_abort:
    nop
    
not_used:
    nop
    
irq:
    nop
    
fiq:
    nop

reset:
    bl set_svc
    bl disable_watchdog    
    bl diasble_interrupt
    bl disable_mmu
    mov pc, lr
    
set_svc:
    mrs r0, cpsr
    bic r0, r0, #0x1f
    orr r0, r0, #0xd3
    msr cpsr, r0
    mov pc, lr

#define pwTCON 0x53000000
disable_watchdog:
    ldr r0, =pwTCON
    mov r1, #0x0
    str r1, [r0]
    mov pc, lr

disable_interrupt
    mvn r1, #0x0
    ldr r0, =0x4a000008
    str r1,[r0]
    mov pc, lr    

disable_mmu
    mcr p15,0,r0,c7,c7,0
    mrc p15,0,r0,c1,c0,0
    bic r0,r0,#0x00000007
    mcr p15,0,r0,c1,c0,0
    mov pc, lr

 

关闭mmu和cache

标签:bsp   efi   进程   保存   instr   svc   地址   mvn   software   

原文地址:https://www.cnblogs.com/sanshijvshi/p/8338223.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!