ARM 学习笔记 (三) S3C2440 MMU 配置

本文详细介绍了ARM处理器S3C2440的MMU(内存管理单元)配置,包括MMU的作用、分页概念、虚拟地址与物理地址的映射,以及S3C2440的内存映射方式,特别是Section模式。通过实例展示了虚拟地址如何通过MMU转换为物理地址,并探讨了访问控制机制,包括DOMAIN ACCESS CONTROL REGISTER、段描述符中的AP位和Domain位的作用,阐述了权限检查的过程。
摘要由CSDN通过智能技术生成

接上回说;

         在中断配置时 有一个函数  MMU_Init()  这个是MMU的初始化函数,用来初始化存储器管理单元的 (Memory Manage Unit  )。那这个单元是来干嘛的呢,顾名思义,用来管理存储器的。 许多年以前,当人们还在使用DOS或是更古老的操作系统的时候,计算机的内存还非常小,一般都是以K为单位进行计算,相应的,当时的程序规模也不大,所以 内存容量虽然小,但还是可以容纳当时的程序。但催着图形界面的兴起还有用户需求的不断加大,应用程序的规模也随着膨胀起来,终于一个难题出现在程序员的面前,那就是应用程序太大以至于内存容纳不下该程序,通常解决的办法是把程序分割成许多成为覆盖快(overlay)的片段。覆盖筷0首先运行。结束时他将调用另一个覆盖块 虽然覆盖块的交换是有OS完成的,但是必须先由程序员把程序进行分割,这是一个费时费力的工作,而且相当枯燥,人们必须找到更好的办法从根本上解决这个问题。不久人们找到了一个办法,这就是虚拟存储器(virtual memory)技术

           虚拟存储器的基本思想是程序,数据,堆栈的总的大小可以超过物理存储器的大小,操作系统把当前使用的部分保留在内存中,而把其他未使用的部分保存在磁盘上。比如对一个16MB的程序和一个内存只有4MB的机器,OS通过选择可以决定各个时刻将哪4M的内容保留在内存中,并在需要时在内存和磁盘间交换程序片段,这样就可以把这个16M的程序运行在一个只有4M内存的机器上了,而这个16M的程序在运行前不必由程序员进行分割。

         任何时候,计算机上都运载一个程序能够产生的地址集合,我们称之为地址范围。这个范围的大小有CPU的位数决定。例如一个32位的CPU,它的地址范围是0~0xFFFFFFFF(4G),而对于一个64位的CPU,它的地址范围为0~0xFFFFFFFFFFFFFFFF(64T)。这个范围就是我们的程序能够产生的地址范围,我们把这个地址范围称之为虚拟地址空间,该空间中的某一个地址我们称之为虚拟地址。与虚拟地址空间和虚拟地址相对应的则是物理地址空间和物理地址,大多数时候我们的系统所具备的物理地址空间只是虚拟地址空间的一个子集,这里举一个最简单的例子直观的说明这两者,对于一台内存为256MB的32bit x86主机来说,的虚拟地址空间范围是0~0xFFFFFFFF(4G),而其物理地址空间范围是0x0~0x0FFFFFFF(256MB).在没有使用虚拟存储器的情况下,虚拟地址被直接送到内存总线上,使具有相同地址的物理存储器被读写。而在使用了虚拟存储器的情况下,虚拟地址不是被直接送到内存地址总线上的而是送到了内存管理单元---------MMU ! ! ! ! ! ! !

        MMU是由一个或一组芯片组成,一般存在协处理器中,其功能是把虚拟地址映射为物理地址

        大多数使用虚拟存储器的系统都使用一种称为分页(paging)。虚拟地址空间划分成称为页(page)的单位,而相应的物理地址空间也被进行划分,单位 是页框(frame).页和页框的大小必须相同。接下来配合图片我以一个例子说明页与页框之间在MMU的调度下是如何进行映射的

        在这个例子中我们有一台可以生成16位地址的机器,它的虚拟地址范围从0x0000~0xFFFF(64K),而这台机器只有32K的物理地址,因此他可 以运行64K的程序,但该程序不能一次性调入内存运行。这台机器必须有一个达到可以存放64K程序的外部存储器(例如磁盘或是FLASH),以保证程序片 段在需要时可以被调用。在这个例子中,页的大小为4K,页框大小与页相同(这点是必须保证的,内存和外围存储器之间的传输总是以页为单位的),对应64K 的虚拟地址和32K的物理存储器,他们分别包含了16个页和8个页框。
我们先根据上图解释一下分页后要用到的几个术语,在上面我们已经接触了页和页框,上图中绿色部分是物理空间,其中每一格表示一个物理页框。橘黄色部分是虚 拟空间,每一格表示一个页,它由两部分组成,分别是Frame Index(页框索引)和位p(present 存在位),Frame Index的意义很明显,它指出本页是往哪个物理页框进行映射的,位p的意义则是指出本页的映射是否有效,如上图,当某个页并没有被映射时(或称“映射无 效

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值