嵌入式Linux--MMU 痛定思痛。 2022-11-20 08:24 340阅读 0赞 ### 目录 ### * 什么是MMU * 一、MMU的产生 * * 虚拟存储器的基本思想: * 二、MMU工作过程 # 什么是MMU # 全称:**memory management unit** 【内存管理单元】 * 1、CPU中用来管理虚拟存储器、物理存储器的控制线路 * 2、同时也负责虚拟地址映射为物理地址 * 3、以及提供硬件机制的内存访问授权 # 一、MMU的产生 # 许多年以前,当人们还在使用DOS或是更古老的操作系统的时候,计算机的内存还非常小,一般都是以K为单位进行计算,相应的,当时的程序规模也不大,所以内存容量虽然小,但还是可以容纳当时的程序。但随着图形界面的兴起还用用户需求的不断增大,应用程序的规模也随之膨胀起来,终于一个难题出现在程序员的面前,那就是应用程序太大以至于内存容纳不下该程序,通常解决的办法是把程序分割成许多称为覆盖块(overlay)的片段。覆盖块0首先运行,结束时他将调用另一个覆盖块。虽然覆盖块的交换是由OS完成的,但是必须先由程序员把程序先进行分割,这是一个费时费力的工作,而且相当枯燥。人们必须找到更好的办法从根本上解决这个问题。不久人们找到了一个办法,这就是虚拟存储器(virtual memory)。 ## 虚拟存储器的基本思想: ## **程序,数据,堆栈的总的大小可以超过物理存储器的大小,操作系统把当前使用的部分保留在内存中,而把其他未被使用的部分保存在磁盘上,比如对一个16MB的程序和一个内存只有4MB的机器,OS通过选择,可以决定各个时刻将哪4M的内容保留在内存中,并在需要时在内存和磁盘间交换程序片段,这样就可以把这个16M的程序运行在一个只具有4M内存机器上了。而这个16M的程序在运行前不必由程序员进行分割。** **地址范围:** 指处理器能够产生的地址集合,如一个32bit的处理器ARM9,其能产生的地址集合是0x0000 0000 ~ 0xffff ffff(4G),这个地址范围也称为虚拟地址空间,其中对应的地址为虚拟地址。 **虚拟地址与物理地址:** 与虚拟地址空间和虚拟地址相对应的是物理地址空间和物理地址;物理地址空间只是虚拟地址空间的一个子集。如一台内存为256MB的32bit X86主机,其虚拟地址空间是0 ~ 0xffffffff(4GB),物理地址空间范围是0 ~ 0x0fff ffff(256M) \*\*分页机制:\*\*如果处理器没有MMU,或者有MMU但没有启用,CPU执行单元发出的内存地址将直接传到芯片引脚上,被内存芯片(以下称为物理内存,以便与虚拟内存区分)接收,这称为物理地址(Physical Address,以下简称PA),如下图所示; ![在这里插入图片描述][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI4ODc3MTI1_size_16_color_FFFFFF_t_70_pic_center] 如果处理器启用了MMU,CPU执行单元发出的内存地址将被MMU截获,从CPU到MMU的地址称为虚拟地址(Virtual Address,以下简称VA),而MMU将这个地址翻译成另一个地址发到CPU芯片的外部地址引脚上,也就是将VA映射成PA,,如下图: ![在这里插入图片描述][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI4ODc3MTI1_size_16_color_FFFFFF_t_70_pic_center 1] 大多数使用MMU的机器都采用分页机制。虚拟地址空间以页为单位进行划分,而相应的物理地址空间也被划分,其使用的单位称为页帧,页帧和页必须保持相同,因为内存与外部存储器之间的传输是以页为单位进行传输的。 例如,MMU可以通过一个映射项将VA的一页0xb7001000 0xb7001fff 映射到PA的一页0x2000 0x2fff,如果CPU执行单元要访问虚拟地址0xb7001008,则实际访问到的物理地址是0x2008。 任何时候,计算机上都存在一个程序能够产生的地址集合,我们称之为地址范围。这个范围的大小由CPU的位数决定,例如一个32位的CPU,它的地址范围是0~0xFFFFFFFF (4G)而对于一个64位的CPU,它的地址范围为0 ~ 0xFFFFFFFFFFFFFFFF (64T),这个范围就是我们的程序能够产生的地址范围,我们把这个地址范围称为虚拟地址空间,该空间中的某一个地址我们称之为虚拟地址。与虚拟地址空间和虚拟地址相对应的则是物理地址空间和物理地址,大多数时候我们的系统所具备的物理地址空间只是虚拟地址空间的一个子集,这里举一个最简单的例子直观地说明这两者,对于一台内存为256MB的32bit x86主机来说,它的虚拟地址空间范围是0 ~ 0xFFFFFFFF(4G),而物理地址空间范围是0x000000000 ~ 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的意义则是指出本页的映射是否有效,如上图,当某个页并没有被映射时(或称映射无效,Frame Index部分为X),该位为0,映射有效则该位为1。 -------------------- [参考一][Link 1] [参考二][Link 2] [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI4ODc3MTI1_size_16_color_FFFFFF_t_70_pic_center]: /images/20221120/3418c3324cc24c338e5a32c2a43fb0b3.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzI4ODc3MTI1_size_16_color_FFFFFF_t_70_pic_center 1]: /images/20221120/479ffcae8ced4192b28da6a24b1a2f07.png [Link 1]: https://blog.csdn.net/fanhaisen001/article/details/52161344 [Link 2]: http://www.techbulo.com/948.html
相关 嵌入式简介 文章目录 嵌入式的定义 嵌入式人才的要求 基本要求 专业要求 从技术上来区分嵌入式 嵌入式硬件工程师必备技能 嵌入 淩亂°似流年/ 2023年10月14日 20:31/ 0 赞/ 176 阅读
相关 嵌入式Jetty Jetty 可以在嵌入式模式下运行。这意味着无需构建 WAR 文件并将其部署在独立的 Jetty 服务器中。Jetty 是一个软件组件,可以像任何其他 POJO(Plain O 短命女/ 2023年09月30日 10:57/ 0 赞/ 138 阅读
相关 nginx 嵌入式 ./configure --help --help print this message --prefix= ゞ 浴缸里的玫瑰/ 2023年02月12日 10:26/ 0 赞/ 18 阅读
相关 【嵌入式】嵌入式天地博客汇总 00. 目录 文章目录 00. 目录 01. GCC工具 02. 嵌入式C语言 03. STM32博客教程 悠悠/ 2023年01月22日 06:59/ 0 赞/ 170 阅读
相关 嵌入式 分类: 1. 用预处理指令\define 声明一个常数,用以表明1年中有多少秒(忽略闰年问题) \define SECONDS\_PER\_YEAR (60 \ 60 \ 青旅半醒/ 2022年09月18日 13:56/ 0 赞/ 397 阅读
相关 嵌入式Linux who命令 显示以下内容:登录名、tty、登录日期和时间 ![在这里插入图片描述][634d955a4ed34f6e99bfe653cbc3b86d.png] l 迈不过友情╰/ 2022年09月14日 11:25/ 0 赞/ 518 阅读
相关 嵌入式笔试 1.在int a\[3\]\[4\]=\{0\}中,数组a中每个元素均可以得到初值0; 在int a\[3\]\[4\]=\{2\}中,数组a中第一个元素为2,其余为0; 向右看齐/ 2022年05月26日 22:42/ 0 赞/ 493 阅读
相关 嵌入式目录 第一部分:Linux平台搭建与环境熟悉 了解Liunx系统 区分各种版本的Liunx系统 以便拓展 Liunx视野 1. Liunx简介 2.Liun系统主要特点; 3 港控/mmm°/ 2022年01月06日 19:39/ 0 赞/ 478 阅读
还没有评论,来说两句吧...