二. 页面映射管理
1. 页表管理
我们知道CPU需要访问指令和数据,第一步就是将指令或数据地址放到地址总线上,由内存控制器负责将指令或数据从内存中读出,然后放到数据总线上,CPU从数据总线上获取指令或数据。由于CPU访问的是虚拟地址,虚拟地址必须经过转换成实际的地址才能送到地址总线上。这个地址转换工作,在现代CPU里有个专门的硬件模块负责,就是MMU(Memory Management Unit)。
在介绍MMU转换工作之前,我们先了解一下地址空间的概念。
(1). 地址空间
地址空间是一个抽象的概念。
我们说具有不同的地址空间的时候,是指在不同的地址空间的地址没有逻辑上的关联。举个例子,如果地址0x0000与地址0x0003在相同的地址空间,则它们具有某种关系,它们代表了不同的数据存放位置,具有唯一性。如果这两个地址相同,我们则可以认为存放的数据是相同的。如果这两个地址在不同的地址空间,则它们是没有关联的。不管它们是否具有相同的地址。在不同地址空间的地址没有可比性。
这里我们可以分为虚拟地址空间和实际的物理地址空间。
虚拟的地址空间代表了进程运行的空间,是CPU可以访问的地址,在这个空间里,程序的执行不需要考虑实际设备在哪儿。对于程序来说,这是系统提供给它的一段地址,在这段地址里,它可以访问任何它想访问的地方。但是这只是一段地址,如果没有映射到实际设备地址,是没有任何意义的。不同的进程具有不同的用户虚拟地址空间。
我们可以想象成程序的执行就是CPU与外部设备的交互过程。对于外部设备,我们有必要把它们统一编址在同一个地址空间,这样