ARM Cortex-A学习(3):MMU内存管理单元

内存管理单元(MMU)负责虚拟地址到物理地址的转换。MMU通过翻译表将程序使用的虚拟地址映射到实际的物理内存位置,实现对内存的动态管理和隔离。这不仅允许更灵活的内存分配,还提高了系统的安全性和稳定性。了解MMU的工作原理对于开发底层代码、BootLoader和驱动程序都很重要。

文章目录

  • 1 虚拟地址和物理地址
  • 2 MMU
    • 2.1 表的条目
    • 2.2 表的查找
    • 2.3 多级页表
  • 3 例:ARMv8-A的地址空间
  • 4 总结

1 虚拟地址和物理地址

关于虚拟地址的概念,可以参考我的这篇文章:物理地址、链接地址、加载地址、虚拟/逻辑地址的区别

虚拟地址允许操作系统控制呈现给应用程序的内存视图,如操作系统可以控制内存的可见性和访问权限。这使得操作系统能够对应用程序进行沙盒化,并提供对底层硬件的抽象。它的好处如下:

  • 操作系统可以将多个分散的物理内存区域呈现为一个连续的虚拟地址空间供应用程序使用。

  • 软件开发人员无需关心物理内存,地址转换是由操作系统和硬件共同完成的。

在实际应用中,每个应用程序可以使用自己的一组虚拟地址,将其映射到物理系统中的不同位置。当操作系统将控制权从一个应用程序转移到另一个应用程序时,它会更新内部的映射表,以确保当前运行的应用程序的虚拟地址正确地映射到物理内存中的相应位置。这样,即使不同应用程序使用相同的虚拟地址,它们实际上指向不同的物理内存位置,从而实现了应用程序之间的隔离和独立性。

虚拟地址和物理地址之间通过翻译页表进行映射:

在这里插入图片描述

翻译页表存储在内存中,通常由操作系统进行管理。页表的映射可以通过软件配置,从而改变虚拟地址和物理地址之间的映射关系。

2 MMU

MMU执行地址转换操作,它包含以下组成部分:

  • 表遍历单元:包含从内存读取翻译页表的逻辑
  • 翻译后备缓冲区(TLBs,Translation Lookaside Buffers):用于缓存最近使用的页表翻译转换结果,这可以加快内存的访问速度

由软件发出的内存地址都是虚拟的,虚拟地址传递给MMUMMU检查TLBs缓存,若缓存未命中,则表遍历单元将从主存中读取数据并缓存,如下所示:

在这里插入图片描述

在访问内存之前,虚拟地址必须被翻译为物理地址。另外,在Armv6及更高版本的处理器上,数据缓存使用物理地址(物理标记的地址)存储数据。所以,在进行缓存查找时,需要提前将虚拟地址翻译为物理地址。

2.1 表的条目

翻译页表通过将虚拟地址空间分成相等大小的块,并为每个块在表中提供一个条目来实现。

  • 翻译表的每个条目对应着虚拟地址空间中的一个块,而这些块会被映射到物理地址空间的相应块。
  • 表中的第0个条目对应着虚拟地址空间中的块0,第1个条目对应着块1,以此类推。
  • 表中条目包含相应物理内存块的地址以及访问该物理地址时要使用的属性(如读/写/缓存策略等)。

在这里插入图片描述

2.2 表的查找

表查找发生在虚拟地址转化为物理地址的时候。此时,由软件发出的虚拟地址被分为两部分:

在这里插入图片描述

上图为单层查找的例子。其中:

  • Which entry:应该查找哪个块条目,并将其用作对表的索引,该块条目包含虚拟地址对应的物理地址
  • Offset in block:块内的偏移,翻译过程中不会改变

2.3 多级页表

在2.1中的图为单级查找,虚拟地址空间被分割成相等的大小。但在实际的页表实现中是使用多级页表实现的。

一级表将虚拟地址空间分割成大块,该表中的每个条目可以指向相等大小的物理内存块,或者它可以指向另一个表,该表将块细分为更小的块。下图是三级多级页表的示例:

