当前位置: 首页 > news >正文

linux 内核 - 内存管理单元(MMU)与地址翻译(一)

        MMU 不仅负责将虚拟地址转换为物理地址,还能防止未经授权的内存访问。对于一个进程而言,它所需访问的任何页面都必须存在于该进程的某个 VMA 中,因此也必须记录在该进程的页表里(每个进程都有自己的页表)。

        内存是按照固定大小的块来组织的:在虚拟内存中称为“页(page)”,在物理内存中称为“帧(frame)”。在我们的例子中,大小为 4 KB。不过,这个大小在内核中是通过宏 PAGE_SIZE 定义并可访问的。但需要注意,页面大小是由硬件决定的。在一个以 4 KB 为页大小的系统中,字节地址 0 到 4095 属于第 0 页,字节地址 4096 到 8191 属于第 1 页,以此类推。

        引入页表(page table)的概念,是为了管理页面与帧之间的映射关系。页面被分布到页表中,每个页表项(PTE, Page Table Entry)对应着一个页面与一个物理帧之间的映射。随后,每个进程都会被分配一组页表,用来描述它所有的内存区域。

        为了在页面之间进行遍历,每个页面都会被分配一个索引,称为页号(page number)。对于物理帧来说,则称为页帧号(PFN, Page Frame Number)。这样一来,VMA(更准确地说是逻辑地址)就由两部分组成:页号和偏移量(offset)。在 32 位系统中,偏移量由地址中最低的 12 位表示;而在页大小为 8 KB 的系统中,偏移量由最低的 13 位表示。下面的示意图展示了这种将地址拆分为“页号 + 偏移量”的概念:

        

        操作系统或 CPU 是如何知道某个逻辑地址对应哪个物理地址的呢?它们使用页表作为翻译表,每个页表项的索引就是虚拟页号,而该索引对应的值就是 PFN(页帧号)。当需要通过虚拟内存访问物理内存时,操作系统首先会提取偏移量和虚拟页号,然后遍历该进程的页表,将虚拟页号与物理页匹配。一旦找到对应关系,就可以访问该物理页帧中的数据。

        

http://www.lryc.cn/news/626506.html

相关文章:

  • Flink Stream API - 顶层Operator接口StreamOperator源码超详细讲解
  • 软件测试中,JMeter 的作用以及优缺点是什么?
  • 【报错】Please do not run this script with sudo bash
  • three.js学习记录(第四节:材质外观)
  • Git 新手完全指南(二):在vscode中使用git
  • 【图像算法 - 19】慧眼识苗:基于深度学习与OpenCV的大棚农作物生长情况智能识别检测系统
  • PostgreSQL 中的金钱计算处理
  • K8S-Secret资源对象
  • 从零开始学AI——13
  • 机器学习(Machine Learning, ML)
  • mysql数据恢复
  • iOS App 上架实战 从内测到应用商店发布的全周期流程解析
  • QT聊天项目DAY20
  • java17学习笔记
  • 【Tech Arch】Apache HBase分布式 NoSQL 数据库
  • idea maven 设置代理
  • FastAPI初学
  • 《深度解析PerformanceObserverAPI: 精准捕获FID与CLS的底层逻辑与实践指南》
  • 【STM32】HAL库中的实现(六):DAC (数模转换)
  • 调用海康威视AI开放平台接口实现人体关键点检测
  • Java毕业设计选题推荐 |基于SpringBoot+Vue的知识产权管理系统设计与实现
  • langchain-ds的报告生成提示词
  • 结构化 OCR 技术:破解各类检测报告信息提取难题
  • Objective-C 版本的 LiveEventBus 效果
  • java和javascript在浮点数计算时的差异
  • Flink实现Exactly-Once语义的完整技术分解
  • mac 搭建docker-compose,部署docker应用
  • Android 入门到实战(三):ViewPager及ViewPager2多页面布局
  • linux内核 - 内存管理单元(MMU)与地址翻译(二)
  • 0820 SQlite与c语言的结合