MMU:内存管理单元。

CPU寻址的方式:

未使用MMU:CPU发出地址(PA) 直接内存寻址(SDRAM or DDRx)。

使用MMU  :CPU发出地址(VA) MMU接收CPU发来的地址 经过某种转换

变成实际的物理地址去寻址。

那么是MMU是如何实现VA到PA的转化的呢?

 建立VA与PA的对应关系:

MMU有段描述符(1M)(还有页描述符大页(64KB)小页(4KB)和极小页(1KB))

我们这里说段页表的建立。

比如32位CPU,4G的寻址空间可分为4094个段(4G/1MB)

所以可以建立4096个对应的关系而实际的内存肯定没到4G(VA-PA 可多对一)

所以首先要在内存中指定存放该对应表的其实位置(可通过CP15协处理器指定)

映射表的大概示意图如下

VA(0-4095)                PA(高12位)

0              ----        有效PA高12bit + AP + DOMAIN + cacheable + bufferable + 描述符

1              ----        有效PA高12bit + AP + DOMAIN + cacheable + bufferable + 描述符

2              ----        有效PA高12bit + AP + DOMAIN + cacheable + bufferable + 描述符

···

···

4094       ----        有效PA高12bit + AP + DOMAIN + cacheable + bufferable + 描述符

4095       ----        有效PA高12bit + AP + DOMAIN + cacheable + bufferable + 描述符

AP:AP权限为所有用户可读写 在多进程时使用 用来保护进程

DOMAIN:配合AP使用 权限管理

cacheable :C位 使能MMU缓存

bufferable :B位 使能MMU缓冲区

描述符:MMU使用段描述符(还有页描述符大页(64KB)小页(4KB)和极小页(1KB))

以下是建立1MB映射的C语言描述:

phyaddr = 0x30000000;

viraddr   = 0xa0000000;

*(mmu_ttb_base + (viraddr >> 20)) = ((phyaddr & 0xfff00000) | 低20位的属性描述);

VA到PA转化过程:

CPU发出VA:比如0xa0000123,转化过程如下图:

OK,到此,便得到了实际的物理地址!


MMU段式映射(VA -> PA)过程分析的更多相关文章

  1. MMU_段式映射

    首先, 段式映射的示意图如下: 该例程有5个文件构成: head.s-------------入口程序 mmu.lds-----------连接文件 init.c---------------初始化文 ...

  2. 对MMU段式转换的理解

    本文将详细介绍MMU段式转换的过程,并在文末附上一篇讲MMU比较详细的文章.具体什么是MMU,什么时段是转换就不在本文讲了,直接戳文末的链接. 首先,进行段式转换的条件.我们要拥有一个虚拟地址,还有一 ...

  3. 内存管理单元--MMU

    现代操作系统普遍采用虚拟内存管理(Virtual Memory Management)机制,这需要处理器中的MMU(Memory Management Unit,内存管理单元)提供支持,本节简要介绍M ...

  4. MMU内存管理单元

    arm-linux学习-(MMU内存管理单元) 什么是MMU MMU(Memory Management Unit)主要用来管理虚拟存储器.物理存储器的控制线路,同时也负责虚拟地址映射为物理地址,以及 ...

  5. 硬件篇之MMU

    <背景> MMU即内存管理单元(Memory Manage Unit),是一个与软件密切相关的硬件部件,也是理解linux等操作系统内核机制的最大障碍之一.可以说,不懂MMU使很多人一直停 ...

  6. MMU介绍【转】

    转自:http://blog.csdn.net/martree/article/details/3321578 虚拟存储器的基本思想是程序,数据,堆栈的总的大小可以超过物理存储器的大小,操作系统把当前 ...

  7. [转帖]MMU内存管理单元

    MMU内存管理单元 https://www.cnblogs.com/alantu2018/p/9002309.html 之前对这一块一直不理解 最近学习了点 CPU time slice 以及 con ...

  8. ARMv7-A 架构下的MMU

    ARM架构中MMU的作用主要就是将CPU发出的虚拟地址转换成为物理地址,从实现内核和用户程序和用户程序之间的虚拟地址空间隔离.MMU的主要组成为两部分,其一是内部的TLBs缓存:还有就是转换表装换单元 ...

  9. Linux内存管理 (2)页表的映射过程

    专题:Linux内存管理专题 关键词:swapper_pd_dir.ARM PGD/PTE.Linux PGD/PTE.pgd_offset_k. Linux下的页表映射分为两种,一是Linux自身的 ...

随机推荐

  1. 入门教程:.NET开源OpenID Connect 和OAuth解决方案IdentityServer v3 术语(二)

    你应该知道的在文档和对象模型中使用一些特定的术语: OpenID Connect Provider (OP) 授权服务器 Thinktecture IdentityServer v3 是一个.NET ...

  2. C++(二十三) — 内存泄漏及指针悬挂

    1.内存泄漏 动态申请的内存空间没有正常释放,但也不能继续使用. ; pch1 = new char('A'); // 此处申请的空间未被释放. char *pch2 = new char; pch1 ...

  3. mysql的bin或者sbin目录可执行文件

    一. mysql服务和myql服务启动程序 1. mysqld mysqld就是mysql server,负责管理对mysql数据的访问. 当mysql server启动后,它会监听来自客户端的网络连 ...

  4. HostFileChangeMonitor

    HostFileChangeMonitor 类是 FileChangeMonitor 类型的具体实现. 此类密封,因此无法扩展. 如果要使用现有缓存实现以及监视更改的文件和目录,此类非常有用. 对于每 ...

  5. 2017.11.2 Talk to customers for an hour

    yesterday::: Hi Huang, For the better performance of the test the Con 6 should be connected all the ...

  6. Linux下安装SVN(Subversion)

    一.安装直接运行命令用YUM安装: yum install subversion -y 二.创建版本库创建版本库用svnadmin create命令,大概语法是svnadmin create svn库 ...

  7. 让ListView中的控件失去焦点:android:descendantFocusability="blocksDescendants"

    值得注意的是,ListView中的控件不能设置clickable="true",否则会无视父控件的blockDescendants. 可参考: https://segmentfau ...

  8. Oracle 索引的失效和重建

    查询指定表的索引 SELECT T1.TABLE_NAME, T1.INDEX_NAME, T1.INDEX_TYPE, T1.UNIQUENESS, T1.TABLE_OWNER, T1.STATU ...

  9. bzoj 4555 求和

    求 $\sum\limits_{i=0}^n\sum\limits_{j=0}^n Stirling2(i,j) \times 2^j \times j!$ $n \leq 100000$ sol: ...

  10. HBase错误大全

    1. stopping hbasecat: /tmp/hbase-root-master.pid: No such file or directory 原因:hadoop的pid文件丢失,hadoop ...