0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

MMU如何知道页表在内存中的具体地址

麦辣鸡腿堡 来源:嵌入式Linux充电站 作者:Vincent 2023-10-08 11:52 次阅读

MMU怎么知道这个页表在内存中的具体地址呢?

通常CPU会提供一个页表基址寄存器操作系统使用,用于给MMU指示页表的基地址。不同处理器架构对应的寄存器也不一样:

x86:CR3(Control Register 3)

ARM-v8:系统寄存器TTBR(Translation Table Base egister)

RISC-V:SATP(Supervisor Address Translation and Protection)

图片

页表基址寄存器存储了第一级页表的基地址,通过访问该寄存器,就能知道页表在那个位置。

多级页表转换过程

实际使用中,都是用多级页表来存储虚拟地址和物理地址的映射关系,

以二级页表为例(假设是32位系统),其虚拟地址转换为物理地址的过程如图所示:

图片

PGD:Pgea Global Directory,全局页目录,存储了下一级页表的基地址

PTE:Page Table Entrys,页表入口,PTE才是真正存储了物理地址的页表

VA到PA的转换过程:

MMU通过访问页表基址寄存器,得到一级页表PGD的基地址,再结合虚拟地址中的PGD index找到了下一级页表PTE的基地址;得到了PTE的基址,再结合虚拟地址中的PTE index找到PFN,然后再和VA相加得到物理地址。

这里需要注意,使用多少级的页表、以及虚拟地址、物理地址的格式、PTE的格式等等,与32系统还是64位系统有关,也与处理器的架构有关,需要根据不同系统、不同处理器架构分析。

但是MMU工作原理都是一样的,不管是二级页表、三级页表还是四级页表,都是通过第一级页表找到第二级页表,通过第二级页表找到第三级页表。最终找到物理地址。只要明白了MMU的工作原理,分析其他的页表也是大同小异。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5334

    浏览量

    120208
  • Linux
    +关注

    关注

    87

    文章

    11279

    浏览量

    209263
  • 内存
    +关注

    关注

    8

    文章

    3016

    浏览量

    73989
  • MMU
    MMU
    +关注

    关注

    0

    文章

    91

    浏览量

    18282
收藏 人收藏

    评论

    相关推荐

    关于MMU的问题

    刚开始学,好多东西都云里雾里的TT为什么在bootloader里要进行初始化然后开启MMU,然后在进入内核后还要创建开启
    发表于 05-06 17:25

    带你走进嵌入式ARM MMU神秘的内部世界

    表项,2bit可以区分4种表项,具体每种表项的结构如下: 简而言之L1
    发表于 08-22 11:22

    ARM MMU 理解(基于ARM 920T)

    、4KB和1KB大小地址空间的映射。要实现从虚拟地址到物理地址的映射,必然会遇到一个问题,如何找到这个。对于
    发表于 08-29 11:10

    MMU的产生及MMU工作过程详解

    送到内存地址总线上,而是送到内存管理单元——MMU(主角终于出现了)。他由一个或一组芯片组成,一般存在与协处理器,其功能是把虚拟地址映射为
    发表于 07-03 08:19

    ARM11 S3C6410的地址

    存放二级的基址; 二级基址+ VA[19:12] = 二级描述符的入口
    发表于 08-17 00:53

    裸机加强版MMU章节创建,地址映射相同

    ARM裸机1期加强版 024_mmu_cache_021\002_mmu_021_004\mmu.c 文件/* 2.3 for 64M sdram */创建
    发表于 04-18 07:45

    CC2541烧写加密设置的具体地址在哪里?

    structure具体地址是在哪里呢?我在0x7FF0和0xFFF0地址都试过填写加密位,读取的加密状态都为0(DBGLOCK设置为0);2.Flash一共128(0~127),但是FLASH_PAGES-1:0最多只有12
    发表于 09-23 08:53

    ARM的内存管理(MMU)是如何实现的?

    ( translate table )是实现 MMU 功能不可缺少的一步。是位于系统的内存
    发表于 10-23 15:29

    鸿蒙内核源码分析(内存映射篇):虚拟地址与物理地址之间是如何映射的

    和常量数据,全局变量数据以及运行时动态申请内存所分配的实际物理内存存放位置。MMU采用(page table)来实现虚实
    发表于 11-19 10:52

    MMU表工作机制的简单评析

    对于一个有MMU的CPU而言,MMU开启后,CPU是这样寻址的:CPU任何时候,一切时候,发出的地址都是虚拟地址,这个虚拟地址发给
    的头像 发表于 02-02 14:08 1.1w次阅读
    对<b class='flag-5'>MMU</b>和<b class='flag-5'>页</b>表工作机制的简单评析

    为什么要用MMU?为什么要用虚拟地址

    既然MMU开启后,硬件会自动的将虚拟地址转换成物理地址,那么还需要我们软件做什么事情呢?即创建一个翻译都需要做哪些事情呢?或者说启用一个
    的头像 发表于 04-26 14:37 4916次阅读

    MMU原理:CPU是如何访问到内存的?

    当CPU访问虚拟地址0的时候,MMU会去查上面的第0行,发现第0行没有命中,于是无论以何种形式(R读,W写,X执行)访问,MMU都会给C
    发表于 11-09 12:30 1155次阅读
    <b class='flag-5'>MMU</b>原理:CPU是如何访问到<b class='flag-5'>内存</b>的?

    MMU内存管理单元的宏观理解

    最近一直在学习内存管理,也知道MMU是管理内存的映射的逻辑IP,还知道里面有个TLB。 今天刚刚好看到了几篇前辈的文章,很是不错,于是这里来
    的头像 发表于 11-26 15:21 574次阅读
    <b class='flag-5'>MMU</b><b class='flag-5'>内存</b>管理单元的宏观理解

    MMU命中、缺页介绍

    命中、缺页 (1)命中 • a) 处理器要对虚拟地址VA进行访问。 • b) MMU的TLB没有命中,通过TWU遍历主存
    的头像 发表于 11-26 16:19 1083次阅读
    <b class='flag-5'>MMU</b><b class='flag-5'>中</b>的<b class='flag-5'>页</b>命中、缺页介绍

    MMU多级映射过程

    空间,也有相应的负责虚拟地址到物理地址之间的转换。MMU查询的过程,用户进程的一级
    的头像 发表于 11-26 16:28 950次阅读
    <b class='flag-5'>MMU</b>多级<b class='flag-5'>页</b><b class='flag-5'>表</b>映射过程