图文详解Linux分页机制!

原创 程序员cxuan 2023-05-30 08:00

点击蓝色“程序员cxuan”即可关注作者

加个“星标”,及时接收最新文章

分页机制是 80x86 内存管理机制的第二种机制,分段机制用于把虚拟地址转换为线性地址,而分页机制用于把线性地址转换为物理地址。分页机制可以用于任何一种分段机制,也可以理解为先有分段机制才有分页机制,这是由于历史原因,分段机制要比分页机制更轻,先出现的分段后出现的分页。

处理器的分页机制用于把线性地址划分成一个个的页面,这些划分成页面的线性地址会被映射到物理空间的页面上。

我们知道分段的保护措施有两种,一种是利用任务之间的保护;一种是利用内存段和寄存器之间的保护。

分页机制有几种页面级的保护措施,分段机制和保护措施可以和分页机制的保护措施一起使用,也可以使用分页机制的保护措施替换分段机制的保护。

比如分页机制可以在页面的基础上加强读/写保护。另外,在页面单元上,分页机制还提供了用户和超级用户两级保护。

分页机制可以通过 CR0 控制寄存器的 PG 这个标志位来判断是否开启分页机制;如果 PG = 1 ,则表示启用分页操作,处理器会使用本节描述的机制将线性地址转换为物理地址。如果 PG = 0,则表示禁用分页机制,此时分段产生的线性地址会被直接用作物理地址。

分段机制和分页机制还有一个区别就是:分段机制可以在任意可变长度的内存上进行操作,而分页机制只能对固定大小的页面(内存块)进行操作。分页机制把线性和物理地址空间都划分成页面。线性地址空间中的页面都可以映射在物理地址空间内,如下图所示。

80x86 使用 4K (2 ^ 12) 字节固定大小的页面,每个页面均是 4KB,并且对齐于 4KB 地址边界处。这表示分页机制会把 4GB 划分成为以 4KB 为基础的页面,共划分 1M(1048576) 个,线性地址的低 12 bit 位可以直接作为页内偏移量,也可直接作为物理地址的低 12 位。

现在我们知道线性地址空间会经过分页机制映射到物理内存空间上,这是一个正常能够映射到的情况,如果映射不到怎么办?也就是说包含线性地址空间的页面不在物理内存中怎么办?此时处理器就会产生一个页错误异常。页错误异常的处理程序会让操作系统从磁盘中把相应的页面加载到物理内存中。当页面加载到物理内存中后,会从异常处理程序中返回,使得处于异常指令的位置继续向下执行指令。

页错误异常是分页机制实现换入换出过程中出现频次非常高的一种异常机制,它就好像 bug 一样如影随形,而且频繁的页面换入换出操作会很耗费处理器资源,所以为了减少频繁换入换出的操作,采用了一种局部性原理的方式:把经常访问的页目录和相关页 "保存" 起来,这里采用了一种硬件实现,即转换查找缓冲区(Translation Lookaside Buffer)。有了 TLB,处理器会先从 TLB 中查找相关页,TLB 中不存在的页才会从内存中进行读取,此时的 TLB 相当于是内存的一个副本。

页表结构

页表中每个页表项的大小为 32 位,其中 20 位来存放物理基地址,剩余的 12 位存放可用于存放页面是否存在等属性信息。如果线性地址索引的页表项被标注为存在,则表示该项有效,我们可以从中取得物理地址;如果线性地址索引的页表项不存在,那么访问物理页面就会产生异常。

下面是一个线性地址到物理地址的变换过程图。

可以看到,80x86 使用了两级页,这是为了减少页的数量所设计的,因为虽然每个页字节是 4K,共有 2 ^ 20 (1MB)个页,总共占据 4MB 大小,但实际上应用程序一次用不到这么多页,会造成资源浪费,所以采用了一种分层的设计方式。

第一级称为页目录(page directory),它被存放在 1 个 4K 页面中,因为一共有 2 ^ 10 次方(1 MB)个页目录,每个目录是 4 字节,所以是在一个 4K 页面中。线性地址的最高十位(22 - 31 位)用作一级表(页目录)中的索引来访问二级表。

第二级称为页表(page table),它和页目录一样,也是占据一个页面,最多含有 1K 个 4 字节的页表。页表项会存储 20 位的物理地址,线性地址中的 12 - 21 位作为页表的索引,用于获取含有 20 位物理地址的页表项。页表项的 20 位物理基地址和线性地址中的低 12 位一起合成最终的 32 位物理地址。

页表项结构

现在我们知道线性地址的低 12 位和页表存储的 20 位可以合成物理地址,页表项除了能够存储地址外,还有一些其他的属性,下面是页表项的结构图。

