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

【微知】ARM CPU是如何获取某个进程的页表的?(通过TTBR寄存器,MMU进行处理)

ARM CPU 中用于存储访问某个进程的页表的寄存器是 TTBR(Translation Table Base Register)。有TTBR0和TTBR1。TTBR0用户空间的一级页表基址,1是内核页表。cpu访存获取物理地址流程 如果mmu发现tlb里面miss就通过pdbg拿pa物理地址。Intel是CR3。ARMv7 架构中每个 CPU 核也都有相应的 TTBR 寄存器来支持进程地址空间的管理。MMU 在进行地址映射时,会根据 TTBCR(TTB 控制寄存器)中的值以及虚拟地址的高位地址来选择对应的 TTBR 寄存器。V8架构更多,根据运行级别还有不同的TTBR更多参考:arm和intel的页表目录基地址寄存器。
每次进程切换的时候会把进程控制块(Process Control Block,PCB在linux中是task struct接口)的mm_struct中的属于进程页表的一级页表基地址写入TTBR寄存器。这个结构是mm_struct的pgd_t * pgd
当CPU访问虚拟内存的时候,如果tlb misss,MMU(Memory Management Unit 内存管理单元)会根据TTBR寄存器的值(是硬件提供给软件配置的接口)MMU能够动态的根据配置去获取不同进程页表的一级页表地址,然后依次根据偏移逐级获取到虚拟地址对应的物理地址,或者对应的IO地址。并且通过本次访问之后会将映射关系存入MMU的TLB(Translation Lookaside Buffer,转换后备缓冲器。MMU中的一个高速缓存,用于存储最近使用的虚拟地址到物理地址的转换映射信息。TLB的作用是加速地址转换过程,减少内存访问时间,提高系统性能)中,方便下次快速访问。
当通过MMU将虚拟地址转化为物理地址的最后一级页表的时候,如果发现当前页表不在内存中(比如被换出到swap分区),页表的标记位present位0表示不在内存中。会触发缺页中断,缺页中断处理例程中会将实际内存从swap分区切换到内存中。该部分用户不感知。具体内促访问磁盘还是物理内存的时延差别待进一步确认。

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

相关文章:

  • C++封装、继承、多态(虚函数)
  • 表面法线估计(Surface Normal Estimation)
  • 【JavaSE】String 类
  • AI:机器学习模型-线性回归
  • 《数字图像处理》教材寻找合作者
  • Java 8 的流(Stream API)简介
  • JavaScript instanceof 运算符全解析
  • 蓝桥杯省模拟赛 数位和
  • Linux: 进程信号初识
  • STL 性能优化实战:解决项目中标准模板库的性能瓶颈
  • windows部署docker
  • 第1章-3 MySQL的逻辑架构
  • py数据结构day3
  • java 使用 spring AI 实战MCP
  • es自定义ik分词器中文词库实现热更新
  • java项目分享-分布式电商项目附软件链接
  • C++ 新特性 | C++ 11 | 左值、右值与将亡值
  • Windows 实战-evtx 文件分析--笔记
  • 1.4 基于模拟退火改进蛇算法优化VGG13SE网络超参数的故障诊断模型
  • VMware上的windows虚拟机安装使用Docker方法