在这里插入图片描述

在Armv8-A架构中,多级表的最大级别为四级(0到3)。虚拟地址空间被划分为不同级别的表,第一级表负责将虚拟地址空间分成大块,而每个表项可以指向相等大小的物理内存块,或者指向另一个表,该表将块细分为更小的块。这种多级结构的设计使得系统可以同时处理大范围的内存块和较小的内存块,从而在灵活性和效率之间找到平衡。

  • 大块相对于小块需要更少的读取级别来进行转换,大块在TLB中缓存更高效
  • 小块使软件能够对内存分配进行精细控制,但小块在TLB中的缓存效率较低,因为小块需要通过多个级别进行多次读取以进行转换
  • 为了平衡使用大映射的效率与使用小映射的灵活性以获得最佳性能,操作系统必须管理这种权衡

3 例:ARMv8-A的地址空间

不同的异常等级(Exception Level,EL)通常对应于不同的特权级别和内存空间。每个EL都有其自己的地址空间和访问权限。这种设计提供了对系统资源的分隔和管理,同时允许在不同特权级别上运行不同的软件实体,如用户空间应用程序、操作系统内核、虚拟化管理器等。

这里以ARMv8-A为例,在ARMv8-A架构中有以下4种EL

  • EL0(用户空间): 通常用于运行普通应用程序代码,访问受限制的用户空间内存。
  • EL1(内核空间): 用于运行操作系统内核代码,具有更高的特权级别和对系统资源的更广泛访问权限。
  • EL2(hypervisor级别): 通常用于虚拟化支持,允许运行多个虚拟机实例。它有自己的地址空间和控制权,可以管理虚拟机的运行。
  • EL3(监管者级别): 可能用于处理一些与系统安全性相关的任务,例如启动过程中的安全任务。它也有自己的地址空间和特权级别。

在这里插入图片描述

  • 图中EL前面的NS表示Non-Secure,图表中未显示Secure EL0Secure EL1Secure EL2的虚拟地址空间,实际上EL0-EL3也是有安全空间的。

  • 由于存在多个虚拟地址空间,指定一个地址属于哪个地址空间变得很重要

    • 例如,NS.EL2:0x8000指的是在非安全hypervisor级别(NS.EL2)的虚拟地址空间中的0x8000。在其它的EL中也可以有自己的0x8000.

虚拟化

从上图还可知,Non-secure EL0Non-secure EL1的虚拟地址经过两组表。这些表支持虚拟化,并允许hypervisor(即虚拟机监控程序,位于NS.EL2)虚拟化虚拟机所看到的物理内存视图。

虚拟化分为两个阶段:

(1)第一阶段:表由操作系统控制,它将虚拟地址翻译为中间物理地址(intermediate physical addresses,IPA)。在第一阶段中,操作系统认为这些IPAs是物理地址空间。

(2)第二阶段:虚拟机监控程序(hypervisor)控制第二组翻译,它将IPAs翻译为物理地址

在这里插入图片描述

尽管表格格式存在细微的差异,但通常阶段1和2的地址翻译过程是相同的。

4 总结

本文大概地介绍了一下ARM中MMU的概念,主要是了解一下在Cortex-A核中有这样一个内存管理单元,它可以将虚拟地址转化为物理地址。对于具体地,内存是如何映射的,TLB表格是如何缓存的等知识,都与操作系统的实现有关,后续我们学到Linux再介绍。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/319389.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

工业协议转换网关:打破通信壁垒,实现设备互联

在工业自动化领域,各种设备和系统间的通信协议不尽相同,这给不同设备间的集成和数据交互带来了挑战。工业协议转换网关作为一种解决这一问题的关键设备,能够实现不同协议间的转换和数据传输,打破通信壁垒,提高设备的协…

HarmonyOS4 vp单位计算