这里需要特别注意的是,页目录的结构和页表的结构是一样的,只不过他俩描述的主体不一样,一个描述的是页目录,一个描述的是页表。

  • P -- 位 0 是存在(Present)标志,用于指明表项对地址转换是否有效。P = 1 表示有效,P = 0 表示无效,在页的转换过程中,如果说涉及的页目录或页表的表项无效,也就是页面没有再物理地址中,就会产生一个异常。如果 P = 0 ,那么除了表项无效外,其余的 bit 位可以自由使用。
  • R/W -- 位 1 是读/写(Read/Write)标志,当 R/W = 1 时,表示该页可以被读、写和执行;当 R/W = 0 时,表示该页只读或可执行;当处理器运行在超级用户权限下(0、1、2)时,此位不会发生作用。
  • U/S -- 位 2 是用户/超级用户(User/Supervisor)标识,如果此位为 0 ,表示任意特权级下面的应用程序都可以访问,如果此位为 1 ,那么页面只能允许在特权级为 0、1、2 也就是超级用户特权级下才能访问。
  • A -- 位 5 是已访问(Accessed)标志,此位仅用于统计页面的访问情况,如果页面已经访问过,就会置 1,但是操作系统会通过定期复位来重置此标识位。
  • D -- 位 6 是页面已修改(Dirty)标志,也就是我们常说的"脏位",当处理器对页面执行写操作时,就会设置对应页面的 D 标志。
  • AVL -- 保留字段,这个字段专门提供给程序使用。

根据上面字段的描述,可以看到页目录和页表项中的 P 位为分页技术的虚拟存储提供了必要的标识,若线性地址空间中的页面存在于物理内存中,那么对应的表项 P = 1,并且该表项中含有相应的物理地址。页面不在物理内存中的表项 P = 0 。如果程序访问物理内存中不存在的页面,处理器就会产生一个缺页异常。此时操作系统就会利用这个异常把缺少的页面从磁盘调入内存,把相应的物理地址放在表项中,返回程序继续执行引起异常的指令并且设置 P = 1。

A 和 D 这两个标志位是实现虚拟存储的基础,这两个标志位可以定期检测指定的页面是否访问过并且是否可以读写,从而判断哪些页面可以移出到磁盘。比如一个页面从磁盘读入内存后,它的 D 标志位为 0 ,那么当页被移除磁盘时,它的 D 位还是 0 的话,就可以判断这个页面无需调入磁盘。D = 1 表示页面已经被修改过,就需要将其写回到磁盘上。




