内存虚拟化技术,具体的实现方法有哪两种?

内存虚拟化技术通过MMU半虚拟化和影子页表实现虚拟地址到机器地址的转换。MMU半虚拟化中,VMM参与页表的验证和转换,将映射关系写入Guest OS页表。影子页表则由VMM维护,Guest OS页表保持不变,VMM在缺页时补全影子页表。影子页表缓存技术用于平衡时间开销和空间开销。
摘要由CSDN通过智能技术生成
引入内存虚拟化技术后,内存系统中存在3种地址。
机器地址(Machine Address,MA):真实硬件的机器地址,在地址总线上可以见到的地址信号。
虚拟机物理地址(Guest Physical Address,GPA):经过VMM抽象后虚拟机看到的伪物理地址。
虚拟地址(Virtual Address,VA):Guest OS提供给其应用程序使用的线性地址空间。



虚拟地址到虚拟机物理地址的映射关系,记作g
虚拟机物理地址到机器地址的映射关系,记作f


操作系统的内存管理单元(Memory Management Unit,MMU)只能完成一次虚拟地址到物理地址的映射,但获得的物理地址只是虚拟机物理地址而不是机器物理地址,所以需要VMM参与,以获得总线上可以使用的机器地址为实现虚拟地址到机器地址的高效转换,目前普遍采用的方法是由VMM根据映射f和g生成复合映射f·g并直接写入MMU,具体的实现方法有两种:


MMU半虚拟化(MMU Paravirtualization)


这种方式主要为Xen所用

<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值