存储管理单元存储管理单元MMU概述
  在ARM系统中,存储管理单元MMU主要完成以下工作:
1、虚拟存储空间到物理存储空间的映射。在ARM中采用页式虚拟存储管理。他把虚拟地址空间分成一个个固定大小的块,每一块称为一页,把物理内存的地址空间也分成同样大小的页。页的大小可以分为粗粒度和细粒度两种。MMU要实现虚拟地址到物理地址的转换。
2、存储访问权限的控制
3、设置虚拟存储空间的缓冲特性

MMU的操作步骤
1、使无效cachen/TLB
  在S3C6410中 CP15中的寄存器C7用于控制cache和写缓冲区,他是一个只写的寄存器。使用MRC指令读取该寄存器,将产生不可预知的结果。使用MCR指令写该寄存器,具体操作格式如下:
    MCR p15, 0, <Rd>, <c7>, <CRm>, <opcode_2>
其中 CRm = c7 ,opcode_2 = 0 表示使无效整个cache(Icachen和Dcachen),
其中 CRm = c10 ,opcode_2 = 4 表示清空写缓冲区
    
2、将页表地址告诉MMU
页表存放在内存中,系统通常有一个寄存器来保存页表的基地址,在ARM中系统控制协处理器CP15的寄存器c2用来保存页表的基地址。具体操作格式如下
    MCR p15, 0, <Rd>, <c2>, <CRm>, <opcode_2>
    其中 CRm = c0 ,opcode_2 = 0 表示写入基地址

3、设置域
  MMU可以将整个存储空间分为最多16个域。每个域对应一定的内存区域,该区域具有相同的访问控制属性。MMU中寄存器C3用于控制与该域相关的属性配置

4、使能cache
  和cache和写缓冲操作相关的寄存器包括CP15中的寄存器C7、寄存器C9以寄存器C1中的某些位寄存器c1中与cache和写缓冲区操作相关的为有C(bit[2]),W(bit[3]),I(bit[12]),和RR(bit[14])其中 CRm = c7 ,opcode_2 = 0 表示使无效整个cache(Icachen和Dcachen).

5、使能MMU
  CP15的寄存器C1的位[0]用于控制禁止/使能MMU。当CP15的寄存器C1的位[0]设置成0时,禁止MMU;当CP15的寄存器C1的位[0]设置成1时,使能MMU;C(bit[2]) 当数据cache和指令cache是分开的时候,本控制禁止/使能数据cache;当数据cache和指令cache是统一的时候该控制位禁止/使能整个cache
  0  禁止cache
  1  使能cache
 W(bit[3]) 禁止/使能写入缓冲
  0 禁止写入缓冲
  1 使能写入缓冲
 I(bit[12]) 当数据cache和指令cache是分开的时候,本控制禁止/使能指令cache;
  0  禁止cache
  1  使能cache

RR(bit[14]) 如果系统中的淘汰算法可以选择的话,本控制位选择淘汰算法
  0 选择常规的淘汰算法
  1 选择预测性的淘汰算法

 //将页表地址告诉MMU,启动MMU
.global mmu_enable
mmu_enable:
//使无效cache/TLB
mov r1, #
mcr p15, , r1, c7, c7, //使无效ICache、DCache
mcr p15, , r1, c7, c10, //使无效写缓冲
mcr p15, , r1, c8, c7, //使无效指令、数据TLB //将页表地址告诉MMU
mcr p15, , r0, c2, c0, //写入页表地址,r0位页表基地址 //设置域
mrc p15, , r1, c3, c0, //获取控制寄存器的值
orr r1, r1, #
mcr p15, , r1, c3, c0, //使能ICache、DCache
mcr p15, , r1, c1, c0, //读取控制寄存器的值 orr r1,r1, #(<<)
orr r1,r1, #(<<)
orr r1,r1, #(<<)
mcr p15, , r1, c1, c0, //写入控制寄存器 //使能MMU
orr r1,r1,#(<<)
mcr p15,,r1,c1,c0,
//返回
mov pc lr

MMU.S

