虚拟地址到物理地址的映射
2018-03-07 19:17
288 查看
虚拟地址和物理地址
========================================= CPU通过地址来访问内存中的单元,地址有虚拟地址和物理地址之分,如果CPU没有MMU(Memory Management Unit, 内存管理单元),或者有MMU但没有启用,CPU核在取指令或访问内存时发出的地址将
直接传到CPU芯片的外部地址引脚上,直接被内存芯片(以下称为物理内存,以便与虚拟内存区分)接收,
这称为物理地址(Physical Address, 以下简称PA),如下图所示:
图1. 物理地址示意图
如果CPU启用了MMU,CPU核发出的地址将被MMU截获,从CPU到MMU的地址称为虚拟地址(Virtual Address, 以下简称VA),而MMU将这个地址翻译成另一个地址发到CPU芯片的外部地址引脚上,也就是将
虚拟地址映射成物理地址,如下图所示:
图2. 虚拟地址示意图
MMU将虚拟地址映射到物理地址是以页(Page)为单位的,对于32位CPU通常一页为4K。例如,虚拟地址 0xB7001000~0xB7001FFF是一个页,可能被MMU映射到物理地址0x2000~0x2FFF, 物理内存中的一个物理页面也称为一个页框(Page Frame) Datasheet中介绍各种寄存器时,所附带的地址就是物理地址。 既然虚拟地址最终要转换为物理地址,那么为何还需要虚拟地址呢?
虚拟地址提供了权限检查功能:比如我们设置虚拟地址和物理地址之间的映射关系时,可以设置某块地址是只读的,只写的,只有CPU处于管理模式时才能访问等。这些功能可以让系统的内核,用户程序的运行空间相互独立:用户程序即使出错,也无法破坏内核;用户程序A崩溃了,也无法影响到用户程序B。 当开启分段分页机制时,典型的x86寻址过程为
内存寻址的工作是由Linux内核和MMU共同完成的,其中Linux内核负责cr3,gdtr等寄存器的设置,页表的维护,页面的管理,MMU则进行具体的映射工作。
========================================= CPU通过地址来访问内存中的单元,地址有虚拟地址和物理地址之分,如果CPU没有MMU(Memory Management Unit, 内存管理单元),或者有MMU但没有启用,CPU核在取指令或访问内存时发出的地址将
直接传到CPU芯片的外部地址引脚上,直接被内存芯片(以下称为物理内存,以便与虚拟内存区分)接收,
这称为物理地址(Physical Address, 以下简称PA),如下图所示:
图1. 物理地址示意图
如果CPU启用了MMU,CPU核发出的地址将被MMU截获,从CPU到MMU的地址称为虚拟地址(Virtual Address, 以下简称VA),而MMU将这个地址翻译成另一个地址发到CPU芯片的外部地址引脚上,也就是将
虚拟地址映射成物理地址,如下图所示:
图2. 虚拟地址示意图
MMU将虚拟地址映射到物理地址是以页(Page)为单位的,对于32位CPU通常一页为4K。例如,虚拟地址 0xB7001000~0xB7001FFF是一个页,可能被MMU映射到物理地址0x2000~0x2FFF, 物理内存中的一个物理页面也称为一个页框(Page Frame) Datasheet中介绍各种寄存器时,所附带的地址就是物理地址。 既然虚拟地址最终要转换为物理地址,那么为何还需要虚拟地址呢?
虚拟地址提供了权限检查功能:比如我们设置虚拟地址和物理地址之间的映射关系时,可以设置某块地址是只读的,只写的,只有CPU处于管理模式时才能访问等。这些功能可以让系统的内核,用户程序的运行空间相互独立:用户程序即使出错,也无法破坏内核;用户程序A崩溃了,也无法影响到用户程序B。 当开启分段分页机制时,典型的x86寻址过程为
内存寻址的工作是由Linux内核和MMU共同完成的,其中Linux内核负责cr3,gdtr等寄存器的设置,页表的维护,页面的管理,MMU则进行具体的映射工作。
相关文章推荐
- 内核物理地址和虚拟地址之间的静态映射过程
- x86虚拟地址到物理地址的映射学习
- linux中S3C2440的物理地址映射到虚拟地址详解
- Linux驱动虚拟地址和物理地址的映射
- Linux驱动虚拟地址和物理地址的映射
- x86虚拟地址到物理地址的映射学习
- Linux 虚拟地址与物理地址的映射关系分析
- 通过windbg查看虚拟地址到物理地址的映射过程
- ARM中虚拟地址到物理地址的映射示意图
- 有时间分析 物理地址到虚拟地址的映射
- 虚拟地址和物理地址及其映射
- Linux驱动虚拟地址和物理地址的映射
- 虚拟地址与物理地址的映射
- 虚拟地址 物理地址 映射
- Linux 虚拟地址与物理地址的映射关系分析【转】
- Windows内存管理之虚拟地址到物理地址的映射
- x86虚拟地址到物理地址的映射学习
- Linux内核访问外设I/O资源的方式(设备物理地址和设备虚拟地址),静态映射和动态映射
- 虚拟地址_物理地址_逻辑地址_页表_内存映射