最近在研究xen的源码,看到了影子机制这一部分,查过一些资料,简单总结一下自己的理解。
在真实的物理机器里,我们可以将地址层次抽象成两层,一层是虚拟地址,另一层是物理地址。不同的进程分配不同且不一定连续的物理地址空间,而客户机页表维护着虚拟地址与物理地址之间的映射关系,这使得进程看到的虚拟地址是连续的。
在虚拟机里,客户系统认为的自己的物理地址是连续的地址空间,但其实也仅仅是宿主机分配的一部分不一定连续的地址空间。客户机页表能进行客户机虚拟地址与客户机物理地址的转换,那么真实的宿主机物理地址跟客户系统看到的客户物理地址如何来进行转换呢?
Xen这一款虚拟机产品,是同时支持半虚拟化以及全虚拟化的,而xen也提供两种地址转换模式:直接模式和影子模式。
半虚拟化方式是允许修改客户操作系统的,于是可以通过修改客户机操作系统页表,让页表维护客户机虚拟地址到宿主机物理地址之间的映射,这就是直接模式。而全虚拟化时,客户机操作系统是不能修改的,那原客户机页表维护的映射就不一定能正确找到真实的宿主机物理地址,于是就采用影子模式。
影子模式,也就是影子页表机制,是在原来的两层地址层次基础上加了一层伪物理地址层次。