我们在harmonyOS中设置宽度等单位时 需要在后面写明具体是什么单位 width("100%")这里 我们就写明了是 百分之百 如果不写 直接给数值 width(100)那么 它就会按vp去读 这里就被读为 100vp vp 之前是一种移动端宽度概念 后面鸿蒙重定义了它的概念 计算公式是 px 乘…

macbook录屏快捷键大全,教你快速录制视频

“有人知道macbook电脑有录屏快捷键吗,现在录屏的速度太慢了,每次打开都要浪费不少时间,要是有录屏快捷键,应该会快很多,有哪位大佬知道吗?教教我!” 无论是在工作还是生活中,电脑已…

el-select下拉框 change事件返回该项所有数据

主要代码 value-key <template><div><el-selectv-model"value"value-key"label"placeholder"请选择"change"selectChange"><el-optionv-for"item in options":key"item.label":label"…

Python爬虫篇(四):京东数据批量采集

京东数据批量采集 ●前言 一年一度的端午节又到了&#xff0c;甜咸粽子之争也拉开了帷幕&#xff0c;它价格高昂&#xff0c;它味道鲜美&#xff0c;然而&#xff0c;默默无名的它却备受广大民众喜爱&#xff01;好家伙&#xff0c;一看就是老qq看点了 &#xff0c;那咱们能做…

电锯切割狂

欢迎来到程序小院 电锯切割狂 玩法&#xff1a;把木块切成等分的碎片&#xff0c;每关都会有切割次数&#xff0c;木块数&#xff0c;切割越均匀分数越搞&#xff0c; 有简单、正常、困难、专家版&#xff0c;快去解锁不同版本进行切割吧^^。开始游戏https://www.ormcc.com/pl…

2023到2024年:前端发展趋势展望

本文探讨了2023年至2024年之间前端领域的发展趋势。我们将关注以下几个方面的变化&#xff1a;无代码/低代码开发的兴起、WebAssembly的广泛应用、跨平台技术的发展、人工智能在前端的应用以及用户体验的不断优化。 随着技术的飞速发展&#xff0c;前端开发在推动互联网与移动应…

numpy数组05-numpy的索引和切片

numpy中可以对其中的某一行&#xff08;列&#xff09;进行数据处理。 上节课我们已经取出了CSV文件中的二维数组&#xff0c;本次对这个二维数组为例&#xff0c;进行练习操作。 示例代码如下&#xff1a; import numpy as npus_file_path "US_video_data_numbers.cs…

【响应式编程-02】Lambda的语法格式和使用

一、简要描述 Lambda的语法格式Lambda的使用 二、Lambda的语法格式 (parameters) -> {statements;}(pararmeters) -> expression 1、(parameters) -> {statements;} parameters: 函数的参数列表statements: 执行语句-> : 使用指定参数去完成某个功能 public int me…

【基础篇】十一、JVM方法区

文章目录 1、方法区2、方法区的位置3、模拟方法区的溢出4、方法区的字符串常量池5、常量池案例6、String的intern方法7、静态变量的存放位置 1、方法区 方法区线程共享&#xff0c;存了以下几部分&#xff1a; 类的元信息运行时常量池字符串常量池 类的元信息&#xff0c;即…

05-SpringCloud-RabbitMQ-概述

RabbitMQ 1.初识MQ 1.1.同步和异步通讯 微服务间通讯有同步和异步两种方式&#xff1a; 同步通讯&#xff1a;就像打电话&#xff0c;需要实时响应。 异步通讯&#xff1a;就像发邮件&#xff0c;不需要马上回复。 两种方式各有优劣&#xff0c;打电话可以立即得到响应&am…

FPGA高端项目:纯verilog的 10G-UDP 高速协议栈,提供7套工程源码和技术支持

目录 1、前言免责声明更新说明 2、相关方案推荐我这里已有的以太网方案本协议栈的千兆网UDP版本1G 千兆网 TCP-->服务器 方案1G 千兆网 TCP-->客户端 方案10G 万兆网 TCP-->服务器客户端 方案 3、该UDP协议栈性能4、详细设计方案设计架构框图网络调试助手GT资源使用GT…