Tiny6410之MMU开启的更多相关文章

  1. 第七章 内存管理单元MMU介绍

    7.1 内存管理单元MMU介绍 7.1.1 S3C2410/S3C2440 MMU特性 负责虚拟地址到物理地址的映射,并提供硬件机制的内存访问权限检查 特性: 与ARM V4兼容的映射长度.域.访问权 ...

  2. MMU(why)

    在ARM中,MMU几个主要作用: 1. I/D Cache 管理      -> 大幅提高代码运行效率. 2. PA/VA 重映射        -> 实现多进程内存空间映射. 3. 内存 ...

  3. 转 s3c2440硬件学习----内存管理单元MMU

    本篇基本是韦东山书上的 一.内存管理单元MMU介绍 内存管理单元简称MMU,它负责虚拟地址到物理地址的映射,并提供硬件机制的内存访问权限检查.MMU使得每个用户进程拥有自己独立的地址空间,并通过内存访 ...

  4. JZ2440 裸机驱动 第7章 内存管理单元MMU

    本章目标:     了解虚拟地址和物理地址的关系:     掌握如何通过设置MMU来控制虚拟地址到物理地址的转化:     了解MMU的内存访问权限机制:     了解TLB.Cache.Write ...

  5. 第4天--linux内核学习

    驱动使用方式1.编译到内核中 * make uImage进入到系统后mknod /dev/led c 500 0 创建设备节点 2.编译为模块 M make module进入到系统后 mknod /d ...

  6. U-Boot GOT表分析和u-boot.lds解读

    转自:http://blog.sina.com.cn/s/blog_70dd16910100zab6.html u-boot-2010.09/arch/powerpc/cpu/mpc86xx/star ...

  7. arm linux kernel 从入口到start_kernel 的代码分析

    参考资料: <ARM体系结构与编程> <嵌入式Linux应用开发完全手册> Linux_Memory_Address_Mapping http://www.chinaunix. ...

  8. ARMv8 Linux内核head.S源码分析

    ARMv8Linux内核head.S主要工作内容: 1. 从el2特权级退回到el1 2. 确认处理器类型 3. 计算内核镜像的起始物理地址及物理地址与虚拟地址之间的偏移 4. 验证设备树的地址是否有 ...

  9. Linux X86在下面TLB机制

    TLB - translation lookaside buffer 快表.直译为翻译后备缓冲器,也能够理解为页表缓冲.地址变换快速缓存. 因为页表存放在主存中,因此程序每次訪存至少须要两次:一次訪存 ...

随机推荐

  1. Smith Numbers - PC110706

    欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/uva10042.html 原创:Smit ...

  2. JavaScript修改Canvas图片

    用JavaScript修改Canvas图片的分辨率(DPI)   应用场景: 仓库每次发货需要打印标签, Canvas根据从数据库读取的产品信息可以生成标签JPG, 但是这个JPG图片的默认分辨率(D ...

  3. JavaScript事件的几个细节

    JavaScript事件的几个细节 一.是捕获还是冒泡 昨天被问到一个问题:事件流有几个阶段?在这几个阶段中,事件一共发生几次? 问题很简单,但对于事件一共发生几次有点乱.总觉得捕获也能触发事件.冒泡 ...

  4. IOS使用 Visual Format Language 定义水平和垂直约束

    定义限制条件来改变一个 UI 组件在其父视图的水平和垂直方向布局的方法. 可以使用方程式里 H:方向符号代表水平方向的边距,使用 V:方向符号代表垂直方向的边 距. 转载请注明,本文转自:http:/ ...

  5. mac下安装eclipse以及python

    因为前几天刚重装了我的mac osx 系统,从昨天开始我就在安装各种软件,当我安装好破解版的myeclipse后,在我安装pydev插件的时候,虽然现实成功但是在preference中死活找不到pyd ...

  6. WPF之TreeList的实现方法1

    WPF之TreeList的实现方法(一) 做项目的时候根据需求,WPF现有的控件不能完全满足我们的需求, 很多时候我们需要对现有的控件做一下加工. 最简单的我们可能会把Tree转换成List形式有的叫 ...

  7. 关于Jquery 序列化表单的注意事项

    在JQuery 的serialize方法序列化表单的过程中,如果表单的name值最后有空格,会出现“+”号,查源码可见原因.这一小问题就浪费了半小时的时间,记录下来,备忘.

  8. js中的AMD规范

    回首萧瑟,残月挂角,孤草弄影. 看了一下上一篇随笔的日期,距离上一篇日志又过去了许久.在这段时间中,我尽全力去拯救那间便利店,可惜到最后依然失败,这一次是所有的出路全部没有了,我也做了所有的努力.闲下 ...

  9. 编译linux内核时出错

    在编译linux内核的时候使用make menuconfig 可能出现下面的错误 *** Unable to find the ncurses libraries or the*** required ...

  10. .Net用户使用期限的设置、限制通用小组件

    .Net用户使用期限的设置.限制通用小组件 最近比较项目组的同事都比较烦,不断的穿梭在不同的项目之间,一个人同时要兼顾多个项目的维护修改.甚至刚放下这个客户的电话,另一个客户的电话就进来了.究其原因, ...