程序员cxuan cxuan 写的文章还不错。会分享计算机底层、计算机网络、操作系统,Java基础、框架、源码等文章。
评论
  • RDDI-DAP错误通常与调试接口相关,特别是在使用CMSIS-DAP协议进行嵌入式系统开发时。以下是一些可能的原因和解决方法: 1. 硬件连接问题:     检查调试器(如ST-Link)与目标板之间的连接是否牢固。     确保所有必要的引脚都已正确连接,没有松动或短路。 2. 电源问题:     确保目标板和调试器都有足够的电源供应。     检查电源电压是否符合目标板的规格要求。 3. 固件问题: &n
    丙丁先生 2024-12-01 17:37 57浏览
  • By Toradex胡珊逢简介嵌入式领域的部分应用对安全、可靠、实时性有切实的需求,在诸多实现该需求的方案中,QNX 是经行业验证的选择。在 QNX SDP 8.0 上 BlackBerry 推出了 QNX Everywhere 项目,个人用户可以出于非商业目的免费使用 QNX 操作系统。得益于 Toradex 和 QNX 的良好合作伙伴关系,用户能够在 Apalis iMX8QM 和 Verdin iMX8MP 模块上轻松测试和评估 QNX 8 系统。下面将基于 Apalis iMX8QM 介
    hai.qin_651820742 2024-11-29 15:29 151浏览
  • 《高速PCB设计经验规则应用实践》+PCB绘制学习与验证读书首先看目录,我感兴趣的是这一节;作者在书中列举了一条经典规则,然后进行详细分析,通过公式推导图表列举说明了传统的这一规则是受到电容加工特点影响的,在使用了MLCC陶瓷电容后这一条规则已经不再实用了。图书还列举了高速PCB设计需要的专业工具和仿真软件,当然由于篇幅所限,只是介绍了一点点设计步骤;我最感兴趣的部分还是元件布局的经验规则,在这里列举如下:在这里,演示一下,我根据书本知识进行电机驱动的布局:这也算知行合一吧。对于布局书中有一句:
    wuyu2009 2024-11-30 20:30 88浏览
  • 国产光耦合器正以其创新性和多样性引领行业发展。凭借强大的研发能力,国内制造商推出了适应汽车、电信等领域独特需求的专业化光耦合器,为各行业的技术进步提供了重要支持。本文将重点探讨国产光耦合器的技术创新与产品多样性,以及它们在推动产业升级中的重要作用。国产光耦合器创新的作用满足现代需求的创新模式新设计正在满足不断变化的市场需求。例如,高速光耦合器满足了电信和数据处理系统中快速信号传输的需求。同时,栅极驱动光耦合器支持电动汽车(EV)和工业电机驱动器等大功率应用中的精确高效控制。先进材料和设计将碳化硅
    克里雅半导体科技 2024-11-29 16:18 161浏览
  • 艾迈斯欧司朗全新“样片申请”小程序,逾160种LED、传感器、多芯片组合等产品样片一触即达。轻松3步完成申请,境内免费包邮到家!本期热荐性能显著提升的OSLON® Optimal,GF CSSRML.24ams OSRAM 基于最新芯片技术推出全新LED产品OSLON® Optimal系列,实现了显著的性能升级。该系列提供五种不同颜色的光源选项,包括Hyper Red(660 nm,PDN)、Red(640 nm)、Deep Blue(450 nm,PDN)、Far Red(730 nm)及Ho
    艾迈斯欧司朗 2024-11-29 16:55 157浏览
  • 最近几年,新能源汽车愈发受到消费者的青睐,其销量也是一路走高。据中汽协公布的数据显示,2024年10月,新能源汽车产销分别完成146.3万辆和143万辆,同比分别增长48%和49.6%。而结合各家新能源车企所公布的销量数据来看,比亚迪再度夺得了销冠宝座,其10月新能源汽车销量达到了502657辆,同比增长66.53%。众所周知,比亚迪是新能源汽车领域的重要参与者,其一举一动向来为外界所关注。日前,比亚迪汽车旗下品牌方程豹汽车推出了新车方程豹豹8,该款车型一上市就迅速吸引了消费者的目光,成为SUV
    刘旷 2024-12-02 09:32 62浏览
  • 国产光耦合器因其在电子系统中的重要作用而受到认可,可提供可靠的电气隔离并保护敏感电路免受高压干扰。然而,随着行业向5G和高频数据传输等高速应用迈进,对其性能和寿命的担忧已成为焦点。本文深入探讨了国产光耦合器在高频环境中面临的挑战,并探索了克服这些限制的创新方法。高频性能:一个持续关注的问题信号传输中的挑战国产光耦合器传统上利用LED和光电晶体管进行信号隔离。虽然这些组件对于标准应用有效,但在高频下面临挑战。随着工作频率的增加,信号延迟和数据保真度降低很常见,限制了它们在电信和高速计算等领域的有效
    腾恩科技-彭工 2024-11-29 16:11 106浏览
  • 戴上XR眼镜去“追龙”是种什么体验?2024年11月30日,由上海自然博物馆(上海科技馆分馆)与三湘印象联合出品、三湘印象旗下观印象艺术发展有限公司(下简称“观印象”)承制的《又见恐龙》XR嘉年华在上海自然博物馆重磅开幕。该体验项目将于12月1日正式对公众开放,持续至2025年3月30日。双向奔赴,恐龙IP撞上元宇宙不久前,上海市经济和信息化委员会等部门联合印发了《上海市超高清视听产业发展行动方案》,特别提到“支持博物馆、主题乐园等场所推动超高清视听技术应用,丰富线下文旅消费体验”。作为上海自然
    电子与消费 2024-11-30 22:03 75浏览
  • 在现代科技浪潮中,精准定位技术已成为推动众多关键领域前进的核心力量。虹科PCAN-GPS FD 作为一款多功能可编程传感器模块,专为精确捕捉位置和方向而设计。该模块集成了先进的卫星接收器、磁场传感器、加速计和陀螺仪,能够通过 CAN/CAN FD 总线实时传输采样数据,并具备内部存储卡记录功能。本篇文章带你深入虹科PCAN-GPS FD的技术亮点、多场景应用实例,并展示其如何与PCAN-Explorer6软件结合,实现数据解析与可视化。虹科PCAN-GPS FD虹科PCAN-GPS FD的数据处
    虹科汽车智能互联 2024-11-29 14:35 149浏览
  • 光耦合器作为关键技术组件,在确保安全性、可靠性和效率方面发挥着不可或缺的作用。无论是混合动力和电动汽车(HEV),还是军事和航空航天系统,它们都以卓越的性能支持高要求的应用环境,成为现代复杂系统中的隐形功臣。在迈向更环保技术和先进系统的过程中,光耦合器的重要性愈加凸显。1.混合动力和电动汽车中的光耦合器电池管理:保护动力源在电动汽车中,电池管理系统(BMS)是最佳充电、放电和性能监控背后的大脑。光耦合器在这里充当守门人,将高压电池组与敏感的低压电路隔离开来。这不仅可以防止潜在的损坏,还可以提高乘
    腾恩科技-彭工 2024-11-29 16:12 119浏览
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2024-12-02 10:40 63浏览
  • 学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&
    youyeye 2024-11-30 14:30 65浏览
  • 在电子技术快速发展的今天,KLV15002光耦固态继电器以高性能和强可靠性完美解决行业需求。该光继电器旨在提供无与伦比的电气隔离和无缝切换,是现代系统的终极选择。无论是在电信、工业自动化还是测试环境中,KLV15002光耦合器固态继电器都完美融合了效率和耐用性,可满足当今苛刻的应用需求。为什么选择KLV15002光耦合器固态继电器?不妥协的电压隔离从本质上讲,KLV15002优先考虑安全性。输入到输出隔离达到3750Vrms(后缀为V的型号为5000Vrms),确保即使在高压情况下,敏感的低功耗
    克里雅半导体科技 2024-11-29 16:15 119浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